linux运维、架构之路-redis集群
一、介绍
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集群的更多相关文章
- Linux运维--12.手动部署Rabbit集群
1.安装rabbit组件 10.100.2.51 controller1 10.100.2.52 controller2 10.100.2.53 controller3 #每个节点 yum insta ...
- linux运维架构师职业规划
1.假如你从来未接触过Linux的话,首先要做的就找一本指导书来学习.现在公认的Linux的入门书籍是“鸟哥的私房菜”,讲的很全面,鸟哥的私房菜一共分为两部,一部是基础篇,一部是服务器篇.“鸟哥的私房 ...
- 架构师之路-redis集群解析
引子 上篇<架构师之路-https底层原理>里我提到了上面的整体视图,文章也介绍了想要真正能在工作中及时正确解决问题的基本功:原理理解透彻.今天以redis集群解析为例介绍一个及时敏锐的发 ...
- 剑指架构师系列-Redis集群部署
初步搭建Redis集群 克隆已经安装Redis的虚拟机,我们使用这两个虚拟机中的Redis来搭建集群. master:192.168.2.129 端口:7001 slave:192.168.2.132 ...
- linux运维、架构之路-Kubernetes集群部署
一.kubernetes介绍 Kubernetes简称K8s,它是一个全新的基于容器技术的分布式架构领先方案.Kubernetes(k8s)是Google开源的容器集群管理系统(谷歌内部 ...
- linux运维、架构之路-Kubernetes集群部署TLS双向认证
一.kubernetes的认证授权 Kubernetes集群的所有操作基本上都是通过kube-apiserver这个组件进行的,它提供HTTP RESTful形式的API供集群内外客户端调 ...
- 【mongoDB运维篇④】Shard 分片集群
简述 为何要分片 减少单机请求数,降低单机负载,提高总负载 减少单机的存储空间,提高总存空间. 常见的mongodb sharding 服务器架构 要构建一个 MongoDB Sharding Clu ...
- Redis 集群环境的搭建
下载与解压 [root@localhost ~]# cd /usr/temp/ [root@localhost temp]# wget http://download.redis.io/release ...
- Nginx+Lua+Redis整合实现高性能API接口 - 网站服务器 - LinuxTone | 运维专家网论坛 - 最棒的Linux运维与开源架构技术交流社区! - Powered by Discuz!
Nginx+Lua+Redis整合实现高性能API接口 - 网站服务器 - LinuxTone | 运维专家网论坛 - 最棒的Linux运维与开源架构技术交流社区! - Powered by Disc ...
随机推荐
- H5如何测试?
它跟安卓APP与IOS APP有什么样的区别呢?★ 我们以往的APP是使用原生系统内核的,相当于直接在系统上操作,是我们传统意义上的软件,更加稳定 ★ H5的APP先得调用系统的浏览器内核,相当于是在 ...
- jmeter遍历时间戳
list如下 实现步骤 实现步骤其实很简单,只需要一个foreach控制器,和一段转换时间戳的代码 第一步把时间戳提取出来 第二步把提取的时间戳传入foreach控制器,然后在控制器下面遍历转换 im ...
- Java中的内存泄露 和 JVM GC(垃圾回收机制)
一.什么是Java中的内存泄露? 在Java中,内存泄漏就是存在一些被分配的对象,这些对象有下面两个特点, 首先,这些对象是可达的,即在有向图中,存在通路可以与其相连:其次,这些对象是无用的,即程序以 ...
- PSP周总结03
周日 周一 周二 周三 周四 周五 周六 所花时间 120 150 190 180 180 300 代码量 159 372 博客量 1 了解的知识点 阅读构建之法 软件工程概论 阅读构建之法 图书 ...
- CentOS安装部署sha##dow**socks
注意事项,pip版本不能太低,实测9.0.3可行(需要python 2.7,低版本python升级办法另有文章介绍). pip --version 以shadowsocks-2.8.2为例: pip ...
- 《深入浅出WPF》学习总结之控件与布局
一.控件到底是什么 控件的本质是“数据+算法”——用户输入原始数据,算法处理原始数据并得到结果数据.问题就在于程序如何将结果数据展示给用户.同样一组数据,你可以使用LED阵列显示出来,或者是以命令行模 ...
- switch条件变量的取值类型
switch条件变量的取值类型主要有以下六种: 1)JDK1.5(不含JDK1.5)之前只能是byte.short.int.char类型,不能是float.double.long.boolean类型. ...
- [Python3] 003 变量类型概述 & 数字类型详叙
目录 0. 变量类型概述 1. 数字类型详叙 1.1 整数 1.1.1 常用进制 1.1.2 少废话,上例子 1.2 浮点数 1.2.1 使用浮点数时可以"偷懒" 1.2.2 科学 ...
- MySql-Mysql技术内幕~SQL编程学习笔记(N)
1._rowid 类似Oracle的rowid mysql> ; +-------+----+----------------+-------------+---------------+--- ...
- 这款多线程中间件,吊打 Redis!
Java技术栈 www.javastack.cn 优秀的Java技术公众号 今天给大家介绍的是KeyDB,KeyDB项目是从redis fork出来的分支.众所周知redis是一个单线程的kv内存存储 ...