• 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连接并等待

Redis:13--常用功能之redis-cli redis-server等命令相关推荐

  1. Redis的常用功能

    排序: sort mylist 排序 sort mylist alpha desc limit 0 2 字母排序 sort list by it:* desc by命令 sort list by it ...

  2. Redis事务,ACID性质,但是Redis不支持事务回滚

    ACID性质 1.原子性 事物具有原子性指的是,数据库将事务中的多个操作当做一个整体来执行,服务器要么执行事务中的所有操作,要么就一个操作也不执行. 对于Redis的事务功能来说,事务队列中的命令要么 ...

  3. redis+lua现实游戏中的一些常用功能

    为什么80%的码农都做不了架构师?>>>    游戏中一些常用的功能,仅仅使用redis提供的命令来实现,恐怕难度比较大.好在redis支持lua,能让一系列的操作变为原子操作,让这 ...

  4. 分布式内存数据库---redis配置文件常用配置介绍

    想要熟练使用redis,那么redis的相关配置也要非常熟悉,在大数据开发中使用redis就常常需要修改redis的常见配置. 一. redis的单位 redis的数据单位跟常用的单位有点不一样,打开 ...

  5. NoSQL概述-Redis安装-常用五大数据类型-概述Bitmaps,HyperLogLog,Geospatial和redis.conf 基本解析

    NoSQL 概述 NoSQL(NoSQL=Not Only SQL),意即"不仅仅是SQL",泛指 非关系型的数据库. NoSQL不依赖业务逻辑方式存储,而以简单的key-valu ...

  6. Redis简介、与memcached比较、存储方式、应用场景、生产经验教训、安全设置、key的建议、安装和常用数据类型介绍、ServiceStack.Redis使用(1)...

    1.NOSQL简介 nosql的产生并不是要彻底的代替关系型数据库,而是作为传统关系型数据库的一个补充. Facebook和360使用Cassandra来存储海量社交数据 Twitter在其url抓取 ...

  7. Redis 的各项功能解决了哪些问题?

    先看一下Redis是一个什么东西 官方简介解释到:Redis是一个基于BSD开源的项目,是一个把结构化的数据放在内存中的一个存储系统,你可以把它作为数据库,缓存和消息中间件来使用.同时支持string ...

  8. Redis 的各项功能到底解决了哪些问题?

    点击上方 好好学java ,选择 星标 公众号 重磅资讯.干货,第一时间送达今日推荐:2020年7月程序员工资统计,平均14357元,又跌了,扎心个人原创100W+访问量博客:点击前往,查看更多 来源 ...

  9. Redis和nosql简介,api调用;Redis数据功能(String类型的数据处理);List数据结构(及Java调用处理);Hash数据结构;Set数据结构功能;sortedSet(有序集合)数

    1.Redis和nosql简介,api调用 14.1/ nosql介绍 NoSQL:一类新出现的数据库(not only sql),它的特点: 1.  不支持SQL语法 2.  存储结构跟传统关系型数 ...

  10. Redis 中常用命令

    Redis 中常用命令 keys 返回满足给定 pattern 的所有 key. 127.0.0.1:6379> keys *1) "name2"2) "myzse ...

最新文章

  1. HSQLDB安装与使用
  2. 测温枪的工作原理全面解析,如何测出你的温度
  3. python list查找元素下标_Python 查找list中的某个元素的所有的下标方法
  4. C# 请求接口返回中文乱码→???
  5. Cookie、cookie使用方法
  6. 单基因gsea_筛到5分的核心基因以后你可以怎么做?
  7. 基于JAVA+SpringMVC+Mybatis+MYSQL的学生信息与选课系统
  8. 复合选择器-链接伪类选择器(HTML、CSS)
  9. mysql libc.so.6_解决安装mysql动态库libstdc++.so.6、libc.so.6版本过低问题
  10. 远哥跟你说 Spring的 classpath 通配符加载配置文件
  11. Linux应用调试-strace命令
  12. IDEA导入Git中项目
  13. js检查身份证号是否正确
  14. WDS+MDT全自动部署系统、自动加域、自动计算机取名(SN序列号或MAC地址)
  15. 如何更改PS中的键盘快捷键
  16. WZ-S甲醛传感器使用说明代码应用案例笔记
  17. 助力技术社区发展,网易易盾帮助SegmentFault加强内容风控管理
  18. javascript中使用getMonth()获得月份比实际月份少一个月
  19. 心理咨询类_微信小程序项目实战、含:标注图、效果图、视频、源码
  20. 下载excel打开后弹出警告提示,文件类型和文件内容不符问题处理

热门文章

  1. Qt 编码问题QTextCodec
  2. 沃尔沃挖机计算机故障,沃尔沃挖掘机常见故障及原因总结,用户们可以看看
  3. sql字符串拼接_Mybatis的SqlSession执行sql过程
  4. python database ioerror_python – IOError:[Errno 2]没有这样的文件或...
  5. linux下grpc安装编译,linux下安装grpc插件 (c++和go语言)
  6. 【转】飞扬青云_Qt开发经验
  7. 【转】c# 命名空间和程序集
  8. 【转】C# 命名空间 Namespace (学习心得 23)
  9. C# async 和 await 理解
  10. 一步步编写操作系统4 安装x86虚拟机 bochs