一、介绍

           redis cluster 3.0之后的功能,至少需要3(Master)+3(Slave)才能建立集群,是无中心的分布式存储架构,可以在多个节点之间进行数据共享,解决了Redis高可用、可扩展等问题。

二、安装部署

1、环境

[root@redsi ~]# cat /etc/redhat-release
CentOS release 6.9 (Final)
[root@redsi ~]# uname -r
2.6.-.el6.x86_64
[root@redsi ~]# /etc/init.d/iptables status
iptables: Firewall is not running.
[root@redsi ~]# getenforce
Disabled
[root@redsi ~]# hostname -I
10.0.0.2

2、redis cluster是基于上一篇博文已经安装好的redis

①创建集群节点目录

mkdir /usr/local/redis-cluster/{..}/data -p
[root@redsi redis-cluster]# ll /usr/local/redis-cluster/
total
drwxr-xr-x root root -- :
drwxr-xr-x root root -- :
drwxr-xr-x root root -- :
drwxr-xr-x root root -- :
drwxr-xr-x root root -- :
drwxr-xr-x root root -- :
drwxr-xr-x root root -- : bin

②创建命令目录

mkdir /usr/local/redis-cluster/bin -p
cd /server/tools/redis-3.2./src
cp mkreleasehdr.sh redis-benchmark redis-check-aof redis-check-dump redis-cli redis-server redis-trib.rb /usr/local/redis-cluster/bin

③创建一个redis实例

