用到的安装包

https://pan.baidu.com/s/1wwLm3C7oWcM9ptwMjRltGA

提取码:vdfp

系统环境:centos7

---------------------------------------------------------------------------------------------------------------------------------------------------

1.虚拟机配置网络

vi /etc/sysconfig/network-scripts/ifcfg-ens33
修改
BOOTPROTO=static
ONBOOT=yes
增加
IPADDR=192.168.10.101
PREFIX=24
GATEWAY=192.168.10.2
DNS1=10.8.1.10

  重启服务

systemctl restart network.service

2.安装gcc,安装ruby需要

yum -y install gcc gcc-c++

3.安装redis

tar -zxf redis-4.0.1.tar.gz
cd /usr/local/src/redis-4.0.1

  安装两个redis,MALLOC=libc解决jemalloc 重载了Linux下的 ANSIC 的 malloc 和 free 函数问题

make PREFIX=/usr/local/bin/redis/redis1 install
make PREFIX=/usr/local/bin/redis/redis2 install

  安装目录的redis.conf拷到redis1下并修改redis.conf文件参数

cp redis.conf /usr/local/bin/redis/redis1
cd /usr/local/bin/redis/redis1
vi redis.conf
##########################################
bind 192.168.10.101    // 绑定机器的机器IP,不用127.0.0.1,否则创建集群可能失败
port 7001 // 修改成对应的端口号
daemonize yes // 后台运行
pidfile /var/run/redis_7001.pid // pid文件
logfile "./redis.log" // 日志
appendonly yes // 开启 aop 备份
appendfsync always // 每写一条 备份 一次
cluster-enabled yes // 开启 Redis Cluster
cluster-config-file nodes-7001.conf // 记录集群信息,不用手动维护,Redis Cluster 会自动维护
cluster-node-timeout 15000 // Cluster 超时时间 节点宕机发现时间,可以理解为主节点宕机后从节点升级为主节点时间
cluster-require-full-coverage no // 只要有结点宕机导致16384个槽没全被覆盖,整个集群就全部停止服务,所以一定要改为no
##########################################

  copy一份上边修改好的conf到redis2,然后快速修改配置文件的参数例

cp redis.conf /usr/local/bin/redis/redis2
sed -i 's/7001/8001/g' /usr/local/bin/redis/redis2/redis.conf

  如果拷到其他机器上配置除了修改端口也注意修改下conf的绑定ip,例

sed -i 's/192.168.10.101/192.168.10.102/g' /usr/local/redis/redis1/redis.conf

  redis目录下启动redis脚本

vi startup.sh

cd /usr/local/bin/redis/redis1/bin/
./redis-server ../redis.conf
cd
cd /usr/local/bin/redis/redis2/bin/
./redis-server ../redis.conf
cd

  关闭脚本

vi shutdown.sh
cd /usr/local/bin/redis/redis1/bin/
./redis-cli -h 192.168.10.101 -p 7001 shutdown
./redis-cli -h 192.168.10.101 -p 8001 shutdown
./redis-cli -h 192.168.10.102 -p 7002 shutdown
./redis-cli -h 192.168.10.102 -p 8002 shutdown
./redis-cli -h 192.168.10.103 -p 7003 shutdown
./redis-cli -h 192.168.10.103 -p 8003 shutdown

  删除备份脚本

vi remove.sh

cd /usr/local/bin/redis/redis1/bin/
rm appendonly.aof dump.rdb nodes-*.conf redis.log
cd /usr/local/bin/redis/redis2/bin/
rm appendonly.aof dump.rdb nodes-*.conf redis.log

  授权脚本执行权限

chmod +x startup.sh
chmod +x shutdown.sh
chmod +x remove.sh

  启动redis

sh startup.sh

  查看是否启动

ps aux|grep redis

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

///////////////////////////////////////////////////////////
// 以下用于redis集群的工具只在一台机器上安装就可以了 //
///////////////////////////////////////////////////////////

4.安装ruby

cd /usr/local/src
tar -zxf ruby-2.6.3.tar.gz
cd /usr/local/src/ruby-2.6.3
./configure --prefix=/usr/local/bin/ruby
make && make install

  解决-bash: ruby: command not found问题

ln -s /usr/local/bin/ruby/bin/ruby /usr/bin/ruby

5.安装zlib

