高性能高并发网站架构,教你搭建Redis5缓存集群

1、Redis集群介绍前端

Redis真的是一个优秀的技术,它是一种key-value形式的NoSQL内存数据库,由ANSI C编写,遵照BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。 Redis最大的特性是它会将全部数据都放在内存中,因此读写速度性能很是好。Redis是基于内存进行操做的,性能较高,能够很好的在必定程度上解决网站一瞬间的并发量,例如商品抢购秒杀等活动。node

网站承受高并发访问压力的同时,还须要从海量数据中查询出知足条件的数据,须要快速响应,前端发送请求、后端和mysql数据库交互,进行sql查询操做,读写比较慢,这时候引入Redis ,把从mysql 的数据缓存到Redis 中,下次读取时候性能就会提升;固然,它也支持将内存中的数据以快照和日志的形式持久化到硬盘,这样即便在断电、机器故障等异常状况发生时数据也不会丢失,Redis能从硬盘中恢复快照数据到内存中。mysql

Redis 发布了稳定版本的 5.0 版本,放弃 Ruby的集群方式,改用 C语言编写的 redis-cli的方式,是集群的构建方式复杂度大大下降。Redis-Cluster集群采用无中心结构,每一个节点保存数据和整个集群状态,每一个节点都和其余全部节点链接。redis

为了保证数据的高可用性,加入了主从模式,一个主节点对应一个或多个从节点,主节点提供数据存取,从节点则是从主节点拉取数据备份,当这个主节点挂掉后,就会有这个从节点选取一个来充当主节点,从而保证集群不会挂掉。sql

redis-cluster投票:容错,投票过程是集群中全部master参与,若是半数以上master节点与master节点通讯超过(cluster-node-timeout),认为当前master节点挂掉。数据库

集群中至少应该有奇数个节点,因此至少有三个节点,每一个节点至少有一个备份节点,因此下面使用6节点(主节点、备份节点由redis-cluster集群肯定)。6个节点分布在一台机器上,采用三主三从的模式。实际应用中,最好用多台机器,好比说6个节点分布到3台机器上,redis在创建集群时为自动的将主从节点进行不一样机器的分配。vim

2、单机redis模式后端

下载源码redis5.0并解压编译缓存

​wget http://download.redis.io/releases/redis-5.0.0.tar.gz
tar xzf redis-5.0.0.tar.gz
cd redis-5.0.0
make

redis前端启动须要改为后台启动.bash

修改redis.conf文件,将daemonize no -> daemonize yes
vim redis.conf
启动redis
/www/server/redis/src/redis-server /www/server/redis/redis.conf
查看redis是否在运行 
ps aux|grep redis

  

如今是单机redis模式完成。

3、redis集群模式:

1.建立6个Redis配置文件

cd /usr/local/
mkdir redis_cluster  //建立集群目录
cd redis_cluster
mkdir 7000 7001 7002 7003 7004 7005//分别表明6个节点    
其对应端口 7000 7001 7002 70037004 7005

2.复制配置文件到各个目录

cp /www/server/redis/redis.conf  /usr/local/redis_cluster/7000/
cp /www/server/redis/redis.conf  /usr/local/redis_cluster/7001/
cp /www/server/redis/redis.conf  /usr/local/redis_cluster/7002/
cp /www/server/redis/redis.conf  /usr/local/redis_cluster/7003/
cp /www/server/redis/redis.conf  /usr/local/redis_cluster/7004/
cp /www/server/redis/redis.conf  /usr/local/redis_cluster/7005/ 

 3.分别修改配置文件

vim /usr/local/redis_cluster/7000/redis.conf
vim /usr/local/redis_cluster/7001/redis.conf
vim /usr/local/redis_cluster/7002/redis.conf
vim /usr/local/redis_cluster/7003/redis.conf
vim /usr/local/redis_cluster/7004/redis.conf
vim /usr/local/redis_cluster/7005/redis.conf

 以下

port 7000 #端口
cluster-enabled yes #启用集群模式
cluster-config-file nodes_7000.conf #集群的配置 配置文件首次启动自动生成
cluster-node-timeout 5000 #超时时间 5秒
appendonly yes #aof日志开启 它会每次写操做都记录一条日志
daemonize yes #后台运行
protected-mode no #非保护模式
pidfile  /var/run/redis_7000.pid
//下面能够不写
#若设置密码,master和slave需同时配置下面两个参数:
masterauth "jijiji" #链接master的密码
requirepass "jijiji" #本身的密码 

cluster-config-file,port,pidfile对应数字

4.启动节点

cd /www/server/redis/src/
./redis-server /usr/local/redis_cluster/7000/redis.conf
./redis-server /usr/local/redis_cluster/7001/redis.conf
./redis-server /usr/local/redis_cluster/7002/redis.conf
./redis-server /usr/local/redis_cluster/7003/redis.conf
./redis-server /usr/local/redis_cluster/7004/redis.conf
./redis-server /usr/local/redis_cluster/7005/redis.conf

 查看redis运行

ps aux|grep redis

 

5.启动集群

/www/server/redis/src/redis-cli --cluster create 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005  --cluster-replicas 1

 这里使用的命令是create,由于咱们要建立一个新的集群。 该选项--cluster-replicas 1意味着咱们但愿每一个建立的主服务器都有一个从服。 

 

输入yes

至此,Reids5 集群搭建完成。

6.检查Reids5集群状态

能够执行redis-cli --cluster check host:port检查集群状态slots详细分配。 

redis-cli --cluster info 127.0.0.1:7000

7.中止Reids5集群

(1).由于Redis能够妥善处理SIGTERM信号,因此直接kill -9也是能够的,能够同时kill多个,而后再依次启动。

kill -9 PID PID PID

(2).redis5 提供了关闭集群的工具,修改文件: /www/server/redis/utils/create-cluster/create-cluster

端口PROT设置为6999,NODES为6,工具会生成 7000-7005 六个节点 用于操做。

修改后,执行以下命令关闭集群:

/www/server/redis/utils/create-cluster/create-cluster stop  

从新启动集群:

/www/server/redis/utils/create-cluster/create-cluster start 

8.帮助信息

执行redis-cli --cluster help,查看更多帮助信息

redis-cli --cluster help
相关文章
相关标签/搜索