Redis——高级主题

介绍Redis的高级主题,包括服务器配置、Redis事务、Redis发布和订阅、Pipeline批量发送请求、数据备份与恢复等。

1、服务器配置

在Windows和Linux的Redis服务器里面,都有一个配置文件。Redis配置文件位于Redis安装目录下,在不同操作系统下,Redis配置文件名是不一样的:

  • 在Windows下,Redis配置文件名为redis.windows.conf。
  • 在Linux下,Redis配置文件名为redis.conf。

在Linux下使用redis-server命令启动Redis服务器时,可以在命令后面指定配置文件。例如,在Linux下使用如下命令启动Redis服务器:

$ redis-server /usr/local/redis/conf/redis.conf

也可以通过Redis的CONFIG命令对Redis配置文件进行查看或设置项。

1.1、Redis服务器允许远程主机访问

若主机需要远程访问Redis服务器,则可以修改Redis配置文件redis.conf。文件中bind字段默认为bind 127.0.0.1,表示只能在本机访问Redis服务器,如下图所示:
在这里插入图片描述
若允许远程主机访问Redis服务器,可以将bind 127.0.0.1改为bind 0.0.0.0。

找到daemonize no,把这一项的no改成yes。daemonize yes主要是开启Redis的守护进程,可以在Linux启动时自动运行Redis,将Redis服务器作为守护进程(daemon)来运行:

daemonize yes

关闭protected-mode模式,让外部网络可以直接访问Redis服务器。在Redis配置文件中找到protected-mode yes,把这一项的yes改成no:

protected-mode no

1.2、客户端远程连接Redis服务器

远程连接Redis服务器需要使用redis-cli命令,redis-cli命令的用法为:redis-cli[OPTIONS][cmd[arg[arg…]]]。

redis-cli命令的关键参数如下:

  • -h:主机IP地址,默认是127.0.0.1。
  • -p:端口,默认是6379。
  • -a:密码,如果Redis设置了密码,需要传递密码。

假设有两台Redis服务器,Redis服务器的IP地址分别是192.168.1.11和192.168.1.14。现在需要在192.168.1.11上通过redis-cli命令远程访问192.168.1.14上的Redis服务器,在192.168.1.11上通过以下命令远程连接192.168.1.14上的Redis服务器:

$ redis-cli -h 192.168.1.14 -p 6379  
192.168.1.14:6379> SET age 20 
OK 
192.168.1.14:6379> GET age 
"20"

通过本例,客户端远程连接到192.168.1.14上的Redis服务器,设置了一个String类型的值,使age等于“20”。

1.3、设置密码

通过Redis配置文件来设置密码,客户端连接到Redis服务器时就需要密码验证,这样可以让Redis服务器更安全。

1、通过命令设置Redis密码

首先通过CONFIG GET requirepass命令查看Redis服务器是否设置了密码验证:

127.0.0.1:6379> CONFIG GET requirepass 
1) "requirepass" 
2) ""

默认情况下requirepass对应的参数是空的,即没有密码,表示不需要通过密码验证就可以连接到Redis服务器。

然后设置Redis服务器的当前密码为123。Redis服务器重新启动后又会将密码重置为默认,即没有密码,因此不建议用此种方式设置密码:

127.0.0.1:6379> CONFIG SET requirepass "123" 
OK 
127.0.0.1:6379> CONFIG GET requirepass
1) "requirepass" 
2) "123"

通过命令设置Redis密码的完整实例如下:

[root@bogon bin]# ./redis-cli -h 127.0.0.1 -p 6379  
# 获取现有Redis服务器密码 
127.0.0.1:6379> CONFIG GET requirepass 
1) "requirepass" 
2) "" 
# 设置新密码 
127.0.0.1:6379> CONFIG SET requirepass "123" 
OK 
127.0.0.1:6379> exit 
# 重新设置密码后,连接Redis服务器需添加密码参数 
[root@bogon bin]# ./redis-cli -h 127.0.0.1 -p 6379 -a 123 
127.0.0.1:6379> set age 20 
OK

重新设置密码后,需要重新登录Redis服务器才能获取操作权限。

2、通过修改Redis配置文件设置密码

编辑redis.conf配置文件,添加requirepass值设置密码:

requirepass 123

以上设置的Redis服务器的访问密码为123,读者可以根据实际需要进行密码的设置。

重启Redis服务器后,再次进入Redis客户端并输入以下内容:

