Django-32 Redis1
坑1:redis执行redis-service /etc/redis.conf卡死
解决:要把redis.conf配置里面的daemonize的no改成yes
配置文件路径:/etc/redis.conf
mysql配置文件:/etc/mysql/mysql.conf.d/mysqld.cnf
备份:cp redis.conf redis_bak.conf
修改备份文件的用户组为redis:chown redis:root redis_bak.conf
添加密码
- 修改redis.conf配置:500行左右:requirepass 密码
- 关闭redis
/usr/bin/redis-cli shutdown
or
kill -9 PID - 启动redis redis-server /etc/redis.conf
- 验证:redis-cli -a 密码
ping 返回pong就是成功了。
远程连接
- 注释掉本地IP地址绑定
69行: # bind 127.0.0.1 ::1 - 关闭保护模式(把yes改为no)
88行:protected-mode no - 重启redis服务
- 客户端连接试一下:redis-cli -h 10.0.8.10 -a 密码
命令介绍
-
select number
切换数据库(redis默认有16个库,0-15位具体库的编号,默认进入的库的编号为0) -
info
查看信息 -
keys表达式
查找所有符合给定模式的key
KEYS * 匹配数据库中所有key
KEYS h?llo 匹配hello,hallo等
KEYS h*llo 匹配hllo和heeeeello等
注:正式环境中,请勿使用此命令,由于redis单进程单线程当key很多时,当前命令会阻塞redis -
type key
返回key的数据类型 -
exists key
当前key是否存在,1在0不在 -
del key
删除key -
rename key newkey
改变key名字 -
flushdb
清除所在库的所有数据库 -
flushall
清除所有数据库数据
基础概念
1、字符串、数字,都会转为字符串来存储
2、以二进制的方式存储在内存中
注意:
- key命名规范
可采用 -wang:email - key命名规范
1,key值不宜过长,消耗内存,且在数据中查找这类键值的计算成本高
2,不宜过短,可读性差 - 值
1,一个字符串类型的值最多能存512M内容
常用命令
- set key value nx ex
设置一个字符串的key
nx:not exist 表示key不存在时,才存储这个key
ex:expire 过期时间,单位s - strlen key
获取key存储值的长度 - getrange key start stop
获取指定返回切片内容【包含start stop】 - setrange key index value
从索引值开始,用value替换原内容,返回最新长度 - mset key1 value1 key2 value key3 value3
批量添加key和value - mget key1 key2 key3
批量获取key的值
数值操作
- incrby key 步长
将key增加指定步长 - decrby key 步长
将key减少指定步长
incr key
+1操作
decr key
-1 操作 - incrbyfloat key step
float类型
应用场景
缓存
mysql数据存储到redis字符串类型中
并发计数-点赞/秒杀
利用redis单进程单线程特点,并发问题转为串行问题
带有效期的验证码
借助过期时间,存放验证码;到期后自动消亡
过期时间
默认情况下,key没有过期时间,需要手动指定
方案1:直接用set的ex参数
set key value ex 3
方案2:使用expire通用命令
1,set key value
2,expire key 5 # 5秒
3,pexpire key 5 # 5毫秒
检查过期时间
- ttl key - 通用命令
返回值:
-1:代表当前key,没有过期时间
>0:代表当前key的剩余存活时间
-2:代表当前key不存在
删除过期时间 persist key(把带有过期时间的key变为永久不过期)
返回值:
1:删除成功
0:没有过期时间或者key不存在
redis删除过期key机制
每个redis数据库中,都会有一个特殊容器负责存储带有过期时间的key以及它对应的过期时间,这个容器称为“过期字典”。
针对过期字典中的key,redis结合,惰性删除和定期删除两大机制,有效删除过期数据。
最大内存检查
最后一道保险 - maxmemory 配置选项
一旦内存量超过最大限制,redis会在执行命令时触发内存淘汰(需手动在redis.conf中激活maxmemory配置项)
主流淘汰机制如下:
默认(no-enviction):禁入大多数写命令
volatile-lru:从已设置过期时间的内存数据集中挑选最近最少使用的数据淘汰
volatile-ttl:从已设置过期时间的内存数据集中挑选即将过期的数据淘汰
volatile-random:从已设置过期时间的内存数据集中任意挑选数据淘汰
allkeys-lru:从内存数据集中挑选最近最少使用的数据 淘汰
allkeys-random:从数据集中任意挑选数据淘汰
数据类型-列表
1、 元素是字符串类型
2、列表头尾增值快,中间增删慢,增删元素是常态
3、元素可重复
4、最多可包含2^32-1个元素
5、索引同python列表
增加
- lpush key value1 value2
从列表头部压入元素
返回list新的长度 - rpush key value1 value2
从列表尾部压入元素
返回list新的长度 - rpoplpush key1 key2
从列表key1尾部弹出一个元素压入key2的头部
返回被弹出的元素 - linsert key after|before value newvalue
在列表指定元素后/前插入元素
返回:
1,如果命令执行成功,返回列表长度
2,如果没有找到pivot,返回-1
3,如果key不存在或空列表,返回0
查看
- lrange key start stop
查看列表的元素 - llen key
获取列表长度
删除
-
lpop key
从列表左边弹出一个元素 -
rpop key
从列表右边弹出一个元素 -
blpop key timeout
列表左边,阻塞弹出,列表为空时阻塞
-brpop key timeout
列表右边,阻塞弹出,列表为空时阻塞
1, 如果弹出的列表不存在或为空,就会阻塞
2,超过时间设置为0,就是永久阻塞,直到有数据可以弹出
3,如果多个客户端阻塞再同一个列表上,使用first in first service原则,先到先服务 -
lrem key count value
删除指定元素
count>0:表示从头开始向尾搜索,移除与value相等的元素,数量为count
count<0:表示从尾开始向头搜索,移除与value相等的元素,数量为count
count=0:移除表中所有与value相等的值 -
ltrim key start stop
保留指定范围内的元素
场景:保存微博评论最后500条
ltrim weibo:comments 0 499
更新
- lset key index newvalue
设置list指定索引的值
list应用场景
1,存储微博评论,做切割,只保留最新的xx个
2,生产者消费者模型,做中间层,存放生产者的任务