Redis:13--常用功能之redis-cli redis-server等命令

  • Redis提供了redis-cli、redis-server、redis-benchmark等Shell工具。它们 虽然比较简单,但是麻雀虽小五脏俱全,有时可以很巧妙地解决一些问题

一、redis-cli

  • 在前面数据库连接的时候已经redis-cli的-h、-p参数,除了这些参数,还有很多有用的参数,要了解redis-cli的全部参数,可以执行redis-cli-help命令来进行查看

  • 下面将对一些重要参数的含义以及使用场景进行说明

-x

  • -x选项代表从标准输入(stdin)读取数据作为redis-cli的最后一个参数

  • 例如下面的操作会将字符串world作为set hello的值:

-c

  • -c(cluster)选项是连接Redis Cluster节点时需要使用的

  • -c选项可以防止moved和ask异常,有关Redis Cluster将在后面介绍

-a

  • 如果Redis配置了密码,可以用-a(auth)选项,有了这个选项就不需要手动输入auth命令

  • 如果需要redis的“requirepass”配置参数:

  • CONFIG SET requirepass "123456" 可以设置redis的登录密码为123456

--scan、--pattern

  • --scan选项和--pattern选项用于扫描指定模式的键,相当于使用scan命令

--slave

  • -slave选项是把当前客户端模拟成当前Redis节点的从节点,可以用来获取当前Redis节点的更新操作,有关于Redis复制会在后面文章详细介绍。合理的利用这个选项可以记录当前连接Redis节点的一些更新操作,这 些更新操作很可能是实际开发业务时需要的数据

  • 注意:ING命令是由于主从复制产生的,后面文章会对主从复制进行介绍

  • 下面开启第一个客户端,使用--slave选项,看到同步已完成:

  • 在后侧开启另一个客户端做一些更新操作,然后左侧的第一个客户端会收到Redis节点的更新操作:

--rdb

  • --rdb选项会请求Redis实例生成并发送RDB持久化文件,保存在本地

  •  可使用它做持久化文件的定期备份。有关Redis持久化在后面会详细介绍

--pipe

  • --pipe选项用于将命令封装成Redis通信协议定义的数据格式,批量发送给Redis执行,有关Redis通信协议将在后面会详细介绍

  • 例如下面操作 同时执行了set hello world和incr counter两条命令:

echo -en '*3\r\n$3\r\nSET\r\n$5\r\nhello\r\n$5\r\nworld\r\n*2\r\n$4\r\nincr\r\n$7\r\ncounter\r\n' | redis-cli --pipe

--bigkeys

  • --bigkeys选项使用scan命令对Redis的键进行采样,从中找到内存占用比较大的键值,这些键可能是系统的瓶颈

--eval

  • --eval选项用于执行指定Lua脚本,有关Lua脚本的使用将在后面会详细介绍

  • latency有三个选项,分别是--latency、--latency-history、--latency-dist。它们都可以检测网络延迟,对于Redis的开发和运维非常有帮助

①--latency

  • 该选项可以测试客户端到目标Redis的网络延迟

  • 例如当前拓扑结构如下图所示。客户端B和Redis在机房B,客户端A在机房A,机房A和机房B是跨地区的

  • 客户端B:

  • 客户端A:

  • 可以看到客户端A由于距离Redis比较远,平均网络延迟会稍微高一些

②--latency-history

  • --latency的执行结果只有一条,如果想以分时段的形式了解延迟信息, 可以使用--latency-history选项,可以通过-i参数控制间隔时间

③--latency-dist

  • 该选项会使用统计图表的形式从控制台输出延迟统计信息

--stat

  • --stat选项可以实时获取Redis的重要统计信息,虽然info命令中的统计信 息更全,但是能实时看到一些增量的数据(例如requests)对于Redis的运维 还是有一定帮助的,如下所示:

--raw、--no-raw

  • --no-raw选项是要求命令的返回结果必须是原始的格式,--raw恰恰相反,返回格式化后的结果

  • 在Redis中设置一个中文的value:

  • 如果正常执行get或者使用--no-raw选项,那么返回的结果是二进制格式:

  • 如果使用了--raw选项,将会返回中文:

二、redis-server

--test-memory

  • redis-server除了启动Redis外,还有一个--test-memory选项。--test-memory可以用来检测当前操作系统能否稳定地分配指定容量的内存给 Redis,通过这种检测可以有效避免因为内存问题造成Redis崩溃

  • 例如下面操作检测当前操作系统能否提供1G的内存给Redis。整个内存检测的时间比较长,就不显示图片了

redis-server --test-memory 1024
  • 当输出passed this test时说明内存检测完毕,最后会提示--test-memory只是简单检测,如果有质疑可以使用更加专业的内存检测工具。

  • 通常无需每次开启Redis实例时都执行--test-memory选项,该功能更偏向于调试和测试,例如,想快速占满机器内存做一些极端条件的测试,这个功 能是一个不错的选择

