1、密码问题(默认没有密码)
ERR Client sent AUTH, but no password is set
Redis 127.0.0.1:6379> CONFIG SET requirepass “123456”
OK
redis 127.0.0.1:6379> AUTH 123456
Ok
或者在redis的配置文件redis.conf中打开requirepass注释
2、版本问题
ERR Unsupported CONFIG parameter: notify-keyspace-events
将Redis-2.4.5,更新到redis-2.8.12
3、非本地连接问题
redis默认只能localhost登录
在redis的配置文件redis.conf中,找到bind 127.0.0.1,替换成0.0.0.0
Linux下安装redis
1、先通过yum安装gcc : yum install -y gcc g++ gcc-c++ make
2、执行make 对Redis解压后文件进行编译
tar -zxzf redis-3.0.7.tar.gz
cd redis-3.0.7
make
3、编译成功后,进入src文件夹,执行make install进行Redis安装
redis-server:redis服务
redis-cli:redis client,提供一个redis客户端,以供连接到redis服务,进行增删改查等操作
redis-sentinel:redis实例的监控管理、通知和实例失效备援服务
redis-benchmark:redis的性能测试工具
redis-check-aof:若以AOF方式的持久化,当意外发生时用来快速修复
redis-check-rdb:若以RDB方式的持久化,当意外发生时用来快速修复
启动服务端:
[root@mcs-slave-2 ~]# cd /home/lzy/redis-stable/
[root@mcs-slave-2 redis-stable]# ./src/redis-server redis.conf
关闭服务端:
[root@mcs-slave-2 redis-stable]# ./src/redis-cli -p 6379 shutdown
ps -ef|grep redis
netstat -lnp | grep 6379
调用客户端:
[root@mcs-slave-2 redis-stable]# ./src/redis-cli
127.0.0.1:6379> CONFIG SET requirepass “123456”
OK
配置自启动
1、设置redis.conf中daemonize为yes,确保守护进程开启。
2、编写开机自启动脚本 vi /etc/init.d/redis
3、设置权限 chmod 755 /etc/init.d/redis
chmod +x /etc/init.d/redis 修改读写权限
4、启动测试 /etc/init.d/redis start
service redis start
service redis stop
[root@mcs-slave-2 redis-stable]# /etc/init.d/redis start
Starting Redis server…
Redis is running…
5.开启服务自启动 chkconfig redis on
6.加入开机自启服务
chkconfig --add redis
7.关机重启测试 reboot
[root@mcs-slave-2 ~]# chkconfig --list
jexec 0:关 1:开 2:开 3:开 4:开 5:开 6:关
mysql 0:关 1:关 2:开 3:开 4:开 5:开 6:关
netconsole 0:关 1:关 2:关 3:关 4:关 5:关 6:关
network 0:关 1:关 2:开 3:开 4:开 5:开 6:关
redis 0:关 1:关 2:开 3:开 4:开 5:开 6:关
注意:该输出结果只显示 SysV 服务,并不包含原生 systemd 服务。SysV 配置数据可能被原生 systemd 配置覆盖。 如果您想列出 systemd 服务,请执行 'systemctl list-unit-files'。欲查看对特定 target 启用的服务请执行 'systemctl list-dependencies [target]'。
docker下安装redis
下载redis镜像:docker pull redis
启动:sudo docker run -d –name redis -p 6379:6379 redis
//安装redis client
yuminstallredis−tools//启动redis−cli redis-cli -h localhost -p 6379
$ redis-cli -h 127.0.0.1 -p 6379 -a myPassword
//redis-cli
localhost:6379> set hello world
localhost:6379> get hello
“world”
java调用jedis
@Bean
public JedisConnectionFactory connectionFactory(){
JedisConnectionFactory conn = new JedisConnectionFactory();
conn.setDatabase(3);
conn.setHostName("127.0.0.1");
conn.setPassword("123456");
conn.setPort(6379);
conn.setTimeout(3000);
return conn;
}
重新整理:
redis安装
tar zxvf redis-2.8.9.tar.gz
cd redis-2.8.9
#直接make 编译
make
#可使用root用户执行`make install`,将可执行文件拷贝到/usr/local/bin目录下。这样就可以直接敲名字运行程序了。
make install
启动 ./redis-server &
检测
#检测后台进程是否存在
ps -ef |grep redis
#检测6379端口是否在监听
netstat -lntp | grep 6379
#使用`redis-cli`客户端检测连接是否正常
./redis-cli
127.0.0.1:6379> keys *
(empty list or set)
127.0.0.1:6379> set key "hello world"
OK
127.0.0.1:6379> get key
"hello world"
停止
#使用客户端
redis-cli shutdown
#因为Redis可以妥善处理SIGTERM信号,所以直接kill -9也是可以的
kill -9 PID
通过指定配置文件启动
#修改daemonize为yes,即默认以后台程序方式运行
daemonize no
#可修改默认监听端口
port 6379
#修改生成默认日志文件位置
logfile "/home/futeng/logs/redis.log"
#配置持久化文件存放位置
dir /home/lzy/data/redisData
启动时指定配置文件
redis-server ./redis.conf
#如果更改了端口,使用`redis-cli`客户端连接时,也需要指定端口,例如:redis-cli -p 6380
启动脚本
推荐在生产环境中使用启动脚本方式启动redis服务。启动脚本redis_init_script 位于位于Redis的 /utils/ 目录下。
#redis服务器监听的端口
REDISPORT=6379
#服务端所处位置,在make install后默认存放与`/usr/local/bin/redis-server`,如果未make install则需要修改该路径,下同。
EXEC=/usr/local/bin/redis-server
#客户端位置
CLIEXEC=/usr/local/bin/redis-cli
#Redis的PID文件位置
PIDFILE=/var/run/redis_${REDISPORT}.pid
#配置文件位置,需要修改
CONF="/etc/redis/${REDISPORT}.conf"
配置环境
1. 根据启动脚本要求,将修改好的配置文件以端口为名复制一份到指定目录。需使用root用户。
mkdir /etc/redis
cp redis.conf /etc/redis/6379.conf
2. 将启动脚本复制到/etc/init.d目录下
cp redis_init_script /etc/init.d/redisd
3. 设置为开机自启动
在启动脚本开头添加如下两行注释以修改其运行级别:
#!/bin/sh
# chkconfig: 2345 90 10
# description: Redis is a persistent key-value database
#设置为开机自启动服务器
chkconfig redisd on
#打开服务
service redisd start
#关闭服务
service redisd stop