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