redis集群搭建教程(以3.2.2为例)
redis从3.0版本开始支持集群,2.X版本主支持sentinel主从模式;所以要搭建集群务必下载3.0以上版本,本教程以3.2.2版本为例。
redis集群最少要有3个主节点,最典型的是3主3从组成集群;本教程以在同一台主机(192.168.220.128)搭建3个主节点(master)的集群为例。
1.下载
下载页面:https://redis.io/download
当前最新版本下载:http://download.redis.io/releases/redis-4.0.1.tar.gz
历史版本下载:http://download.redis.io/releases/
2.安装
先创建基本的目录结构
mkdir redis
mkdir redis/adm
mkdir redis/bin-3.2.
ln -s bin-3.2. redis/bin
mkdir redis/data
mkdir redis/conf
mkdir redis/logs
mkdir redis/tmp
解压编译redis
tar -zxf redis-3.2..tar.gz
cd redis-3.2.
make
将redis二进制文件和ruby脚本移动bin目录,将配置文件移到conf目录
cd src
ll |grep x
cp mkreleasehdr.sh redis-benchmark redis-check-aof redis-check-rdb redis-cli redis-sentinel redis-server redis-trib.rb ../../redis/bin
cd ..
cp runtest runtest-cluster runtest-sentinel ../redis/bin
cp redis.conf sentinel.conf ../redis/conf/
3.配置和启动redis
创建各端口进程的data目录
cd redis/data
mkdir
mkdir
mkdir
mkdir
mkdir
mkdir
创建各端口进程的配置文件,其中portNum和bind的IP根据自己情况修改
cd ../conf
for portNum in
do
cat > redis-$portNum.conf <<EOF
daemonize yes
pidfile /usr/myapp/redis/tmp/redis-$portNum.pid
dir /usr/myapp/redis/data/$portNum/ loglevel notice
logfile /usr/myapp/redis/logs/redis-$portNum.log
maxclients bind 192.168.220.128
port $portNum protected-mode yes
#requirepass yourpasswd cluster-enabled yes
cluster-config-file nodes-$portNum.conf
cluster-node-timeout
cluster-require-full-coverage no appendonly no
appendfsync everysec
auto-aof-rewrite-percentage
auto-aof-rewrite-min-size 256mb save "" repl-diskless-sync no
repl-diskless-sync-delay
EOF
done
创建集群时上边的bind最好只绑定一个本机网卡的IP地址,127.0.0.1也不要绑,不然在后边使用redis-trib创建集群时会一直停在等待节点加入状态。(不绑127.0.0.1的问题是redis-cli需要用-h指定IP才能登录)
然后启动各server进程
cd ../bin
./redis-server ../conf/redis-.conf
./redis-server ../conf/redis-.conf
./redis-server ../conf/redis-.conf
./redis-server ../conf/redis-.conf
./redis-server ../conf/redis-.conf
./redis-server ../conf/redis-.conf
4.安装ruby
由于redis官方提供的集群组建脚本是ruby写的,所以我们需要安装ruby
yum -y install ruby ruby-devel rubygems rpm-build
gem install redis
对于内网环境可能或是不能连接外网或没有源,需要先在别的机器上离线下载然后上传上去离线安装
yum install --downloaddir=. --downloadonly ruby #下载ruby及其依赖到当前目录,如果还有其他包没下载可模仿下载
yum install --downloaddir=. --downloadonly rubygems #下载gem及其依赖到当前目录
wget https://rubygems.global.ssl.fastly.net/gems/redis-3.2.2.gem
yum localinstall ruby -y #进入上传的ruby存放的目录执行
yum localinstall rubygems -y #进入上传的rubygems目录执行
gem install -l ./redis-3.2..gem
yum localinstall有时装不上改用rpm逐个包安装即可;ruby依次安装compat-readline5--ruby-libs--ruby;gem依次安装ruby-irb--ruby-rdoc--rubygems
5.创建集群
cd ../bin
./redis-trib.rb create --replicas 192.168.220.128: 192.168.220.128: 192.168.220.128: 192.168.220.128: 192.168.220.128: 192.168.220.128:
在提示Can I set the above configuration? (type 'yes' to accept):时输入yes接受即可(redis-trib有时会报错权限不足,以root执行即可)
6.查看集群情况
./redis-cli -h 192.168.220.128 -p -c cluster nodes
-c是登录集群使可以自动跳转;如果要确保集群可用,可登录set/get一下
参考:
http://www.cnblogs.com/wuxl360/p/5920330.html
redis集群搭建教程(以3.2.2为例)的更多相关文章
- centos redis集群搭建
说明: 10.0.0.111部署6500,6501,6502三个主节点 10.0.0.222部署6500,6501,6502三个备份节点 1.安装redis:略 2.配置内核参数 # 配置 vm.ov ...
- redis集群搭建踩坑笔记
推荐参考教程:https://blog.csdn.net/pucao_cug/article/details/69250101 错误: from /usr/lib/ruby/2.3.0/rubygem ...
- 25.redis集群搭建笔记
###Redis集群### 0.准备 软件: redis-3.0.0.gem redis-3.0.0.tar.gz#源码 1.安装ruby环境 redis基于ruby槽位计算,hash算法技术,k ...
- Redis 集群搭建详细指南
先有鸡还是先有蛋? 最近有朋友问了一个问题,说毕业后去大城市还是小城市?去大公司还是小公司?我的回答都是大城市!大公司! 为什么这么说呢,你想一下,无论女孩男孩找朋友都喜欢找个子高胸大的.同样的道理嘛 ...
- 二、redis集群搭建
redis集群搭建 redis3.0后支持集群.集群中应该至少有三个节点,每个节点有一备份节点.需要6台服务器.搭建伪分布式,需要6个redis实例.搭建集群的步骤: 一.安装单机版redis 第一步 ...
- redis集群搭建及注意事项
上一篇:redis的安装及注意事项 这里,在一个Linux虚拟机上搭建6个节点的redis伪集群,思路很简单,一台虚拟机上开启6个redis实例,每个redis实例有自己的端口.这样的话,相当于模拟出 ...
- Linux Redis集群搭建与集群客户端实现(Python)
硬件环境 本文适用的硬件环境如下 Linux版本:CentOS release 6.7 (Final) Redis版本: Redis已经成功安装,安装路径为/home/idata/yangfan/lo ...
- [转载] Redis集群搭建最佳实践
转载自http://blog.csdn.net/sweetvvck/article/details/38315149?utm_source=tuicool 要搭建Redis集群,首先得考虑下面的几个问 ...
- Linux Redis集群搭建与集群客户端实现
硬件环境 本文适用的硬件环境如下 Linux版本:CentOS release 6.7 (Final) Redis版本: Redis已经成功安装,安装路径为/home/idata/yangfan/lo ...
随机推荐
- 【Python】【有趣的模块】【requests】【二】快速上手
[一]参数及结果 [二]响应内容 >>> r = requests.get('https://github.com/timeline.json') >>> prin ...
- C#:导入Excel通用类(Xls格式)
PS:在CSV格式和XLSX格式中有写到通用调用的接口和引用的插件,所以在这个xls格式里面并没有那么详细,只是配上xls通用类. 一.引用插件NPOI.dll.NPOI.OOXML.dll.NPOI ...
- C#:MVC打印PDF文件
在百度上找了许多PDF文件打印,但是符合我需求的打印方式还没看到,所以根据看了https://www.cnblogs.com/TiestoRay/p/3380717.html的范例后,研究了一下,做出 ...
- Codeforces Round #290 (Div. 2) E. Fox And Dinner 网络流建模
E. Fox And Dinner time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...
- 【汇总】基于.NET平台常用的框架整理
分布式缓存框架: Microsoft Velocity:微软自家分布式缓存服务框架. Memcahed:一套分布式的高速缓存系统,目前被许多网站使用以提升网站的访问速度. Redis:是一个高性能的K ...
- 导入dmp文件时,需要删除原有ORACLE数据库实例
导入dmp文件时,对于已存在的数据库实例及表处理方式:删除实例. 1.以管理员身份登录 sqlplus / as sysdba 2.停止实例 shutdown abort; 执行结果:ORACLE i ...
- Ado.net之存储过程的使用【三】
重点是红色标记区域的代码,设置本次执行的是存储过程,如果不设置,默认操作的是sql语句 private void LoadData() { string constr = @"databas ...
- MySQL学习(十)
要做:商城的留言板 一般情况,做留言板的显示很容易,直接select查询,再显示出来,但eschop中的留言板难点在于留言数据来自2张表,feedback表和comment表,我们需要把两张表中的内容 ...
- 牛客国庆集训派对Day3 A Knight
Knight 思路: bfs打表找规律 如下图 代码: #pragma GCC optimize(2) #pragma GCC optimize(3) #pragma GCC optimize(4) ...
- Python全栈开发-执行字符串形式的语句和字符串形式的表达式方法(即exec和eval方法)
Python有时需要动态的创造Python代码,然后将其作为语句执行 或 作为表达式计算. exec用于执行存储在字符串中的Python代码. 1. 语句与表达式的区别:表达式是 某事,语句是 ...