10分钟带你初识redis基础

为什么使用nosql:

关系数据库的缺点:

1.无法处理每秒上万次的qps,优于关系数据库没有大量的io,硬盘io位性能瓶颈

2关系型数据库表字段有限,记录数量有限,最多256列,当表数据到达百万读写速度下降

3无法简单的通过增加硬件,服务节点来提高系统性能

nosql的优点:

1支持高并发,数据存于内存,读写性能高

2无需事先建立字段,随时存储自定义的数据格式,在关系型数据库中必须实现添加好字段

3.高可用,支持实现高可用架构,哨兵/集群cluster 等

4成本低开源基本不收费

nosql的缺点:

1.没有约束没有索引

2.没有标准的sql语句

3.数据之间无联系

redis的安装及下载

linux安装:

下载redis的压缩包(自行百度)并解压,因为redis是c编写的需要c的编译器,安装gcc,yum -y install gcc

到/root/redis/redis-3.2.9/src以下目录执行  make命令 编译c文件,至此安装完成

启动redis:到redis-3.2.9/src 下执行 ./redis-server &

关闭redis:到redis-3.2.9/src 下执行./redis-cli shutdown  可以直接输入也可以在client端直接关掉(处理逻辑是先拒绝请求把当前数据处理完关闭程序)

客户端链接

QPS10w

1.直接启动 ./redis-cli

2.指定所要链接的redis  ./redis -cli -h 127.0.0.1 -p 6379

redis的基本命令

ping : 判断网络是否通

dbsize:查看当前数据库的key的数目

redis默认使用16个库,从0-15 对数据库的修改可以在redis-conf中的database 16

切换数据库:select db 选择第6个库 select 5

删除当前的数据库 flushdb

redis的key的操作命令

1.keys pattern 查找符合pattern的key值。partten可以使用通配符

如:keys *

如:keys zhang?an

2.exists: exists key【key】判断key是否存在,存在返回1,其他返回0,当使用多个key值时候,返回key的数量

3.expire :expire key seconds 设置key的生存时间秒 ,超过时间key自动删除,设置成功返回1其他情况返回0

4.ttl key:以s为单位查看key的剩余存活时间,

-1表示永不过期

-2表示不存在

其余数字以s为单位表示剩余时间

redis的五种数据类型:

String:存储字符串,包括二进制及序列化后的数据 最大存储512m

语法:set/get/incr(数字类型+1)/decr(数字类型-1)/append 在原来key基础上加value返回value长度,

strlin key:返回key 所存储的字符串的长度

getrange key start end: 截取字符串,返回截取的字符串

setrange key offset value:用value替换key的存储的值从offset开始,不存在的当空字符串处理

mset 同时设置多个key 同理 mget 同时取多个value

(简单语法没有截图,如果需要请留言)

hash:是一个string类型的field和value的映射表


语法:hset/hget /hmset(存多个value)/hmget

hmget key field ... 指定多个field,空field返回null

hgetall key 返回所有的key的filed 及 value

hkeys:看所有的field列表

hvals key:返回hash表中所有域的值

hexists:查看给定的field是否存在,存在返回1不存在返回0

list:简单的字符串列表,按照插入顺序排序,可以从左从右添加


语法:lpush/rpush/lrange key start stop -1表示最后一个数字

lindex key index 获取key中下标为index的元素 lrang zhangfan(key) 0 4

llen key:获取列表key的长度

lrem key count value:根据count删除value的值,count>0从左侧删除counts数量的value,反之从右边,若count =0 删除所有value、

lset key index value,将第几位的值改为value的值

set(无序):是string类型的无序集合,集合成员是唯一的、


语句:sadd/smembers/scard key/srem key member(删除key中的一个或多个value)/

srandmember key {count}随机返回一个数据 有count返回count的数据、

spop key 【count】 删除一个随机元素,有count删除随机的count的值

zset:与set一样也是string的无序集合,且不允许重复的成员,不同点是每一个元素都关联一个分数,redis会根据分树进行排序

语法 zadd:zdd key score member 【。。。。。】


查询zrange -1 表示最后一个,其余的跟之前是一样的

zrevrange key start stop [withscores]:指定区间的score及value返回,按照score从高到底

zrem key member 【。。。。。。。。】:删除一个或者多个成员,不存在即被忽略

zrangebyscore key min max 【withscores】 【limit offset count】:获取有序集中所有的score介于min和满之间的

zount key min max :score值在【min及max】之间成员的数量

新增:

经纬度的数据类型:(geospatial)()

geoadd location 1.0.0.0 2.0.0.0 home(设置经纬度)

geopos location home(获取经纬度)

新增hyperloglogs(奇数统计){1.1.2.4} 有四个

使用非常小的内存统计非常大的数据量

redis订阅通知,消息队列

使用subscribe (具体频道) psubscribe(可使用通配符频道)

pubulish:发布消息

redis事务

redis的事务理解:保证事务的多条命令都能正常执行,没有回滚的概念

multi:标志一个事物的开始,将多条命令放到队列里进行缓存

exec:执行事务中的每条命令,相当于执行队列中的每条命令,如果事务被打断,返回nil

discard:取消事务的所有的命令


* 事务执行之前如果有命令执行错误(语法有错),无法执行此事务,整个事务被放弃

* 放入事务中的命令,语法没错但是执行时候出现错误,此时事务正常提交的并执行

 Redis的watch机制

watch机制:监听一个或者多个key,如果key的value在exec执行之前被修改了,整个事务被取消,watch机制使得事务的exec变成有条件的,事务只有在被watch的key没有被修改的前提下才会执行

语法:watch key。。。。/unwatch key。。。。


在另外一个界面修改后此时事务失效

为什么使用lua脚本:

