Redis多配置

application.yml

# application.yml
server:
  port: 8001
  
spring:
#redis集群
  redis:
    open:
        host: 127.0.0.1
        port: 6379
        timeout: 20000
        auth: null
    dmp:
        host: 127.0.0.1
        port: 6379
        timeout: 20000
        password: 'password'

配置类

package com.octupus.rta_lixian.config;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.util.StringUtils;
import redis.clients.jedis.JedisPoolConfig;

/**
 * @Author: Willis
 * @Date: 2020/4/28 10:57
 */

@Configuration
public class RedisTemplateConfig {
    //open
    @Value("${spring.redis.open.host}")
    private String openHost;
    @Value("${spring.redis.open.port}")
    private Integer openPort;
    @Value("${spring.redis.open.auth}")
    private String openPassword;
//    @Value("${spring.redis.open.database}")
//    private Integer openDatabase;

    //dmpdb
    @Value("${spring.redis.dmp.host}")
    private String dmpHost;
    @Value("${spring.redis.dmp.port}")
    private Integer dmpPort;
    @Value("${spring.redis.dmp.password}")
    private String dmpPassword;
//    @Value("${spring.redis.dmp.database}")
//    private Integer dmpDatabase;

    private static final int MAX_IDLE = 200; //最大空闲连接数
    private static final int MAX_TOTAL = -1; //最大连接数
    private static final long MAX_WAIT_MILLIS = 2000; //建立连接最长等待时间


    //配置工厂
    public RedisConnectionFactory connectionFactory(String host, int port, String password, int maxIdle,
                                                    int maxTotal, long maxWaitMillis) {
        JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory();
        jedisConnectionFactory.setHostName(host);
        jedisConnectionFactory.setPort(port);

        if (!StringUtils.isEmpty(password)) {
            jedisConnectionFactory.setPassword(password);
        }

        jedisConnectionFactory.setPoolConfig(poolConfig(maxIdle, maxTotal, maxWaitMillis, false));
        jedisConnectionFactory.afterPropertiesSet();
        return jedisConnectionFactory;
    }

    //连接池配置
    public JedisPoolConfig poolConfig(int maxIdle, int maxTotal, long maxWaitMillis, boolean testOnBorrow) {
        JedisPoolConfig poolConfig = new JedisPoolConfig();
        poolConfig.setMaxIdle(maxIdle);
        poolConfig.setMaxTotal(maxTotal);
        poolConfig.setMaxWaitMillis(maxWaitMillis);
        poolConfig.setTestOnBorrow(testOnBorrow);
        return poolConfig;
    }


    @Bean(name = "redisTemplateopen")
    public StringRedisTemplate redisTemplateOpen() {
        StringRedisTemplate template = new StringRedisTemplate();
        template.setConnectionFactory(
                connectionFactory(openHost, openPort, openPassword, MAX_IDLE, MAX_TOTAL, MAX_WAIT_MILLIS));
        return template;
    }


    @Bean(name = "redisTemplatedmp")
    public StringRedisTemplate redisTemplateDmp() {
        StringRedisTemplate template = new StringRedisTemplate();
        template.setConnectionFactory(
                connectionFactory(dmpHost, dmpPort, dmpPassword, MAX_IDLE, MAX_TOTAL, MAX_WAIT_MILLIS));
        return template;
    }
}

使用示例

	@Resource(name = "redisTemplateopen")
    StringRedisTemplate openJedisService;
    openJedisService.opsForValue().get(Key)
    openJedisService.opsForValue().set(Key, "0")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于 Redis 的多数据源配置,你可以通过以下步骤来实现: 1. 在 Redis配置文件中,一般是 redis.conf 文件,你可以通过 `redis-server --help` 命令查看该文件的位置。开该文件并进行以下操作: 2. 复制一份默认的配置,并为每个数据源设置不同的端口号和数据目录。例如,你可以在配置文件中添加以下内容: ``` # 第一个数据源 port 6379 dir /var/lib/redis/redis1 # 第二个数据源 port 6380 dir /var/lib/redis/redis2 # 其他数据源... ``` 这里我们假设你要配置两个数据源,分别使用端口号 6379 和 6380,并分别使用不同的数据目录。 3. 保存并关闭配置文件。 4. 启动 Redis 服务器时,使用不同的配置文件启动多个实例。可以通过以下命令来启动两个实例: ``` redis-server /path/to/redis.conf redis-server /path/to/redis.conf --port 6380 ``` 这样就会启动两个 Redis 实例,分别使用不同的配置文件和端口号。 5. 现在你就可以通过不同的端口号来访问不同的 Redis 数据库了。例如,使用端口号 6379 访问第一个数据源,使用端口号 6380 访问第二个数据源。 请注意,这只是一种简单的方法来配置 Redis 的多数据源,你也可以使用 Redis Cluster 或者类似的工具来管理多个 Redis 实例。另外,确保每个实例的配置文件中的端口号、数据目录等设置是正确的,并且能够与你的应用程序进行连接。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值