NoSQL: Redis (key-value存储)

安装

  • 下载 : https://redis.io
  • 解压 : tar zxvf redis-3.2.5.tar.gz
  • 复制: 推荐放到usr/local目录下
    sudo mv -r redis-3.2.3/* /usr/local/redis
    进入redis目录
    cd /usr/local/redis/
    
  • 生成 : sudo make
  • 测试 : sudo make test -> 运行时间会较长
运行
  • 启动服务器 : 在桌面目录 redis-server (按ctrl+c停止)
  • 启动客户端: 在新终端中运行 redis-cli
  • 运行命令
    ping
    set 'a' '123'
    
  • 当添加键值后, 发现在当前运行目录下, 创建了一个文件; dump.rdb, 这个文件用于将数据持久化存储

基本配置

基本配置
  • 在源文件/usr/local/redis目录下, 文件redis.conf为配置文件
  • 绑定地址: 如果需要远程访问, 可将此行注释 : bind 127.0.0.1
  • 端口: 默认为6379 port 6379
  • 是否以守护进程运行
    • 如果以守护进程运行, 则不会再命令行阻塞, 类似于服务
    • 如果以非守护进程运行, 则当前终端被阻塞, 无法使用
    • 推荐改为yes, 以守护进程运行
    • daemonize no|yes
  • 数据文件 : dbfilename dump.rdb
  • 数据文件存储路径
    dir的默认值为 ./, 表示当前目录
    推荐改为: dir /var/lib/redis
    
使用配置文件方式启动
  • 直接运行redis-server会直接运行, 阻塞当前终端
  • 一般配置文件都放在/etc/目录下 : sudo cp /usr/local/redis/redis.conf /etc/redis/
  • 推荐制定配置文件启动 : sudo redis-server /etc/redis/redis.conf
  • 停止redis服务
    ps ajx|grep redis
    sudo kill -9 redis的进程id
    

数据操作

  • redis是key-value的数据, 所以每个数据都是一个键值对
  • 键的类型是字符串
  • 值的类型分为5种 :
    • 字符串 : string
    • 哈希 : hash
    • 列表 : list
    • 集合 : set
    • 有序集合 : zset
string
  • string 是 redis最基本的类型
  • 最大能存储512MB数据
  • string类型是二进制安全的, 即可以为任何数据(数字, 图片, 序列化对象)
  • 命令 :
    • 设置
      • 设置键值 : set key value
      • 设置键值及过期时间, 以秒为单位 : SETEX key seconds value
      • 设置多个键值 : MSET key value [key value ...]
    • 获取
      • 根据键获取值, 如果不存在此键则返回nil : GET key
      • 根据多个键获取多个值 : MGET key [key ...]
    • 运算(要求值必须是数字, 才能参与运算)
      • 将key对应的value加1 : INCR key
      • 将key对应的value减1 : DECR key
      • 将key对应的value减整数 : DECRBY key decrement
    • 其他
      • 追加值 : APPEND key value
      • 获取值长度 : STRLEN key
键命令
  • 查找建, 参数接受正则 : KSYS pattern
  • 判断键是否存在, 如果存在返回1, 不存在返回0 : EXIST key [key ...]
  • 查看键对应的value的类型 : TYPE key
  • 删除键及对应的值 : DEL key [key ...]
  • 设置过期时间, 以秒为单位(创建的时候没有设置过期时间, 则会一直存在, 知道使用DEL移除) EXPIRE key seconds
  • 查看有效时间, 以秒为单位 : TTL key
hash
  • hash用于存储对象, 对象的格式为键值对
  • 设置 :
    • 设置单个属性 : HSET key field value
    • 设置多个属性 : HMSET key field value [field value ...]
  • 获取 :
    • 获取一个属性 : HGET key field
    • 获取多个属性 : HMGET key field [field ...]
    • 获取所有属性和值 : HGETAll key
    • 获取所有的属性 : HKEYS key
    • 返回包含属性的个数 : HLEN key
    • 获取所有值 : HVALS key
  • 其他 :
    • 判断属性是否存在 : HEXISTS key field
    • 删除属性及值 : HDEL key field [field ...]
    • 返回值的字符串长度 : HSTRLEN key field
list
  • 列表的元素类型为string
  • 按照插入顺序排序
  • 在列表的头部或者尾部添加元素
  • 设置 :
    • 在头部插入数据 : LPUSH key value [value ...]
    • 在尾部插入数据 : RPUSH key value [value ...]
    • 在一个元素的前|后插入新元素 : LINSERT key BEFORE|AFTER PIVOT value
    • 索引: LSET key index value
      • 设置指定索引的元素值
      • 索引是基于0的下标
      • 索引可以是负数, 表示偏移量是从list尾部开始计数, 如-1表示列表的最后一个元素
  • 获取 :
    • 移除并且返回key对应的list的第一个元素 : LPOP key
    • 移除并且返回key对应的list的最后一个元素 : RPOP key
    • 返回一个范围 : LRANGE key start stop
      • 返回存储在key的列表里制定范围内的元素
      • start和end偏移量都是基于0的下标
      • 偏移量也可以是负数, 表示偏移量是从list尾部开始计数, 如-1表示列表的最后一个元素
  • 其他 :
    • 裁剪列表, 改为元集合的一个子集 : LTPIM key start stop
      • start和end偏移量都是基于0的下标
      • 偏移量也可以是负数, 表示偏移量是从list
    • 返回存储在key里的list的长度 : LLEN key
    • 返回列表里索引对应的元素 : LINDEX key index
set
  • 无序集合
  • 元素为string类型
  • 元素具有唯一性, 不重复
  • 设置 :
    • 添加元素 : SADD key member [member ...]
  • 获取 :
    • 返回key集合所有的元素 : SMEMBERS key
    • 返回集合元素个数 : SCARD key
  • 其他 :
    • 求多个集合的交集 : SINTER key [key ...]
    • 求某集合与其他集合的差集 : SDIFF key [key ...]
    • 求多个集合的合集 : SUNION key [key ...]
    • 判断元素是否在集合中 : SISMEMBER key member
zset
  • sorted set, 有序集合

  • 元素为string类型

  • 元素具有唯一性, 不重复

  • 每个元素都会关联一个double类型的score, 表示权重, 通过权重将元素从小到大排序

  • 元素的score可以相同

  • 设置 :

    • 添加元素 : ZADD key score member [score member ...]
  • 获取 :

    • 返回制定范围内的元素 : ZRANGE key start stop
    • 返回元素个数 : ZCARD key
    • 返回有序集key中, score值在min和max之间的成员 : ZCOUNT key min max
    • 返回有序集key中, 成员member的score值 : ZSCORE key member
  • 其他 :

    • 求多个集合的交集 : SINTER key [key ...]
    • 求某集合与其他集合的差集 : SDIFF key [key ...]
    • 求多个集合的合集 : SUNION key [key ...]
    • 判断元素是否在集合中 : SISMEMBER key member

高级用法

发布订阅
  • 发布订阅
    • 发布者不是计划发送消息给特定的接收者(订阅者), 而是发布的消息分到不同的频道, 不需要知道什么样的订阅者订阅
    • 订阅者对一个或多个频道感兴趣, 只需要接受感兴趣的消息, 不需要知道什么样的发布者发布的
    • 发布者和订阅者的解耦合可以带来更大的扩展性和更加动态的网络拓扑
    • 客户端发到频道的消息, 将会被推送到所有订阅此频道的客户端
    • 客户端不需要主动去获取消息, 只需要订阅频道, 这个频道的内容就会被推送过来
  • 消息的格式
    • 推送消息的格式包含三部分
    • part1: 消息类型, 包含三种类型
      • subscribe : 表示订阅成功
      • unsubscribe : 表示取消订阅成功
      • message : 表示其它终端发布消息
    • 如果第一部分的值为subscribe, 则第二部分是频道, 第三部分是现在订阅的频道的数量
    • 如果第一部分的值为unsubscribe, 则第二部分是频道, 第三部分是现在订阅的频道的数量, 如果为0则表示当前没有任何订阅任何频道, 当在Pub/Sub以外状态, 客户端可以发出任何redis命令
  • 如果第一部分的值为message, 则第二部分是来源频道的名称, 第三部分是消息的内容
  • 命令
    • 订阅 : SUBSCRIBE 频道名称 [频道名称 ... ]
    • 取消订阅 : UNSUBSCRIBE 频道名称 [频道名称 ... ] (如果不写参数, 则表示取消所有订阅)
    • 发布 : PUBLISH 频道 消息
主从配置
  • 一个mater可以拥有多个slave, 一个slave又可以拥有多个slave, 如此下去, 形成了强大的多级服务器集群架构
  • 比如 : 将ip为192.168.1.10的机器作为主服务器, 将ip为192.168.1.11的机器作为从服务器
    • 设置主服务器的配置 : bind 192.168.1.10
    • 设置从服务器的配置 : (注意: 在slaveof后面写主机ip, 再写端口(端口必须写))
          bind 192.168.1.11
          slaveof 192.168.1.10 6379
      
    • 在master和slave分别执行info命令, 查看输出信息
      • 在master上写数据 : set hello world
      • 在slave上读数据 : get hello
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容