剑指架构师系列-Redis集群部署

初步搭建Redis集群

克隆已经安装Redis的虚拟机,我们使用这两个虚拟机中的Redis来搭建集群。

master:192.168.2.129 端口:7001

slave:192.168.2.132 端口:7002

sentinel:192.168.2.129 端口:26379

来说一下这个sentinel,sentinel是一个管理redis实例的工具,它可以实现对redis的监控、通知、自动故障转移。sentinel不断的检测redis实例是否可以正常工作,通过API向其他程序报告redis的状态,如果redis master不能工作,则会自动启动故障转移进程,将其中的一个slave提升为master,其他的slave重新设置新的master服务器。

来配置一下sentinel.conf,内容如下:

port 26379
daemonize yes
logfile "/var/log/redis/sentinel.log"
sentinel monitor master1 192.168.1.129 7001 1
sentinel down-after-milliseconds master1 1000
sentinel failover-timeout master1 5000  

做为master的redis不需要修改redis.conf配置,但需要修改一下slave的redis配置,将端口修改为7002,并且添加如下的配置:

slaveof 192.168.1.129 7001

配完了master, slave和sentinel后,必须按照如下顺序来启动redis集群:

master->slave->sentinel

执行如下的命令所在的目录为:redis-stable/src

 ./redis-server ../redis.conf   // 启动master与slave

./redis-sentinel ../sentinel.conf  // 启动sentinel

使用客户端来查看:

./redis-cli -p 26379 -h 192.168.2.129 

内容如下图:

2、Spring Session Date Redis访问Redis Sentinel

使用上次新建的模块mazhi-redis进行测试。pom.xml文件不需要改变。但是redis.properties的配置需要改变,如下:

spring.redis.database=0
spring.redis.host=192.168.2.129
# Login password of the redis server.
spring.redis.password=
spring.redis.pool.max-active=8
spring.redis.pool.max-idle=8
spring.redis.pool.max-wait=-1
spring.redis.pool.min-idle=0
spring.redis.port=7001
# Name of Redis server.
spring.redis.sentinel.master=master1
# Comma-separated list of host:port pairs.
spring.redis.sentinel.nodes=192.168.2.129:26379
spring.redis.timeout=0

注意必须是redis.properties这个名称,而且必须要放到src/main/resources目录下,这是一种约定。

spring.redis.sentinel.master必须与sentinel.conf文件中指定的值一致,如下:

sentinel monitor master1 192.168.1.129 7001 1

spring.redis.sentinel.nodes值为sentinel的ip:端口,可以有多个。

在org.mazhi.redis.config目录下新建RedisSentinalConfig.java文件,内容如下:

@Configuration
@PropertySource(value = "classpath:/redis.properties")
@EnableCaching
public class RedisSentinalConfig extends CachingConfigurerSupport{

    @Bean
    public KeyGenerator wiselyKeyGenerator(){  // 配置key的生成规则
        return new KeyGenerator() {
            public Object generate(Object target, Method method, Object... params) {
                StringBuilder sb = new StringBuilder();
                sb.append(target.getClass().getName());
                sb.append(method.getName());
                for (Object obj : params) {
                    sb.append(obj.toString());
                }
                return sb.toString();
            }
        };

    }

    @Bean
    public CacheManager cacheManager(@SuppressWarnings("rawtypes") RedisTemplate redisTemplate) {
        return new RedisCacheManager(redisTemplate);
    }

    @Bean
    public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {
        StringRedisTemplate template = new StringRedisTemplate(factory);
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        template.setValueSerializer(jackson2JsonRedisSerializer);
        template.afterPropertiesSet();
        return template;
    }
}

新建一个User的实体对象,如下:

package org.mazhi.redis.bean;

public class User {
    private Long id;
    private String name;
    private String address;  

    public User(Long id,String name, String address) {
        this.id = id ;
        this.name = name;
        this.address = address;
    }  

    public User() {
    }
   ...

}

在org.mazhi.redis.service目录下新建DemoService.java文件,内容如下:

@Service
public class DemoService {
    @Cacheable(value = "usercache",keyGenerator = "wiselyKeyGenerator")
    public User findUser(Long id,String firstName,String lastName){
        System.out.println("======当Redis中不存在这条数据时会执行这里=========");
        return new User(id,firstName,lastName);
    }
}

在org.mazhi.redis.web目录下新建RedisSentinelController.java文件,内容如下:

	@Autowired
	DemoService demoService;

	@RequestMapping("/addToRedis")
	@ResponseBody
	public void putCache() {
		demoService.findUser(1l, "mazhi", "ordos");
		System.out.println("添加成功!");
	}

	@RequestMapping("/findFromRedis")
	@ResponseBody
	public void testCache() {
		User user = demoService.findUser(1l, "mazhi", "ordos");
		System.out.println("user:" + "/" + user.getName() + "/" + user.getAddress());
	}
}

启动Spring Boot后,在浏览器中输入如下地址:

http://localhost:8081/redis-sentinel/addToRedis

Eclipse的控制台打印如下信息:

======当Redis中不存在这条数据时会执行这里=========
添加成功!
添加成功!

接着输入如下地址进行访问:

http://localhost:8081/redis-sentinel/getFromRedis

打印结果如下:

user:/mazhi/ordos
user:/mazhi/ordos

来看一下Redis的数据库,如下图所示。

看Key的生成形式,这就是调用我们在RedisSentinalConfig.java文件中指定的方法wiselyKeyGenerator()生成的。

看一下192.168.2.132上的redis,可以看到两个Redis的信息是同步的。