127.0.0.1:6379>KEYS * 
(error) NOAUTH Authentication required

发现没有权限进入当前数据库,需要使用AUTH命令进行授权操作:

127.0.0.1:6379>AUTH 123 
OK

输入密码则成功进入当前数据库,用这种方式每次进入当前数据库的时候都需要输入密码。

还有一种简单的方式,即直接登录数据库并授权:

[root@bogon bin]# ./redis-cli -h 127.0.0.1 -p 6379 -a 123

在本例中,我们设置了Redis服务器的访问密码为123。建议用此种方式设置密码,重启Redis服务器后就可以使用设置好的密码连接Redis服务器了。

1.4、Redis端口修改

Redis默认的端口是6379,在redis.conf配置文件里搜索6379就能找到端口参数配置,如下所示:

# Accept connections on the specified port, default is 6379 (IANA #815344). 
# If port 0 is specified Redis will not listen on a TCP socket. 
port 6379

可以将默认的端口修改成指定的端口,不要端口冲突就行。启动Redis服务器后,可以使用ps-ef|grep redis命令查看Redis服务器占用的端口,如下图所示:
在这里插入图片描述
从上图可以看出,现在Redis服务器使用的端口是6379。

1.5、查看配置

可以通过CONFIG GET命令查看配置。CONFIG GET命令的基本语法如下:

redis 127.0.0.1:6379> CONFIG GET CONFIG_SETTING_NAME

实例:查看Redis的日志级别。

127.0.0.1:6379> CONFIG GET loglevel 
1) "loglevel" 
2) "notice"

1.6、修改配置

可以通过修改redis.conf配置文件或使用CONFIG SET命令来修改配置。

CONFIG SET命令的基本语法如下:

redis 127.0.0.1:6379> CONFIG SET CONFIG_SETTING_NAME NEW_CONFIG_VALUE

实例:修改Redis记录的日志级别:

127.0.0.1:6379> CONFIG SET loglevel "notice" 
OK 
127.0.0.1:6379>  CONFIG GET loglevel 
1) "loglevel" 
2) "notice" 
127.0.0.1:6379>

1.7、配置项说明

redis.conf配置项说明如下:
(1)Redis默认不是以守护进程的方式运行的,可以通过daemonize配置项修改。如果指定为yes,表示启用守护进程:

daemonize no

(2)当Redis以守护进程的方式运行时,Redis默认会把pid写入/var/run/redis.pid文件,可以通过pidfile配置项来指定:

pidfile /var/run/redis.pid

(3)指定Redis监听端口,可以通过port配置项来指定,默认端口为6379:

port 6379

(4)指定绑定的主机地址,可以用于限制连接,默认只能本机访问Redis服务器:

bind 127.0.0.1

(5)指定Redis客户端闲置多长时间后关闭连接,如果指定为0,表示关闭该功能:

timeout 300

(6)指定日志的记录级别,Redis支持4个级别,即debug、verbose、notice、warning,默认值为verbose:

loglevel verbose

(7)指定日志文件的保存路径,如果指定为"",表示默认为标准输出:

logfile ""

(8)指定数据库的数量,默认数据库数量为0,可以使用SELECT命令来连接指定的数据库:

databases 16

(9)指定在多长时间内执行多少次更新操作,Redis就将数据同步到数据文件中:

save <seconds> <changes>

Redis的默认配置文件中设置了3个触发条件:

save 900 1

save 300 10

save 60 10000

save 900 1表示900s(15min)内有1个更新,save 300 10表示300s(5min)内有10个更新,save 60 10000表示60s(1min)内有10 000个更新,Redis就将数据同步到数据文件中。

(10)对于存储到磁盘中的Redis快照,可以设置是否进行压缩存储,默认值为yes。如果指定为yes,Redis会采用LZF压缩算法对存储到磁盘中的Redis快照进行压缩。如果不想消耗CPU来压缩快照的话,可以指定为no来关闭该选项,但是存储在磁盘上的快照会比较大:

rdbcompression yes

(11)指定存储数据的本地数据库的文件名,默认值为dump.rdb。

dbfilename dump.rdb

(12)指定本地数据库存放目录:

dir/usr/local/redis/bin

(13)指定当本机为Slave(从服务器)服务时,Master(主服务器)服务的IP地址及端口。在Redis启动时,它会自动从Master服务进行数据同步:

slaveof <masterip> <masterport>

