Redis笔记:

什么是Redis?

Redis 是开源免费的,遵守BSD协议,是一个高性能的key-value非关系型数据库。

redis单线程问题

所谓的单线程指的是网络请求模块使用了一个线程(所以不需考虑并发安全性),即一个线程处理所有网络请求,其他模块仍用了多个线程。

redis采用多路复用机制:即多个网络socket复用一个io线程,实际是单个线程通过记录跟踪每一个Sock(I/O流)的状态来同时管理多个I/O流.

*Redis**特点*

Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。

Redis不仅仅支持简单的key-value类型的数据,同时还提供String,list,set,zset,hash等数据结构的存储。

Redis支持数据的备份,即master-slave模式的数据备份。

性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。

原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。

丰富的特性 – Redis还支持 publish/subscribe, 通知, 设置key有效期等等特性。

*redis作用:*

可以减轻数据库压力,查询内存比查询数据库效率高。

Redis应用:

token生成、session共享、分布式锁、自增id、验证码等。

*比较重要的**3**个可执行文件:*

redis-server:Redis服务器程序

redis-cli:Redis客户端程序,它是一个命令行操作工具。也可以使用telnet根据其纯文本协议操作。

redis-benchmark:Redis性能测试工具,测试Redis在你的系统及配置下的读写性能。

RDB同步机制:

  1. 开启和关闭:默认情况下是开启了。如果想关闭,那么注释掉redis.conf文件中的所有save选项就可以了。
  2. 同步机制:
    • save 900 1:如果在900s以内发生了1次数据更新操作,那么就会做一次同步操作。
    • save 300 10:如果在300s以内发生了10数据更新操作,那么就会做一次同步操作。
    • save 60 10000:如果在60s以内发生了10000数据更新操作,那么就会做一次同步操作。
  3. 存储内容:具体的值,而是命令。并且是经过压缩后存储进去的。
  4. 存储路径:根据redis.conf下的dir以及rdbfilename来指定的。默认是/var/lib/redis/dump.rdb
  5. 优点:
    • 存储数据到文件中会进行压缩,文件体积比aof小。
    • 因为存储的是redis具体的值,并且会经过压缩,因此在恢复的时候速度比AOF快。
    • 非常适用于备份。
  6. 缺点:
    • RDB在多少时间内发生了多少写操作的时候就会出发同步机制,因为采用压缩机制,RDB在同步的时候都重新保存整个Redis中的数据,因此你一般会设置在最少5分钟才保存一次数据。在这种情况下,一旦服务器故障,会造成5分钟的数据丢失。
    • 在数据保存进RDB的时候,Redis会fork出一个子进程用来同步,在数据量比较大的时候,可能会非常耗时。

AOF同步机制:

  1. 开启和关闭:默认是关闭的。如果想要开启,那么修改redis.conf中的appendonly yes就可以了
  2. 同步机制:
    • appendfsync always:每次有数据更新操作,都会同步到文件中。
    • appendfsync everysec:每秒进行一次更新。
    • appendfsync no:使用操作系统的方式进行更新。普遍是30s更新一次。
  3. 存储内容:存储的是具体的命令。不会进行压缩。
  4. 存储路径:根据redis.conf下的dir以及appendfilename来指定的。默认是/var/lib/redis/appendonly.aof
  5. 优点:
    • AOF的策略是每秒钟或者每次发生写操作的时候都会同步,因此即使服务器故障,最多只会丢失1秒的数据。
    • AOF存储的是Redis命令,并且是直接追加到aof文件后面,因此每次备份的时候只要添加新的数据进去就可以了。
    • 如果AOF文件比较大了,那么Redis会进行重写,只保留最小的命令集合。
  6. 缺点:
    • AOF文件因为没有压缩,因此体积比RDB大。
    • AOF是在每秒或者每次写操作都进行备份,因此如果并发量比较大,效率可能有点慢。
    • AOF文件因为存储的是命令,因此在灾难恢复的时候Redis会重新运行AOF中的命令,速度不及RDB。

给redis指定密码:

  1. 设置密码:在reids.conf配置文件中,将requirepass pasword取消注释,并且指定你想设置的密码。
  2. 使用密码连接reids:
    • 先登录上去,然后再使用autho password命令进行授权。
    • 在连接的时候,通过-a参数指定密码进行连接。

其他机器连接redis:

如果想要让其他机器连接本机的redis服务器,那么应该在redis.conf配置文件中,指定bind 本机的ip地址。这样别的机器就能连接成功。

redis数据结构

*存储字符串*
1.set key value:设定key持有指定的字符串value,如果该key存在则进行覆盖操作,总是返回OK
2.get key: 获取key的value。如果与该key关联的value不是String类型,redis将返回错误信息,因为get命令只能用于获取String value;如果该key不存在,返回null。
3.getset key value:先获取该key的值,然后在设置该key的值。
4.incr key:将指定的key的value原子性的递增1. 如果该key不存在,其初始值为0,在incr之后其值为1。如果value的值不能转成整型,如hello,该操作将执行失败并返回相应的错误信息
5.decr key:将指定的key的value原子性的递减1.如果该key不存在,其初始值为0,在incr之后其值为-1。如果value的值不能转成整型,如hello,该操作将执 行失败并返回相应的错误信息。
6.incrby key increment:将指定的key的value原子性增加increment,如果该key不存在,器初始值为0,在incrby之后,该值为increment。如果该值不能转成 整型,如hello则失败并返回错误信息
7.decrby key decrement:将指定的key的value原子性减少decrement,如果该key不存在,器初始值为0,在decrby之后,该值为decrement。如果该值不能 转成整型,如hello则失败并返回错误信息
8.append key value:如果该key存在,则在原有的value后追加该值;如果该key 不存在,则重新创建一个key/value