Redis基础

来源:互联网 发布:光荣使命手游巨人网络 编辑:程序博客网 时间:2024/05/22 13:03

Redis基础的一些随笔
REmote DIctionary Server(Redis) ,Redis常被称作是一款数据结构服务器(data structure server).

Redis的优点:
性能极高 – Redis能支持超过 100K+ 每秒的读写频率。
丰富的数据类型 – Redis支持的数据类型 String, List, Hashe, Set 及 ZSet
原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。

Redis安装步骤(官网有http://redis.io/download):
1、进入root目录,并下载Redis的安装包
wget http://download.redis.io/releases/redis-3.2.4.tar.gz
2、在目录下,解压按照包,生成新的目录redis-3.2.4
tar xzf redis-3.2.4.tar.gz
3、进入解压之后的目录,进行编译
cd redis-3.2.4
make
4、启动Redis redis-server
5、进入Redis redis-cli

Redis数据类型及基本操作不写了,太多,一一列出来太累,看官网http://redis.io/commands

Redis安全性设置:
设置密码的方式有两种:

1、使用config set 命令的requirepass 参数,具体格式为
config set requirepass “password”
2、配置redis.conf(/etc/redis/redis.conf)中设置requirepass属性,后面为密码。
这里写图片描述
输入认证的方式也有两种:
1、登录时可以 redis-cli -a password
2、登录后使用 auth password

redis三种模式:主从、哨兵、集群
主从:主从数据一致,主用来读写,从用来读
哨兵:启动哨兵程序用来监听redis,当主服务器挂掉时在从节点中投票选择一个从节点来作为主节点
集群:高可用.多个主从模式的组合,每个主从只储存一部分数据

Redis主从复制(环境限制没试过)特点:
1、master可以拥有多个slave。
2、多个slave可以连接同一个master外,还可以连接到其他的slave。(当master宕机后,相连的slave转变为master)
3、主从复制不会阻塞master,再同步数据时,master可以继续处理client请求。
4、提高了系统的可伸缩性。
Redis主从复制的过程:
1、Slave与master建立连接,发送sync同步命令。
2、 Master会启动一个后台进程,将数据库快照保存到文件中,同时Master主进程会开始收集新的写命令并缓存。
3、 后台完成保存后,就将此文件发送给Slave。
4、 Slave将此文件保存到磁盘上。

Redis事物
Redis的事务只能保证client发起的事务中的命令可以连续的执行,而且不会插入其他的client命令,当一个client在连接中发出multi命令时,这个连接就进入一个事务的上下文,该连接后续的命令不会执行,而是存放到一个队列中,当执行exec命令时,redis会顺序的执行队列中的所有命令。如果其中执行出现错误,执行正确的不会回滚,不同于关系型数据库的事务。
这里写图片描述

Redis持久化机制(划重点啦,不需要会操作,有这个概念就行)
Redis是一个支持持久化的内存数据库,Redis需要经常将内存中的数据同步到磁盘来保证持久化。

Redis支持两种持久化方式:
1、snapshotting(快照),将数据存放到文件里,默认方式。
是将内存中的数据已快照的方式写入到二进制文件中,默认文件dump.rdb,可以通过配置设置自动做快照持久化的方式。可配置Redis在n秒内如果超过m个key被修改就自动保存快照。
save 900 1 #900秒内如果超过1个key被修改,则发起快照保存
save 300 10 #300秒内如果超过10个key被修改,则快照保存
2、 Append-only file(缩写为aof),将读写操作存放到文件中,生产中推荐使用此方式。
由于快照方式在一定间隔时间做一次,所以如果Redis意外down掉的话,就会丢失最后一次快照后的所有修改。
aof比快照方式有更好的持久化性,是由于使用aof时,redis会将每一个收到的写命令都通过write函数写入到文件中当redis启动时会通过重新执行文件中保存的写命令来在内存中重新建立整个数据库的内容。

由于os会在内核中缓存write做的修改,所以可能不是立即写到磁盘上,这样aof方式的持久化也还是有可能会丢失一部分数据。可以通过配置文件告诉redis我们想要通过fsync函数强制os写入到磁盘的时机。

0 0
原创粉丝点击