(14)指定当Master服务设置了密码保护时,Slave服务连接Master服务的密码:

masterauth <master-password>

(15)指定Redis的连接密码。如果配置了连接密码,则客户端在连接Redis时需要使用AUTH命令提供密码,默认配置是关闭的:

requirepass foobared

(16)指定同一时间内客户端允许的最大连接数,如果设置为maxclients 0,表示不做限制。当客户端连接数达到最大限制时,Redis会关闭新的连接并向客户端发送max number of clients reached错误信息:

maxclients 128

(17)指定Redis的最大内存限制。Redis在启动时会把数据缓存到内存中,达到最大内存后,Redis会尝试清除已到期的key。Redis新的vm(虚拟内存)机制,会把key存放在内存,把value存放在swap区:

maxmemory <bytes>

(18)指定Redis是否在每次执行更新操作后进行日志记录,在默认情况下Redis是异步地把内存中的数据写入磁盘的。如果不开启此选项,可能会在主机断电时丢失一段时间内的数据。该选项默认值为no:

appendonly no

(19)指定更新日志文件名,默认值为appendonly.aof:

appendfilename appendonly.aof

(20)指定更新日志的条件,共有3个可选值:

  • no:表示等操作系统进行数据缓存后才同步到磁盘,特点是速度快。
  • always:表示每次执行更新操作后,需要手动调用fsync()将数据写到磁盘,特点是速度慢,比较安全。
  • everysec:表示每秒同步一次数据到磁盘,是上面两个选项的折中选项,也是默认值。
appendfsync everysec

(21)指定是否启用虚拟内存机制,默认值为no:

vm-enabled no

(22)指定虚拟内存文件路径,默认值为/tmp/redis.swap。不可多个Redis实例共享:

vm-swap-file /tmp/redis.swap

(23)指定将所有大于vm-max-memory的数据存入虚拟内存,默认值为0,无论vm-max-memory多小,所有索引数据都是内存存储的(Redis的索引数据就是key),也就是说,当vm-max-memory设置为0的时候,其实是所有value都存储在磁盘:

vm-max-memory 0

(24)Redis的swap文件被分成了很多个page,一个对象可以保存在多个page上,但一个page不能被多个对象共享:

vm-page-size 32

(25)指定swap文件中的page数量:

vm-pages 134217728

(26)指定访问swap文件的线程数,此选项值最好不要超过计算机的核数。如果设置为0,那么所有对swap文件的操作都是串行的,可能会造成比较长时间的延迟。此选项默认值为4:

vm-max-threads 4

(27)指定在向客户端响应时,是否把较小的包合并为一个包发送,默认值为yes:

glueoutputbuf yes

2、Redis事务

Redis的事务可以一次执行多个命令,有以下两个重要的特点:

  • 事务是一个单独的隔离操作:事务中的所有命令都会按顺序执行,事务在执行的过程中,不会被其他客户端发送的命令所打断。
  • 事务是一个原子性操作:事务中的命令要么全部被执行,要么全部都不执行。

一个事务会经历3个阶段,即开始事务、命令入队、执行事务,如下图所示:
在这里插入图片描述

2.1、Redis事务的常用命令

下表列出了Redis事务的常用命令及其描述:
在这里插入图片描述
在这里插入图片描述

2.2、简单事务控制

以下是一个简单事务控制的实例。先使用MULTI命令开始一个事务,然后将多个命令入队到事务中,最后由EXEC命令触发事务,一起执行事务块内的所有命令:

127.0.0.1:6379> SET age 20 
OK 
127.0.0.1:6379> MULTI 
OK 
#两个SET命令都没有被执行,而是被放到了队列中 
127.0.0.1:6379> SET age 21 
QUEUED 
127.0.0.1:6379> SET age 22 
QUEUED 
127.0.0.1:6379> GET age 
QUEUED 
#SADD命令也没有被执行,也被放到了队列中 
127.0.0.1:6379> SADD tag "java" "python" "c" 
QUEUED 
127.0.0.1:6379> SMEMBERS tag 
QUEUED 
# 触发事务,一起执行队列中的命令,执行命令后返回的是执行3个命令的结果 
127.0.0.1:6379> EXEC 
1) OK 
2) OK 
3) "22" 
4) (integer) 3 
5) 1) "python" 
   2) "c" 
   3) "java" 
