redis介绍
redis是用C语言开发的一个开源的高性能键值对(key-value)数据库。它通过提供多种键值数据类型来适应不同场景下的存储需求,目前为止redis支持的键值数据类型如下字符串、列表(lists)、集合(sets)、有序集合(sorts sets)、哈希表(hashs)
redis的应用场景
- 缓存(数据查询、短连接、新闻内容、商品内容等等)。(最多使用)
- 分布式集群架构中的session分离。
- 聊天室的在线好友列表。
- 任务队列。(秒杀、抢购、12306等等)
- 应用排行榜。
- 网站访问统计。
- 数据过期处理(可以精确到毫秒)
yum安装redis
- 安装
#检查是否有redis yum 源
yum install redis
#下载fedora的epel仓库
yum install epel-release
#安装redis数据库
yum install redis
- 安装完毕后,使用下面的命令启动redis服务
# 启动redis
service redis start
# 停止redis
service redis stop
# 查看redis运行状态
service redis status
# 查看redis进程
ps -ef | grep redis
- 设置redis为开机自动启动
chkconfig redis on
- 进入redis服务
# 进入本机redis
redis-cli
# 列出所有key
keys *
- 防火墙开放相应端口
# 开启6379
/sbin/iptables -I INPUT -p tcp --dport 6379 -j ACCEPT
# 开启6380
/sbin/iptables -I INPUT -p tcp --dport 6380 -j ACCEPT
# 保存
/etc/rc.d/init.d/iptables save
# centos 7下执行
service iptables save
修改redis默认端口和密码
1、打开配置文件
vi /etc/redis.conf
2、修改默认端口,查找 port 6379 修改为相应端口即可
3、修改默认密码,查找 requirepass foobared 将 foobared 修改为你的密码
4、使用配置文件启动 redis
redis-server /etc/redis.conf &
5、使用端口登录
redis-cli -h 127.0.0.1 -p 6179
6、输入刚才输入的密码
auth 111
8、停止redis
考虑到 Redis 有可能正在将内存中的数据同步到硬盘中,强行终止 Redis 进程可能会导致数据丢失。正确停止Redis的方式应该是向Redis发送SHUTDOWN命令,
当Redis收到SHUTDOWN命令后,会先断开所有客户端连接,然后根据配置执行持久化,最后完成退出。
Redis可以妥善处理 SIGTERM信号,所以使用 kill Redis 进程的 PID也可以正常结束Redis,效果与发送SHUTDOWN命令一样。
方式1:命令方式关闭redis
redis-cli -h 127.0.0.1 -p 6179
shutdown
方式2:进程号杀掉redis
ps -ef | grep redis
kill -9 XXX
三、使用redis desktop manager远程连接redis
1、访问如下网址下载redis desktop manager
https://redisdesktop.com/download
2、安装后启动,新建一个连接
3、填写如下信息后点击“Test Connection”测试是否连接成功
4、如果长时间连接不上,可能有两种可能性
a)bind了127.0.01:只允许在本机连接redis
b)protected-mode设置了yes(使用redis desktop manager工具需要配置,其余不用)
解决办法:
# 打开redis配置文件
vi /etc/redis.conf
# 找到 bind 127.0.0.1 将其注释
# 找到 protected-mode yes 将其改为
protected-mode no
5、重启redis
service redis stop
service redis start
6、再次连接即可
问题总结
1、redis通过6379端口无法连接服务器
使用netstat -tlnp查看端口,可以看到6379对应的是127.0.0.1,所以导致远程客户端无法连接
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 127.0.0.1:6379 0.0.0.0:* LISTEN 1770/redis-server 1
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 1542/nginx: master
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1216/sshd
tcp6 0 0 :::3306 :::* LISTEN 1013/mysqld
解决:
1、清除iptables规则
#查看iptables规则
iptables -L -n
#清除全部iptables规则
iptables -F
2、修改redis.conf配置文件将bind 127.0.0.1改为bind 0.0.0.0
vi /etc/redis.conf
#bind 127.0.0.1
bind 0.0.0.0
之后重启redis
#命令方式关闭redis
redis-cli -h 127.0.0.1 -p 6179
shutdown
#进程号杀掉redis
ps -ef | grep redis
kill -9 XXX
3、阿里云添加安全组规则,添加6379端口
参考阅读
https://www.cnblogs.com/rslai/p/8249812.html
https://www.cnblogs.com/herblog/p/9305668.html