redis查看执行的命令+配置文件命令

1.SLOWLOG LEN
获取 Slowlog 的长度,以确定 Slowlog 中有多少条记录

2.SLOWLOG GET
获取 Slowlog 中的具体记录。你可以使用 SLOWLOG GET 命令来获取第 n 条记录的详细信息,其中 n 是记录的索引(从 0 开始)

3.如果你想获取多条最慢的执行语句,可以循环使用 SLOWLOG GET 命令来获取不同索引的记录。
请注意,Slowlog 只会记录执行时间超过指定阈值的命令,默认阈值是 10 毫秒。你可以通过配置参数 slowlog-log-slower-than 来调整阈值。同时,Slowlog 的记录是有限的,当记录数量达到设置的最大限制后,旧的记录会被新的记录替代。

在实际应用中,你可以编写脚本或程序来自动获取并分析 Slowlog,以便获取最慢的执行语句信息。

4.slowlog-log-slower-than
这个参数定义了一个执行时间的阈值,单位是微秒(μs)。只有执行时间超过这个阈值的命令才会被记录在 Slowlog 中。默认值是 10000 微秒(10 毫秒)。你可以根据需要调整这个阈值,以控制记录在 Slowlog 中的命令范围。

5.slowlog-max-len
这个参数定义了 Slowlog 的最大长度,即 Slowlog 中可以记录的最多命令数量。当 Slowlog 中的记录数量达到这个值时,旧的记录会被新的记录替代。默认值是 128。如果你希望保留更多的 Slowlog 记录,可以适当增加这个参数的值。

6.Slowlog 中的每条记录包含以下信息

id: 一个递增的唯一标识符,表示 Slowlog 记录的序号。
timestamp: 记录被创建的时间戳,通常以秒为单位。
execution_time: 命令的执行时间,以微秒(μs)为单位。即命令从开始执行到结束所花费的时间。
command: 执行的命令及其参数,以数组的形式表示。

例如,假设你执行了以下命令:
SET key1 value1

如果该命令执行时间超过了 Slowlog 的阈值,相应的 Slowlog 记录可能如下所示:
1) 1) (integer) 1
   2) (integer) 1652204489
   3) (integer) 2356
   4) 1) "SET"
      2) "key1"
      3) "value1"
      
在这个记录中,id 是 1,timestamp 表示时间戳,execution_time 是 2356 微秒,command 是执行的 SET 命令及其参数。

实机操作:
redis查看执行的命令+配置文件命令_第1张图片

二、Redis 集群配置示例

# Redis 集群配置示例

# 设置端口号和绑定 IP 地址
port 7000
bind 127.0.0.1

# 设置工作目录
dir /path/to/redis/data

# 设置集群模式
cluster-enabled yes

# 设置集群配置文件名
cluster-config-file nodes.conf

# 设置节点的超时时间
cluster-node-timeout 15000

# 配置节点的 IP 地址和端口号
cluster-announce-ip 127.0.0.1
cluster-announce-port 7000

# 配置其他节点之间的通信端口号
cluster-announce-bus-port 17000

# 配置集群节点的密码(如果需要)
cluster-require-full-coverage no
cluster-migration-barrier 1

# 设置持久化规则
save 900 1
save 300 10
save 60 10000

# 配置日志文件
logfile "redis.log"

# 配置密码保护
requirepass yourpassword

# 配置集群节点的主从关系
slaveof 127.0.0.1 7001

# 设置是否后台运行
daemonize yes

nodes.conf

172.16.0.101:6379@16379 myself,master - 0 0 1 connected 0-5460
172.16.0.102:6379@16379 master - 0 0 2 connected 5461-10922
172.16.0.103:6379@16379 master - 0 0 3 connected 10923-16383

每行记录了一个节点的信息,以空格分隔的字段。以下是各个字段的含义:
节点地址和端口:172.16.0.101:6379@16379 表示节点的 IP 地址、端口号和用于集群总线的额外端口号。
节点标识:myself,master 表示节点是当前节点,并且是主节点。
未使用的字段:这些字段在较旧的版本中使用,现在基本不再使用。
节点状态:connected 表示节点正常连接。
分片槽分配:0-5460 表示当前节点负责管理的分片槽范围。
在实际部署中,每个节点会自动生成类似的节点信息,并将其写入 nodes.conf 文件。你无需手动编辑 nodes.conf,而是让 Redis 集群自动维护节点信息。如果需要手动操作节点信息,可以使用 CLUSTER 命令或者一些管理工具来进行。
需要注意的是,nodes.conf 文件中的信息会在集群重新配置、扩展或收缩等操作时进行更新。

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