# 查看 age对应的字符串 
127.0.0.1:6379> GET age 
"22" 
# 查看 tag对应的集合 
127.0.0.1:6379> SMEMBERS tag 
1) "python" 
2) "c" 
3) "java"

从本例中可以看到,两个SET命令和一个SADD命令并没有被立即执行而是放到了队列中,在执行EXEC命令后3个命令才被连续执行,最后返回的是3个命令的执行结果。

2.3、取消一个事务

我们可以执行DISCARD命令来取消一个事务,让事务回滚。实例如下:

127.0.0.1:6379> SET age 20 
OK 
127.0.0.1:6379> GET age 
"20" 
127.0.0.1:6379> MULTI 
OK 
127.0.0.1:6379> SET age 21 
QUEUED 
127.0.0.1:6379> SET age 22 
QUEUED 
127.0.0.1:6379> DISCARD 
OK 
127.0.0.1:6379> GET age 
"20"

从本例中可以看到,两个SET命令并没有被立即执行而是放到了队列中,在执行DISCARD命令后清空事务的命令队列并退出事务的上下文,也就是事务回滚。

2.4、乐观锁控制复杂事务

乐观锁就是利用版本号比较机制,只是在读数据的时候,将读到的数据的版本号一起读出来,当对数据的读操作结束并准备写数据的时候,再进行一次数据的版本号的比较。若版本号没有变化,即认为数据是一致的,没有更改,可以直接写入;若版本号有变化,则认为数据被更新,不能写入,防止脏写。

乐观锁工作机制:执行WATCH命令监视Redis给定的每一个key,当执行EXEC命令时如果监视的任何一个key自从执行WATCH命令后发生过变化,则整个事务会回滚,不执行任何操作。

3、Redis发布和订阅

Redis发布和订阅是一种消息通信模式:发送者(Publish)用来发送消息,订阅者(Subscribe)用来接收消息。Redis客户端可以订阅任意数量的频道。

下图展示了频道channel1,以及订阅这个频道的3个客户端client2、client5和client1之间的关系:
在这里插入图片描述
当有新消息通过PUBLISH命令发送给频道channel1时,这个消息就会被发送给订阅它的3个客户端(client2、client5和client1),如下图所示:
在这里插入图片描述

3.1、Redis发布和订阅的常用命令

在这里插入图片描述

3.2、Redis发布和订阅实例

以下实例演示了发布和订阅是如何工作的。

首先,打开一个客户端连接Redis服务器,作为订阅者接收消息。在本实例中我们创建了一个订阅频道,命名为redisChat:

127.0.0.1:6379> SUBSCRIBE redisChat 
Reading messages... (press Ctrl-C to quit) 
1) "subscribe" 
2) "redisChat" 
3) (integer) 1

其次,重新开启一个Redis客户端,作为发送者发送消息,然后在同一个频道redisChat发布两次消息,订阅者就能接收消息:

127.0.0.1:6379> PUBLISH redisChat "message1" 
(integer) 1 
127.0.0.1:6379> PUBLISH redisChat "message2" 
(integer) 1 
127.0.0.1:6379>

订阅者的客户端会显示如下消息:

127.0.0.1:6379> SUBSCRIBE redisChat 
Reading messages... (press Ctrl-C to quit) 
1) "subscribe" 
2) "redisChat" 
3) (integer) 1 
1) "message" 
2) "redisChat" 
3) "message1" 
1) "message" 
2) "redisChat" 
3) "message2"

4、Redis管道

Redis是一个客户端-服务器(CS)模型的TCP服务器,使用和HTTP类似的相应请求协议。一个客户端可以通过一个Socket连续发送多个请求命令,每个请求命令发出后客户端通常会阻塞并等待Redis服务器处理,Redis服务器处理完请求后会将结果通过响应报文返回给客户端。

Redis的管道(Pipeline)可以一次性发送多条命令并在执行完后一次性将结果返回。管道可以减少客户端与Redis服务器的通信次数,从而降低往返延时时间。管道实现的原理是队列,而队列遵循先进先出原则,这样就保证了数据的顺序性。

Redis管道技术可以在Redis服务器启动时使用,在Redis客户端向Redis服务器发送请求(Request),并一次性读取所有Redis服务器的响应(Response)。

在Linux客户端新建脚本pipeline.sh:

[root@localhost ~]# touch pipeline.sh

使用vi命令修改pipeline.sh:

[root@localhost ~]# vi pipeline.sh

