俩台服务器搭建redis集群

1、俩服务器分别新建目录:usr/local/redis-cluster

2、下载源码并解压编译(使用redis版本5.0.4)

3、tar xzf redis-5.0.4.tar.gz

4、cd redis-5.0.4

5、make & make install

测试编译:发现报错

6、cd src

make test

CC Makefile.dep

You need tcl 8.5 or newer in order to run the Redis test

make: *** [test] Error 1

问题原因:缺少依赖,进行安装

7、yum install tcl

8、再次测试编译ok

make test

\o/ All tests passed without errors!

Cleanup: may take some time... OK

9、至此,可以启动redis了,默认启动模式为前端启动,指令如下

cd usr/local/bin

./redis-server

10、验证启动是否成功

ps -ef | grep redis

11、报错

a、运行redis-server报错bash: redis-server: command not found

这是因为在系统的usr/local/bin目录下没有命令文件,这就要将usr/local/redis-cluster/redis/ redis-5.0.4/bin下redis-server、redis-cli、redis-benchmark、redis-check-aof、redis-check-rdb、redis-sentinel这些可执行文件复制到local/bin下

c、所以修改redis.conf里的daemonize改为yes

12、前端启动的话,如果客户端关闭,redis服务也会停掉,只能新开一个窗口或者改成后台启动redis。

具体做法分为两步 ->

第一步:将redis解压文件里面的redis.conf文件复制到当前目录,修改redis.conf里的daemonize改为yes

第二步:启动

13、创建集群目录

俩台服务器在redis-cluster下分别创建7001,7002,7003 // 7004,7005,7006目录

mkdir 7001 7002 7003

mkdir 7004 7005 7006

14、首先对redis.conf下的参数进行修改

(1)、daemonize 设置yes   设置后台运行redis

(2)、cluster-enabled 设置yes并去掉注释  (启动集群模式)

(3)、cluster-node-timeout 设置5000并去掉注释

(4)、bind 127.0.0.1(默认ip为127.0.0.1 需要改为其他节点机器可访问的ip 否则创建集群时无法访问对应的端口,无法创建集群 )

(5)、protected-mode设置 no(关闭保护模式)需要不同服务器的节点连通,这个就要设置为 no

(6)、appendonly 设置yes   aof日志开启 有需要就开启,它会每次写操作都记录一条日志 

15、复制redis.conf

分别复制redis.conf文件到7001-7006目录下

根据不同端口需要个性化设置的地方(可以批量替换)

(1)、port 7001(分别对每个机器的端口号进行设置)

(2)、设置pidfile存放在 run目录下的文件名  pidfile  /var/run/redis_7001.pid

(3)、logfile /var/log/redis/redis_7001.log

(4)、dbfilename dump_7001.rdb

(5)、appendfilename "appendonly_7001.aof"

(6)、cluster-config-file nodes-7001.conf(集群节点信息文件) 去掉注释

16、创建集群

(1)、先对每台服务器的端口进行开放

输入命令行: uname

会出现系统的名称

再输入

cat /etc/redhat-release

则会出现具体系统

vim /etc/sysconfig/iptables

“I”键输入命令行:

-A INPUT -m state --state NEW -m tcp -p tcp --dport 7001 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp --dport 7002 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp --dport 7003 -j ACCEPT

....

注意BUG点:新开放的端口行一定要在端口行22的下面一行

(2)、关闭防火墙

重启防火墙使配置生效:

[root@Neo777 ~]# /etc/init.d/iptables restart

查看开放端口

[root@Neo777 ~]# /etc/init.d/iptables status

关闭防火墙命令为:

[root@Neo777 ~]# /etc/init.d/iptables stop

(3)、创建集群

./redis-cli --cluster create 172.25.44.10:7001 172.25.44.10:7002 172.25.44.10:7003 172.25.44.11:7004 172.25.44.11:7005 172.25.44.11:7006 --cluster-replicas 1

留意屏幕,会有一句(type 'yes' to accept),输入 yes ,回车,就是接受自动分配的三主三从

如果最后出现

[OK] All nodes agree about slots configuration.

>>> Check for open slots...

>>> Check slots coverage...

[OK] All 16384 slots covered.

说明成功了。

如果是出现

Waiting for the cluster to join...........

一直有 “.”出现,说明另一台服务器的端口策略没通,一直在等那边的节点加入集群,那么恭喜你,要悲剧了.....

