redis集群的搭建,踩过得坑

1,我搭的是伪集群,就是在一台机器上启动了六个redis服务html

2,启动一个redis服务,很简单,下载包,解压,直接redis-server redis.conf启动就能够node

3,集群的话,看了好多教程,说的特别复杂,个人方法就是讲redis.文件复制六份,修改里面的端口,还有pidfile,,还有开启集群的功能(就是把注释放开就好),而后依次用命令起redis

4,起来以后,就须要搭建集群了,如今这六个服务是没有主从,没有用任何交互的,因此,须要经过一个工具将这六个整合起来。执行这个工具的命令后,可能会提示什么什么版本过低,(好像是2.2.0什么什么???)而后升级一下就能够了。再执行就ok了,会提示你谁是master,谁是slave。vim

没什么大坑,挺容易的ruby

 

在本身服务器上,从新搭一次,再补充一下服务器

1,第一步:下载redis安装包wget http://download.redis.io/releases/redis-4.0.6.tar.gz工具

2,第二步:解压压缩包tar -zxvf redis-4.0.6.tar.gz命令行

3,第三步:yum安装gcc依赖:yum install gcc  server

4,第四部:跳转到redis解压目录下cd redis-4.0.6htm

5,第五步:编译安装;make 

6,第六步:启动redis,不少教程说redis-server命令在bin目录下,其实redis4版本的命令都在src文件夹下

这里说一下,若是直接启动的话,命令行会停在启动框内,不能进行别的操做,对应的就是默认启动不是后台启动。因此须要:

vim redis.conf -》daemonize no改为daemonize yes.conf

 

7,再启动。而后验证一下,ps -ef |grep redis

会看到127.0.0.1:6379进程启动了,这里说下,redis默认端口是6379

(cd src && make install这条命令能够吧src里面的命令加载到/usr/local/bin中)

 

 

1,而后在搭建集群,我打算9001,9002,9003,做为master,9004,9005,9006是slave

我在/usr/redisz/在新建了redis-cluster文件夹:mkdir redis-cluster

而后将/usr/redis/redis-4.0.6/redis.conf复制到/usr/redisz/redis-cluster下,并重命名为redis9001.conf

cp /usr/redis/redis-4.0.6/redis.conf /usr/redisz/redis-cluster/redis9001.conf

修改redis9001.conf内容以下:vim redis9001.conf

                    bind 192.168.1.21             #本机IP

      port 9001                   #改成设定的端口

      daemonize yes                    #后台启动(刚才咱已经设置好了)

      cluster-enabled yes          #启动集群模式

                     pidfile /var/run/redis_9001.pid           #pid 改不改都行
 

      cluster-config-file nodes-9001.conf  #集群内部配置文件,改掉端口号 

      cluster-node-timeout 15000     #节点超时时间,单位:毫秒

改完以后,redis-server redis9001.conf启动便可

ps -ef |grep redis 你会发现9001端口的进程后会有中括号[cluster]

2,将redis9001.conf复制redis9002.conf->redis9006.conf六份,而后9002-9006设置的和9001同样。

这里说一个妙招:替换

先vim redis9002.conf

而后执行:%s/9001/9002/g

意思是将全文中的9001改成9002

而后依次启动,redis-server redis900x.conf

3,如今虽然6个都起来了,但彼此之间没有关系

参考(https://www.cnblogs.com/ding2016/p/7892542.html):

redis-trib.rb环境准备(该文件存在于redis-4.0.1/src/目录中)    //只须要在其中一台上执行此步骤!!

      redis-trib.rb是采用Ruby实现的Redis集群管理工具。内部经过Cluster相关命令帮助

    咱们简化集群建立、检查、槽迁移和均衡等常见操做,使用以前须要安装Ruby依赖环境。

①安装Ruby

    ~]# wget http://cache.ruby-lang.org/pub/ruby/2.3/ruby-2.3.5.tar.gz

    ~]# tar zxvf  ruby-2.3.5.tar.gz

    ~]# cd ruby-2.3.5

    ruby-2.3.5]# ./configure  --prefix=/opt/ruby

    ruby-2.3.5]# make && make install

    ruby-2.3.5]# ln -s /opt/ruby/bin/ruby /usr/bin/ruby

    ruby-2.3.5]# ln -s /opt/ruby/bin/gem /usr/bin/gem

    ~]#ruby -v    //查看一下

    

   ②安装rubygem redis依赖

    ~]# wget http://rubygems.org/downloads/redis-3.3.0.gem

                     yum install rubygems

    ~]# gem install -l redis-3.3.0.gem

    

 ③检查redis-trib.rb的可用性

    ~]# ./redis-4.0.1/src/redis-trib.rb    //以下图所示表明可用了

    

4,建立集群:
redis-trib.rb create  --replicas 1 192.168.56.99:9001 192.168.56.99:9002 192.168.56.99:9003 192.168.56.99:9004 192.168.56.99:9005 192.168.56.99:9006

发现报错,是由于redis900X.conf配置文件中 bind 127.0.0.1

将此配置改成

bind 192.168.56.99

再启动集群,ok,显示以下:

Using 3 masters:
192.168.56.99:9001
192.168.56.99:9002
192.168.56.99:9003
Adding replica 192.168.56.99:9004 to 192.168.56.99:9001
Adding replica 192.168.56.99:9005 to 192.168.56.99:9002
Adding replica 192.168.56.99:9006 to 192.168.56.99:9003

M: 0a65ddf6b06c03e007597472795b5fc903bf0f19 192.168.56.99:9001    slots:0-5460 (5461 slots) master M: 9d5fd6c8c452a635158cc4bde36d490da98fe0cf 192.168.56.99:9002    slots:5461-10922 (5462 slots) master M: 2840c063aa41135cb30568e9f64e83a4ace49661 192.168.56.99:9003    slots:10923-16383 (5461 slots) master S: cc35b6238e2a535b4e4bc0e1de165c9f291c6d5c 192.168.56.99:9004    replicates 0a65ddf6b06c03e007597472795b5fc903bf0f19 S: b047ef4b392a5ef68a3ffd6cd265a1f7b82c8b6c 192.168.56.99:9005    replicates 9d5fd6c8c452a635158cc4bde36d490da98fe0cf S: 91000ed4e6794c026af50a6287e1c7def1e30b77 192.168.56.99:9006    replicates 2840c063aa41135cb30568e9f64e83a4ace49661  

相关文章
相关标签/搜索