Redis缓存服务是运维工作中比较常见的一种维护工作,下面就redis日常操作命令在此做一简单小结,以备查用:

1)连接redis服务命令
# redis-cli -h redis主机ip或主机域名 -p redis端口 -a redis密码

[root@redis-test01 ~]# /data/redis-4.0.1/src/redis-cli -h 192.168.10.10 -p 6379 -a redis@123
192.168.10.10:6379>

2)在tomcat下的redis.properties可查看相关参数

#服务器地址
redis.host #服务器端口
redis.port #授权密码
redis.password

3)关于key的相关操作命令

查看或取出所有的key值
keys * 查看含SHOP的key值
keys SHOP_* 查看所有包括kevin字样的key值
keys kevin* 查key中已保存的value值
lrange key 0 -1 查看redis下,当前的key值是否存在。如查看kevin这个key值是否存在
exists key kevin 删除当前的key值,如删除kevin这个key值
del kevin 设置过期时间,比如设置kevin这个key值20秒过期
expire kevin 20 清空当前数据库
flushdb 批量删除key的集合
redis-cli -h 192.168.10.10 -p 6379 keys "web*"| xargs redis-cli -h 192.168.10.10 -p 6379 del
清除redis中指定的key值(比如清除redis中包含kevin的key值)
[root@redis-test01 ~]# /data/redis-4.0.1/src/redis-cli -h 192.168.10.10 -p 6379 -a redis@123  keys "kevin*" |xargs /data/redis-4.0.1/src/redis-cli -h 192.168.10.10 -p 6379 -a redis@123 del
停掉redis
[root@redis-test01 ~]# /data/redis-4.0.1/src/redis-cli -h 192.168.10.10 -p 6379 -a redis@123 shutdown

redis相关命令列表

命令原型 时间复杂度 命令描述 返回值
KEYS pattern O(N) 时间复杂度中的N表示数据库中Key的数量。获取所有匹配pattern参数的Keys。需要说明的是,在我们的正常操作中应该尽量避免对该命令的调用,因为对于大型数据库而言,该命令是非常耗时的,对Redis服务器的性能打击也是比较大的。pattern支持glob-style的通配符格式,如*表示任意一个或多个字符,?表示任意字符,[abc]表示方括号中任意一个字母。 匹配模式的键列表。
DEL key [key ...] O(N) 时间复杂度中的N表示删除的Key数量。从数据库删除中参数中指定的keys,如果指定键不存在,则直接忽略。还需要另行指出的是,如果指定的Key关联的数据类型不是String类型,而是List、Set、Hashes和Sorted Set等容器类型,该命令删除每个键的时间复杂度为O(M),其中M表示容器中元素的数量。而对于String类型的Key,其时间复杂度为O(1)。 实际被删除的Key数量。
EXISTS key  O(1) 判断指定键是否存在。 1表示存在,0表示不存在。
MOVE key db  O(1) 将当前数据库中指定的键Key移动到参数中指定的数据库中。如果该Key在目标数据库中已经存在,或者在当前数据库中并不存在,该命令将不做任何操作并返回0。   移动成功返回1,否则0。
RENAME key newkey  O(1) 为指定指定的键重新命名,如果参数中的两个Keys的命令相同,或者是源Key不存在,该命令都会返回相关的错误信息。如果newKey已经存在,则直接覆盖。   
RENAMENX key newkey O(1) 如果新值不存在,则将参数中的原值修改为新值。其它条件和RENAME一致。 1表示修改成功,否则0。
PERSIST key O(1) 如果Key存在过期时间,该命令会将其过期时间消除,使该Key不再有超时,而是可以持久化存储。 1表示Key的过期时间被移出,0表示该Key不存在或没有过期时间。
EXPIRE key seconds  O(1)  该命令为参数中指定的Key设定超时的秒数,在超过该时间后,Key被自动的删除。如果该Key在超时之前被修改,与该键关联的超时将被移除。  1表示超时被设置,0则表示Key不存在,或不能被设置。
EXPIREAT key timestamp  O(1)  该命令的逻辑功能和EXPIRE完全相同,唯一的差别是该命令指定的超时时间是绝对时间,而不是相对时间。该时间参数是Unix timestamp格式的,即从1970年1月1日开始所流经的秒数。 1表示超时被设置,0则表示Key不存在,或不能被设置。 
TTL key  O(1) 获取该键所剩的超时描述。  返回所剩描述,如果该键不存在或没有超时设置,则返回-1。
RANDOMKEY O(1)   从当前打开的数据库中随机的返回一个Key。 返回的随机键,如果该数据库是空的则返回nil。
TYPE key  O(1)  获取与参数中指定键关联值的类型,该命令将以字符串的格式返回。 返回的字符串为string、list、set、hash和zset,如果key不存在返回none。
SORT key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern ...]] [ASC|DESC] [ALPHA] [STORE destination]  O(N+M*log(M))  这个命令相对来说是比较复杂的,因此我们这里只是给出最基本的用法,有兴趣的网友可以去参考redis的官方文档。 返回排序后的原始列表。

