Redis

一 概述

1.Redis

Redis是行使C语言编写的按照内存且协助持久化的、高品质的key-value的noSQL数据库,首要囤积访问量较大、更改频仍、安全须要不高的数目。

2.NoSQL

非关系型数据库。关系型数据库是根据关系模型建立的数据库,关系模型显示的是切实可行世界中实体间的涉及关系。

3.BSD协议

BSD开源协议是一个给予使用者极大自由的商谈,使用者可以修改源码,公布修改后的代码。

4.音讯中间件

帮衬与有限支撑分布式应用程序间共同如故异步收发音讯的中间件。

5.音讯队列

为了实用地控制新闻的收发进程而在新闻中间件中置放的储存新闻的数据结构,拔取队列,先进先出。

6.SOA

Service-Oriented
Architecture,面向服务的架构,将应用程序分为若干个粗粒度、松耦合的选用模块,再经过中立的接口将那几个模块联系起来。

二 key命名

key01::key02:多层,相邻层用:隔开

三 常用操作

  • redis-server.exe
    redis-windows-conf:启动服务器。
  • redis-cli.exe -h 127.0.0.1 -p
    6379:通过IP与端口连接某个redis服务。
  • keys
    *:查看当前数据库中所有的key。
  • config get
    *:获取全部陈设信息。
  • help command:查看操作含义。
  • help
    @string:查看string全体操作。
  • rename key01
    key02:为key重命名。
  • type key:获取数据类型。
  • del key:删除key。
  • flushdb:清空当前数据库。
  • flushall:清空所有数据库。

四 string

1.增

  • set key value:赋值。
  • mset key01 value01 key02
    value02:为八个键赋值,具有原子性,同时打响,同时战败。
  • set key value
    nx:只有在键不存在时才方可设置。
  • set key value
    xx:唯有在键存在时才得以设置。
  • set key value ex
    seonds:设置键的超时。
  • getset key
    value:先取值,后赋值。

    2.删


del key:删除key。

3.改

  • incr key:增1。
  • incrby key
    increment:增指定的量。
  • incrbyfloat key
    increment:增float型数据指定的量。
  • decr key:减1。
  • decrby key
    decrement:减指定的量。

    4.查


  • get key:取值。
  • strlen key:获取字符串长度。
  • exists
    key:存在重返1,不存在重返0.

    5.索引


从头开头,索引从0开首,1,2….
从尾初始,索引从-1起来,-2.-3…

  • setrange key index
    value:替换指定索引地方的值。
  • getrange key begin
    end:获取指定索引区间的值。
  • getrange key 0 -1:获取全部。

五 LinkedList

1.LinkedList,双向链表,查询效能低,增删效用高。

2.增

  • LPUSH key value01
    value02:从左边压入元素。
  • RPUSH key value02
    value02:从左侧压入元素。

    3.删


  • LPOP
    KEY:从左侧弹出一个要素,相当于从list中删去该因素。
  • RPOP KEY:从左边弹出一个要素。
  • ltrim key start end
    :删除指定范围外的因素。

    lrem key count
    value:删除链表中值为value的元素count个。

  • count>0:从左侧初阶删除。

  • count<0:从左边伊始删除。
  • count=0:删除所有。

    4.改


LINSERT key before/after oldValue
newValue:在指定元素前后插入元素,假设指定元素不设有,则不进行其余操作。假诺指定元素存在三个,只操作第二个要素。

RPOPLPUSH key01
key02:从key01右侧弹出一个要素压入key02左边。

5.查

llen key:长度即列表中元素个数。

6.索引

从左至右,从0开端;从右至左,从-1先导。

  • LRANGE key start
    end:获取指定索引区间的元素。
  • LRANGE key 0 -1:获取全体要素。
  • LINDEX key
    index:获取指定索引地方的值。
  • LSET key index
    value:设置指定索引地点的值。

六 hash