三、redis-benchmark

  • redis-benchmark可以为Redis做基准性能测试,它提供了很多选项帮助开发和运维人员测试Redis的相关性能,下面分别介绍这些选项

  • 详情参阅:https://redis.io/topics/benchmarks

-h

  • 指定服务器主机名

  • 默认值127.0.0.1

-p

  • 指定服务器端口

  • 默认值为6379

-s

  • 指定服务器socket

-c

  • -c(clients)选项代表客户端的并发数量(默认是50)

-n <requests>

  • -n(num)选项代表客户端请求总量(默认是100000)

  • 例如下面的命令代表100各个客户端同时请求Redis,一 共执行20000次。redis-benchmark会对各类数据结构的命令进行测试,并给出性能指标:

redis-benchmark -c 100 -n 20000

  • 例如上面一共执行了20000次get操作,在0.81秒完成,每个请求数据量是3个字节,2.44%的命令执行时间小于1毫秒,Redis每秒可以处理24691.36次get请求

-d

  • 以字节的形式指定set/get值的数据大小

  • 默认值为2

-q

  • -q选项仅仅显示redis-benchmark的requests per second信息

  • 例如,接着上面的演示案例

redis-benchmark -c 100 -n 20000 -q

 

-r

  • 在一个数据库内容为空的Redis上,执行了redis-benchmark命令之后会发现数据库中自动新增4个键:

  • 如果想向Redis插入更多的键,可以执行使用-r(random)选项,可以向Redis插入更多随机的键

redis-benchmark -c 100 -n 20000 -r 10000
  • -r选项会在key、counter键上加一个12位的后缀,-r10000代表只对后四位做随机处理(-r不是随机数的个数)。例如进行上面的操作后,key的数量和结果结构如下:

-P

  • 通过管道传输请求,-P选项代表每个请求pipeline的数据量(默认为1)

-k<boolean>

  • -k选项代表客户端是否使用keepalive,1为使用,0为不使用,默认值为 1

-t

  • -t选项可以对指定命令进行基准测试

--csv

  • --csv选项会将结果按照csv格式输出,便于后续处理,如导出到Excel 等

-L

  • 死循环,永久执行测试

-I

  • Idle模式。仅打开N个idle连接并等待

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis:16---常用功能之(慢查询日志)

一、慢查询日志介绍 许多存储系统(例如MySQL)提供慢查询日志帮助开发和运维人员定位系统存在的慢操作。所谓慢查询日志就是系统在命令执行前后计算每条命令的执行时间,当超过预设阀值,就将这条命令的相关信息记录下来,Redis也提供了类似的功能Redis的慢查询日志功能用于记…

leetcode256. 粉刷房子

假如有一排房子&#xff0c;共 n 个&#xff0c;每个房子可以被粉刷成红色、蓝色或者绿色这三种颜色中的一种&#xff0c;你需要粉刷所有的房子并且使其相邻的两个房子颜色不能相同。 当然&#xff0c;因为市场上不同颜色油漆的价格不同&#xff0c;所以房子粉刷成不同颜色的花…

Redis:21---客户端相关配置篇

一、客户端相关配置①客户端的限制maxclientsRedis提供了maxclients参数来限制最大客户端连接数&#xff0c;一旦连接数超过 maxclients&#xff0c;新的连接将被拒绝maxclients默认值是10000可以通过info clients来查询当前Redis的连接数&#xff1a;可以通过config set maxcl…

Redis:23---info命令总结

info命令的格式有3种&#xff1a;info&#xff1a;部分Redis系统状态统计信息info all&#xff1a;全部Redis系统状态统计信息&#xff0c;一次性打印下面所有p的内容info p&#xff1a;某一块的系统状态统计信息。info命令所有的p如下所示模块名模块含义 Server服务器信息Clie…

Redis:22---客户端API:client、monitor)

一、client listclient list命令能列出与Redis服务端相连的所有客户端连接信息。例如下面代码是在一个Redis实例上执行client list的结果&#xff0c;其中每一行代表一个客户端信息&#xff1a;下面将选择几个重要的属性进行说明&#xff0c;其余通过表格的形式进行展示①标识&…

leetcode175. 组合两个表(SQL)

表1: Person ---------------------- | 列名 | 类型 | ---------------------- | PersonId | int | | FirstName | varchar | | LastName | varchar | ---------------------- PersonId 是上表主键 表2: Address ---------------------- | 列名 …

Redis:20---常用功能之(发布与订阅)

一、发布与订阅概述Redis提供了基于“发布/订阅”模式的消息机制&#xff0c;此种模式下&#xff0c;消息发布者和订阅者不进行直接通信&#xff0c;发布者客户端向指定的频道&#xff08;channel&#xff09;发布消息&#xff0c;订阅该频道的每个客户端都可以收到该消息。 下…

Redis:19---常用功能之(HyperLogLog)