cp -a /usr/local/redis/* /usr/local/redis-cluster/9001/

修改redis.conf配置文件

port                                 #每个节点的端口号
daemonize yes
bind 10.0.0.2 #绑定当前机器 IP
dir /usr/local/redis-cluster//data/ #数据文件存放位置
pidfile /var/run/redis_9001.pid #pid 9001和port要对应
cluster-enabled yes #启动集群模式
cluster-config-file nodes9001.conf #9001和port要对应
cluster-node-timeout
appendonly yes

④再创建其它5个redis实例

cp -a /usr/local/redis-cluster//* /usr/local/redis-cluster/9002
cp -a /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9003
cp -a /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9004
cp -a /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9005
cp -a /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9006

再依次修改redis.conf配置文件

port                                 #修改以下4处,依次改为9002、9003、9004、9005、9006
dir /usr/local/redis-cluster//data/
pidfile /var/run/redis_9001.pid
cluster-config-file nodes9001.conf

###到此为止基础环境已准备好###

三、安装完ruby环境

###直接执行gem install redis时,报错###

gem install redis
ERROR: Error installing redis:
redis requires Ruby version >= 2.2..

①安装安装RVM

gpg2 --keyserver hkp://keys.gnupg.net --recv-keys D39DC0E3
curl -L get.rvm.io | bash -s stable
find / -name rvm -print

②查看rvm库中已知的ruby版本

rvm list known 

③安装一个ruby版本

rvm install 2.3. 

④使用一个ruby版本

rvm use 2.3.  

⑤设置默认版本

rvm use 2.3. --default 

⑥卸载一个已知版本

rvm remove 2.0.

⑦安装redis

gem install redis 

⑧查看ruby版本

ruby --version 

四、集群搭建

1、启动六个节点的redis

redis-server /usr/local/redis-cluster//redis.conf
redis-server /usr/local/redis-cluster//redis.conf
redis-server /usr/local/redis-cluster//redis.conf
redis-server /usr/local/redis-cluster//redis.conf
redis-server /usr/local/redis-cluster//redis.conf
redis-server /usr/local/redis-cluster//redis.conf
###查看进程###
[root@redsi ~]# ps aux|grep redis
root 0.1 0.9 ? Ssl : : redis-server 10.0.0.2: [cluster]
root 0.1 0.9 ? Ssl : : redis-server 10.0.0.2: [cluster]
root 0.1 0.9 ? Ssl : : redis-server 10.0.0.2: [cluster]
root 0.1 0.7 ? Ssl : : redis-server 10.0.0.2: [cluster]
root 0.1 0.9 ? Ssl : : redis-server 10.0.0.2: [cluster]
root 0.1 0.9 ? Ssl : : redis-server 10.0.0.2: [cluster]

2、创建集群

/usr/local/redis-cluster/bin/redis-trib.rb create --replicas  10.0.0.2: 10.0.0.2: 10.0.0.2: 10.0.0.2: 10.0.0.2: 10.0.0.2:

###命令说明###

调用ruby命令来进行创建集群,--replicas  表示主从复制比例为 :,即一个主节点对应一个从节点;然后,默认给我们分配好了每个主节点和对应从节点服务,以及solt的大小,因为在Redis 集群中有且仅有  个 solt ,默认情况会给我们平均分配,当然你可以指定,后续的增减节点也可以重新分配。

###输入yes后开始创建集群###

###如上图所示,集群创建成功###

3、集群验证

①使用客户端命令连接集群节点

[root@redsi ~]# redis-cli -h 10.0.0.2 -c -p
10.0.0.2:> set name lulu
-> Redirected to slot [] located at 10.0.0.2:9002 #自动连接到了9002节点,这是集群的一个数据分配特性
OK
10.0.0.2:> get name
"lulu"

②连接其它节点验证

[root@redsi ~]# redis-cli -h 10.0.0.2 -c -p
10.0.0.2:> get name
-> Redirected to slot [] located at 10.0.0.2:
"lulu"

###至此,redis集群搭建完毕###

linux运维、架构之路-redis集群的更多相关文章

  1. Linux运维--12.手动部署Rabbit集群

    1.安装rabbit组件 10.100.2.51 controller1 10.100.2.52 controller2 10.100.2.53 controller3 #每个节点 yum insta ...

  2. linux运维架构师职业规划

    1.假如你从来未接触过Linux的话,首先要做的就找一本指导书来学习.现在公认的Linux的入门书籍是“鸟哥的私房菜”,讲的很全面,鸟哥的私房菜一共分为两部,一部是基础篇,一部是服务器篇.“鸟哥的私房 ...

  3. 架构师之路-redis集群解析

    引子 上篇<架构师之路-https底层原理>里我提到了上面的整体视图,文章也介绍了想要真正能在工作中及时正确解决问题的基本功:原理理解透彻.今天以redis集群解析为例介绍一个及时敏锐的发 ...

  4. 剑指架构师系列-Redis集群部署

    初步搭建Redis集群 克隆已经安装Redis的虚拟机,我们使用这两个虚拟机中的Redis来搭建集群. master:192.168.2.129 端口:7001 slave:192.168.2.132 ...

  5. linux运维、架构之路-Kubernetes集群部署

    一.kubernetes介绍        Kubernetes简称K8s,它是一个全新的基于容器技术的分布式架构领先方案.Kubernetes(k8s)是Google开源的容器集群管理系统(谷歌内部 ...

  6. linux运维、架构之路-Kubernetes集群部署TLS双向认证

    一.kubernetes的认证授权       Kubernetes集群的所有操作基本上都是通过kube-apiserver这个组件进行的,它提供HTTP RESTful形式的API供集群内外客户端调 ...

  7. 【mongoDB运维篇④】Shard 分片集群

    简述 为何要分片 减少单机请求数,降低单机负载,提高总负载 减少单机的存储空间,提高总存空间. 常见的mongodb sharding 服务器架构 要构建一个 MongoDB Sharding Clu ...

  8. Redis 集群环境的搭建

    下载与解压 [root@localhost ~]# cd /usr/temp/ [root@localhost temp]# wget http://download.redis.io/release ...

  9. Nginx+Lua+Redis整合实现高性能API接口 - 网站服务器 - LinuxTone | 运维专家网论坛 - 最棒的Linux运维与开源架构技术交流社区! - Powered by Discuz!

    Nginx+Lua+Redis整合实现高性能API接口 - 网站服务器 - LinuxTone | 运维专家网论坛 - 最棒的Linux运维与开源架构技术交流社区! - Powered by Disc ...

随机推荐

  1. Scratch少儿编程系列:(二)界面介绍及相关概念

    本系列后续所有Scratch的讲解均基于2.0版本介绍.系统启动后,界面如下: Scratch主要包括6个区域: 1. 菜单:新建.打开.保存 Scratch文件,2.0版本文件后缀名为 .sb2 2 ...

  2. YARN日志聚合相关参数配置

    日志聚合是YARN提供的日志中央化管理功能,它能将运行完成的Container/任务日志上传到HDFS上,从而减轻NodeManager负载,且提供一个中央化存储和分析机制.默认情况下,Contain ...

  3. 25. Reverse Nodes in k-Group[H]k个一组翻转链表

    题目 Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. ...

  4. C#银行卡号每隔4位数字加一个空格

    1.填写银行卡号每隔4位数字加一个空格 Regex.Replace(dic["BankCardNo"].ToString(), @"(\d{4}(?!$))", ...

  5. Python_ONLINE_习题集_1 递归

    1.1 使用递归实现:计算某个数的阶乘 def func(x): if x == 2: return 2 else: return x*func(x-1) a = func(4) print(a) 2 ...

  6. Tensorflow模型保存与加载

    在使用Tensorflow时,我们经常要将以训练好的模型保存到本地或者使用别人已训练好的模型,因此,作此笔记记录下来. TensorFlow通过tf.train.Saver类实现神经网络模型的保存和提 ...

  7. MySQL-快速入门(15)MySQL Replication,主从复制

    1.何为主从复制. 从一个MySQL主服务器(master)将数据复制到另一台或多台MySQL从服务器(slaves)的过程,将主数据库的DDL和DML操作通过二进制日志传到复制服务器上,然后在从服务 ...

  8. A+B and A*B problem 大数相加 相乘 模拟

    A+B and A*B problem 大数相加 相乘 模拟 题意 给你两个数a和b,这两个数很大,然后输出这两个数相加的和,相乘的积. 解题思路 模拟,但是还是搜了搜代码实现,发现这个大佬写的是真的 ...

  9. 查看linux中所有用户的三种方式

    通过使用/etc/passwd 文件,getent命令,compgen命令这三种方法查看系统中用户的信息. Linux 系统中用户信息存放在/etc/passwd文件中. 这是一个包含每个用户基本信息 ...

  10. python中输入某年某月某日,判断这一天是这一年的第几天?

    输入某年某月某日,判断这一天是这一年的第几天?程序分析 特殊情况,闰年时需考虑二月多加一天: 直接上代码 #定义一个函数,判断是否为闰年 def leapyear(y): return (y % 40 ...