Redis配置与优化
- 一、部署Redis
- 二、Redis数据类型
- 2.1 String (字符串)
- 2.2 Hash(哈希字典)
- 2.3 List(列表)
- 2.4 Set(集合-无序集合)
- 2.5 zset(sorted set:有序集合)
- 三、多数据库概念
- 四、key常规管理
- 4.1 验证key是否存在 exists
- 4.2 重命名 rename
- 4.3 设置超时时间PEXPIRE (单位:毫秒)
- 4.4 查看剩余时间PTTL (单位:毫秒)
- 4.5 取消超时时间
- 4.6 查看类型type
- 4.7 随机返回key RANDOMKEY
- 4.8 查看所有key
- 五、AOF持久化和重写配置
- 5.1 AOF的持久化的配置
- 5.2 AOF的重写配置
一、部署Redis
- 部署Redis
[root@localhost ~]# iptables -F ###清除防火墙规则
[root@localhost ~]# iptables -t nat -F ###清除防火墙表规则
[root@localhost ~]# setenforce 0 ###关闭核心防护
[root@localhost ~]# yum -y install gcc gcc-c++ ###安装gcc、gcc-c++环境包
将包上传到服务器
[root@localhost ~]# tar zxvf redis-5.0.7.tar.gz -C /opt/ ###解压redis到opt目录下
[root@localhost ~]# cd /opt/redis-5.0.7/
[root@localhost redis-5.0.7]# make ###编译
[root@localhost redis-5.0.7]# make install ###编译安装
[root@localhost redis-5.0.7]# cd utils/
[root@localhost utils]# ./install_server.sh ###执行自动安装脚本
一直回车
Selected config:Port: 6379
Config file :/etc/redis/6379.conf //配置文件路径
Log file:/var/log/redis_6379.log1 //日志文件路径
Data dir: /var/lib/redis/6379 //数据文件路径
Executable : /usr/local/redis/bin/redis-server //可执行文件路径Cli Executable : /usr/local/bin/redis-cli //客户端命令工具
[root@localhost utils]# netstat -anpt | grep redis ###查看一下redis启动了没
tcp 0 0 127.0.0.1:6379 0.0.0.0:* LISTEN 6124/redis-server 1
[root@localhost utils]# redis-cli -h 127.0.0.1 -p 6379 ###连接本地数据库
127.0.0.1:6379> set name zhangsan ###创建一个name键,赋予一个zhangsan的值
OK
127.0.0.1:6379> get name ###输出name键的值
"zhangsan"
127.0.0.1:6379> quit ###退出
[root@localhost utils]# vim /etc/redis/6379.conf ###配置redis主配置文件
70行 bind 127.0.0.1 20.0.0.21 ###监听20.0.0.21
[root@localhost utils]# /etc/init.d/redis_6379 stop ###关闭redis_6379服务
[root@localhost utils]# /etc/init.d/redis_6379 start ###开启redis_6379服务
/etc/init.d/redis_6379 restart ###重启redis_6379服务
/etc/init.d/redis_6379 status ###查看redis_6379服务状态
[root@localhost utils]# redis-cli -h 20.0.0.21 -p 6379 --raw ###连接远程数据库,加--raw可以解决中文乱码问题
20.0.0.21:6379> type name ###用type查看类型
string ###字符串类型
二、Redis数据类型
Redis支持五种数据类型: string(字符串)最常规的基础类型,hash(哈希)用来存储对象的(对象又包含多个属性和参数),list(列表)存的都是字符串的集合,set(集合)及zset(sorted set:有序集合)。
2.1 String (字符串)
示例:
20.0.0.21:6379> set name zhangsan ###创建一个name键,值是zhangsan
OK
20.0.0.21:6379> get name ###查看name键的值
zhangsan
2.2 Hash(哈希字典)
//作用场景:
键值对集合,即编程语言中的Map类型 适合存储对象,并且可以像数据库中update一个属性一样只修改某一项属性值
示例:
20.0.0.21:6379> hmset stu name lisi age 18 sex 男 ###创建一个stu对象,有姓名、年龄、性别值。一个对象当中包含多个key(键)和value(值)
OK
20.0.0.21:6379> hget stu name ###查看stu对象里的name键的值
lisi
20.0.0.21:6379> hget stu age
18
20.0.0.21:6379> hget stu sex
男
20.0.0.21:6379> keys * ###获取所有的符合规则的键值列表
stu
name
2.3 List(列表)
/作用场景:
增删快,提供了操作某一段元素的APl 1,最新消息排行等功能(比如朋友圈的时间线)2,消息队列
20.0.0.21:6379> lpush hobby play ###创建一个hobby的列表名,和列表值
1
20.0.0.21:6379> lpush hobby read
2
20.0.0.21:6379> lpush hobby sport
3
20.0.0.21:6379> lpush hobby sport
4
20.0.0.21:6379> lrange hobby 0 10 ###查看hobby的的列表名,从0到10
sport
sport
read
play
20.0
数据从右往左取值
存不进去显示0
可以存重复的数据
2.4 Set(集合-无序集合)
sadd命令
添加一个string元素到key对应的set集合中,成功返回1,如果元素已经在集合中返回0。
示例:
20.0.0.21:6379> sadd color red green yellow ###创建一个color集合,有三个值
3
20.0.0.21:6379> smembers color ###查看color的值
yellow
green
red
20.0.0.21:6379> sadd color red ###在重复创建一个值,显示0不能创建了!
0
Set(集合是)无序的,不能拿到指定信息
Set(集合)不能有重复数据
只要是集合当中就不能有重复数据
2.5 zset(sorted set:有序集合)
- zadd命令
添加元素到集合,元素在集合中存在则更新对应score
示例:
20.0.0.21:6379> ZADD co 0 red ###co结合名称,定义的分数、也可以是索引,然后是值
1
20.0.0.21:6379> ZADD co 0 blue
1
20.0.0.21:6379> ZADD co 0 green
1
20.0.0.21:6379> ZADD co 1 yellow
1
20.0.0.21:6379> zrangebyscore co 0 10 ###利用co建立索引调用出来,起始位是0、结束位是10
blue
green
red
yellow
20.0.0.21:6379> zrangebyscore co 0 0
blue
green
red
20.0.0.21:6379> zrangebyscore co 1 1
yellow
三、多数据库概念
示例:
20.0.0.21:6379> select 1 ###切换到1数据库
OK
20.0.0.21:6379[1]> set name zhangsan
OK
20.0.0.21:6379[1]> select 2
OK
20.0.0.21:6379[2]> set name zhangsan
OK
20.0.0.21:6379[2]> FLUSHALL ###高危命令,清空所有数据库的数据,0-15的数据库
注意:
Redis不支持自定义数据库的名字,每个数据库都以编号命名,开发者必须自己记录哪些数据库存储了哪些数据。
另外Redis也不支持为每个数据库设置不同的访问密码,所以一个客户端要么可以访问全部数据库,
要么连一个数据库也没有权限访问。最重要的一点是多个数据库之间并不是完全隔离的,
比如FLUSHALL命令可以清空一个Redis实例中所有数据库中的数据。
综上所述,这些数据库更像是一种命名空间,而不适宜存储不同应用程序的数据。
作用场景:
可以使用0号数据库存储某个应用生产环境中的数据,使用1号数据库存储测试环境中的数据,
但不适宜使用0号数据库存储A应用的数据而使用1号数据库B应用的数据,不同的应用应该使用不同的Redis实例存储数据。
由于Redis非常轻量级,一个空Redis实例占用的内存只有1M左右,所以不用担心多个Redis实例会额外占用很多内存。
20.0.0.21:6379[2]> select 1 ###切换数据库,但每个库之间都是隔离的
OK
20.0.0.21:6379[2]> move stu 1 ###用move数据库迁移,将stu库迁移到2库(0-15所以1是库2)
0
20.0.0.21:6379[2]> keys * ###查看库里的所有key值
name
四、key常规管理
4.1 验证key是否存在 exists
20.0.0.21:6379[2]> set name zhangsan ###创建一个name的name键,键里面放一个zhangsan值
OK
20.0.0.21:6379[2]> exists name ###查看name键存不存在,存在显示1,不存在显示0
1
4.2 重命名 rename
20.0.0.21:6379[2]> rename name na ###将name键改名成na
OK
4.3 设置超时时间PEXPIRE (单位:毫秒)
192.168.195.180:6379> PEXPIRE na 3000 ###设置na的键超时时间为3秒,三秒后就不存在
1
192.168.195.180:6379> get na
4.4 查看剩余时间PTTL (单位:毫秒)
192.168.195.180:6379> PEXPIRE name 30000 ###给name设置30秒
1
192.168.195.180:6379> PTTL name ###查看name剩余时间
22528
4.5 取消超时时间
192.168.195.180:6379> set name zhangsan
oK
192.168.195.180:6379>PEXPIRE name 50000
1
192.168.195.180:6379> PTTL name
44606
192.168.195.180:6379> PERSIST name
1
192.168.195.180:6379> PTTL name
-1
192.168.195.180:6379> get name
zhangsan
4.6 查看类型type
192.168.195.180:6379> lpush color red blue
2
192.168.195.180:6379> TYPE color
list
192.168.195.180:6379> set name zhangsan
oK
192.168.195.180:6379>TYPE name
string
4.7 随机返回key RANDOMKEY
192.168.195.180:6379> mset age 18 score 88 sex boy
oK
192.168.195.180:6379> RANDOMKEY
sex
192.168.195.180:6379> RANDOMKEY
color
192.168.195.180:6379> RANDOMKEY
sex
4.8 查看所有key
192.168.195.180:6379> KEYS *
color
score
sex
age
五、AOF持久化和重写配置
5.1 AOF的持久化的配置
[root@localhost utils]# vim /etc/redis/6379.conf
700行 appendonly yes ###开启AOF持久化
704行 appendfilename "appendonly.aof" ###AOF文件名称
729行 appendfsync always ###一直进行同步,开启
730行 #appendfsync everysec ###每秒进行同步,注释掉
731行 #appendfsync no ###不进行同步,注释掉
796行 aof-load-truncated yes ###忽略最后一条语句,开启
注意:删除注释后,命令得跟左边顶格,不能留空格,不然不生效!!!
5.2 AOF的重写配置
[root@localhost utils]# vim /etc/redis/6379.conf
no-appendfsync-on-rewrite yes ###满足下面两个要求,就会开启去重
auto-aof-rewrite-percentage 100 ###aof文件大小是上次日志重写时aof文件大小的两倍时
auto-aof-rewrite-min-size 64mb ###大小超过了64m