一、HyperLogLog概述HyperLogLog并不是一种新的数据结构&#xff08;实际类型为字符串类型&#xff09;&#xff0c;而是一种基数算法&#xff0c;通过HyperLogLog可以利用极小的内存空间完成独立总数的统计&#xff0c;数据集可以是IP、Email、ID等HyperLogLog提供了3个命令&a…

计算时间差的Oracle函数

Oracle函数可以实现诸多的功能&#xff0c;下面就介绍使用Oracle函数计算时间差的实现方法&#xff0c;如果您对Oracle函数方面感兴趣的话&#xff0c;不妨一看。 两个Date类型字段&#xff1a;START_DATE&#xff0c;END_DATE&#xff0c;计算这两个日期的时间差&#xff08;分…

leetcode181. 超过经理收入的员工(SQL)

Employee 表包含所有员工&#xff0c;他们的经理也属于员工。每个员工都有一个 Id&#xff0c;此外还有一列对应员工的经理的 Id。 ------------------------------ | Id | Name | Salary | ManagerId | ------------------------------ | 1 | Joe | 70000 | 3 |…

UNIX(多线程):01---线程简介及线程限制

一、线程的概念 典型的UNIX进程可以看成只有一个控制线程:一个进程在同一时刻只做一件事。有了多个控制线程后,在程序设计时可以把进程设计成在同一时刻能够做不止一件事,每个线程处理各自独立的任务二、线程的优点 通过为每种事件类型分配单独的处理线程,可以简化处理异步…

UNIX(多线程):13---condition_variable、wait、notify_one、notify_all

条件变量std::condition_variable、wait()、notify_one() 线程A: 等待一个条件满足线程B: 专门往消息队列中放入消息(数据),达到一定条件,通知处于等待中的线程A。std::condition_variable实际上是一个类,是一个和条件相关的一个类,说白了就是等待一个条件达成。这个类是…

leetcode176. 第二高的薪水(SQL)

编写一个 SQL 查询&#xff0c;获取 Employee 表中第二高的薪水&#xff08;Salary&#xff09; 。 ------------ | Id | Salary | ------------ | 1 | 100 | | 2 | 200 | | 3 | 300 | ------------ 例如上述 Employee 表&#xff0c;SQL查询应该返回 200 作为第二…

UNIX(多线程):17---异步任务提供者(Provider) 介绍

std::promise 类概述 Promise 对象可以保存某一类型 T 的值,该值可被 future 对象读取(可能在另外一个线程中),因此 promise 也提供了一种线程同步的手段。在 promise 对象构造时可以和一个共享状态(通常是std::future)相关联,并可以在相关联的共享状态(std::future)上保…

leetcode180. 连续出现的数字(SQL)

编写一个 SQL 查询&#xff0c;查找所有至少连续出现三次的数字。 --------- | Id | Num | --------- | 1 | 1 | | 2 | 1 | | 3 | 1 | | 4 | 2 | | 5 | 1 | | 6 | 2 | | 7 | 2 | --------- 例如&#xff0c;给定上面的 Logs 表&#xff0c; 1 是唯一连续…

UNIX(多线程):18---异步任务提供者(Provider) 介绍(续)

本文主要介绍 std::packaged_task。 std::packaged_task 包装一个可调用的对象,并且允许异步获取该可调用对象产生的结果,从包装可调用对象意义上来讲,std::packaged_task 与 std::function 类似,只不过 std::packaged_task 将其包装的可调用对象的执行结果传递给一个 std:…

leetcode182. 查找重复的电子邮箱(SQL)

编写一个 SQL 查询&#xff0c;查找 Person 表中所有重复的电子邮箱。 示例&#xff1a; ------------- | Id | Email | ------------- | 1 | ab.com | | 2 | cd.com | | 3 | ab.com | ------------- 根据以上输入&#xff0c;你的查询应返回以下结果&#xff1a; ----…

UNIX(多线程):19---Future 类型详解

Future 类型详解 本文主要介绍 std::future,std::shared_future 以及 std::future_error,另外还会介绍 <future> 头文件中的 std::async,std::future_category 函数以及相关枚举类型。 std::future 详解 std::future 概述 前面已经多次提到过 std::future,那么 std::…

UNIX(多线程):20---生产者消费者实例

本文将综合运用 C++11 中的新的基础设施(主要是多线程、锁、条件变量)来阐述一个经典问题——生产者消费者模型,并给出完整的解决方案。 生产者消费者问题是多线程并发中一个非常经典的问题,相信学过操作系统课程的同学都清楚这个问题的根源。本文将就四种情况分析并介绍生产…

leetcode183. 从不订购的客户(SQL)

某网站包含两个表&#xff0c;Customers 表和 Orders 表。编写一个 SQL 查询&#xff0c;找出所有从不订购任何东西的客户。 Customers 表&#xff1a; ----------- | Id | Name | ----------- | 1 | Joe | | 2 | Henry | | 3 | Sam | | 4 | Max | ----------- Or…