1、安装:
sudo apt-get install redis-server
2、启动
启动redis服务:redis-server
启动客户端连接本地redis服务:redis-cli
连接远程redis服务:redis-cli -h host -p port -a password
3、配置
查看配置:CONFIG GET CONFIG_SETTING_NAME
修改配置:CONFIG SET CONFIG_SETTING_NAME NEW_CONFIG_VALUE
4、数据类型
字符串String,哈希 hash,列表 list,集合 set,有序集合zset (sorted set)。
5、key命令
DEL key :删除key
DUMP key :序列化key
EXISTS key:检查key是否存在
EXPIRE key seconds:为key设置过期时间
EXPIREAT key timestamp:为key设置过期时间,参数是unix时间戳
PEXPIRE key milliseconds :设置key的过期时间以毫秒计。
PEXPIREAT key milliseconds-timestamp:设置 key 过期时间的时间戳(unix timestamp) 以毫秒计
KEYS pattern:查找所有符合给定模式( pattern)的 key 。
MOVE key db:将当前数据库的 key 移动到给定的数据库 db 当中。
PERSIST key:移除 key 的过期时间,key 将持久保持。
PTTL key:以毫秒为单位返回 key 的剩余的过期时间。
TTL key:以秒为单位,返回给定 key 的剩余生存时间(TTL, time to live)。
RANDOMKEY:从当前数据库中随机返回一个key。
RENAME key newkey:修改key的名称
RENAMENX key newkey:仅当 newkey 不存在时,将 key 改名为 newkey 。
TYPE key:返回key所存储的值的类型。
6、字符串(string)
SET key value:设置指定key的值
GET key:获取指定key的值
GETRANGE key start end:返回key中字符串值的子字符
GETSET key value:将给定key的值设为value,并返回key的旧值(old value)。
GETBIT key offset:对key所存储的字符串值,获取指定偏移量上的位bit。
MGET key1 [key2..]:获取所有(一个或多个)给定key的值。
SETBIT key offset value:对key所存储的字符串值,设置或清除指定偏移量上的位。
SETEX key seconds value:将value关联到key,并将key的过期时间设为seconds(以秒为单位)
SETNX key value:只有在key不存在时设置key的值。
SETRANGE key offset value:用value参数覆写给定key所存储的字符串值,从偏移量offset开始。
STRLEN key:返回key所存储的字符串值的长度。
MSET key value [key value...]:同时设置一个或多个key-value对。
MSETNX key value [key value...]:同时设置一个或多个key-value对,当且仅当所有给定key都不存在。
PSETEX key milliseconds value :这个命令和 SETEX 命令相似,但它以毫秒为单位设置 key 的生存时间,而不是像 SETEX 命令那样,以秒为单位。
INCR key:将key中存储的数字值增一。
INCRBY key increment:将key所存储的值加上给定的增量值increment。
INCRBYFLOAT key increment:将key所存储的值加上给定的浮点增量值(increment)
DECR key:将key中存储的数字值减一。
DECRBY key decrement:key所储存的值减去给定的减量值(increment)
APPEND key value:如果key已经存在并且是一个字符串,APPEND命令将指定value追加到改key原来的值(value)的末尾。
7、哈希(hash)
HDEL key field1 [field2]:删除一个或多个哈希表字段
HEXISTS key field:查看哈希表key中,指定的字段是否存在
HGET key field:获取存储在哈希表中指定字段的值。
HGETALL key:获取哈希表中指定key的所有字段和值
HINCRBY key field increment:为哈希表key中的指定字段的整数值加上增量increment。
HINCRBYFLOAT key field increment:为哈希表key中的指定字段的浮点数值加上增量increment.
HKEYS key:获取所有哈希表中的字段
HLEN key:获取哈希表中字段的数量
HMGET key field1 [field2]:获取指定字段的值
HMSET key field1 value1 [field2 value2...]:同时将多个field-value对设置到哈希表key中
HSET key field value:将哈希表key中的字段field的值设置为value。
HSETNX key field value:只有在字段field不存在时,设置哈希表字段的值。
HVALS key:获取哈希表中所有值。
HSCAN key cursor [MATCH pattern] [COUNT count]:迭代哈希表中的键值对。
8、列表
BLPOP key1 [key2] timeout:移除并获取列表的第一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
BRPOP key1 [key2] timeout:移除并获取列表的最后一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 BRPOPLPUSH source destination timeout:从列表中弹出一个值,将弹出的元素插入到另一个列表中并返回它;如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 LINDEX key index:通过索引获取列表中的元素 LINSERT key BEFORE|AFTER pivot value:在列表的元素前或者后插入元素 LLEN key:获取列表长度 LPOP key:移除并获取列表的第一个元素 LPUSH key value1 [value2]:将一个或多个值插入到列表头部 LPUSHX key value:将一个值插入到已存在的列表头部 LRANGE key start stop:获取列表指定范围内的元素 LREM key count value:移除列表元素 LSET key index value:通过索引设置列表元素的值 LTRIM key start stop:对一个列表进行修剪,就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。 RPOP key:移除并获取列表最后一个元素 RPOPLPUSH source destination :移除列表的最后一个元素,并将该元素添加到另一个列表并返回。 RPUSH key value1 [value2]:在列表中添加一个或多个值 RPUSHX key value:为已存在的列表添加值9、集合
SADD key member1 [member2]:向集合添加一个或多个成员
SCARD key:获取集合的成员数 SDIFF key1 [key2]:返回给定所有集合的差集 SDIFFSTORE destination key1 [key2]:返回给定所有集合的差事并存储在destination中 SINTER key1 [key2]:返回给定所有集合的交集 SINTERSTORE destination key1 [key2]:返回给定所有集合的交集并存储在destination中 SISMEMBER key member:判断member元素是否是集合key的成员 SMEMBERS key:返回集合中的所有成员 SMOVE source destination member:将member元素从source集合移动到destination集合 SPOP key:移除并返回集合中的一个随机元素 SRANDMEMBER key [count]:返回集合中一个或多个随机数 SREM key member1 [member2]:移除集合中一个或多个成员 SUNION key1 [key2]:返回所有给定集合的并集 SUNIONSTORE destination key1 [key2]:所有给定集合的并集存储在destination集合中 SSCAN key cursor [MATCH pattern] [COUNT count]:迭代集合中的元素。10、有序集合
ZADD key score1 member1 [score2 member2]:向有序集合添加一个或多个成员,或者更新已存在成员的分数
ZCARD key:获取有序集合的成员数 ZCOUNT key min max:计算在有序集合中指定区间分数的成员数 ZINCRBY key increment memeber:有序集合中对指定成员的分数加上增量increment ZINTERSTORE destination numkeys key[key...]:计算给定的一个或多个有序集合的交集并将结果集存储在新的有序集合key中 ZLEXCOUNT key min max:在有序集合中计算指定字典区间内成员数量 ZRANGE key start stop [WITHSCORES]:通过索引区间返回有序集合成指定区间内的成员 ZRANGEBYLEX key min max [LIMIT offset count]:通过字典区间返回有序集合的成员 ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]:通过分数返回有序集合指定区间内的成员 ZRANK key member:返回有序集合中指定成员的索引 ZREM key member [member...]:移除有序集合中的一个或多个成员 ZREMRANGEBYLEX key min max:移除有序集合中给定的字典区间的所有成员 ZREMRANGEBYRANK key start stop:移除有序集合中给定的排名区间的所有成员 ZREMRANGEBYSCORE key min max:移除有序集合给定的分数区间的所有成员 ZREVRANGE key start stop [WITHSCORES]:返回有序集合中指定区间内的成员,通过索引,分数从高到低 ZREVRANGEBYSCORE key max min [WITHSCORES]:返回有序集合中指定分数区间内的成员,分数从高到低排序 ZREVRANK key member:返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序 ZSCORE key member:返回有序集中,成员的分数值 ZUNIONSTORE destination numkeys key [key...]:计算给定的一个或多个有序集的并集,并存储在新的key中 ZSCAN key cursor [MATCH pattern] [COUNT count]:迭代有序集合中的元素(包括元素成员和元素分值)11、HyperLogLog
PFADD key element [element...]:添加指定元素到HyperLogLog中
PFCOUNT key [key...]:返回给定HyperLogLog的基数估算值 PFMERGE destkey sourcekey [ sourcekey...]:将多个HyperLogLog合并为一个HyperLogLog。
12、发布订阅 SUBSCRIBE
PSUBSCRIBE pattern [pattern...]:订阅一个或多个符合给定模式的频道
PUNSUBSCRIBE [pattern [pattern...]]:退订所有给定模式的频道 SUBSCRIBE channel [channel...]:订阅给定的一个或多个频道的信息 UNSUBSCRIBE [channel [channel...]]:退订给定的频道 PUBSUB subcommand [argument [argument...]]:查看订阅与发布系统状态 PUBLISH channel message:将信息发送到指定的频道
13、事务
DISCAED:取消事务,放弃执行事务块内的所有命令
EXEC:执行所有事务块内的命令 MULTI:标记一个事务块的开始 UNWATCH:取消WATCH命令对所有key的监视 WATCH key [key...]:监视一个(或多个)key,如果在事务执行之前这个(或这些)key被其他命令所改动,那么事务将被打断。
14、脚本
EVAL script numkeys key[key..] arg[arg..]:执行Lua脚本
EVALSHA sha1 numkeys key [key...] arg[arg..]
SCRIPT EXISTS script [script...]:查看执行的脚本是否已经被保存在缓存当中。
SCRIPT FLUSH:从脚本缓存中移除所有脚本
SCRIPT KILL:杀死当前正在运行的Lua脚本
SCRIPT LOAD script:将脚本script添加到脚本缓存中,但并不立即执行这个脚本。
15、连接
1、AUTH password:验证密码是否正确
2、ECHO message:打印字符串
3、PING:查看服务是否运行
4、QUIT:关闭当前连接
5、SELECT index:切换到指定的数据库
16、服务器
BGREWRITEAOF:异步执行一个AOF(AppendOnly File)文件重写操作
BGSAVE:在后台异步保存当前数据库的数据到磁盘
CLIENT KILL [ip:port] [ID client-id]:关闭客户端连接
CLIENT LIST:获取连接到服务器的客户端连接列表
CLIENT GETNAME:获取连接的名称
CLIENT PAUSE timeout:在指定时间内终止运行来自客户端的命令
CLIENT SETNAME connection-name:设置当前连接的名称
CLUSTER SLOTS:获取集群节点的映射数组
COMMAND:获取Redis命令详情数组
COMMAND COUNT:获取Redis命令总数
COMMAND GETKEYS:获取给定命令的所有键
TIME:返回当前服务器时间
COMMAND INFO command-name [command-name...]:获取指定Redis命令描述的数组。
CONFIG GET parameter:获取指定配置参数的值
GONFIG REWRITE:对启动Redis服务器时所指定的redis.conf配置文件进行改写
CONFIG SET parameter value:修改redis配置参数,无需重启
CONFIG RESETSTAT:充值INFO命令中的某些统计数据
DBSIZE:返回当前数据库的key的数量
DEBUG OBJECT key:获取key的调试信息
DEBUG SEGFAULT:让Redis服务崩溃
FLUSHALL:删除所有数据库的所有key
FLUSHDB:删除当前数据库的所有key
INFO [section]:获取Redis服务器的各种信息和统计数值
LASTSAVE:返回最近一次Redis成功将数据保存到磁盘上的时间,以UNIX时间戳格式表示
MONITOR:实时打印Redis服务器接收到的命令,调试用。
ROLE:返回主从实例所属的角色
SAVE:同步保存数据到硬盘
SHUTDOWN [NOSAVE] [SAVE]:异步保存数据到硬盘,并关闭服务器
SLAVEOF host port:将当前服务器转变为指定服务器的从属服务器(slave server)
SLOWLOG subcommand [argument]:管理redis的慢日志
SYNC:用于复制功能(replication)的内部命令