All Classes
-
All Classes Interface Summary Class Summary Class Description DefaultLettuceConnectionFactory LettuceAsyncCommandsWrapper LettuceCache<K,V> redis缓存没有使用常用的strings类型来搞 使用了hash作为缓存存储模式带来一个问题:redis官方至今没有打算支持hash的field的ttl。 因此需要自己实现针对hash的field的ttl。 为value对象创建包装类ValueWrapper,记录过期时间戳。获取缓存对象的时候查看对象是否已经过期。 对于每个key对象放入一个sortset,以过期时间戳作为分数,创建定时任务定期从sortset和hash 中移除缓存对象。 为了保证数据不会出现永久停留在redis中的问题,设置缓存的过期时间统一为凌晨3点,缓存的凌晨过期 不会造成业务的突然抖动,也能定时清理所有的缓存对象 todo 考虑到对象双写的问题,需要将同时操作sortset和hash的对象移除功能处理为一个 todo 原子操作,需要使用lua脚本来搞。LettuceCache.ValueWrapper<V> LettuceCacheFactory LettuceCacheOptions<K,V> LettuceCommandsWrapper<K,V> LettuceConnectionFactory LettuceConnectionFactory.LettuceConnection ProtostuffCodec<K,V>