【精】搭建redis cluster集群,JedisCluster带密码访问【解决当中各种坑】!
转:
make
make PREFIX=/usr/local/redis install
mkdir confcp /usr/local/redis-3.0.0/redis.conf /usr/local/redis/bin
port 7001 //监听的端口# bind 127.0.0.1 //绑定ip,只允许该ip访问,不填默认为*,表示允许所有ip访问requirepass "你的密码" //开启密码loglevel debug //日志级别,开发模式尽量选用debuglogfile "redis.log" //日志文件路径,此处使用相对路径,将生成到/usr/local/redis下maxmemory 100000000 //允许最大内存占用100mappendonly yes //启用aofauto-aof-rewrite-percentage 80 //部署在同一机器的多个redis实例,建议把auto-aof-rewrite错开(可分别写80-100不等),防止瞬间fork,所有redis进程做rewrite,占用大量内存
- <dependency>
- <groupId>redis.clients</groupId>
- <artifactId>jedis</artifactId>
- <version>2.7.0</version>
- </dependency>
- 连接池整合spring:
- <!-- redis连接池(单例) -->
- <bean id="jedisPool" class="redis.clients.jedis.JedisPool" destroy-method="close">
- <constructor-arg name="poolConfig" ref="jedisPoolConfig"/>
- <constructor-arg name="host" value="${redis.host}"/>
- <constructor-arg name="port" value="${redis.port}"/>
- <constructor-arg name="timeout" value="${redis.timeout}"/>
- <constructor-arg name="password" value="${redis.pass}"/>
- </bean>
- <!-- 连接池配置 -->
- <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
- <!-- 最大连接数 -->
- <property name="maxTotal" value="150" />
- <!-- 最大空闲连接数 -->
- <property name="maxIdle" value="30" />
- <!-- 最小空闲连接数 -->
- <property name="minIdle" value="10" />
- <!-- 获取连接时的最大等待毫秒数,小于零:阻塞不确定的时间,默认-1 -->
- <property name="maxWaitMillis" value="3000" />
- <!-- 每次释放连接的最大数目 -->
- <property name="numTestsPerEvictionRun" value="100" />
- <!-- 释放连接的扫描间隔(毫秒) -->
- <property name="timeBetweenEvictionRunsMillis" value="3000" />
- <!-- 连接最小空闲时间 -->
- <property name="minEvictableIdleTimeMillis" value="1800000" />
- <!-- 连接空闲多久后释放, 当空闲时间>该值 且 空闲连接>最大空闲连接数 时直接释放 -->
- <property name="softMinEvictableIdleTimeMillis" value="10000" />
- <!-- 在获取连接的时候检查有效性, 默认false -->
- <property name="testOnBorrow" value="true" />
- <!-- 在空闲时检查有效性, 默认false -->
- <property name="testWhileIdle" value="true" />
- <!-- 在归还给pool时,是否提前进行validate操作 -->
- <property name="testOnReturn" value="true" />
- <!-- 连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true -->
- <property name="blockWhenExhausted" value="false" />
- </bean>
- @RunWith(SpringJUnit4ClassRunner.class) // 指定测试用例的运行器 这里是指定了Junit4
- @ContextConfiguration("classpath:spring/application*.xml")
- public class RedisTest {
- @Autowired
- private JedisPool pool;
- @Test
- public void testJedisPool() {
- Jedis jedis = null;
- String name = null;
- try {
- jedis = pool.getResource();
- jedis.set("testName", "RCL");
- name = jedis.get("testName");
- } catch (Exception ex) {
- ex.printStackTrace();
- } finally {
- if (jedis != null) {
- // 返回给池
- jedis.close();
- }
- Assert.assertEquals("RCL", name);
- }
- }
-A INPUT -p tcp -m state --state NEW -m tcp --dport 7001 -j ACCEPT //7001即redis端口
重启防火墙
yum install ruby yum install rubygems
拷贝redis-3.0.0.gem至/usr/local。执行:gem install /usr/local/redis-3.0.0.gem
cd /usr/localmkdir redis-clustermkdir redis-cluster/7001mkdir redis-cluster/7002
……
port 700X //各自监听的端口#bind 127.0.0.1 //这里不绑定,默认允许所有ip访问,或者bind 0.0.0.0cluster-enabled yes //开启集群cluster-node-timeout 15000 //15时间内没有收到对方的回复,则单方面认为端节点挂掉另外,由于下面我们需要配置集群密码,故之前配置的 requirepass 先删掉,集群成功后再进行配置。
1.ruby 和rubygem 版本太低,安装新版本。查看gem版本和redis版本(redis-cli -v可查看redis版本)2.查看reids配置文件,bind绑定的允许连接的ip是否正确。3.是否redis配置文件还是使用了密码,使用了密码也可能导致这个错误。
表示集群时,之前的redis已有数据,那么登录到7005的redis中,执行FLUSHALL即可
用redis-cli登录到每个节点执行flushall和cluster reset即可2.6进入集群:./redis-cli -c -p 7001 -h 123.123.123.123(-c即-cluster 表示进入集群模式,不加表示进入单机redis)
(1)登录到每个节点,执行 config set masterauth 你的密码 config set requirepass 你的密码(2)随后登入 7001/bin/redis-cli -c -h 112.74.55.239 -p 7004 -a 你的密码,执行: config rewrite(3)防火墙开放7001到7006端口,以及redis总线:17001到17006:
-A INPUT -p tcp -m state --state NEW -m tcp --dport 7001:7006 -j ACCEPT-A INPUT -p tcp -m state --state NEW -m tcp --dport 17001:17006 -j ACCEPT
- <dependency>
- <groupId>redis.clients</groupId>
- <artifactId>jedis</artifactId>
- <version>2.9.0</version> //2.9.0才支持cluster密码认证,之前版本的jedisCluster.auth("密码")方法里面什么都没有实现,仅仅抛一个JedisClusterException("No way to dispatch this command to Redis Cluster.")
- </dependency>
- 整合spring:
- <!-- redis集群 -->
- <bean id="jedisCluster" class="redis.clients.jedis.JedisCluster">
- <constructor-arg index="0">
- <set>
- <bean class="redis.clients.jedis.HostAndPort">
- <constructor-arg index="0" value="${redis.host}"></constructor-arg>
- <constructor-arg index="1" value="${redis.port1}"></constructor-arg>
- </bean>
- <bean class="redis.clients.jedis.HostAndPort">
- <constructor-arg index="0" value="${redis.host}"></constructor-arg>
- <constructor-arg index="1" value="${redis.port2}"></constructor-arg>
- </bean>
- <bean class="redis.clients.jedis.HostAndPort">
- <constructor-arg index="0" value="${redis.host}"></constructor-arg>
- <constructor-arg index="1" value="${redis.port3}"></constructor-arg>
- </bean>
- <bean class="redis.clients.jedis.HostAndPort">
- <constructor-arg index="0" value="${redis.host}"></constructor-arg>
- <constructor-arg index="1" value="${redis.port4}"></constructor-arg>
- </bean>
- <bean class="redis.clients.jedis.HostAndPort">
- <constructor-arg index="0" value="${redis.host}"></constructor-arg>
- <constructor-arg index="1" value="${redis.port5}"></constructor-arg>
- </bean>
- <bean class="redis.clients.jedis.HostAndPort">
- <constructor-arg index="0" value="${redis.host}"></constructor-arg>
- <constructor-arg index="1" value="${redis.port6}"></constructor-arg>
- </bean>
- </set>
- </constructor-arg>
- <constructor-arg index="1" value="${redis.timeout}"></constructor-arg>
- <constructor-arg index="2" value="${redis.sockettimeout}"></constructor-arg>
- <constructor-arg index="3" value="${redis.maxAttempts}"></constructor-arg>
- <constructor-arg index="4" value="${redis.pass}"></constructor-arg>
- <constructor-arg index="5" ref="jedisPoolConfig"></constructor-arg>
- </bean>
- @RunWith(SpringJUnit4ClassRunner.class)
- @ContextConfiguration("classpath:spring/application*.xml")
- public class RedisTest {
- @Autowired
- private JedisCluster jCluster;
- @Test
- public void testJCluster() {
- jCluster.set("name", "RCL");
- String name = jCluster.get("testName");
- Assert.assertEquals("RCL", name);
- }
【精】搭建redis cluster集群,JedisCluster带密码访问【解决当中各种坑】!的更多相关文章
- Docker Compose 搭建 Redis Cluster 集群环境
在前文<Docker 搭建 Redis Cluster 集群环境>中我已经教过大家如何搭建了,本文使用 Docker Compose 再带大家搭建一遍,其目的主要是为了让大家感受 Dock ...
- Docker 搭建 Redis Cluster 集群环境
使用 Docker 搭建 Redis Cluster,最重要的环节就是容器通信的问题,这一块我们在之前的文章中已经给大家解决了<Docker 网络模式详解及容器间网络通信>,本篇文章主要练 ...
- 搭建redis cluster集群服务
redis 5.0以下为ruby编写,运行命令时需要安装ruby,而5.0以上则为c编写,可直接安装后运行.因此本文使用redis5.0.5 1.编写配置文件 在 /home 下新建 redis-cl ...
- centos6下redis cluster集群部署过程
一般来说,redis主从和mysql主从目的差不多,但redis主从配置很简单,主要在从节点配置文件指定主节点ip和端口,比如:slaveof 192.168.10.10 6379,然后启动主从,主从 ...
- Redis Cluster集群搭建与配置
Redis Cluster是一种服务器sharding分片技术,关于Redis的集群方案应该怎么做,请参考我的另一篇博客http://www.cnblogs.com/xckk/p/6134655.ht ...
- Redis Cluster集群搭建与应用
1.redis-cluster设计 Redis集群搭建的方式有多种,例如使用zookeeper,但从redis 3.0之后版本支持redis-cluster集群,redis-cluster采用无中心结 ...
- Redis cluster集群:原理及搭建
Redis cluster集群:原理及搭建 2018年03月19日 16:00:55 阅读数:6120 1.为什么使用redis? redis是一种典型的no-sql 即非关系数据库 像python的 ...
- Redis Cluster集群搭建<原>
一.环境配置 一台window 7上安装虚拟机,虚拟机中安装的是centos系统. 二.目标 Redis集群搭建的方式有多种,根据集群逻辑的位置,大致可以分为三大类:基于客户端分片的Redis ...
- redis集群与分片(2)-Redis Cluster集群的搭建与实践
Redis Cluster集群 一.redis-cluster设计 Redis集群搭建的方式有多种,例如使用zookeeper等,但从redis 3.0之后版本支持redis-cluster集群,Re ...
随机推荐
- Django--CRM--菜单排序等
一 . 菜单排序 1.我们想把菜单排序.首先给菜单加上权重,权重大的排在上面, 这就要在菜单表上加上一个权重字段. 2. 我们在菜单表里面把权重改一下 3. 需要把权重字段的信息拿出来放到sessio ...
- Golang的md5 hash计算
Golang计算md5值的方法都是接收byte型slice([]byte).而且使用习惯上也觉得略奇怪. 看了好几个例子才看懂. 感觉Golang标准库在设计这些模块的时候,都会考虑使用带New关键字 ...
- git放弃修改,强制覆盖本地代码
$ git fetch --all $ git reset --hard origin/master $ git pull
- QTP 自动化测试桌面程序--笔记(下拉选择、右键菜单、在控件仓库中查找对应的控件)
0 在收集窗口控件信息时-最好将可输入的文字去掉,不然控件的名称按输入的文字标记 1 编辑时录制脚本-默认按当前显示的填入的数据标记控件 可以使用 tool-spy-查看控件的x,y 坐标,按坐标在学 ...
- 一个好玩的小制作,以及在<a/>中的标签href="javascript:;"/href="javascript:void(0);"/href="javascript:"的用法
一:一个小图标的制作 我们在支付宝.微信等某些地方上传文件时会遇到以下的图标,但是这样的图标其实可以用<a/>标签以及css样式完成, 具体代码如下: <!DOCTYPE html& ...
- 扒一扒开源世界有哪些licenses?
摘要:license,中文译为“许可证”.在开源世界里,license是具有法律效力的,通过选择相应的license,版权拥有者可以声称自己相应的权利,包括其他人使用.修改.引用.共享等一系列涉及版权 ...
- Membership 介绍
ASP.NET成员资格为您提供了验证和存储用户凭据的内置方式.因此,ASP.NET成员可以帮助您管理网站中的用户身份验证.您可以使用ASP.NET表单身份验证使用ASP.NET成员身份,方法是使用AS ...
- 当页面上需要的字段不在model中时候,需要自行设置该字段
当页面上需要的字段不在model中时候,需要自行设置该字段
- codeforces474D
Flowers CodeForces - 474D 话说某个幸运的小伙伴X拿到了kevin女神送的蛋糕,然而他的吃法非常奇特,他独创了两种吃蛋糕的办法:一.一次吃一整个蛋糕:二.一次吃k个蛋糕. 那么 ...
- BZOJ2160拉拉队排练——回文自动机
题目描述 艾利斯顿商学院篮球队要参加一年一度的市篮球比赛了.拉拉队是篮球比赛的一个看点,好的拉拉队往往能帮助球队增加士气,赢得最终的比赛.所以作为拉拉队队长的楚雨荨同学知道,帮助篮球队训练好拉拉队有多 ...