-------------------------实例如下-----------------------------
keys/rename/del/exists/move/renamenx命令

查看当前数据库所有的keys
192.168.10.10:6379> keys * 清空当前选择的数据库
192.168.10.10:6379> flushdb
OK 添加String类型的模拟数据
192.168.10.10:6379> set mykey 2
OK
192.168.10.10:6379> set mykey2 "hello"
OK 添加Set类型的模拟数据。
192.168.10.10:6379> sadd mysetkey 1 2 3
(integer) 3 添加Hash类型的模拟数据。
192.168.10.10:6379> hset mmtest username "stephen"
(integer) 1 根据参数中的模式,获取当前数据库中符合该模式的所有key,从输出可以看出,该命令在执行时并不区分与Key关联的Value类型。
192.168.10.10:6379> keys my*
1) "mysetkey"
2) "mykey"
3) "mykey2" 删除下面两个Keys
192.168.10.10:6379> del mykey mykey2
(integer) 2 查看一下刚刚删除的Key是否还存在,从返回结果看,mykey确实已经删除了。
192.168.10.10:6379> exists mykey
(integer) 0 查看一下没有删除的Key,以和上面的命令结果进行比较。
192.168.10.10:6379> exists mysetkey
(integer) 1 将当前数据库中的mysetkey键移入到ID为1的数据库中,从结果可以看出已经移动成功。
192.168.10.10:6379> move mysetkey 1
(integer) 1 打开ID为1的数据库。
192.168.10.10:6379> select 1
OK 查看一下刚刚移动过来的Key是否存在,从返回结果看已经存在了。
redis 127.0.0.1:6379[1]> exists mysetkey
(integer) 1 在重新打开ID为0的缺省数据库。
redis 127.0.0.1:6379[1]> select 0
OK 查看一下刚刚移走的Key是否已经不存在,从返回结果看已经移走。
192.168.10.10:6379> exists mysetkey
(integer) 0 准备新的测试数据。
192.168.10.10:6379> set mykey "hello"
OK 将mykey改名为mykey1
192.168.10.10:6379> rename mykey mykey1
OK 由于mykey已经被重新命名,再次获取将返回nil。
192.168.10.10:6379> get mykey
(nil) 通过新的键名获取。
192.168.10.10:6379> get mykey1
"hello" 由于mykey已经不存在了,所以返回错误信息。
192.168.10.10:6379> rename mykey mykey1
(error) ERR no such key 为renamenx准备测试key
192.168.10.10:6379> set oldkey "hello"
OK
192.168.10.10:6379> set newkey "world"
OK 由于newkey已经存在,因此该命令未能成功执行。
192.168.10.10:6379> renamenx oldkey newkey
(integer) 0 查看newkey的值,发现它也没有被renamenx覆盖。
192.168.10.10:6379> get newkey
"world"

persist/expire/expireat/ttl命令

为后面的示例准备的测试数据。
192.168.10.10:6379> set mykey "hello"
OK 将该键的超时设置为100秒。
192.168.10.10:6379> expire mykey 100
(integer) 1 通过ttl命令查看一下还剩下多少秒。
192.168.10.10:6379> ttl mykey
(integer) 97 立刻执行persist命令,该存在超时的键变成持久化的键,即将该Key的超时去掉。
192.168.10.10:6379> persist mykey
(integer) 1 ttl的返回值告诉我们,该键已经没有超时了。
192.168.10.10:6379> ttl mykey
(integer) -1 为后面的expire命令准备数据。
192.168.10.10:6379> del mykey
(integer) 1
192.168.10.10:6379> set mykey "hello"
OK 设置该键的超时被100秒。
192.168.10.10:6379> expire mykey 100
(integer) 1 用ttl命令看一下当前还剩下多少秒,从结果中可以看出还剩下96秒。
192.168.10.10:6379> ttl mykey
(integer) 96 重新更新该键的超时时间为20秒,从返回值可以看出该命令执行成功。
192.168.10.10:6379> expire mykey 20
(integer) 1 再用ttl确认一下,从结果中可以看出果然被更新了。
192.168.10.10:6379> ttl mykey
(integer) 17 立刻更新该键的值,以使其超时无效。
192.168.10.10:6379> set mykey "world"
OK 从ttl的结果可以看出,在上一条修改该键的命令执行后,该键的超时也无效了。
192.168.10.10:6379> ttl mykey
(integer) -1

type/randomkey/sort命令

由于mm键在数据库中不存在,因此该命令返回none。
192.168.10.10:6379> type mm
none mykey的值是字符串类型,因此返回string。
192.168.10.10:6379> type mykey
string 准备一个值是set类型的键。
192.168.10.10:6379> sadd mysetkey 1 2
(integer) 2 mysetkey的键是set,因此返回字符串set。
192.168.10.10:6379> type mysetkey
set 返回数据库中的任意键。
192.168.10.10:6379> randomkey
"oldkey" 清空当前打开的数据库。
192.168.10.10:6379> flushdb
OK 由于没有数据了,因此返回nil。
192.168.10.10:6379> randomkey
(nil)