好处:一次发送多个命令,减少与服务端链接,减少网络开销

原子性

lua files复杂的命令,命令集的复用

eval lua-script key-num[key1 key2]

因为是单线程lua脚本万一死循环会是其他命令都不能执行

配置文件:超时时间,接受命令不执行,不能中断保持原子性

redis事务失败为什么不会滚?


程序员写的问题,二是为了更快

redis的持久化

redis4.0 以后支持混合持久化;rdb会丢失大量数据,aof文件过大,启动会过慢,所以有以下的结构将rdb 文件 内容和增量的aof文件进行存储,此处aof不再是全量的文件,而是增量的aof的文件

RDB:

在指定的时间间隔内将内存中的数据集以快照的形式存到磁盘中,需要数据恢复时直接将快照文件读取到内存中,存储的是一个二进制文件,默认是dump.rdb

rdb支持多个条件同时生效

默认提供的:保存策略,第二个参数为s,第三个为次数,例1:900s内有一次改变就存储一次

AOF

每次接收到一条改变数据的命令时,他将命令写到一个aof文件中,当redis重启的时候,会通过执行aof中每一条命令来回复数据。

优先使用aof进行数据回复

如何实现:

默认关闭,  
可以修改为,always每次执行都会写比较慢,everysec:每秒执行一次同步
允许重写的最小aof的文件大小,默认64m,当aof文件大于64m时开始整理aof文件。去掉无用的操作命令,100是跟上次重写的文件一样大的时候

aof重写的时候,有新的指令来,会放到aof的缓存中,当aof重写完成,将缓存的数据放到新的重写文件中

redis的主从复制


集群结构

master用于写,slave只负责读,向slave写数据会报错

主从复制的主要流程(全量同步/增量同步)

全量同步:主要发生在slave初始化的阶段:slave会复制master上的所有的数据

1.slave > master 发送sync消息;

2.master收到sync消息执行bgsave生成RDB文件。因为是异步操作,期间收到的请求放入到缓冲区中

3.master执行完bgsave向salve发送快照

4.slave收到快照丢弃所有的旧数据,载入新的数据

5.salve接收完成后,读取缓冲区中的命令

什么是bgsave:bgsave有个兄弟是save,都是master执行生成快照的命令,区别在于,save会阻塞主主进程禁止其他访问,bgsave会fork一个子进程,去生成快照文件,os执行此方法时候会使用写时复制(copy - on - write)策略,即fork执行的时候父子进程是公用同一套内存,当父进程收到写命令的时候会复制一份出来,以保证子进程生成RDB文件不受影响,所有fork的时候是fork某一刻的内存数据。(快照:数据的二进制形式)

在一台服务器上,修改配置文件可以模拟主从场景

主服务器:后台启动,端口号,日志,。。
从服务器:指定主服务器的ip
info replication :可以看出有两个从节点,都是在线状态


单机场景下的容灾处理

了解(线上不会让你自己去设置太low):如果master挂掉,就不能写入只能读取,选一个slave执行“slaveof no one ”将一个slave变成主服务器,将另一台slave重新挂载到新的master下 :slaveof 127.0.0.1 6381

Sentinel 哨兵模式

sentinel是一个sentine运行在特殊模式下的redis服务器

三个主要作用:

1.监控主从服务器是否正常进行

2.提醒被监控的redis出现问题,sentinel会通知其他程序

3.自动故障转移



sentail的启动方式
最后一个参数是有多少投票认为是客观下线

 工作机制:  

sentinel会检测master和slave是否正常,如果某个sentinel挂了,就无法实现监控所以哨兵一般要3个,当某一个sentinel认为被监控的服务下线以后,会向其他sentinel进行确认,判断是否是真的下线?(主管下线 => 客观下线)(超过半数)(,对slave重新升为新的master,当原来的master重新上线时候成为slave

缺点:

切换的过程中可能出现数据的确实

写入只能写到一个mstaer,没有办法水平扩容(多个master)

分布式就是解决水平扩容

Sentinel 集群模式


哨兵模式可以实现高可用,但是要支持高并发,存储海量数据还是不行,所以引入了redis集群

一个redis节点有多个node组成,而多个node之间通过cluster meet命令来实现。

节点间的握手过程

节点A收到客户端的cluster meet命令。然后A收到ip和端口,向这个地址B节点发送一个消息,B回复一个pang,A收到以后回复一个ping,表名握手成功,最后,A节点通过gossip协议将B节点的信息同步给其他节点C,D,E等

槽slot:

redis通过集群分片的形式保存数据,存储单位是槽slot,一共有16384个,如果有3个节点的集群,那么每个集群都有5500左右的槽slot,添加/删除节点的方式是:如新增一个4节点,1-3会匀出一些分配给4各个节点的槽点基本保持一致

处理数据流程:通过slot = CRC16(key)& 16383 (CRC16算法),计算数据在那个槽solt上,然后进行数据处理

故障转移

A > B 节点会进行通信如果A节点认为B节点离线了(发ping消息在cluster_node_timeout时间内没有返回),会通知其他节点,其余节点如果都认为B节点离线(超过半数以上),则B节点真正的离线。

然后会进行类似于raft算法,该节点上的slave会生成master

重定向

因为client链接redis的时候可以链接任何一个节点。所以在cluster模式的情况下当cliet进行请求的时候主要流程:

1.检查当前的key是否存在当前节点(crc16)key / 16384

2.若不是该节点负责,返回moved重定向

3.该slot是否正在迁入或者迁出(迁入的solt有ASKING标记,直接进行操作,若为正在迁出solt则重定向客户端到迁移的目的服务器)



一些redis常被问道的问题:

https://www.jianshu.com/p/20f902aa35ff

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容