@Bean //TODO: replace with ReactiveStringRedisTemplate in future public ReactiveRedisTemplate<String, String> stringReactiveRedisTemplate( ReactiveRedisConnectionFactory reactiveRedisConnectionFactory) { RedisSerializer<String> serializer = new StringRedisSerializer(); RedisSerializationContext<String , String> serializationContext = RedisSerializationContext .<String, String>newSerializationContext() .key(serializer) .value(serializer) .hashKey(serializer) .hashValue(serializer) .build(); return new ReactiveRedisTemplate<>(reactiveRedisConnectionFactory, serializationContext); }
/** * Create a new {@link DefaultStreamReceiver} given {@link ReactiveRedisConnectionFactory} and * {@link org.springframework.data.redis.stream.StreamReceiver.StreamReceiverOptions}. * * @param connectionFactory must not be {@literal null}. * @param options must not be {@literal null}. */ @SuppressWarnings("unchecked") DefaultStreamReceiver(ReactiveRedisConnectionFactory connectionFactory, StreamReceiverOptions<K, V> options) { receiverOptions = options; RedisSerializationContext<K, Object> serializationContext = RedisSerializationContext .<K, Object> newSerializationContext(options.getKeySerializer()) // .key(options.getKeySerializer()).hashKey(options.getHashKeySerializer()) .hashValue(options.getHashValueSerializer()).build(); StreamReadOptions readOptions = StreamReadOptions.empty(); if (options.getBatchSize().isPresent()) { readOptions = readOptions.count(options.getBatchSize().getAsInt()); } if (!options.getPollTimeout().isZero()) { readOptions = readOptions.block(options.getPollTimeout()); } this.readOptions = readOptions; this.template = new ReactiveRedisTemplate(connectionFactory, serializationContext); if (options.getHashMapper() != null) { this.streamOperations = this.template.opsForStream(options.getHashMapper()); } else { this.streamOperations = this.template.opsForStream(); } }
/** * init ReactiveRedisTemplate. * * @param reactiveRedisConnectionFactory {@linkplain ReactiveRedisConnectionFactory} * @return {@linkplain ReactiveRedisTemplate} */ @Bean @Qualifier("reactiveRedisTemplate") public ReactiveRedisTemplate<String, String> stringReactiveRedisTemplate(final ReactiveRedisConnectionFactory reactiveRedisConnectionFactory) { RedisSerializer<String> serializer = new StringRedisSerializer(); RedisSerializationContext<String, String> serializationContext = RedisSerializationContext .<String, String>newSerializationContext() .key(serializer) .value(serializer) .hashKey(serializer) .hashValue(serializer) .build(); return new ReactiveRedisTemplate<>(reactiveRedisConnectionFactory, serializationContext); }
/** * Set the key {@link SerializationPair} given a {@link RedisSerializer}. * * @param serializer must not be {@literal null}. * @return {@literal this} builder. */ default RedisSerializationContextBuilder<K, V> key(RedisSerializer<K> serializer) { key(SerializationPair.fromSerializer(serializer)); return this; }
/** * Set the key {@link RedisElementReader} and {@link RedisElementWriter}. * * @param reader must not be {@literal null}. * @param writer must not be {@literal null}. * @return {@literal this} builder. */ default RedisSerializationContextBuilder<K, V> key(RedisElementReader<K> reader, RedisElementWriter<K> writer) { key(SerializationPair.just(reader, writer)); return this; }
/** * Set the key {@link SerializationPair} given a {@link RedisSerializer}. * * @param serializer must not be {@literal null}. * @return {@literal this} builder. */ default RedisSerializationContextBuilder<K, V> key(RedisSerializer<K> serializer) { key(SerializationPair.fromSerializer(serializer)); return this; }
/** * Set the key {@link RedisElementReader} and {@link RedisElementWriter}. * * @param reader must not be {@literal null}. * @param writer must not be {@literal null}. * @return {@literal this} builder. */ default RedisSerializationContextBuilder<K, V> key(RedisElementReader<K> reader, RedisElementWriter<K> writer) { key(SerializationPair.just(reader, writer)); return this; }
/** * Set the key {@link RedisElementReader} and {@link RedisElementWriter}. * * @param reader must not be {@literal null}. * @param writer must not be {@literal null}. * @return {@literal this} builder. */ default RedisSerializationContextBuilder<K, V> key(RedisElementReader<K> reader, RedisElementWriter<K> writer) { key(SerializationPair.just(reader, writer)); return this; }
private ReactiveRedisTemplate<String, Object> createReactiveRedisTemplate() { RedisSerializer<String> keySerializer = new StringRedisSerializer(); RedisSerializer<Object> defaultSerializer = (this.defaultRedisSerializer != null) ? this.defaultRedisSerializer : new JdkSerializationRedisSerializer(this.classLoader); RedisSerializationContext<String, Object> serializationContext = RedisSerializationContext .<String, Object>newSerializationContext(defaultSerializer) .key(keySerializer).hashKey(keySerializer).build(); return new ReactiveRedisTemplate<>(this.redisConnectionFactory, serializationContext); }
/** * Set the key {@link SerializationPair} given a {@link RedisSerializer}. * * @param serializer must not be {@literal null}. * @return {@literal this} builder. */ default RedisSerializationContextBuilder<K, V> key(RedisSerializer<K> serializer) { key(SerializationPair.fromSerializer(serializer)); return this; }