Python-执行系统命令的更多相关文章

  1. Python执行系统命令的方法 os.system(),os.popen(),commands

    os.popen():用python执行shell的命令,并且返回了结果,括号中是写shell命令 Python执行系统命令的方法: https://my.oschina.net/renwofei42 ...

  2. windows linux 使用python执行系统命令并将结果保存到变量

    最近需要用到os.system 发现不能赋值到变量 后查有更新的模块,如下: os.system os.spawn* os.popen* popen2.* commands.* 重新使用content ...

  3. 转 Python执行系统命令的方法

    传送门 Python执行系统命令的方法 http://www.linux-field.com/?p=15 Python中执行系统命令常见方法有两种: 两者均需 import os (1) os.sys ...

  4. Python执行系统命令并获得输出的几种方法

    [root@a upfc]# ./ffmpeg-linux64-v3.3.1 -i a.mp3 ffmpeg version N-86111-ga441aa90e8-static http://joh ...

  5. python 执行系统命令模块比较

    python 执行系统命令模块比较 1.os.system模块 仅仅在子终端运行命令,返回状态码,0为成功,其他为失败,但是不返回执行结果 如果再命令行下执行,结果直接打印出来 >>> ...

  6. python执行系统命令后获取返回值的几种方式集合

    python执行系统命令后获取返回值的几种方式集合 今天小编就为大家分享一篇python执行系统命令后获取返回值的几种方式集合,具有很好的参考价值,希望对大家有所帮助.一起跟随小编过来看看吧 第一种情 ...

  7. Python执行系统命令的方法

    Python中执行系统命令常见方法有两种: 两者均需 import os (1) os.system # 仅仅在一个子终端运行系统命令,而不能获取命令执行后的返回信息 system(command) ...

  8. Python执行系统命令:使用subprocess的Popen函数

    使用subprocess的Popen函数执行系统命令 参考: http://blog.sina.com.cn/s/blog_8f01450601017dlr.html http://blog.csdn ...

  9. 使用python执行系统命令——subprocess

     背景:subprocess是python官方推荐调用系统命令的模块 import subprocess subprocess最主要的两个方法/类: # 参数说明:stdin和stdout相当于一个管 ...

  10. python执行系统命令后获取返回值

    import os, subprocess # os.system('dir') #执行系统命令,没有获取返回值,windows下中文乱码 # result = os.popen('dir') #执行 ...

随机推荐

  1. Sass学习之路(2)——Sass环境安装(windows版)

    因为本喵目前用的是window10的本子,所以这里就发windows版本的安装流程啦.(希望有朋友可以赞助我一个mac(┳_┳)): 第一步:安装ruby 因为Sass是基于ruby编写的,所以先去官 ...

  2. gridView使用

    只读 for (int i = 0; i <9; i++) { this.gridView1.Columns[i].OptionsColumn.ReadOnly = true; } 不显示面板 ...

  3. SparseArray<E>详解

    SparseArray<E> 是官方推荐的用来替代 HashMap<Integer, E> 的一个工具类,相比来说有着更好的性能(其核心是折半查找函数(binarySearch ...

  4. Static Cell-静态TableView

    使用静态TableView有两个前提,1.要在Storyboard上  2.需要使用TableViewController PS:如果需要设置不同的cell的高度不同的话,还是需要使用tableVie ...

  5. 演示 pull解析的基本步骤(代码演示)

       pull解析器:            * 反序列化:将xml中的数据取出                1.导入jar包                2.创建解析器工厂           ...

  6. iOS UIWebView和网页的交互(OC中调执行JS)

    UIWebView和网页的交互(OC中调执行JS)- (void)viewDidLoad{[super viewDidLoad];// 1.webViewUIWebView *webView = [[ ...

  7. OC语言-08-深拷贝与浅拷贝详解(示例)

    概述 拷贝:复制一个与源对象内容相同的对象 实现拷贝,需要遵守以下两个协议 NSCopying NSMutableCopying 拷贝返回对象的种类 可变,mutableCopy消息返回的对象 不可变 ...

  8. Effective Java 34 Emulate extensible enums with interfaces

    Advantage Disadvantage Enum types Clarity Safety Ease of maintenance. None extensibility Typesafe en ...

  9. 观察者模式--java jdk中提供的支持

    一.简介 观察者设计模式有如下四个角色 抽象主题角色:把所有对观察者对象的引用保存在一个集合中,每个抽象主题角色都可以有任意数量的观察者.抽象主题提供一个接口,可以增加和删除观察者角色.一般用一个抽象 ...

  10. PL/SQL之--存储过程

    一.存储过程 存储过程是一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它.oracle可以把PL/SQL程序储存在数 ...