redis知识归纳
一、linux redis搭建环境
分为docker安装和官网下载手动安装,docker就不描述了
1. 下载
下载获得redis-版本号.tar.gz后将它放入我们的Linux目录/opt
/opt目录下,解压命令:tar -zxvf redis-版本号.tar.gz
解压完成后出现文件夹:redis-版本号,进入目录:cd redis-版本号
2. make
-
进入该目录之后执行make,无错误就直接过,但可能会遇到gcc没有安装的情况,
安装gcc:sudo apt install build-essential
-
第一次错误出现后,再进行make,会出现Jemalloc/jemalloc.h:没有那个文件或目录,这是因为第一次make留下的残留文件,这时可以运行make distclean之后再make
-
make通过后执行make install,显示全部install即可
3. 安装目录
查看默认安装目录:usr/local/bin
Redis-server:Redis服务器启动命令 -> redis-server /配置路径/配置文件
Redis-cli:客户端,操作入口
Redis-benchmark:性能测试工具,可以在自己本子运行,看看自己本子性能如何
Redis-check-dump:修复有问题的dump.rdb文件
Redis-check-aof:修复有问题的AOF文件
Redis-sentinel:redis集群使用
4. 运行前的配置
- 在之前压缩包里,将redis.conf拷贝到任意目录下,我是拷贝到/myredis/redis.conf下。
- 然后不动原有配置,直接改动拷贝的配置文件。将daemonize no改为yes,守护进程开启,才能在后台运行。
- 在安装目录下运行redis-server:redis-server /myredis/redis.conf
5. 客户端连通测试
1)本地连通测试
- 在安装目录下运行redis-cli:redis-cli -p 6379
- 进行连通测试,ping。收到pong则成功。
2)外部连通测试
现在暂时使用的是虚拟机作为redis-server,而在物理机中使用redis-client。这相当于在局域网当中进行联通。
-
这个时候需要修改配置文件中的bind:127.0.0.1,这代表着该redis服务只能允许本地的client进行连接,将他修改为0.0.0.0为允许所有主机。
-
然后本地防火墙开放6379端口
firewall-cmd --add-port=6379/tcp --permanent #执行成功后返回success,--permanent代表永久有效 firewall-cmd --query-port=6379/tcp #如果开启6379成功的话,返回yes
-
用ifconfig获取虚拟机的ip,在外部使用RedisDesktopManager连接虚拟机中的redis即可成功。
6. 设置访问密码
1)方法一、修改配置文件
进入到redis.conf配置文件中取消注释requirepass并在后面改成自己想要的密码
requirepass 123456
需要重启生效
2)方法二、client中修改config
连通后,可以获取到config中的密码,使用config get requirepass
当然也能修改密码config set requirepass 123456
立即生效
3)密码验证
连通后,auth 123456
才能输入指令,不然会被拒绝访问
二、redis知识点
1. 基本通用指令
Select命令切换数据库
Dbsize查看当前数据库的key的数量
Flushdb:清空当前库
Flushall;通杀全部库
2. 键+数据类型(5+1)
1)key
- key * 输出所有键
- exists key的名字,判断某个key是否存在
- move key db --->当前库就没有了,被移除了
- expire key 秒钟:为给定的key设置过期时间
- ttl key 查看还有多少秒过期,-1表示永不过期,-2表示已过期
- type key 查看你的key是什么类型
2)String
- set/get/del/append/strlen
- Incr/decr/incrby/decrby,一定要是数字才能进行加减
- getrange/setrange
- setex(set with expire)键秒值/setnx(set if not exist)
- mset/mget/msetnx
- getset(先get再set)
set k1 v1
#ok
get k1
#"v1"
3)Hash
- hset/hget/hmset/hmget/hgetall/hdel(单增取,多增取,删除)
- hlen 长度
- hexists key 在key里面的某个值的key
- hkeys/hvals 获取keyset/获取valueset
- hincrby/hincrbyfloat 数字加减
- hsetnx 先判断是否存在,不存在就进行hset
> hmset user:1000 username antirez birthyear 1977 verified 1
OK
> hget user:1000 username
"antirez"
> hget user:1000 birthyear
"1977"
> hgetall user:1000
1) "username"
2) "antirez"
3) "birthyear"
4) "1977"
5) "verified"
6) "1"
4)List
- lpush/rpush/lrange 左右入链,输出
- lpop/rpop 左右出链
- lindex,按照索引下标获得元素(从上到下)
- llen 长度
- lrem key 删N个value
- ltrim key 开始index 结束index,截取指定范围的值后再赋值给key
- rpoplpush 源列表 目的列表
- lset key index value 设置list的index下标的值
- linsert key before/after 值1 值2
List可从rpush也能从lpush;
也可从rpop和lpop;
但输出只有lrange并没有rrange;
> rpush mylist A
(integer) 1
> rpush mylist B
(integer) 2
> lpush mylist first
(integer) 3
> lrange mylist 0 -1
1) "first"
2) "A"
3) "B"
5)Set
- sadd/smembers/sismember 增加/输出/检测成员
- scard,获取集合里面的元素个数
- srem key value 删除集合中元素
- srandmember key 某个整数(随机出几个数)
- spop key 随机出栈
- smove key1 key2 在key1里某个值 作用是将key1里的某个值赋给key2
- sdiff/sinter/sunion 差集/交集/并集 params:set1 set2
简单使用
127.0.0.1:6379> sadd myset 1 2 3
(integer) 3
127.0.0.1:6379> SMEMBERS myset
1) "1"
2) "2"
3) "3"
> sismember myset 3
(integer) 1
> sismember myset 30
(integer) 0
6)Zset
- zadd/zrange/zrevrange 增加/从小到大输出/从大到小输出
- zrangebyscore/zrevrangebyscore key 开始score 结束score (取范围score输出)
- zrem key 某score下对应的value值,作用是删除元素
- zcard/zcount key score区间/zrank key values值,作用是获得下标值/zscore key 对应值,获得分数
- zrevrank key values值,作用是逆序获得下标值
根据增加score来进行排序的Set,正常的set指令为sadd myset v1 v2 v3
而Zset的指令为zadd myZset score1 v1 score2 v2 score3 v3
会根据这个score的从小大进行排序,如果相同则比较字符串,得出一个唯一的序列。
添加zset数据
> zadd hackers 1940 "Alan Kay"
(integer) 1
> zadd hackers 1957 "Sophie Wilson"
(integer 1)
> zadd hackers 1953 "Richard Stallman"
(integer) 1
> zadd hackers 1949 "Anita Borg"
(integer) 1
> zadd hackers 1965 "Yukihiro Matsumoto"
(integer) 1
> zadd hackers 1914 "Hedy Lamarr"
(integer) 1
> zadd hackers 1916 "Claude Shannon"
(integer) 1
> zadd hackers 1969 "Linus Torvalds"
(integer) 1
> zadd hackers 1912 "Alan Turing"
(integer) 1
使用zrange(从小到大)或zrevrange(从大到小)来输出他们,
> zrange hackers 0 -1
1) "Alan Turing"
2) "Hedy Lamarr"
3) "Claude Shannon"
4) "Alan Kay"
5) "Anita Borg"
6) "Richard Stallman"
7) "Sophie Wilson"
8) "Yukihiro Matsumoto"
9) "Linus Torvalds"
3. 配置文件
配置文件分为几大块
1)Units单位
# Note on units: when memory size is needed, it is possible to specify
# it in the usual form of 1k 5GB 4M and so forth:
#
# 1k => 1000 bytes
# 1kb => 1024 bytes
# 1m => 1000000 bytes
# 1mb => 1024*1024 bytes
# 1g => 1000000000 bytes
# 1gb => 1024*1024*1024 bytes
#
# units are case insensitive so 1GB 1Gb 1gB are all the same.
配置大小单位,开头有定义一些基本的单位,只支持使用bytes定义,不支持bit,并且对大小写不敏感。
2)INCLUDES包含
可以将配置拆分成细小的配置文件,然后通过总配置文件将其他配置文件包含进来。格式include /path
3)GENERAL通用
名 | 描述 | 默认 |
---|---|---|
daemonize | 守护进程 | no |
pidfile | 以守护进程启动时创建的pid文件路径 | /var/run/redis.pid |
port | 运行的端口号 | 6379 |
tcp-backlog | 设置tcp的backlog最大长度,backlog队列总和=未完成三次握手队列 + 已经完成三次握手队列 | 511 |
Timeout | 定时关闭连接 | 0 |
bind | 允许ip连接 | 127.0.0.1 |
Tcp-keepalive | 单位为秒,如果设置为0,则不会进行Keepalive检测,建议设置成60 | 0 |
Loglevel | 日志等级 | notice |
Logfile | 日志文件路径 | "" |
Syslog-enabled | 是否启动系统日志 | no |
Syslog-ident | 系统日志标志 | redis |
Syslog-facility | 输入日志的设备 | local0 |
Databases | 库的数量 | 16 |
4)SNAPSHOTTING快照
名 | 描述 | 默认 |
---|---|---|
save | save 秒钟 写操作次数 | save 900 1 save 120 10 save 60 10000 |
stop-writes-on-bgsave-error | save出错时停止写 | yes |
rdbcompression | 是否使用LZF压缩快照 | yes |
rdbchecksum | 是否使用CRC64算法进行数据校验 | yes |
dbfilename | 持久化rdb的文件名称 | dump.rdb |
dir | 文件根目录 | ./ |
5)REPLICATION复制
名 | 描述 | 默认 |
---|---|---|
replica serve stale data | 主从复制中是否响应客户端请求 | yes |
replica-read-only | slave端是否只能读不能写 | yes |
6)SECURITY安全
名 | 描述 | 默认 |
---|---|---|
requirepass | redis访问密码 | "" |
7)LIMITS限制
名 | 描述 | 默认 |
---|---|---|
Maxclients | 设置redis同时可以与多少个客户端进行连接 | 10000 |
Maxmemory | 设置redis可以使用的内存量 | 0 |
Maxmemory-policy | 达到最大内存量时使用什么算法移除key | volatile-lru |
Maxmemory-samples | 设置样本数量 | 5 |
8)APPEND ONLY MODE追加
名 | 描述 | 默认 |
---|---|---|
appendonly | 是否开启aof | no |
appendfilename | aof文件名 | "appendonly.aof" |
Appendfsync | 同步策略 | everysec |
No-appendfsync-on-rewri | 重写时是否可以运用appendfsync | no |
Auto-aof-rewrite-min-size | 设置重写的基准值 | 64m |
Auto-aof-rewrite-percenta | 设置重写的基准值 | 100 |
4.持久化
1)RDB(Redis DataBase)
在指定时间内将数据集快照写入磁盘,在上面配置文件中SNAPSHOTTING中的save属性就是配置RDB的快照频率。
save 900 1
save 300 10
save 60 100
,意味着60秒内进行100次修改操作就进行一次快照。300秒内10次,900秒内1次。
并且保存的文件默认为启动的dump.rdb。
使用save和bgsave能立即进行快照。不同在于bgsave是异步执行
2)AOF(Append Only File)
需要手动启动,将appendonly从no改为yes
与RDB不同,AOF中是记录所有操作而并非数据集,在运行redis-server以后,会将aof文件中的操作重新执行一遍。
在配置文件中APPEND ONLY MODE下的重写基准可以设置在文件达到多少级别时进行重写。这会将添加之后再删除的数据操作进行约分扣除。
从配置文件中的Auto-aof-rewrite-min-size与Auto-aof-rewrite-percenta可知rewrite触发机制:redis会记录上次重写时的AOF大小,默认配置是当AOF文件大小是上次rewrite后大小的一倍且文件大于64M时触发
3)机制
在rdb与aof中被恶意插入一些不可被redis识别的语句时,可以执行安装目录下的redis-check-aof --fix
与redis-check-dump --fix
来修复。
在rdb与aof同时启动时,会优先使用aof,如果aof文件损坏,则redis启动会报错。
相同数据集的数据而言aof文件要远大于rdb文件,恢复速度慢于rdb,Aof运行效率要慢于rdb,每秒同步策略效率较好,不同步效率和rdb相同
5.redis事务
redis的事务和数据库中的事务不太一致,在redis事务中,是将所有的操作进行入队,然后再进行全部出队执行。而不是执行一项后再进行下一项。
1)正常执行
使用multi后执行入队操作,最后使用exec执行事务
127.0.0.1:6379> get balance
"100"
127.0.0.1:6379> get dept
"0"
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> DECRBY balance 10
QUEUED
127.0.0.1:6379> INCRBY dept 10
QUEUED
127.0.0.1:6379> EXEC
1) (integer) 90
2) (integer) 10
2)放弃事务
使用discard放弃事务
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> decrby balance 100
QUEUED
127.0.0.1:6379> DISCARD
OK
127.0.0.1:6379> get balance
"90"
3)回滚
在事务中某个操作具有语法错误,不可执行的情况下。事务会全部作废不会生效。
因为redis的事务为入队后出队执行,所以在redis中入队时识别到语法具有错误,进行的回滚,并不是真正的回滚,只是不执行事务。
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> decrby balance 20
QUEUED
127.0.0.1:6379> set error
(error) ERR wrong number of arguments for 'set' command
127.0.0.1:6379> exec
(error) EXECABORT Transaction discarded because of previous errors.
4)指明错误
在事务中某个操作是可执行的,但会报错的操作时,事务不会回滚,只会提示哪一步错误。
127.0.0.1:6379> set string s1
OK
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> decrby balance 20
QUEUED
127.0.0.1:6379> decrby string 20
QUEUED
127.0.0.1:6379> incrby dept 20
QUEUED
127.0.0.1:6379> EXEC
1) (integer) 70
2) (error) ERR value is not an integer or out of range
3) (integer) 30
5)watch监控
使用watch key
来监控某个值在事务的过程中是否被别的client修改。
watch指令类似乐观锁,所以watch之后,在exec之前,别的客户端是能够进行修改的。只有在最后exec之后,进行判断版本时,发现被修改后会报错,事务需要重新入队,重新执行。
通过WATCH命令在事务执行之前监控了多个Keys,倘若在WATCH之后有任何Key的值发生了变化,
EXEC命令执行的事务都将被放弃,同时返回Nullmulti-bulk应答以通知调用者事务执行失败
6.主从复制
主从复制遵循配从不配主,意思是,主机不进行任何配置的情况下,可以被小弟(slave从机)加入。
1)复制操作
自己本地单机实验时,需要拷贝多个redis.conf文件给从机,并且port,rdb,aof,log文件配置需要与主机不同并开启daemonize,使得其与主机的生成文件不同。
配置好之后,开启主机与从机,在刚启动两台服务时,使用info replication
指令都能看到role:master
在从机中使用指令slaveof 127.0.0.1 6379
,再使用info replication
会发现角色变为了slave。这时,主机中添加了记录,在从机中会拷贝过去。
注:因为配置了从机的replica-read-only,所以在变为从机时,只可读不可写。
2)复制原理
- Slave启动成功连接到master后会发送一个sync命令
- Master接到命令启动后台的存盘进程,同时收集所有接收到的用于修改数据集命令,
在后台进程执行完毕之后,master将传送整个数据文件到slave,以完成一次完全同步 - 全量复制:而slave服务在接收到数据库文件数据后,将其存盘并加载到内存中。
- 增量复制:Master继续将新的所有收集到的修改命令依次传给slave,完成同步
- 但是只要是重新连接master,一次完全同步(全量复制)将被自动执行
3)哨兵模式(sentinel)
在主从模式中,如果主机宕机时,那么从机会原理待命不动,这时候需要哨兵模式监督从机进行投票选举,选出一个新的master机器。
在配置文件目录下新建sentinel.conf
,一定不能打错字。
打开新建的哨兵配置文件,在下面填写内容sentinel monitor 被监控数据库名字(自己起名字) 127.0.0.1 6379 1
,这里的1指的是,当从机获得多少票时,自动上位为master。
注:当原有的master回归后,其角色也为master,但他属于“光杆司令”,并没有从机再去恢复为他的slave。