redis集群的搭建

########环境#########
centos 7.2 , 
gcch 环境
ruby 2.0.0 redis
3.2.8 redis-3.3.3gem

 

公司要求搭建redis集群, 本来觉得挺好搞的,没想到弄到现在....

1, 环境准备

gcc , ruby 等环境准备

yum -y install gcc ruby ruby-devel rubygems rpm-build zlib

redis-ruby接口安装, 我直接yum安装的,

gem install redis

你也可以下载 redis.3.3.3.gem 然后执行命令

 

gem install redis-3.3.3.gem

2, 再说下单机redis的搭建方法

1, 下载redis 3.2.8 的安装包: 

wget http://download.redis.io/releases/redis-3.2.8.tar.gz

2, 解压

tar -zxvf redis-3.2.8

3, 进入解压目录下

make

然后安装

make install PREFIX=/opt/wenbronk_soft/redis/redis1

安装完成后, 可在redis1 目录下看到一个bin目录, 对, 就是他了.

 

4, 此时已经可以访问了, 但需要更改下配置文件, 才可以使用外部ip访问

redis.conf 在redis的解压目录下

cp /opt/wenbronk_soft/redis/redis-3.2.8/redis.conf /opt/wenbronk_soft/redis/redis1/bin

vim 

bind 192.168.xx.202       (当前主机的ip)

5, 启动

./redis-server ./redis.conf

现在已经可以通过本地的 ./redis-cli -h localhost -p 6379 或者通过外部ip进行访问了.

3, 接下来是集群的安装

安装集群之前, 首先要保证单个的redis是空的, 也就是没有dump.rb文件没有密码设置, 就是 redis.conf中 masterauth        masterauth         没有设置

 

这儿搭建一个台机器上的伪集群, 分布式集群搭建和这个类似, 只是使用ruby创建集群时ip:port有所区别

注意:     至少需要 3  master+ 2  slave, 官方建议是 3 + 3 , 这儿使用 3  mater + 3 slave

 

1, 修改 redis.conf

添加守护进程: daemonize

port  7000                                        //端口7000,7001,7002,7003,7004,7005,7005
bind 本机ip                                       //默认ip为127.0.0.1 需要改为其他节点机器可访问的ip 否则创建集群时无法访问对应的端口,无法创建集群
daemonize    yes                               //redis后台运行, 
# pidfile  /var/run/redis_7000.pid          //pidfile文件对应7000,7001,7002
cluster-enabled  yes                           //开启集群  把注释#去掉
cluster-config-file  nodes_7000.conf   //集群的配置  配置文件首次启动自动生成 7000,7001,7002
cluster-node-timeout  15000                //请求超时  默认15秒,可自行设置
appendonly  yes                           //aof日志开启  有需要就开启,它会每次写操作都记录一条日志 

2, 复制解压目录下的  redis-trib.rb 到 安装 目录下 (/opt/wenbronk_soft/redis/redis/bin) 

cp /opt/wenbronk_soft/redis/redis-3.2.8/src/redis-trib.rb /opt/wenbronk_soft/redis/redis/bin

此时bin下目录结构为: 

 

3, 复制bin为另外6个实例

4, 进入到每个目录下更改 port设置

从 7000 - 7005

5, 使用启动脚本启动6个实例

cd bin
./redis-server ./redis.conf
cd ..
cd bin1
./redis-server ./redis.conf
cd ..
cd bin2
./redis-server ./redis.conf
cd ..
cd bin3
./redis-server ./redis.conf
cd ..
cd bin4
./redis-server ./redis.conf
cd ..
cd bin5
./redis-server ./redis.conf
cd ..

修改脚本权限

chmod u+x start.sh

6, 查看redis实例额运行状态

ps -ef | grep redis

netstat -tnlp | grep redis

 

 7, 创建集群 

./redis-trib.rb  create  --replicas  1 192.168.50.202:7000 192.168.50.202:7001 192.168.50.202:7002 192.168.50.202:7003 192.168.50.202:7004 192.168.50.202:7005

 

 