key值空间存储的不光是key值,还有此外音讯,比如超时时间,因而key占用空间较大,应该压缩key的数目,把相关数据存放到同一个key中,那样就暴发了数据类型hash,hash相当于HashMap。

在hash中,超时时长只可以设定在key上,不可能设定在field上。

1.增

  • hset key field
    value:为key中的一个字段赋值。
  • hmset key field01 value01 field02
    value02:同时为多少个字段赋值。

    2.删


  • hdel key
    field:删除key中指定字段。

    3.改


  • hincrby key filed
    increment:增加某个整数字段。
  • hincrbyfloat field
    increment:增添某个浮点型字段的值。

    4.查


  • hget key
    field:获取key中指定字段的值。
  • hmget key field01 field02
    :获取多少个字段的值。
  • hgetall
    key:获取具有字段及其相应的值。
  • hkeys key:获取具有字段名。
  • kvals key:获取具有字段的值。
  • hexists key
    field:判断key中是还是不是留存指定字段。
  • hlen key:获取key中字段数目。

七 set

无序,不可重复。所谓无序就是不一样时间查询同一集合,同一排序处元素不一致。

1.增

  • sadd key value01
    vlaue02:添美金素。

    2.删


  • srem key value01
    value02:删除元素。
  • spop key:随机移除一个要素。

    3.查


  • smembers key:获取全部因素
  • srandmember
    key:随机重临一个要素。
  • scard key:再次来到元素个数。
  • sismember key
    value:判断value是还是不是存在。

    4.交并集操作


交并集操作并不会去除被操作集合中的元素。

  • sdiff key01
    key02:求差集,从key01中剔除key02具有的因素,只是一个操作,不会去除key01中的元素。
  • sdiffstore destination key01
    key02:将差集存入指定集合中。
  • suinon key01 key02:求并集。
  • sninonstore destination key01
    key02:将并集结果存到指定集合中。
  • sinter key01 key02:求交集。
  • sinterstore destination key01
    key02:获取交集并蕴藏到指定集合中。

八 sortedset

以不变应万变聚集,有序的来由,每一个元素都都涉及一个分值,依据分值排序。