tar -zxf zlib-1.2.11.tar.gz
cd /usr/local/src/zlib-1.2.11
./configure --prefix=/usr/local/bin/zlib
make && make install

  集成到ruby

cd /usr/local/src/ruby-2.6.3/ext/zlib
ruby ./extconf.rb --with-zlib-dir=/usr/local/bin/zlib
有的版本里边没有top_srcdir,make报错
vi Makefile
增加top_srcdir=../..
make && make install

6.安装perl,安装openssl需要

tar -zxf perl-5.10.0.tar.gz
cd /usr/local/src/perl-5.10.0
./configure.gnu --prefix=/usr/local/bin/perl
make && make install

7.安装openssl

tar -zxf openssl-1.1.0k.tar.gz
cd /usr/local/src/openssl-1.1.0k
./config --prefix=/usr/local/bin/openssl
make && make install

  设置openssl软链接,不然不能用openssl version

ln -s /usr/local/bin/openssl/lib/libssl.so.1.1 /usr/lib64/libssl.so.1.1
ln -s /usr/local/bin/openssl/lib/libcrypto.so.1.1 /usr/lib64/libcrypto.so.1.1

  集成到ruby

cd /usr/local/src/ruby-2.6.3/ext/openssl
ruby ./extconf.rb --with-openssl-dir=/usr/local/bin/openssl
vi Makefile
增加top_srcdir=../..
make && make install

8.安装rubygems

tar -zxf rubygems-3.0.6.tgz
cd /usr/local/src/rubygems-3.0.6
ruby setup.rb --prefix=/usr/local/bin/rubygems

  配置rubygems环境变量

vi /etc/profile
export RUBYGEMS_PATH=/usr/local/bin/rubygems
export PATH=$RUBYGEMS_PATH/bin:$PATH
source /etc/profile

9.创建集群

gem install redis-4.0.1.gem
gem list --local
cd /usr/local/src/redis-4.0.1/src
./redis-trib.rb create --replicas 1 192.168.10.101:7001 192.168.10.101:8001 192.168.10.102:7002 192.168.10.102:8002 192.168.10.103:7003 192.168.10.103:8003

如果执行不通,可以telnet试试,可能防火墙有拦截,需要开通端口号或者关闭防火墙。
开通端口【后边的17xxx和18xxx端口是在配置的redis端口+10000得到的,是集群总线端口,具体信息请查文档】
101机器 7001 8001 17001 18001
102机器 7002 8002 17002 18002
103机器 7003 8003 17003 18003

  首先安装iptables服务

关闭防火墙
systemctl stop firewalld.service
禁止开机启动
systemctl disable firewalld.service
安装iptables服务
yum install iptables-services

  添加完服务后添加规则

101机器

iptables -N REDIS
iptables -A REDIS -s 192.168.10.101 -j ACCEPT
iptables -A REDIS -s 192.168.10.102 -j ACCEPT
iptables -A REDIS -s 192.168.10.103 -j ACCEPT
iptables -A REDIS -j LOG --log-prefix "unauth-redis-access"
iptables -A REDIS -j REJECT --reject-with icmp-port-unreachable
iptables -I INPUT -p tcp --dport 7001 -j REDIS
iptables -I INPUT -p tcp --dport 8001 -j REDIS
iptables -I INPUT -p tcp --dport 17001 -j REDIS
iptables -I INPUT -p tcp --dport 18001 -j REDIS
iptables -I OUTPUT -p tcp --sport 7001 -j REDIS
iptables -I OUTPUT -p tcp --sport 8001 -j REDIS
iptables -I OUTPUT -p tcp --sport 17001 -j REDIS
iptables -I OUTPUT -p tcp --sport 18001 -j REDIS

102机器

iptables -N REDIS
iptables -A REDIS -s 192.168.10.101 -j ACCEPT
iptables -A REDIS -s 192.168.10.102 -j ACCEPT
iptables -A REDIS -s 192.168.10.103 -j ACCEPT
iptables -A REDIS -j LOG --log-prefix "unauth-redis-access"
iptables -A REDIS -j REJECT --reject-with icmp-port-unreachable
iptables -I INPUT -p tcp --dport 7002 -j REDIS
iptables -I INPUT -p tcp --dport 8002 -j REDIS
iptables -I INPUT -p tcp --dport 17002 -j REDIS
iptables -I INPUT -p tcp --dport 18002 -j REDIS
iptables -I OUTPUT -p tcp --sport 7002 -j REDIS
iptables -I OUTPUT -p tcp --sport 8002 -j REDIS
iptables -I OUTPUT -p tcp --sport 17002 -j REDIS
iptables -I OUTPUT -p tcp --sport 18002 -j REDIS

