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的特定属性。

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