使用如下的命令来封闭192.168.2.129上的7001端口到达任何地方的路由,即人为造成了一次master服务的“宕机”。

/sbin/iptables -I INPUT -p tcp --dport 7001 -j DROP

Eclipse的控制台输出如下信息:

2016-04-01 09:02:35.188  INFO 6980 --- [       Thread-2] redis.clients.jedis.JedisSentinelPool    : Created JedisPool to master at 192.168.2.132:7002

master变为了192.168.2.132机器。或者我们可以在sentinel客户端查看,如下:

address已经变成了192.168.2.132了。

恢复192.168.2.129上的7001端口,输入如下的命令:

/sbin/iptables -I  INPUT -p tcp --dport 7001 -j ACCEPT

在192.168.2.129上输入如下命令查看:

./redis-cli -h 192.168.2.129 -p 7001

可以看到如下信息:

角色由以前的master变为slave了,而现在的master是192.168.2.132主机。

时间: 2024-08-04 18:24:35

剑指架构师系列-Redis集群部署的相关文章

剑指架构师系列-Redis安装与使用

1.安装Redis 我们在VMware中安装CentOS 64位系统后,在用户目录下下载安装Redis. 下载redis目前最稳定版本也是功能最完善,集群支持最好并加入了sentinel(哨兵-高可用)功能的redis-stable版, http://download.redis.io/releases/ wget http://download.redis.io/releases/redis-stable.tar.gz tar -xzvf redis-stable.tar.gz cd redi

剑指架构师系列-持续集成之Maven+Nexus+Jenkins+git+Spring boot

1.Nexus与Maven 先说一下这个Maven是什么呢?大家都知道,Java社区发展的非常强大,封装各种功能的Jar包满天飞,那么如何才能方便的引入我们项目,为我所用呢?答案就是Maven,只需要粘贴个Jar包的地址,Maven就会自动到网上查找引入到你的项目中.不过首先你的下载个Maven,然后指定一下 当下来的包包(jar)放到哪里. 我的版本是apache-maven-3.2.1,找到conf里面的配置文件 settings.xml,瞅瞅有没有 <localRepository>E:

剑指架构师系列-spring boot的logback日志记录

Spring Boot集成了Logback日志系统. Logback的核心对象主要有3个:Logger.Appender.Layout 1.Logback Logger:日志的记录器 主要用于存放日志对象,也可以定义日志类型.级别. 级别:ERROR.WARE.INFO.DEBUG和TRACE.没有FATAL,归纳到了ERROR级别里.ERROR.WARN and INFO level messages are logged by default. 在Spring Boot中,最好定义为logb

剑指架构师系列-Logstash分布式系统的日志监控

Logstash主要做由三部署组成: Collect:数据输入 Enrich:数据加工,如过滤,改写等 Transport:数据输出 下面来安装一下: wget https://download.elastic.co/logstash/logstash/logstash-2.3.2.tar.gz tar -zxvf logstash-2.3.2.tar.gz 在logstash-2.3.2目录下创建文件shipper.conf并配置: input { file { path => [ "/

剑指架构师系列-MySQL调优

介绍MySQL的调优手段,主要包括慢日志查询分析与Explain查询分析SQL执行计划 1.MySQL优化 1.慢日志查询分析 首先需要对慢日志进行一些设置,如下: SHOW VARIABLES LIKE 'slow_query_log'; -- 查看是否开启了慢查询 SET GLOBAL slow_query_log_file='/var/lib/mysql/mysql-slow.log'; -- 设置慢查询日志的位置 SET GLOBAL log_queries_not_using_inde

剑指架构师系列-Hibernate需要掌握的Annotation

1.一对多的关系配置 @Entity @Table(name = "t_order") public class Order { @Id @GeneratedValue private int id; private String name; /* * 该属性定义类和类之间的级联关系.定义的级联关系将被容器视为对当前类对象及其关联类对象采取相同的操作, * 而且这种关系是递归调用的.举个例子:Order 和OrderItem有级联关系,那么删除Order时将同时删除它所对 * 应的Or

剑指架构师系列-MySQL的安装及主从同步

1.安装数据库 wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm rpm -ivh mysql-community-release-el7-5.noarch.rpm yum install mysql-community-server 安装时使用root用户权限.安装成功后即可进行启动: /bin/systemctl restart mysqld.service 修改MySQL数据库root用户的密码,如

剑指架构师系列-Linux下的调优

1.I/O调优 CentOS下的iostat命令输出如下: $iostat -d -k 1 2 # 查看TPS和吞吐量 参数 -d 表示,显示设备(磁盘)使用状态:-k某些使用block为单位的列强制使用Kilobytes为单位:1 10表示,数据显示每隔1秒刷新一次,共显示2次. tps:该设备每秒的传输次数,也就是一次I/O请求.多个逻辑请求可能会被合并为"一次I/O请求"."一次传输"请求的大小是未知的. kB_read/s:每秒从设备读取的数据量:kB_wr

剑指架构师系列-持续集成之Maven实现项目的编译、发布和部署

Maven组织项目进行编译.部署 Maven项目基本的结构说明如下: mazhi  // 控制所有荐的编译.部署.发布 mazhi-app-parent  // 项目的父项目,有一些公共的设置可以被子项目继承 mazhi-core  // 基础服务项目,例如公共类等 mazhi-xxx 其中mazhi和mazhi-app-parent是pom格式,而mazhi-core是jar格式,还可以是 war等格式. 我们以新建mazhi和mazhi-core项目为例说明一下. 新建Maven-proje