redis集群redis-cluster搭建

redis集群搭建--参考微信公众号(诗情画意程序员):https://mp.weixin.qq.com/s/s5eJE801TInHgb8bzCapJQ

redis集群redis-cluster搭建_第1张图片

 

这是来自redis官网的一段介绍,大概意思就是:

Redis是一个开源(BSD许可)的内存数据结构存储,用作数据库、缓存和消息代理。它支持诸如字符串、散列、列表、集、带范围查询的排序集、位图、hyperloglogs、带半径查询和流的地理空间索引等数据结构。Redis具有内置的复制、Lua脚本、LRU清除、事务和不同级别的磁盘持久性,并通过Redis Sentinel和带有Redis集群的自动分区提供高可用性。

and so on ...

不过这不是今天的重点,今天的重点是redis的集群搭建。

搭建集群呢,先安装个单击版的,其实呢安装挺简单。

 

redis的安装单机版:

  • redis是c语言开发的。安装redis需要c语言的编译环境。如果没有gcc需要在线安装。yum install gcc-c++

  • 将redis的安装包上传到Linux并解压缩。

  • 进入redis源码目录进行编译。输入命令:make

  • 编译完后进行安装,输入命令:make install PREFIX=/usr/local/redis

       PREFIX指定redis的安装目录,我的安装在了/usr/local/redis

redis集群redis-cluster搭建_第2张图片

 

 

 

这时单击版的就已经安装好了,接下来启动一下:

在redis的安装目录直接启动:

输入命令:[root@localhost bin]# ./redis-server 

redis集群redis-cluster搭建_第3张图片

 

 

 

出现这个界面表示启动成功。

可以通过查看redis进程:

输入命令:ps aux|grep redis

 

 

 

 

但是这是前台启动,退出后redis就关闭了,下面设置后台启动的方法。

  • 把/root/redis-3.0.0/redis.conf复制到/usr/local/redis/bin目录下

  • redis集群redis-cluster搭建_第4张图片
  • 进入/usr/local/redis/bin目录下,修改redis.conf配置文件,将daemonize no 改为 yes,保存并退出

redis集群redis-cluster搭建_第5张图片

 

 

 

  • 这时再次启动redis,但是要指定配置文件以后台启动

    输入命令:[root@localhost bin]# ./redis-server redis.conf

redis集群redis-cluster搭建_第6张图片

 

 

 

可以看到并没有出现redis的启动图标,那是否启动成功了呢?这时我们查看一下redis进程。

输入命令:ps aux|grep redis

 

 

 

可以看到redis已经成功启动。

下面我们开始搭建集群版,下面是redis官网的一段截取。

redis集群redis-cluster搭建_第7张图片

 

 

 

更多的介绍请到redis官网查看。

由于redis-cluster采用投票容错的方式来判断该节点是否挂掉,投票容错简单点说就是投票超总数的一半即判定该节点挂掉,因此最少需要三个节点,但是由于redis-cluster要保证高可用,因此每个主节点需要一个备份机,也就是说至少需要六个节点。

这里在redis官网也提到了。

redis集群redis-cluster搭建_第8张图片

 

 

 六个节点需要六台服务器,这里为了演示就先搭建一个伪分布式,操作步骤和在六台服务器上搭建完全一样。

 

集群环境搭建

步骤一

使用ruby脚本搭建集群,需要ruby的运行环境

安装ruby

yum install ruby

yum install rubygems

redis集群redis-cluster搭建_第9张图片

 

 

 

步骤二

安装ruby脚本运行所需的依赖包 redis-3.0.0.gem

[root@localhost wl]# gem install redis-3.0.0.gem

搭建redis集群

搭建伪分布式,需要6个redis的实例,分别运行在7001,7002,7003,7004,7005,7006端口

步骤一

创建6个redis实例,把之前的单机版复制6份就可以。

在/usr/local/下创建redis-cluster目录

redis集群redis-cluster搭建_第10张图片

 

 

 将/usr/local/redis目录下的单机版复制6分到/usr/local/redis-cluster/

redis集群redis-cluster搭建_第11张图片

 

 

 步骤二

每个实例运行在不同的端口。需要修改redis.conf配置文件。

配置文件中还需要把cluster-enabled yes前的注释去掉。

进入redis01目录下,打开redis.conf配置文件

修改端口号为7001,并把cluster-enabled yes前的注释去掉

redis集群redis-cluster搭建_第12张图片

 

 

 redis集群redis-cluster搭建_第13张图片

 

 

 其他5个做相同的设置,注意端口不一样。

步骤三

  • 启动每个redis实例

  • 使用ruby脚本搭建集群,需要使用redis-trib.rb,此文件在源码src目录下。

  • 进入src目录,将redis-trib.rb复制到/usr/local/redis-cluster目录下

    cp redis-trib.rb /usr/local/redis-cluster

  进入/usr/local/redis-cluster目录执行命令:

  ./redis-trib.rb create --replicas 1 192.168.25.131:7001 192.168.25.131:7002 192.168.25.131:7003 192.168.25.131:7004 192.168.25.131:7005 192.168.25.131:7006

  • 到此redis集群就搭建完成了,这时启动一下。

    逐个启动太费事,编写个脚本

    在redis-cluster目录下创建一个.sh的脚本,

  • redis集群redis-cluster搭建_第14张图片

    创建完成后修改文件的权限 

    chmod u+x start_redis.sh

    运行文件  sh start_redis.sh,启动redis集群

    查看后台进程 ps aux|grep redis 

  • redis集群redis-cluster搭建_第15张图片

     

     可以看到redis集群成功启动。

你可能感兴趣的:(技术)