在pipeline.sh中添加以下内容,脚本文件名为Redis\Chapter04\pipeline.sh:

(echo -en "PING\r\n SET db redis\r\nGET db\r\nSET visitor 0\r\nINCR visitor\r
\nINCR visitor\r\nINCR visitor\r\nGET visitor\r\n"; sleep 10) | nc localhost 6379

给pipeline.sh赋予可执行命令权限:

[root@localhost ~]# chmod +x pipeline.sh

执行pipeline.sh:

[root@localhost ~]# ./pipeline.sh

得到以下内容:

[root@localhost ~]# ./pipeline.sh  
+PONG 
+OK 
$5 
redis 
+OK 
:1 
:2 
:3 
$1 
3

以上实例中,我们首先使用PING命令查看Redis服务器是否可用,之后我们设置了db的值为redis并获取了db的值,最后使visitor自增3次并获取了visitor的值。

打开一个终端,并使用redis-cli命令连接Redis服务器:

127.0.0.1:6379> GET visitor 
"3" 
127.0.0.1:6379> GET db 
"redis"

从上面结果可以看出,Redis数据库已经存储了db和visitor的值。

5、数据恢复与备份

5.1、数据备份

Redis的SAVE命令用于创建当前数据库的快照文件。

实例,使用SAVE命令创建当前数据库的快照:

127.0.0.1:6379> SAVE  
OK

该命令将在Redis安装目录中创建dump.rdb文件。

5.2、数据恢复

如果需要恢复数据,只需将一台Redis服务器上的快照文件(dump.rdb)移动到另一台Redis服务器的安装目录并启动服务即可。获取Redis安装目录可以使用CONFIG命令,如下所示:

127.0.0.1:6379> CONFIG GET dir 
1) "dir" 
2) "/usr/local/redis/bin"

在本例中使用CONFIG GET dir命令输出的Redis安装目录为/usr/local/redis/bin。

创建Redis备份文件也可以使用BGSAVE命令,该命令在后台执行:

127.0.0.1:6379> BGSAVE 
Background saving started

6、Redis性能测试

Redis性能测试是通过同时执行多个命令实现的。Redis性能测试的基本命令如下:

redis-benchmark [option] [option value]

实例:同时执行10 000个请求来测试Redis的性能,如下图所示:
在这里插入图片描述
Redis性能测试工具可选参数如下表所示:
在这里插入图片描述
在这里插入图片描述
实例:使用多个参数来测试Redis性能:

$ redis-benchmark -h 127.0.0.1 -p 6379 -t SET,LPSH -n 10000 -q 
SET: 65789.48 requests per second 
LPUSH: 74074.07 requests per second

以上实例中连接Redis的主机IP地址为127.0.0.1,端口为6379,执行SET命令和LPUSH命令,请求数为10000,通过-q参数让结果只显示每秒执行的请求数。

7、Redis客户端连接

在Redis 2.4中,最大连接数是被直接硬编码写在代码里面的,而在Redis 2.6以后的版本中这个值变成可配置的。maxclients的默认值是10 000,也可以在redis.conf配置文件中对这个值进行修改:

127.0.0.1:6379> CONFIG GET maxclients 
1) "maxclients" 
2) "10000"

以下实例可以在Redis服务器启动时,设置最大连接数为100000:

$ redis-server --maxclients 100000

Redis客户端查看客户端连接的命令及其描述如下表所示:
在这里插入图片描述
Redis客户端命令如下图所示:
在这里插入图片描述

8、Redis服务开机自启动

每次启动Redis服务都需要使用redis-server命令,稍显烦琐。当然也可以把redis-server命令放在启动脚本里,每次运行脚本就可以启动Redis服务了。但有没有更好的方法,让主机每次开机后就自动启动Redis服务呢?答案是肯定的。

8.1、Windows下Redis服务开机自启动

可以把Redis设置成Windows服务,这样Windows启动后就会自启动Redis服务,和Windows服务一样,可以启动/停止服务。

8.1.1、注册Redis为Windows后台服务

在Redis的目录下执行以下命令,执行后Redis就作为Windows后台服务了:

redis-server --service-install redis.windows.conf

如果执行命令成功,会显示下图所示页面:
在这里插入图片描述
按“Win+R”组合键执行services.msc命令,就可以看到Redis已经作为Windows后台服务了。

8.1.2、启动Redis服务

将Redis成功注册到Windows后台服务中后,Redis并没有启动,可以在Windows服务列表中启动Redis服务。启动Redis服务的命令如下:

