草庐IT

redis-cache

全部标签

java - Java实现定时刷新Cache

我的用例是对存储在持久性数据库中的数据维护内存缓存。我使用数据来填充UI上的条目列表/映射。在任何给定时间,UI上显示的数据都应尽可能更新(这可以通过缓存的刷新频率来完成)。常规缓存实现与此特定缓存之间的主要区别在于它需要定期批量刷新所有元素,因此与LRU类型的缓存有很大不同。我需要用Java来实现这个实现,如果有任何现有的框架可以用来围绕它们构建这个框架,那就太好了。我探索了GoogleGuava缓存库,但它更适合按条目刷新而不是批量刷新。没有简单的API可以刷新整个缓存。我们将不胜感激任何帮助。此外,如果可以逐步进行刷新,那就太好了,因为刷新整个缓存时出现的唯一限制是,如果缓存的大

java - Guava 的 Cache<K, Semaphore> 和 weakValues() 是线程安全的吗?

我需要一个按键锁定机制来保护按键绑定(bind)的关键部分。尽管ConcurrentMap对于并发就足够了,我也不希望map累积旧key并无限增长。理想情况下,数据结构最终(或之后立即)释放用于未使用锁的键的内存。我有点想Guava的Cache用weakValues()build会成功的:privatestaticfinalLoadingCacheKEY_MUTEX=CacheBuilder.newBuilder().weakValues().build(newCacheLoader(){@OverridepublicSemaphoreload(Kkey)throwsException

java - Spring Cache - 创建自定义 CacheManager

我正在使用SpringBoot和EhCache开发日历应用程序。我正在尝试缓存以下方法:@Override@Cacheable(value="concerts")publicListgetEvents(StringeventsForUser,DatestartDate,DateendDate)throwsException{returnfetchEventsFromTheServer(eventsForUser,startDate,endDate);}挑战是我想操纵返回的缓存结果。例如,检查是否有给定日期但不同用户的缓存,然后返回它(只要两个用户都满足特定条件)。所以,在返回结果之前我

Java 失败并显示 "Could not reserve enough space for code cache"

我有以下问题:$java-jarprogram.jarErroroccurredduringinitializationofVMCouldnotreserveenoughspaceforcodecache系统看到的内存量似乎足够:$free-mtotalusedfreesharedbufferscachedMem:5959640531800390-/+buffers/cache:2495710Swap:409904099我尝试将堆设置降低到16mb,但没有帮助:$java-Xmx16m-Xms16m-jarprogram.jarErroroccurredduringinitializa

java - 为什么不推荐使用 org.hibernate.cache.Cache?

不仅如此,org.hibernate.cache.Cache.CacheProvider也被弃用了。如果这些是那么我们应该如何创建我们自己的自定义缓存解决方案?替代方法? 最佳答案 JavaDoc解释一下:Thelegacy(andnowdeprecated)approachtocachingisdefinedbytheCacheProviderandCacheinterfacesaswellastheCacheConcurrencyStrategyinterfacealongwiththevariousimplementation

Redis——性能测试

📢📢📢📣📣📣哈喽!大家好,我是【一心同学】,一位上进心十足的【Java领域博主】!😜😜😜✨【一心同学】的写作风格:喜欢用【通俗易懂】的文笔去讲解每一个知识点,而不喜欢用【高大上】的官方陈述。✨【一心同学】博客的领域是【面向后端技术】的学习,未来会持续更新更多的【后端技术】以及【学习心得】。✨如果有对【后端技术】感兴趣的【小可爱】,欢迎关注【一心同学】💞💞💞❤️❤️❤️感谢各位大可爱小可爱!❤️❤️❤️ 目录一、为什么需要性能测试?二、语法格式三、执行性能测试小结一、为什么需要性能测试?性能测试可以让我们了解Redis服务器的性能优劣。在实际的业务场景中,性能测试是必不可少的。在业务系统上线之前

java - 通过 JDBC 将 DDL 与 SELECT 混合时为 "ERROR: cached plan must not change result type"

我在通过JDBC使用PostgreSQL时遇到了一个有趣的问题(无法在JDBC之外重现),我得到了一个“ERROR:cachedplanmustnotchangeresulttype”重现此问题的最简单方法是使用以下代码:Connectionc=getConnection();c.setAutoCommit(true);Liststatements=Arrays.asList("createtablet(aint)","select*fromt","altertabletaddbint","select*fromt","altertabletaddcint","select*fromt

java - Redis token 存储

我想在集群环境中部署我的RESTAPI。为此,我需要将我的OAuth2.0token存储在共享token存储中。目前我正在使用SpringSecurity的InMemoryTokenStore,它不能在多节点集群上共享。我打算使用Redis存储token。我发现最新版本的Spring-SecurityOAuth即2.8.0也提供了RedisTokenStore。我对此有一些疑问:在现有的spring-securityxml配置中使用RedisTokenStore需要进行哪些更改。目前我正在使用InMemoryTokenStore。如何使RedisTokenStore可与集群中的所有节点

Redis集群和Lettuce 配置

Redis官方推荐的java客户端三大客户端Jedis、lettuce、Redissonlettuce、jedis、Redisson三者比较:jedis提供全面的指令支持,在多线程环境下是非线程安全的,性能比较差;lettuce的连接是基于Netty的,连接实例可以在多个线程间并发访问;Jedis和lettuce是比较纯粹的Redis客户端,几乎没提供什么高级功能;Redisson实现了分布式和可扩展的Java数据结构,和Jedis相比,功能较为简单,不支持字符串操作,不支持排序、事务、管道、分区等Redis特性。Redisson的宗旨是促进使用者对Redis的关注分离,从而让使用者能够将精力

java.lang.RuntimeException : ERROR: Failed to recover corrupt cache entry 错误

我刚从我的一位用户那里收到这条错误消息。(IE8,Java1.6.20)。它来自一个小程序,该小程序从Javascript接收指令并在客户端执行某些过程。RangeErrorjava.lang.RuntimeException:ERROR:Failedtorecovercorruptcacheentryatcom.sun.deploy.cache.CacheEntry.recoveratcom.sun.deploy.cache.CacheEntry.getSignerMapatcom.sun.deploy.cache.CachedJarFile.getSignerMapatcom.su