1.增

  • zadd key score01 value01 score02
    value02。

    2.删


  • zrem key value:删除指定元素。
  • zremrangebyrank key start
    end:删除指定排序区间的要素。
  • zremrangebyscore key min
    max:删除指定分值区间的因素。

    3.改


  • zincrby key increment
    value:修改分值。
  • zrank key
    value:获取排序,从小到大,从0起初。
  • zrevrank key
    value:获取排序,从大到小,从0发轫。

    4.查


  • zscore key value01:获取分值。
  • zcard key:获取集合中元素数目。
  • zrange key start end
    [withscores]:获取指定索引区间的值。
  • zrangebyscore key min max [limit
    offset
    count]:获取分值在指定区间的值,limit用于从指定偏移处截取count个数据。min前可以加(表示开区间,只可以加载min上。
  • zcount key min
    max:获取指定分值区间内元素个数。

    5.并集


zunionstore destination numKeys key[key...] weights weight aggregate max/min/sum
  • destination:并集结果存储的聚集。
  • numKey:参加操作的联谊数目。
  • weights:权重,即分值加入运算的百分比,为每一个汇集分别指定。
  • aggregate:整合策略。
  • zinterstore destination numKeys
    key[key…] weights weight aggregate max/min/sum:交集操作。

九 Rdis持久化

1.什么样是持久化?

将数据保存到硬盘中的进程叫做持久化。

2.Redis持久化方式

  • RDB: Redis
    DB,将所有数据以二进制格局保留到dump.rdb文件中,默许开启。
  • AOF:
    AppendOnlyFile,将对数据库的改动操作保存到文件中,默许关闭。

    3.RDB


RDB持久化会生成一个dump.rdb文件,覆盖原有文件。RDB情势

  • 用户发生save操作:阻塞服务器。
  • 用户爆发bgsave操作:后台执行,不会堵塞服务器。原理是开创一个子线程用来扭转持久化文件。
  • 在配置文件中布署,知足指定条件自动持久化,那是常用格局。配置原则:save
    <seconds><changes>,在指定的时间内至少发生指定次数的写操作,才实施bgsave操作,生成rdb文件。

RDB持久化格局每便都将数据库中的全体数量保存到硬盘当中,花费系统资源,不可以反复执行,为了确保RDB间隔时间内数据的莱芜,可以互相使用AOF持久化格局。

4.AOF

⑴系统将内存中的多少写入文件的实施进度:先将数据写入缓冲区,缓冲区满后,再将缓冲区里的内容写入文件。

 ⑵将对数据库的改动操作追加到文件当中,先进行的操作在头里。

⑶AOF的两种艺术

  • always:每执行一个改动操作,都及时写入文件。
  • everysec:每隔1秒,将修改操作写入文件三次,默许值。
  • no:由系统实际,缓冲区满后再写入文件。

⑷AOF文件的重写

为了防止AOF文件过大,可以重写AOF文件,将多个操作合并为一个操作。
重写格局:
率先种办法,BGREWRITEAOP:用于发送该操作,重写AOF文件。
第三种方法,设定配置原则,满意条件时自动重写,以下是重写规范:

auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb

当AOP文件大小达到某个值时,重写。

十 集群

1.一个Redis服务可以有多少个该服务的仿制品,那些Redis服务叫做master服务,其余复制品叫做slave服务。

图片 1

2.master服务会将自己的多少同步给slave服务。

3.master劳务既可以读写,slave服务只好读。

4.将一个劳务设定为slave服务有两种艺术:

  • 客户发出slaveof masterip
    masterport。
  • 在配置文件中配置:slaveof masterip
    masterport。

5.可以在安顿文件废除设定slave的操作,也得以在由客户废除:slaveof no one

6.主从复制存在的标题
唯有一个master服务器执行写操作,假使master服务器现过逝障,写操作就无法推行。

十一 sentinal哨兵机制

1.什么样是哨兵机制?

为主服务器配置一个监听器,这一个监听器称作哨兵,当主服务器暴发故障时,哨兵自动将某一个从服务器提高为主服务器,从而确保服务器不间断地实践。

图片 2

十二 Twemproxy集群

1.在主从复制中,写职务如故由一个节点承担,写压力并不曾缓解,由此发生了Twemproxy集群机制,用户向代理发出请求,由代理将写职责分配到劳动器池中的节点。

图片 3

2.Twenproxy基本原理

劳动器池中的每一个服务器都有一个接到区间,客户发送请求到代办后,代理获取key的hashcode,该值落在哪些区间,就调用哪个服务器。

3.缺点

有一个主导目的,即代理,如若代理出现难点,整个Redis服务就不可能运用,解决方式就是去中央化,使得某一片段现死亡障,全体仍可以运作。

十三 原生集群格局

1.哪些是原生集群情势?

七个Redis主服务器构成一个集群,其中每一个Redis主服务器都称呼一个节点,节点之间交互通讯,节点可以有自己的从服务器来平摊读的压力。

图片 4

2.节点时期通讯的目标之一

每一个节点都得以与其他所有节点通信,充当sentinal角色监控其余节点的运行意况,当某一个节点暴发故障时其余五个节点综合音讯,即便判断该节点不能正常办事,升高该节点的一个从服务器为节点。

十四 Jedis

1.在java中做客Redis服务器,须求导入架包jedis.jar。

2.Jedis是java语言中连接Redis服务器的客户端工具。

3.Jedis基本保留了命令行访问Redis服务器的主意。

4.正像连接关系型数据库最好建立连接池一样,连接Rdis数据库也最好建立连接池,建立连接池时使用的类JedisPoolConfig/JedisPool。

5.单个Redis服务器压力较大,由此得以营造Redis服务器集群,打造集群使用时选用的类HostAndPort/JedisCluster。

 

网站地图xml地图