俩台服务器搭建redis集群5.0.4的更多相关文章

  1. 基于 twemproxy 搭建 redis 集群

    概述 由于单台redis服务器的内存管理能力有限,使用过大内存redis服务器的性能急剧下降,且服务器发生故障将直接影响大面积业务.为了获取更好的缓存性能及扩展型,我们将需要搭建redis集群来满足需 ...

  2. Windows下 搭建redis集群

    Windows下搭建redis集群教程 一,redis集群介绍 Redis cluster(redis集群)是在版本3.0后才支持的架构,和其他集群一样,都是为了解决单台服务器不够用的情况,也防止了主 ...

  3. Windows 环境搭建Redis集群

    环境以及引用资料 1.windows server 2008 r2 enterprise  (木有办法,公司的服务器全是如此,就这种环境搭建吧) 2.redis官方资料下载: https://redi ...

  4. 这次一定要教会你搭建Redis集群和MySQL主从同步(非Docker)

    前言 一直都想自己动手搭建一个Redis集群和MySQL的主从同步,当然不是依靠Docker的一键部署(虽然现在企业开发用的最多的是这种方式),所以本文就算是一个教程类文章吧,但在动手搭建之前,会先聊 ...

  5. docker搭建redis集群

    一.简介 docker作为一个容器技术,在搭建资源隔离性服务上具有很大的优势,在一台服务器上可以启动多个docker容器,感觉每个在容器里面部署的服务就像是部署在不同的服务器上.此次基于docker以 ...

  6. Windows下搭建Redis集群

    Redis集群: 如果部署到多台电脑,就跟普通的集群一样:因为Redis是单线程处理的,多核CPU也只能使用一个核, 所以部署在同一台电脑上,通过运行多个Redis实例组成集群,然后能提高CPU的利用 ...

  7. Redis集群搭建(转自一菲聪天的“Windows下搭建Redis集群”)

    配置Redis参考:http://blog.csdn.net/zsg88/article/details/73715947 使用Ruby配置集群参考:https://www.cnblogs.com/t ...

  8. centos6搭建redis集群搭建(单机多节点)

    一.安装redis 1.安装gcc环境 yum install gcc-c++ 2.下载源码包并解压 wget http://download.redis.io/releases/redis-3.2. ...

  9. 手动搭建 redis 集群

    转自http://meia.fun/article/1544161420745 手动搭建 redis 集群 redis 基本命令: 启动 redis 服务:redis-server xxx.conf ...

随机推荐

  1. 基于mipsel编译Qt4.6.2版本(有具体参数和编译时遇到的问题)

    1.使用的configure配置为:./configure -embedded mips -little-endian -xplatform qws/linux-mips-g++ -prefix /o ...

  2. 跨越DLL边界传递CRT对象潜在的错误

    跨越DLL边界传递CRT对象潜在的错误 翻译:magictong(童磊)2013年5月 版权:microsoft 原文地址:http://msdn.microsoft.com/en-us/librar ...

  3. DirectUI的消息流转

    Windows是一个基于消息循环的系统,DirectUI同样遵循这样的消息流转.当界面呈现.用户点击.定时器等各种各样的消息一旦进入windows消息循环队列,系统自动调用该窗口的WndProc过程. ...

  4. 请你讲一讲JavaScript有哪些数据类型, 数据类型判断有哪些方法?

    js的8种数据类型 JavaScript中有8种数据类型, 包括基本数据类型(number, string, boolean, null, undefined, symbol, bigint)和引用数 ...

  5. screen命令使用简单说明

    首先用screen [-S]命令建立一个session,然后就可以在这个session中建立多个window了.使用screen [-S]可以建立多个session,而每个session又可以建立多个 ...

  6. 程序员修仙之路--优雅快速的统计千万级别uv(留言送书)

    菜菜,咱们网站现在有多少PV和UV了? Y总,咱们没有统计pv和uv的系统,预估大约有一千万uv吧 写一个统计uv和pv的系统吧 网上有现成的,直接接入一个不行吗? 别人的不太放心,毕竟自己写的,自己 ...

  7. [UWP]从头开始创建并发布一个番茄钟

    1. 自己用的番茄钟自己做 在PC上我一直使用"小番茄"作为我的番茄钟软件,我把它打开后放在副显示器最大化,这样不仅可以让它尽到本分,而且还可以告诉我的同事"我正在专心工 ...

  8. 阿里云ECS发送企业邮件

    <?phpuse PHPMailer\PHPMailer\PHPMailer;require '../vendor/autoload.php'; $mail = new PHPMailer(tr ...

  9. jQuery-ajax-.load方法

    使用jQuery封装的ajax是非常好用的,这个里面提供了几个比较好用的方法. load(url[,data, callback])方法: 说明:这个是jQuery中的最底层方法$.ajax()封装的 ...

  10. http协议之状态码

    =================状态码,状态文字======================== 状态码:用来反应服务器的响应状态 状态文字:是用来说明状态码的. 状态码:可以分为这5个大的部分 - ...