redis-server --service-start

8.1.3、停止Redis服务

停止Redis服务的命令如下:

redis-server --service-stop

8.1.4、卸载Redis服务

卸载Redis服务的命令如下:

redis-server --service-uninstall

注意将Redis成功注册到Windows后台服务后,就可以使用Windows命令启动/停止Redis服务,如下图所示:
在这里插入图片描述
启动Redis服务:

net start redis

停止Redis服务:

net stop redis

8.2、Linux下Redis服务开机自启动

8.2.1、修改redis.conf配置文件

为了让redis-server命令能在操作系统启动时自动执行,需要将Redis服务作为守护进程(Daemon)来运行。我们回到/usr/local/redis/conf目录中找到redis.conf配置文件,这个文件是Redis服务运行时加载的配置文件,使用以下命令查看其中的内容:

$ vi /usr/local/redis/conf/redis.conf

此文件内容非常多,但是大部分内容是注释,我们重点关注其中的两个配置项:daemonize和pidfile:

  • daemonize默认值是false,表示Redis服务作为守护进程来运行,需要把它改成daemonize yes。
  • pidfile默认值是pidfile/var/run/redis_6379.pid,表示当Redis服务以守护进程方式运行时,Redis服务默认会把pid写入/var/run/redis_6379.pid文件,Redis服务运行时该文件就存在,Redis服务一旦停止该文件就会自动删除,因而可以用来判断Redis服务是否正在运行。该配置项不用修改。

为了让Redis能在Linux启动时自动运行,需要修改完配置项daemonize后保存redis.conf配置文件,然后退出文件。

8.2.2、## 8.2.1、修改redis.conf配置文件

有了基本配置,Redis还需要有一个管理启动、关闭和重启的脚本。在Redis的源代码里已经提供了一个初始化脚本redis_init_script。这个初始化脚本的位置在%/redis-6.0.6/utils/目录下,如下图所示:
在这里插入图片描述
redis_init_script脚本中指定了端口、Server路径、CLI路径、PIDFILE路径以及CONF路径。在安装时执行了make install命令后,这个脚本不需要做多大改动,因为make install命令会把Redis的可执行命令都复制到/usr/local/bin目录下。

只需要修改CONF选项对应的Redis配置文件为Linux使用的redis.conf配置文件即可。在笔者的计算机上,Redis配置文件保存在/usr/local/redis/conf/redis.conf目录下,读者需要根据实际情况进行修改。修改后的redis_init_script脚本如下图所示:
在这里插入图片描述

8.2.3、将redis_init_script脚本复制到/etc/init.d目录下并修改脚本名字为redis

$ cp redis_init_script /etc/init.d/redis

给redis文件授予执行权限:

$ chmod +x /etc/init.d/redis

8.2.4、开启服务自启动

在/etc/init.d目录下的脚本都是可以在Linux启动时自动启动的服务,还需要一个Linux启动时的配置。开启Redis服务自启动的命令如下:

$ chkconfig redis on

8.2.5、启动和停止Redis服务

重启CentOS之后,就可以执行以下命令启动和停止Redis服务了。

启动Redis服务:

$ service redis start

停止Redis服务:

$ service redis stop

以上两个命令等价于以下命令:

$/etc/init.d/redis start 
$/etc/init.d/redis stop

9、Redis内存分析工具

redis-rdb-tools是用Python编写的用来分析Redis的RDB快照文件的工具。在内存分析中,我们主要用它生成内存报告。

9.1、安装redis-rdb-tools

安装redis-rdb-tools前需要配置Python环境,配置好Python环境后可以通过Python的pip来安装redis-rdb-tools:

$ pip3 install rdbtools python-lzf

9.2、生成内存报告

使用redis-rdb-tools生成内存报告的实例如下:
首先,在Redis客户端生成两条String类型的数据,如下所示:

127.0.0.1:6379> SET name xinping 
OK 
127.0.0.1:6379> SET age 25 
OK 
127.0.0.1:6379> SAVE

然后,把Redis的RDB快照内存报告输出到控制台:

$ rdb -c memory /usr/local/redis/bin/dump.rdb 
database,type,key,size_in_bytes,encoding,num_elements,len_largest_element,expiry 
0,string,age,48,string,8,8, 
0,string,name,64,string,7,7,

