【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个部分:

【Redis】Redis高级特性和应用(慢查询、Pipeline、事务、Lua)_第1张图片

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  

image.png

使用config set完后,若想将配置持久化保存到Redis.conf,要执行config rewrite

image.png

--javascripttypescriptbashsqljsonhtmlcssccppjavarubypythongorustmarkdown

config rewrite

【Redis】Redis高级特性和应用(慢查询、Pipeline、事务、Lua)_第2张图片

注意:

如果配置slowlog-log-slower-than=0表示会记录所有的命令,slowlog-log-slower-than<0对于任何命令都不会进行记录。

2、配置文件设置(修改后需重启服务才生效)

打开Redis的配置文件redis.conf,就可以看到以下配置:

【Redis】Redis高级特性和应用(慢查询、Pipeline、事务、Lua)_第3张图片

slowlog-max-len用来设置慢查询日志最多存储多少条

【Redis】Redis高级特性和应用(慢查询、Pipeline、事务、Lua)_第4张图片

另外Redis还提供了slowlog-max-len配置来解决存储空间的问题。

image.png

你可能感兴趣的:(redis,redis,lua,数据库,缓存,java)