Redis 集群配置
Redis 集群介绍:
(1) 为什么要使用集群:如果数据量很大,单台机器会存在存储空间不够用 、查询速度慢 、负载高等问题,部署集群就是为了解决这些问题
(2) Redis 集群架构如下,采用无中心结构,每个节点保存数据和整个集群状态,每个节点都和其他所有节点连接,我们可以在线增加/删除节点
(3) 所有的节点彼此互联,内部使用二进制协议优化传输速度和带宽,客户端连接集群中任何一个可用节点即可
(4) 为了增加冗余性,所有节点(一台机器被称为一个节点)都可以部署一主一从,也可以是多个从,从库不提供服务,只作为备用
集群环境:
A机器(192.168.216.135)上开三个 Redis 服务,端口分别为 7000,7002,7004
B机器(192.168.216.136)上开三个 Redis 服务,端口分别为 7001,7003,7005
当我们创建集群的时候,会自动选择其中三个 Redis 服务作为主库,其他三个作为从库
注意:这里我们实验的时候在一台机器上模拟三个节点,在实际中应该一台机器一个节点
前提准备:
① 两台机器都关闭防火墙和SELinux,方便实验
② 需要在集群中的一台机器上安装 Ruby 2.2 版本及以上,Redis 集群需 Ruby 支持
- [root@localhost ~]# iptables -F
- [root@localhost ~]# setenforce
- yum -y groupinstall "Development Tools"
- yum -y install gdbm-devel libdb4-devel libffi-devel libyaml libyaml-devel ncurses-devel openssl-devel readline-devel tcl-deve
- cd /root/
- mkdir -p rpmbuild/{BUILD,BUILDROOT,RPMS,SOURCES,SPECS,SRPMS}
- wget http://cache.ruby-lang.org/pub/ruby/2.2/ruby-2.2.3.tar.gz -P rpmbuild/SOURCES
- wget https://raw.githubusercontent.com/tjinjin/automate-ruby-rpm/master/ruby22x.spec -P rpmbuild/SPECS
- rpmbuild -bb rpmbuild/SPECS/ruby22x.spec
- yum -y localinstall rpmbuild/RPMS/x86_64/ruby-2.2.-.el7.centos.x86_64.rpm
- gem install redis
cp /usr/local/src/redis-4.0.1/src/redis-trib.rb /usr/bin/
A机器(192.168.216.135)配置:
- [root@localhost ~]# cat /etc/redis_7000.conf
- port
- bind 192.168.216.135 <--- 这里设置为本机IP地址
- daemonize yes
- pidfile /var/run/redis_7000.pid
- dir /data/redis_data/
- cluster-enabled yes
- cluster-config-file nodes_7000.conf
- cluster-node-timeout
- appendonly yes
- [root@localhost ~]# cp /etc/redis_7000.conf /etc/redis_7002.conf && sed -i 's/7000/7002/g' /etc/redis_7002.conf
- [root@localhost ~]# cp /etc/redis_7000.conf /etc/redis_7004.conf && sed -i 's/7000/7004/g' /etc/redis_7004.conf
- [root@localhost ~]# mkdir -p /data/redis_data/{,,} //创建数据存放目录
- [root@localhost ~]# redis-server /etc/redis_7000.conf //启动三个Redis服务
- [root@localhost ~]# redis-server /etc/redis_7002.conf
- [root@localhost ~]# redis-server /etc/redis_7004.conf
B机器(192.168.216.136)配置:
- [root@localhost ~]# cat /etc/redis_7001.conf
- port
- bind 192.168.216.136 <--- 这里设置为本机IP地址
- daemonize yes
- pidfile /var/run/redis_7001.pid
- dir /data/redis_data/
- cluster-enabled yes
- cluster-config-file nodes_7001.conf
- cluster-node-timeout
- appendonly yes
- [root@localhost ~]# cp /etc/redis_7001.conf /etc/redis_7003.conf && sed -i 's/7001/7003/g' /etc/redis_7003.conf
- [root@localhost ~]# cp /etc/redis_7001.conf /etc/redis_7005.conf && sed -i 's/7001/7005/g' /etc/redis_7005.conf
- [root@localhost ~]# mkdir -p /data/redis_data/{,,} //创建数据存放目录
- [root@localhost ~]# redis-server /etc/redis_7001.conf //启动三个Redis服务
- [root@localhost ~]# redis-server /etc/redis_7003.conf
- [root@localhost ~]# redis-server /etc/redis_7005.conf
创建集群:
- [root@localhost ~]# redis-trib.rb create --replicas 192.168.216.135: 192.168.216.135: 192.168.216.135: \
192.168.216.136: 192.168.216.136: 192.168.216.136:7005 //需要在安装 Ruby 的那台机器上操作,会自动选择其中三个为主库- [root@localhost ~]# redis-trib.rb check 192.168.216.135: //查看集群状态,可以查看到哪些节点是主库,哪些节点是从库,以及集群是否运行正常
操作集群:
- [root@localhost ~]# redis-cli -c -h 192.168.216.135 -p //登录任意一台集群节点,需要使用 -c 参数,指定使用集群的方式登录
- 192.168.216.135:> set name "Tom"
- -> Redirected to slot [] located at 192.168.216.136: //添加一条数据,可以看到被存储到集群的 192.168.216.136:7001 节点上
- OK
- 192.168.216.136:> set name2 "John"
- -> Redirected to slot [] located at 192.168.216.135: //添加一条数据,可以看到被存储到集群的 192.168.216.135:7000 节点上
- OK
- 192.168.216.135:> set name3 "Jeny" //添加一条数据,如果没有集群输出,则表明被存储到本机的集群节点上
- OK
- 192.168.216.135:> cluster nodes //查看集群的所有节点
- 192.168.216.135:> cluster info //查看集群的状态信息
- 192.168.216.135:> cluster meet <ip> <port> //添加集群节点,需要先提前配置好Redis服务,添加的节点都会被设置为主库
- 192.168.216.135:> cluster replicate <node_id> //将当前节点设置为指定节点的从库
- 192.168.216.135:> cluster forget <node_id> //移除某个集群节点
Redis 集群配置的更多相关文章
- java操作redis集群配置[可配置密码]和工具类(比较好用)
转: java操作redis集群配置[可配置密码]和工具类 java操作redis集群配置[可配置密码]和工具类 <dependency> <groupId>red ...
- Redis集群配置(linux)
*弄了一天,有问题直接问我.qq:137416943 1.redis集群的配置和简单使用 Redis集群配置 0.首先要配置环境: 0.1 安装c++ yum install gcc-c++ ...
- java操作redis集群配置[可配置密码]和工具类
java操作redis集群配置[可配置密码]和工具类 <dependency> <groupId>redis.clients</groupId> & ...
- Linux系统下安装Redis和Redis集群配置
Linux系统下安装Redis和Redis集群配置 一. 下载.安装.配置环境: 1.1.>官网下载地址: https://redis.io/download (本人下载的是3.2.8版本:re ...
- centos6.5下redis集群配置(多机多节点)
可参考官网文档:redis集群配置 需要注意的是,集群中的每个节点都会涉及到两个端口,一个是用于处理客户端操作的(如下介绍到的6379/6380),另一个是10000+{监听端口},用于集群各个节点间 ...
- redis简介以及redis集群配置
简介: redis 是一个高性能的key-value数据库..它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted set --有序 ...
- redis 集群配置实战
文章转载自:http://hot66hot.iteye.com/blog/2050676 最近研究Redis-cluster,正好搭建了一个环境,遇到了很多坑,系统的总结下,等到redis3 rele ...
- spring 使用redis集群配置
上面两篇介绍了redis集群的配置合一些基本的概念,所以接下来当然是要在项目中使用咯,redis的java支持已经做的非常好了,所以我们来试着使用这些api来进行redis的操作,首先我们需要操作re ...
- redis集群配置
客户端分片 程序端实现 代理proxy,访问proxy,proxy指定redis保存位置. Twemproxy Redis cluster ,会造成一部分数据丢失,无中心化1.将数据自动切分(spli ...
- redis集群配置,spring整合jedis,缓存同步
前台的商品数据(图片等加载缓慢)查询,先从redis缓存查询数据. redis是一个nosql数据库,内存版数据库,读取速度11w/s.本身具有内存淘汰机制,是单线程服务器(分时操作系统),线程安全. ...
随机推荐
- 图的基本算法(BFS和DFS)
图是一种灵活的数据结构,一般作为一种模型用来定义对象之间的关系或联系.对象由顶点(V)表示,而对象之间的关系或者关联则通过图的边(E)来表示. 图可以分为有向图和无向图,一般用G=(V,E)来表示图. ...
- FPGA中的时序分析(五)
时序约束实例详解 本篇博客结合之前的内容,然后实打实的做一个约束实例,通过本实例读者应该会实用timequest去分析相关的实例.本实例以VGA实验为基础,介绍如何去做时序约束. 首先VGA这种情况属 ...
- 【Html】div 加载 html页面的方法
做网页的单页面应用时,需要在一个HTML的Div元素中加载另一个HTML页面,以前有一种方法就是用iframe,举例如下:(亲测可行) <div class="main-contain ...
- 【转】【Python】Python3爬虫实现自动登录、签到
工具:Fiddler 首先下载安装Fiddler,这个工具是用来监听网络请求,有助于你分析请求链接和参数. 打开目标网站:http://www.17sucai.com/,然后点击登录 好了,先别急着登 ...
- 今日Q群:QQ群众群友反馈问题的归纳总结
今日Q群:QQ群群友反馈问题的归纳总结 今天Q群里还算比较活跃,归纳总结后主要有以下几类问题: 一.如何在Excel中按指定规则对有颜色的单元格进行过滤删选 具体的解决办法,请参照今天发布微信 ...
- Java数组排序和搜索
如何排序数组并搜索其中的元素? 以下示例显示如何使用sort()和binarySearch()方法来完成任务.用户定义的方法printArray()用于显示数组输出: package com.yiib ...
- JDBC删除数据库实例
在本教程将演示如何在JDBC应用程序中删除一个指定的数据库. 在执行以下示例之前,请确保您已经准备好以下操作: 具有数据库管理员权限,以在给定模式中创建数据库. 要执行以下示例,需要用实际用户名和密码 ...
- e830. 向JTabbedPane中加入一个卡片
This example demonstrates various ways to add a tab to a tabbed pane. // Create a tabbed pane JTabbe ...
- Retrofit/OkHttp API接口加固技术实践(下)
作者/Tamic http://blog.csdn.net/sk719887916/article/details/65448628 imageMogr2/auto-orient/strip%7Cim ...
- jQuery/CSS3类似阿里巴巴的商品导航菜单实现教程
有两天没发表文章了,今天来说说利用jQuery和CSS3制作一款类似阿里巴巴左侧商品菜单导航,这款菜单看起来非常大气,可以展示非常多的产品类目,如果你在设计电子商务网站,不妨可以拿来参考,一下是效果图 ...