103机器

iptables -N REDIS
iptables -A REDIS -s 192.168.10.101 -j ACCEPT
iptables -A REDIS -s 192.168.10.102 -j ACCEPT
iptables -A REDIS -s 192.168.10.103 -j ACCEPT
iptables -A REDIS -j LOG --log-prefix "unauth-redis-access"
iptables -A REDIS -j REJECT --reject-with icmp-port-unreachable
iptables -I INPUT -p tcp --dport 7003 -j REDIS
iptables -I INPUT -p tcp --dport 8003 -j REDIS
iptables -I INPUT -p tcp --dport 17003 -j REDIS
iptables -I INPUT -p tcp --dport 18003 -j REDIS
iptables -I OUTPUT -p tcp --sport 7003 -j REDIS
iptables -I OUTPUT -p tcp --sport 8003 -j REDIS
iptables -I OUTPUT -p tcp --sport 17003 -j REDIS
iptables -I OUTPUT -p tcp --sport 18003 -j REDIS

  保存放行规则防止重启失效,每台虚机添加规则后即执行

保存放行规则防止重启失效,/etc/sysconfig/iptables
service iptables save
重启防火墙使配置生效
systemctl restart iptables.service
设置防火墙开机启动
systemctl enable iptables.service
关闭防火墙
systemctl stop iptables.service
打开防火墙
systemctl start iptables.service

10.虚机之间设置ssh免密访问

  修改机器名,分别操作

vi /etc/sysconfig/network
增加
NETWORKING=yes
HOSTNAME=server101

  修改hosts

vi /etc/hosts
增加
192.168.10.101 server101
192.168.10.102 server102
192.168.10.103 server103

  几台机器分别生成密钥对

ssh-keygen -t rsa
cd /root/.ssh下查看
生成了
~/.ssh/id_rsa.pub
~/.ssh/id_rsa

  把公钥发送给对方

scp /root/.ssh/id_rsa.pub root@server102:/root/.ssh/pub101

  然后对方机器上操作,将公钥内容加入到授权列表

cat pub101 >>authorized_keys

  授权

chmod 700 .ssh
chmod 600 .ssh/authorized_keys

 11.启动所有redis脚本,需要机器之间建立ssh免密登录设置

vi startall.sh
==============================================
#!/bin/sh
SHELLL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/ ssh root@server101 "bash" </usr/local/bin/redis/startup.sh
ssh root@server102 "bash" </usr/local/bin/redis/startup.sh
ssh root@server103 "bash" </usr/local/bin/redis/startup.sh

  删除所有备份,就把startall.sh中的最后startup.sh换成remove.sh即可

vi removeall.sh
==============================================
#!/bin/sh
SHELLL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/ ssh root@server101 "bash" </usr/local/bin/redis/remove.sh
ssh root@server102 "bash" </usr/local/bin/redis/remove.sh
ssh root@server103 "bash" </usr/local/bin/redis/remove.sh

  