在生成的报告中有database(key所在的Redis数据库编号)、type(key类型)、key(键)、size_in_bytes(key占用的内存大小)、encoding(RDB编码方式)、num_elements(key中的value的个数)、len_largest_element(key中的value的长度)和expiry(key的过期时间)从返回的报告可以看出key为age的String类型数据占用了46个字节,key为name的String类型数据占用了64个字节。

也可以使用以下命令把Redis的内存报告生成为memory.csv文件,并将文件输出到控制台:

$ rdb -c memory /usr/local/redis/bin/dump.rdb > memory.csv 
$ cat memory.csv  
database,type,key,size_in_bytes,encoding,num_elements,len_largest_element,expiry 
0,string,age,48,string,8,8, 
0,string,name,64,string,7,7,

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/378548.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

VMWare下载安装(包含Window是和Mac)

VMWare下载安装&#xff08;包含Window是和Mac&#xff09; 文章目录 VMWare下载安装&#xff08;包含Window是和Mac&#xff09;一、windows下载VMWare①&#xff1a;下载01&#xff1a;网盘下载02&#xff1a;官方下载 ②&#xff1a;安装③&#xff1a;密钥 二、Mac下载VMWa…

vue3:26—新的内置组件

目录 Teleport Suspense Teleport 什么是Teleport? Teleport 是一种能够将我们的组件html结构移动到指定位置的技术 当在元素中的css使用了filter滤镜属性的时候&#xff0c;会导致内部 fixed 元素定位发生错误&#xff0c;即不再相对 viewport 进行定位&#xff0c;而是相对…

使用 WMI 查询安全软件信息

在这篇文章中&#xff0c;我们将详细介绍如何使用 Windows Management Instrumentation (WMI) API 来查询当前计算机上安装的安全软件的基本信息。我们将分析代码的各个部分&#xff0c;并解释每个步骤所涉及的技术和原理。 一、什么是 WMI&#xff1f; WMI 是 Windows Manag…

BlueLotus 下载安装使用

说明 蓝莲花平台BlueLotus&#xff0c;是清华大学曾经的蓝莲花战队搭建的平台&#xff0c;该平台用于接收xss返回数据。 正常执行反射型xss和存储型xss&#xff1a; 反射型在执行poc时&#xff0c;会直接在页面弹出执行注入的poc代码&#xff1b;存储型则是在将poc代码注入用…

基于51 单片机的交通灯系统 源码+仿真+ppt

主要内容&#xff1a; 1&#xff09;南北方向的绿灯、东西方向的红灯同时亮40秒。 2&#xff09;南北方向的绿灯灭、黄灯亮5秒&#xff0c;同时东西方向的红灯继续亮。 3&#xff09;南北方向的黄灯灭、左转绿灯亮&#xff0c;持续20秒&#xff0c;同时东西方向的红灯继续…

Spinnaker多云持续交付平台: 部署Minio存储服务

目录 一、实验 1.环境 2.K8S storage节点部署NFS 3.K8S 动态创建PV 4.K8S master节点部署HELM3 4.K8S master节点部署Minio存储服务&#xff08;第一种方式安装&#xff09; 5.Minio客户端安装MC命令 6.K8S master节点使用Docker 部署Minio存储服务&#xff08;第二种方…

设计模式学习笔记05(小滴课堂)

讲解Adapeter设计模式和应用场景 接口的适配器案例实战 代码&#xff1a; 定义一个接口&#xff1a; 编写适配器&#xff1a; 写我们的商品类&#xff1a; 会员类&#xff1a; 这样我们不同的需求可以根据需要去实现不同的接口方法&#xff0c;而不用实现全部接口方法。 适配…

elasticsearch重置密码操作

安装es的时候需要测试这个url&#xff1a;http://127.0.0.1:9200/ 出现弹窗让我输入账号和密码。我第一次登录&#xff0c;没有设置过账号和密码&#xff0c; 解决方法是&#xff1a;在es的bin目录下打开cmd窗口&#xff0c;敲命令&#xff1a;.\elasticsearch-reset-password…

移动Web——Bootstrap

1、Bootstrap-简介 Bootstrap是由Twitter公司开发维护的前端UI框架&#xff0c;它提供了大量编写好的CSS样式&#xff0c;允许开发者结合一定HTML结构及JavaScript&#xff0c;快速编写功能完善的网页及常见交互效果 <!DOCTYPE html> <html lang"en"> &…

