Redis 简介
Redis 是用 C 语言开发的一个开源的高性能键值对(key-value)数据库。它通过提供多种键值数据类型来适应不同场景下的存储需求,目前为止 Redis 支持的键值数据类型如下:
- 字符串类型
- 散列类型
- 列表类型
- 集合类型
- 有序集合类型
Redis 的应用场景
- 缓存(数据查询、短连接、新闻内容、商品内容等等)
- 分布式集群架构中的 session 分离
- 聊天室的在线好友列表
- 任务队列(秒杀、抢购、12306 等等)
- 应用排行榜
- 网站访问统计
- 数据过期处理(可以精确到毫秒)
Redis HA 方案
HA(High Available,高可用性群集)机集群系统简称,是保证业务连续性的有效解决方案,一般有两个或两个以上的节点,且分为活动节点及备用节点。通常把正在执 行业务的称为活动节点,而作为活动节点的一个备份的则称为备用节点。当活动节点出现问题,导致正在运行的业务(任务)不能正常运行时,备用节点此时就会侦测到,并立即接续活动节点来执行业务。从而实现业务的不中断或短暂中断。
Redis 一般以主/从方式部署(这里讨论的应用从实例主要用于备份,主实例提供读写)该方式要实现 HA 主要有如下几种方案:
Redis一致性哈希算法
将用户和redis节点的hash值对应到一个32位的环形数据结构上,环形结构首尾封闭,用户通过hash算法来定位在环形结构上,redis节点也通过hash算法来定位到环形结构上,此时的命中问题就变成了,用户节点通过顺时针旋转,在旋转的过程中若碰到redis节点,就在该节点上读取数据,若此时在环形结构上增加新的redis节点,由于是顺时针寻找对应的redis节点,所以用户此时的redis命中率还是很高的,不会因为增加了一台redis节点就导致大量的用户命中失败的情况出现。
Redis Sentinel 原理
Redis Sentinel /cluster 集群部署
略
Redis 命令汇总
参考资料
连接操作相关的命令
- ping:测试连接是否存活如果正常会返回 pong
- echo:打印
- select:切换到指定的数据库,数据库索引号 index 用数字值指定,以 0 作为起始索引值
- quit:关闭连接(connection)
- auth:简单密码认证
服务端相关命令
- time:返回当前服务器时间
- client list: 返回所有连接到服务器的客户端信息和统计数据 参见 http://redisdoc.com/server/client_list.html
- client kill ip:port:关闭地址为 ip:port 的客户端
- save:将数据同步保存到磁盘
- bgsave:将数据异步保存到磁盘
- lastsave:返回上次成功将数据保存到磁盘的Unix时戳
- shundown:将数据同步保存到磁盘,然后关闭服务
- info:提供服务器的信息和统计
- config resetstat:重置 info 命令中的某些统计数据
- config get:获取配置文件信息
- config set:动态地调整 Redis 服务器的配置(configuration)而无须重启,可以修改的配置参数可以使用命令 CONFIG GET * 来列出
- config rewrite:Redis 服务器时所指定的 redis.conf 文件进行改写
- monitor:实时转储收到的请求
- slaveof:改变复制策略设置
发布订阅相关命令
- psubscribe:订阅一个或多个符合给定模式的频道 例如 psubscribe news.* tweet.*
- publish:将信息 message 发送到指定的频道 channel 例如 publish msg "good morning"
- pubsub channels:列出当前的活跃频道 例如 PUBSUB CHANNELS news.i*
- pubsub numsub:返回给定频道的订阅者数量 例如 PUBSUB NUMSUB news.it news.internet news.sport news.music
- pubsub numpat:返回客户端订阅的所有模式的数量总和
- punsubscribe:指示客户端退订所有给定模式。
- subscribe:订阅给定的一个或多个频道的信息。例如 subscribe msg chat_room
- unsubscribe:指示客户端退订给定的频道。
对 KEY 操作的命令
- exists(key):确认一个 key 是否存在
- del(key):删除一个 key
- type(key):返回值的类型
- keys(pattern):返回满足给定 pattern 的所有 key
- randomkey:随机返回 key 空间的一个
- keyrename(oldname, newname):重命名 key
- dbsize:返回当前数据库中 key 的数目
- expire:设定一个 key 的活动时间(s)
- ttl:获得一个 key 的活动时间
- move(key, dbindex):移动当前数据库中的 key 到 dbindex 数据库
- flushdb:删除当前选择数据库中的所有 key
- flushall:删除所有数据库中的所有 key
对 String 操作的命令
- set(key, value):给数据库中名称为 key 的 string 赋予值 value
- get(key):返回数据库中名称为 key 的 string 的 value
- getset(key, value):给名称为 key 的 string 赋予上一次的 value
- mget(key1, key2,…, key N):返回库中多个 string 的 value
- setnx(key, value):添加 string,名称为 key,值为 value
- setex(key, time, value):向库中添加 string,设定过期时间 time
- mset(key N, value N):批量设置多个 string 的值
- msetnx(key N, value N):如果所有名称为 key i 的 string 都不存在
- incr(key):名称为 key 的 string 增 1 操作
- incrby(key, integer):名称为 key 的 string 增加 integer
- decr(key):名称为 key 的 string 减 1 操作
- decrby(key, integer):名称为 key 的 string 减少 integer
- append(key, value):名称为 key 的 string 的值附加 value
- substr(key, start, end):返回名称为 key 的 string 的 value 的子串
对 List 操作的命令
- rpush(key, value):在名称为 key 的 list 尾添加一个值为 value 的元素
- lpush(key, value):在名称为 key 的 list 头添加一个值为 value 的元素
- llen(key):返回名称为 key 的 list 的长度
- lrange(key, start, end):返回名称为 key 的 list 中 start 至 end 之间的元素
- ltrim(key, start, end):截取名称为 key 的 list
- lindex(key, index):返回名称为 key 的 list 中 index 位置的元素
- lset(key, index, value):给名称为 key 的 list 中 index 位置的元素赋值
- lrem(key, count, value):删除 count 个 key 的 list 中值为 value 的元素
- lpop(key):返回并删除名称为 key 的 list 中的首元素
- rpop(key):返回并删除名称为 key 的 list 中的尾元素
- blpop(key1, key2,… key N, timeout):lpop 命令的 block 版本。
- brpop(key1, key2,… key N, timeout):rpop 的 block 版本。
- rpoplpush(srckey, dstkey):返回并删除名称为 srckey 的 list 的尾元素,并将该元素添加到名称为 dstkey 的 list 的头部
对 Set 操作的命令
- sadd(key, member):向名称为 key 的 set 中添加元素 member
- srem(key, member) :删除名称为 key 的 set 中的元素 member
- spop(key) :随机返回并删除名称为 key 的 set 中一个元素
- smove(srckey, dstkey, member) :移到集合元素
- scard(key) :返回名称为 key 的 set 的基数
- sismember(key, member) :member 是否是名称为 key 的 set 的元素
- sinter(key1, key2,…key N) :求交集
- sinterstore(dstkey, (keys)) :求交集并将交集保存到 dstkey 的集合
- sunion(key1, (keys)) :求并集
- sunionstore(dstkey, (keys)) :求并集并将并集保存到 dstkey 的集合
- sdiff(key1, (keys)) :求差集
- sdiffstore(dstkey, (keys)) :求差集并将差集保存到 dstkey 的集合
- smembers(key) :返回名称为 key 的 set 的所有元素
- srandmember(key) :随机返回名称为 key 的 set 的一个元素
对 Hash 操作的命令
- hset(key, field, value):向名称为 key 的 hash 中添加元素 field
- hget(key, field):返回名称为 key 的 hash 中 field 对应的 value
- hmget(key, (fields)):返回名称为 key 的 hash 中 field i 对应的 value
- hmset(key, (fields)):向名称为 key 的 hash 中添加元素 field
- hincrby(key, field, integer):将名称为 key 的 hash 中 field 的 value 增加 integer
- hexists(key, field):名称为 key 的 hash 中是否存在键为 field 的域
- hdel(key, field):删除名称为 key 的 hash 中键为 field 的域
- hlen(key):返回名称为 key 的 hash 中元素个数
- hkeys(key):返回名称为 key 的 hash 中所有键
- hvals(key):返回名称为 key 的 hash 中所有键对应的 value
- hgetall(key):返回名称为 key 的 hash 中所有的键(field)及其对应的 value
Redis Sentinel
- ping :返回 pong
- sentinel masters :列出所有被监视的主服务器,以及这些主服务器的当前状态。
- sentinel slaves:列出给定主服务器的所有从服务器,以及这些从服务器的当前状态。
- sentinel get-master-addr-by-name:返回给定名字的主服务器的 IP 地址和端口号。如果这个主服务器正在执行故障转移操作,或者针对这个主服务器的故障转移操作已经完成,那么这个命令返回新的主服务器的 IP 地址和端口号。
- sentinel reset:重置所有名字和给定模式 pattern 相匹配的主服务器。pattern 参数是一个 Glob 风格的模式 重置操作清楚主服务器目前的所有状态,包括正在执行中的故障转移,并移除目前已经发现和关联的,主服务器的所有从服务器和 Sentinel 。
- sentinel failover:当主服务器失效时,在不询问其他 Sentinel 意见的情况下,强制开始一次自动故障迁移(不过发起故障转移的 Sentinel 会向其他 Sentinel 发送一个新的配置,其他 Sentinel 会根据这个配置进行相应的更新)。