多台虚机redis cluster集群的更多相关文章

  1. redis cluster(集群)模式的创建方式

    redis常用的架构有三种,单例.哨兵.集群,其他的都说过了,这里只简单介绍集群搭建. 单例最简单没什么好说的. 哨兵之前说过,该模式下有哨兵节点监视master和slave,若master宕机可自动 ...

  2. Redis Cluster集群架构实现(四)--技术流ken

    Redis集群简介 通过前面三篇博客的介绍<Redis基础认识及常用命令使用(一)--技术流ken>,<Redis基础知识补充及持久化.备份介绍(二)--技术流ken>,< ...

  3. centos6下redis cluster集群部署过程

    一般来说,redis主从和mysql主从目的差不多,但redis主从配置很简单,主要在从节点配置文件指定主节点ip和端口,比如:slaveof 192.168.10.10 6379,然后启动主从,主从 ...

  4. Redis cluster集群:原理及搭建

    Redis cluster集群:原理及搭建 2018年03月19日 16:00:55 阅读数:6120 1.为什么使用redis? redis是一种典型的no-sql 即非关系数据库 像python的 ...

  5. redis cluster集群部署

    上一篇http://www.cnblogs.com/qinyujie/p/9029153.html,主要讲解了 redis cluster 集群架构 的优势.redis cluster 和 redis ...

  6. Redis Cluster 集群的实现和管理

    系统环境 CentOS 7 集群规划 在一台物理机(实际部署应当分散到多个物理机上),创建6个Redis节点,其中3个主节点.3个从节点. 节点表: IP 端口 主从 路径 192.168.1.21 ...

  7. Ubuntu 16.04下Redis Cluster集群搭建(官方原始方案)

    前提:先安装好Redis,参考:http://www.cnblogs.com/EasonJim/p/7599941.html 说明:Redis Cluster集群模式可以做到动态增加节点和下线节点,使 ...

  8. 借 redis cluster 集群,聊一聊集群中数据分布算法

    Redis Cluster 集群中涉及到了数据分布问题,因为 redis cluster 是多 master 的结构,每个 master 都是可以提供存储服务的,这就会涉及到数据分布的问题,在新的 r ...

  9. redis cluster集群的原理

    redis集群的概述: 在以前,如果前几年的时候,一般来说,redis如果要搞几个节点,每个节点存储一部分的数据,得借助一些中间件来实现,比如说有codis,或者twemproxy,都有.有一些red ...

随机推荐

  1. Jenkins 进阶篇 - 权限配置

    Jenkins的授权策略 Jenkins 默认的授权策略是[登录用户可以做任何事],也就是人人都是管理员,可以修改所有的设置以及构建所有的任务,不用做任何设置,有账号登录到 Jenkins 系统即可, ...

  2. hadoop操作hdfs错误

    本文转自:http://www.aboutyun.com/blog-61-22.html 当我们对hdfs操作的时候,我们可能会碰到如下错误 错误1:权限问题 Exception in thread ...

  3. centos7 之 设置环境变量(转载)

    设置centos环境变量,可以用export命令,也可以通过修改文件形式实现,本文以lavavel需要设置环境变量为例,将 /root/.config/composer/vendor/bin 路径加到 ...

  4. 160crackme002

    一.查壳 结果:vb写的,并且无壳 二.运行程序 发现了这个程度调用了vb调用窗口的api.这时有两种方式: 1.再重新调试,运行到有窗口的时候,F12暂停,按ctrl+K,查看dll调用,再数据窗口 ...

  5. 关于vector.size()的一些常见错误总结

    1. 问题引入 通过查看[https://www.cplusplus.com/reference/vector/vector/] 的vector.size()说明,即 member type defi ...

  6. WPF技巧:通过代码片段管理器编写自己常用的代码模板提示效率

    在写自定义控件的时候,有一部分功能是当内部的值发生变化时,需要通知控件的使用者,而当我在写依赖项属性的时候,我可以通过popdp对应的代码模板来完成对应的代码,但是当我来写属性更改回调的时候,却发现没 ...

  7. Linux | 文件编辑命令

    cat cat 命令是是一次性显示文件的所有内容 cat 是 concatenate 的缩写,表示:连接/串联 cat 文件名 可以看到,cat 命令是一次性显示出所有的文件内容,这就导致了,有的文件 ...

  8. P4480 「BJWC2018」「网络流与线性规划24题」餐巾计划问题

    刷了n次用了奇淫技巧才拿到rk1,亥 这道题是网络流二十四题中「餐巾计划问题」的加强版. 于是怀着试一试的心情用费用流交了一发: 哇塞,过了9个点!(强烈谴责出题人用*造数据 下面是费用流解法简述: ...

  9. 知识全聚集 .Net Core 技术突破 丨ABP vNext 开始

    介绍 很久没有更新博客了,之前想更新但是发现博客园崩了,外加工作上的调换也比较忙,最近有了点时间我来继续更新下这个系列的文章. 今年3月份我带着我们研发组同事,将公司产品从老Abp重构到Abp vNe ...

  10. C语言:fopen

    fopen,传递文件名参数,w+选项读取用fread或fgets,其中fread是按字节读取,fgets每次读取一个字符串写入用fwrite或fputs或fprintf,fwrite按字节写入,fpu ...