上海亚商投顾:成交量突破万亿 沪指重回2800

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 一.市场情绪 昨日A股三大指数延续上涨&#xff0c;深成指领涨&#xff0c;沪指重新站上2800点。不过&#xff0c;指数黄白分…

MATLAB环境下基于深层小波时间散射网络的ECG信号分类

2012年&#xff0c;法国工程学院院士Mallat教授深受深度学习结构框架思想的启发&#xff0c;提出了基于小波变换的小波时间散射网络&#xff0c;并以此构造了小波时间散射网络。 小波时间散射网络的结构类似于深度卷积神经网络&#xff0c;不同的是其滤波器是预先确定好的小波…

从源码学习访问控制符使用

从源码学习访问控制符使用 Java中的访问控制符 ​ 在Java中&#xff0c;有四个访问控制符&#xff1a;public、protected、default&#xff08;默认或缺省&#xff0c;不使用关键字&#xff09;和private。 ​ 它们的访问范围如下&#xff1a; public&#xff1a;公共访问权…

【人工智能】人工智能 – 引领未来科技的潮流

写在前面 引言红利挑战结论 引言 人工智能是指使计算机系统表现出类似于人类智能的能力。其目标是实现机器具备感知、理解、学习、推理和决策等智能行为。人工智能的发展可以追溯到上世纪50年代&#xff0c;随着计算机技术和算法的不断进步&#xff0c;人工智能得以实现。 今天…

『运维备忘录』之 Kubernetes(K8S) 常用命令速查

一、简介 kubernetes&#xff0c;简称K8s&#xff0c;是用8代替名字中间的8个字符“ubernete”而成的缩写&#xff0c;是一个开源的&#xff0c;用于管理云平台中多个主机上的容器化的应用。kubernetes是基于容器技术的分布式架构解决方案&#xff0c;具有完备的集群管理能力&a…

今日早报 每日精选15条新闻简报 每天一分钟 知晓天下事 2月8日,星期四

每天一分钟&#xff0c;知晓天下事&#xff01; 2024年2月8日 星期四 农历腊月廿九 1、 气象局&#xff1a;南方地区雨雪冰冻天气趋于结束&#xff0c;需警惕融雪融冰引发的次生灾害。 2、 应急管理部&#xff1a;1月各种自然灾害共造成228.9万人次不同程度受灾&#xff0c;直…

网络套件字(理论知识)

一、源IP地址和目的IP地址 上次说到IP地址是为了是为了让信息正确的从原主机传送到目的主机&#xff0c;而原IP地址和目的IP地址就是用于标识两个主机的&#xff0c;既然叫做地址必然有着路径规划的作用&#xff0c;而路径规划最重要的就是&#xff0c;从哪来到哪去&#xff0…

计算机毕业设计 | SSM超市进销存管理系统(附源码)

1&#xff0c;绪论 1.1 开发背景 世界上第一个购物中心诞生于美国纽约&#xff0c;外国人迈克尔库伦开设了第一家合作商店&#xff0c;为了更好地吸引大量客流量&#xff0c;迈克尔库伦精心设计了低价策略&#xff0c;通过大量进货把商品价格压低&#xff0c;通过商店一次性集…

论文封面下划线总是对不齐,这3步你肯定没做!

论文封面 在写论文时&#xff0c;总会遇到论文封面下划线对不齐&#xff0c;学会下面这三招轻松搞定封面。 解决方法 ①选中文字&#xff0c;点击“插入”&#xff0c;选择“表格”&#xff0c;找到“文本转化为表格”。列数为2&#xff0c;文字分割位置选空格&#xff0c;设置…

路由器如何映射端口映射?

在现代互联网中&#xff0c;随着网络应用的不断发展&#xff0c;很多用户需要进行远程访问或搭建服务器来满足自己的需求。由于网络安全的原因&#xff0c;直接将内网设备暴露在公网中是非常危险的。为了解决这个问题&#xff0c;路由器映射端口映射技术应运而生。本文将介绍什…

Python进阶--爬取美女图片壁纸(基于回车桌面网的爬虫程序)

目录 一、前言 二、爬取下载美女图片 1、抓包分析 a、分析页面 b、明确需求 c、抓包搜寻 d、总结特点 2、编写爬虫代码 a、获取图片页网页源代码 b、提取所有图片的链接和标题 c、下载并保存这组图片 d、 爬取目录页的各种类型美女图片的链接 e、实现翻页 三、各…