Spring Data Redis(Repositories-CDI integration)

CDI integration 集成CDI

仓储接口的实例通常都是通过容器来创建的,当使用Spring Data时,自然会选择Spring作为容器。这方面的支持已经想到成熟,可以轻松的建立Spring容器,来创建bean 实例。给Spring Data Redis 配备一个自定义的CDI扩展,使得可以在CDI 环境中使用仓储抽象封装。这个扩展是JAR 的一部分,所有你需要做的就是激活它,将Spring Data Redis JAR放入你的classpath 中。

通过实现一个CDI Producer,为RedisConnectionFactory 和RedisOperations 构建基础设施:

class RedisOperationsProducer {


  @Produces
  RedisConnectionFactory redisConnectionFactory() {

    JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory();
    jedisConnectionFactory.setHostName("localhost");
    jedisConnectionFactory.setPort(6379);
    jedisConnectionFactory.afterPropertiesSet();

    return jedisConnectionFactory;
  }

  void disposeRedisConnectionFactory(@Disposes RedisConnectionFactory redisConnectionFactory) throws Exception {

    if (redisConnectionFactory instanceof DisposableBean) {
      ((DisposableBean) redisConnectionFactory).destroy();
    }
  }

  @Produces
  @ApplicationScoped
  RedisOperations<byte[], byte[]> redisOperationsProducer(RedisConnectionFactory redisConnectionFactory) {

    RedisTemplate<byte[], byte[]> template = new RedisTemplate<byte[], byte[]>();
    template.setConnectionFactory(redisConnectionFactory);
    template.afterPropertiesSet();

    return template;
  }

}

必要的设置取决于你运行的JavaEE 环境。

Spring Data Redis CDI 扩展将收集所有可用的仓储库作为CDI bean,并在容器请求一个仓储类型的bean时,创建一个Spring Data 仓储的代理:

class RepositoryClient {

  @Inject
  PersonRepository repository;

  public void businessMethod() {
    List<Person> people = repository.findAll();
  }
}

Redis 仓储需要RedisKeyValueAdapter 和RedisKeyValueTemplate 的实例。如果这些beans 不存在,Spring Data CDI 的扩展会创建并管理它们。不管怎样,可以提供自己的beans 来配置RedisKeyValueAdapter 和RedisKeyValueTemplate的特定属性。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值