[wenbronk@localhost bin]$ ./redis-trib.rb  create  --replicas  1 192.168.50.202:7000 192.168.50.202:7001 192
.168.50.202:7002 192.168.50.202:7003 192.168.50.202:7004 192.168.50.202:7005>>> Creating cluster
>>> Performing hash slots allocation on 6 nodes...
Using 3 masters:
192.168.50.202:7000
192.168.50.202:7001
192.168.50.202:7002
Adding replica 192.168.50.202:7003 to 192.168.50.202:7000
Adding replica 192.168.50.202:7004 to 192.168.50.202:7001
Adding replica 192.168.50.202:7005 to 192.168.50.202:7002
M: b06c9670ad6e16cf41c9eeefb8260ad29dbb52e8 192.168.50.202:7000slots:0-5460 (5461 slots) master
M: 048291cbc8e9ccf81de57f02150447340d310fe0 192.168.50.202:7001slots:5461-10922 (5462 slots) master
M: 740557eca4a8fa31d67fe6a7f6b34814f3f96094 192.168.50.202:7002slots:10923-16383 (5461 slots) master
S: 63a9d243b8da03169dee24ec9403e50f36ab7cb0 192.168.50.202:7003replicates b06c9670ad6e16cf41c9eeefb8260ad29dbb52e8
S: 824b5d23e012cd7082701e3737ce8ea21eb8abe3 192.168.50.202:7004replicates 048291cbc8e9ccf81de57f02150447340d310fe0
S: f00948f8f9df4c10cba340cab3f0767d98f00b77 192.168.50.202:7005replicates 740557eca4a8fa31d67fe6a7f6b34814f3f96094
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join...
>>> Performing Cluster Check (using node 192.168.50.202:7000)
M: b06c9670ad6e16cf41c9eeefb8260ad29dbb52e8 192.168.50.202:7000slots:0-5460 (5461 slots) master1 additional replica(s)
M: 740557eca4a8fa31d67fe6a7f6b34814f3f96094 192.168.50.202:7002slots:10923-16383 (5461 slots) master1 additional replica(s)
S: 824b5d23e012cd7082701e3737ce8ea21eb8abe3 192.168.50.202:7004slots: (0 slots) slavereplicates 048291cbc8e9ccf81de57f02150447340d310fe0
S: f00948f8f9df4c10cba340cab3f0767d98f00b77 192.168.50.202:7005slots: (0 slots) slavereplicates 740557eca4a8fa31d67fe6a7f6b34814f3f96094
M: 048291cbc8e9ccf81de57f02150447340d310fe0 192.168.50.202:7001slots:5461-10922 (5462 slots) master1 additional replica(s)
S: 63a9d243b8da03169dee24ec9403e50f36ab7cb0 192.168.50.202:7003slots: (0 slots) slavereplicates b06c9670ad6e16cf41c9eeefb8260ad29dbb52e8
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.

ok, 集群搭建完成

 深坑, redis 集群之间的通讯端口为basePort + 1w

4 链接集群

1, redis客户端连接

 -c 连接集群

-p 如果bind 绑定的是本机地址, 那么必须加

./redis-cli -h 192.168.50.202 -p 7006 -c

2, 简单测试

set abc 1234
get abc

 

3, java连接

Jedis Cluster 会自动去发现集群中的节点,所以JedisClusterNodes只需要 add一个实例

ps -ef | grep redis | awk '{print $2}' | xargs kill -9

 

明天单独写吧.. 东西很多..

 

原创地址, http://www.cnblogs.com/wenbronk/p/6864390.html  转载请注明出处, 谢谢

转载于:https://www.cnblogs.com/wenbronk/p/6864390.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/252674.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2017-2018-1 20155227 《信息安全系统设计基础》第十三周学习总结

2017-2018-1 20155227 《信息安全系统设计基础》第十三周学习总结 找出全书你认为最重要的一章,深入重新学习一下,要求(期末占10分): 完成这一章所有习题详细总结本章要点给你的结对学习搭档讲解你的总结并获取反馈我选…

进程间五种通信方式

进程间通信(IPC,InterProcess Communication)是指在不同进程之间传播或交换信息。 IPC的方式通常有管道(包括无名管道和命名管道)、消息队列、信号量、共享存储、Socket、Streams等。其中 Socket和Streams支持不同主机…

电子书下载:Silverlight 5 in Action

下载:http://www.ctdisk.com/file/8447319

Virtualbox桥接网卡设置

正常情况下,像设置virtualbox虚拟机的桥接网卡非常简单,只需要点配置,然后在配置界面点击网络,然后在右边的网络里选择桥接网络即可。但是如果这么简单就好了,今天要说的就是在不正常的情况下是怎么设置的。 工具/原料…

SQL疑难杂症【4 】大量数据查询的时候避免子查询

前几天发现系统变得很慢,在Profiler里面发现有的SQL执行了几十秒才返回结果,当时的SQL如下: 可以看得出来,在652行用了子查询,恰巧目标表(QS_WIP)中的记录数为100000000,通过如下SQL可以得到: S…

『原创』一个基于Win CE 5.0的Txt文件阅读器

最近,拿到一台亲戚送的GPS导航仪,其系统是基于WinCE5.0的,所以我觉得可以写点小程序上去,上网一搜,还附带破解方法,把GPS破解后就变成一台屏幕超大的PDA了,于是我想用它看电子书,无奈…

ARM Cortex-A系列(A53、A57、A73等)处理器性能分类与对比

在如今这个电子产品泛滥的年代,仅仅靠品牌或是外观已经不足以辨别产品的优劣,其内置的处理器自然也就成为了分辨产品是否高端的标准之一。那么我们今天就不妨好好了解一下近几年来电子产品中较为主流的RAM处理器。 在这之前让我们先简单认识一下处理器的…

.NET 3.5 - DLINQ(LINQ to SQL)之面向对象的添加、查询、更新和删除

步步为营VS 2008 .NET 3.5(8) - DLINQ(LINQ to SQL)之面向对象的添加、查询、更新和删除作者&#xff1a;webabcd介绍以Northwind为示例数据库&#xff0c;DLINQ(LINQ to SQL)之完全面向对象的添加操作、查询操作、更新操作和删除操作示例Sample.aspx <% Page Language&quo…

