【Redis】Redis高级特性和应用(慢查询、Pipeline、事务、Lua)
目录
Redis的慢查询
慢查询配置
慢查询操作命令
慢查询建议
Pipeline
事务
Redis的事务原理
Redis的watch命令
Pipeline和事务的区别
Lua
Lua入门
安装Lua
Lua基本语法
注释
标示符
关键词
全局变量
Lua中的数据类型
Lua 中的函数
Lua 变量
Lua中的控制语句
循环控制
if条件控制
Lua 运算符
Lua其他特性
Java对Lua的支持
Maven
参考代码
Redis中的Lua
eval 命令
命令格式
命令说明
示例
Lua 脚本中调用 Redis 命令
evalsha 命令
redis-cli 执行脚本
Redis与限流
使用Redis+Lua语言实现限流
限流算法
固定窗口算法
滑动窗口算法
TCP中的滑动窗口
漏洞算法
令牌算法
Redis的慢查询
许多存储系统(例如 MySQL)提供慢查询日志帮助开发和运维人员定位系统存在的慢操作。所谓慢查询日志就是系统在命令执行前后计算每条命令的执行时间,当超过预设阀值,就将这条命令的相关信息(例如:发生时间,耗时,命令的详细信息)记录下来,Redis也提供了类似的功能。
Redis客户端执行一条命令分为如下4个部分:
1、发送命令
2、命令排队
3、命令执行
4、返回结果
需要注意,慢查询只统计步骤3的时间,所以没有慢查询并不代表客户端没有超时问题。因为有可能是命令的网络问题或者是命令在Redis在排队,所以不是说命令执行很慢就说是慢查询,而有可能是网络的问题或者是Redis服务非常繁忙(队列等待长)。
慢查询配置
对于任何慢查询功能,需要明确两件事:多慢算慢,也就是预设阀值怎么设置?慢查询记录存放在哪?
Redis提供了两种方式进行慢查询的配置
1、动态设置
慢查询的阈值默认值是10毫秒
参数:slowlog-log-slower-than就是时间预设阀值,它的单位是微秒(1秒=1000毫秒=1 000 000微秒),默认值是10 000,假如执行了一条“很慢”的命令(例如keys *),如果它的执行时间超过了10 000微秒,也就是10毫秒,那么它将被记录在慢查询日志中。
我们通过动态命令修改
--javascripttypescriptbashsqljsonhtmlcssccppjavarubypythongorustmarkdown
config set slowlog-log-slower-than 20000
使用config set完后,若想将配置持久化保存到Redis.conf,要执行config rewrite
--javascripttypescriptbashsqljsonhtmlcssccppjavarubypythongorustmarkdown
config rewrite
注意:
如果配置slowlog-log-slower-than=0表示会记录所有的命令,slowlog-log-slower-than<0对于任何命令都不会进行记录。
2、配置文件设置(修改后需重启服务才生效)
打开Redis的配置文件redis.conf,就可以看到以下配置: