当前位置: 首页 > news >正文

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

image.png

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

image.png

注意:

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

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

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

http://www.lryc.cn/news/254646.html

相关文章:

  • 【pytorch】深度学习入门一:pytorch的安装与配置(Windows版)
  • 安装postgresql驱动及python使用pyodbc指定postgresql驱动调用postgresql
  • 【OpenCV】计算机视觉图像处理基础知识
  • Course1-Week3-分类问题
  • Dockerfile 指令的最佳实践
  • Drools 入门:折扣案例
  • 微信小程序中生命周期钩子函数
  • “无忧文件安全!上海迅软DSE文件加密软件助您轻松管控分公司数据!
  • 详解线段树
  • C语言——指针的运算
  • Apache Hive(部署+SQL+FineBI构建展示)
  • python入门级简易教程
  • 模拟一个集合 里面是设备号和每日的日期
  • antdesign前端一直加载不出来
  • 排序算法介绍(一)插入排序
  • 2023新优化应用:RIME-CNN-LSTM-Attention超前24步多变量回归预测算法
  • RNN:文本生成
  • Rust UI开发(五):iced中如何进行页面布局(pick_list的使用)?(串口调试助手)
  • Linux学习笔记2
  • 数据结构算法-插入排序算法
  • 安装Kuboard管理K8S集群
  • 网络安全行业大模型调研总结
  • Linux AMH服务器管理面板本地安装与远程访问
  • Sharding-Jdbc(3):Sharding-Jdbc分表
  • zookeeper集群 +kafka集群
  • 2022年全国大学生数据分析大赛医药电商销售数据分析求解全过程论文及程序
  • Python版本与opencv版本的对应关系
  • 【开源视频联动物联网平台】LiteFlow
  • 家用智能门锁——智能指纹锁方案
  • Qt6 QRibbon 一键美化Qt界面