ARM版本系列及家族成员梳理

ARM公司简介 ARM是Advanced RISC Machines的缩写&#xff0c;它是一家微处理器行业的知名企业&#xff0c;该企业设计了大量高性能、廉价、耗能低的RISC &#xff08;精简指令集&#xff09;处理器。 1985年第一个ARM原型在英国剑桥诞生。 公司的特点是只设计芯片&#xff0c…

tomcat源码阅读之StandardHost和StandardEngine

StandardHost及UML类图&#xff1a; 1、StandardHost类是Host接口的默认实现&#xff1b;其继承自ContainerBase类&#xff0c;说明他也是一个容器类&#xff0c;既然是容器类&#xff0c;那肯定也有管道对象PipeLine和阀门&#xff0c;其基础阀门&#xff08;Basic Valve&…

安防监控产业链全景梳理

安防行业是随着现代社会安全需求应运而生的产业&#xff0c;围绕着视频监控技术的改革创新&#xff0c;行业从“看得见、看得远、看得清到看得懂”&#xff0c;一共经历模拟监控、数字监控、网络高清监控和智能监控4个阶段&#xff0c;每一阶段的突破&#xff0c;都由上游技术的…

Vue项目搭建步骤

一&#xff0e; vue-cli初始化1. 全局安装 vue-cli  npm install --global vue-cli2. 创建一个基于 webpack 模板的新项目  vue init webpack my-project3. 安装依赖  cd my-project  npm install (换源安装: npm install --registry https://registry.npm.taobao.org …

Python tutor 简介

Python tutor 能够直观显示object 引用关系。 网址是 http://www.pythontutor.com/visualize.html 先分享一下我的一个Python tutor&#xff1a; 点我出现神奇&#xff1a; 1&#xff09; 编辑code。 2&#xff09; 运行&#xff0c; 能够看到以下界面。 这个工具是很酷的&…

光学镜头行业发展现状及趋势,智能手机应用领域占比最高

一、光学镜头分类 光学镜头也叫摄像镜头或摄影镜头&#xff0c;简称镜头&#xff0c;其功能就是光学成像。光学镜头是光学成像系统中的必备组件&#xff0c;直接影响到成像质量的好坏&#xff0c;影响算法的实现和效果。从结构来看&#xff0c;光学镜头一般由精密五金、塑胶零…

关于_vmvare workstation装32ubuntu的问题

刚开始启动的时候是黑屏&#xff0c;没有任何反应 1.bios也设置BIOS intel virtual technology 设置了enabled(开启硬件虚拟化:要运行一些操作系统&#xff0c;虚拟化软件和虚拟机&#xff0c;硬件虚拟化就需要启用。大多数情况下&#xff0c;不需要虚拟化技术的操作系统可以正…

360°环视(全景影像)系统发展趋势

360环视系统&#xff0c;系统同时采集车辆四周的影像&#xff0c;经过图像处理单元一系列的智能算法处理&#xff0c;最终形成一幅车辆四周的全景俯视图显示在屏幕上&#xff0c;直观地呈现出车辆所处的位置和周边情况。系统大大地拓展了驾驶员对周围和环境的感知能力&#xff…

数学之路(3)-机器学习(3)-机器学习算法-SVM[7]

SVM是新近出现的强大的数据挖掘工具&#xff0c;它在文本分类、手写文字识别、图像分类、生物序列分析等实际应用中表现出非常好的性能。SVM属于监督学习算法&#xff0c;样本以属性向量的形式提供&#xff0c;所以输入空间是Rn的子集。 图1 如图1所示&#xff0c;SVM的目标是找…

CPU、GPU、FPGA、ASIC等AI芯片特性及对比

1、前言 目前&#xff0c;智能驾驶领域在处理深度学习AI算法方面&#xff0c;主要采用GPU、FPGA 等适合并行计算的通用芯片来实现加速。同时有部分芯片企业开始设计专门用于AI算法的ASIC专用芯片&#xff0c;比如谷歌TPU、地平线BPU等。在智能驾驶产业应用没有大规模兴起和批量…

人工智能Ai芯片层出不穷,GPU、FPGA、ASIC用于人工智能的优势和劣势对比

人工智能&#xff08;AI&#xff09;主要包括三大要素&#xff0c;分别是数据、算法和算力。其中数据是基础&#xff0c;正是因为在实际应用当中的数据量越来越大&#xff0c;使得传统计算方式和硬件难以满足要求&#xff0c;才催生了AI应用的落地。而算法是连接软件、数据、应…

全景视频拼接关键技术

一、原理介绍 图像拼接(Image Stitching)是一种利用实景图像组成全景空间的技术&#xff0c;它将多幅图像拼接成一幅大尺度图像或360度全景图&#xff0c;图像拼接技术涉及到计算机视觉、计算机图形学、数字图像处理以及一些数学工具等技术。图像拼接其基本步骤主要包括以下几…