redis 使用lettuce 啟動內存泄漏錯誤的解決方案
redis 使用 lettuce 出現(xiàn)
LEAK: hashedwheelTimer.release() was not called before it's garbage-collected. Enable advanced leak
內存泄漏。其實是內存不夠大導致。
找到eclispe 中window->preferences->Java->Installed JRE ,點擊右側的Edit 按鈕,在編輯界面中的 “Default VM Arguments ”選項中,填入如下值即可。
-Xms64m -Xmx128m
內存調的足夠大可解決。
另一種方法無法解決。不知道是不是方法設置不對的問題
1、打開eclipse配置文件eclipse.ini,更改把-Xmx(其數(shù)值代表jvm可以使用的最大內存數(shù))
2. 運行java程序時,選擇run->run configuration->arguments,輸入-Xms100M -Xmx800M(-Xms代表jvm啟動時分配的內存大小,-Xmx代表可最大分配多少內存)。
補充:Redis連接池Lettuce踩坑記錄
一、引言
近期項目頻繁部署不同測試環(huán)境,在搭建運行環(huán)境與部署項目過程中踩到了不少Redis的坑。項目是基于SpringBoot2.1.12,SpringBoot2.1.X集成jar包Spring-data-redis-start 使用Lettuce作為Redis連接池。
SpringBoot1.x默認采用Jedis作為redis客戶端連接池。
SpringBoot2.x,spring-data-redis 默認采用Lettuce作為redis客戶端驅動連接池。
二、踩坑場景
運行環(huán)境Redis集群中某個master節(jié)點不穩(wěn)定連接不上,導致SpringBoot應用連接Redis報錯,報錯連接timeout。
三、解決方案
基于Spring-data-redis重寫RedisConnectionFactory Bean。需要設置“取消校驗集群節(jié)點的成員關系”:.validateClusterNodeMembership(false)。
1、redis配置
spring: redis: cluster: nodes: - ${redis.host.cluster} #redis集群ip-port password: ${redis.password} timeout: 5000 #連接超時時間 lettuce: pool: max-active: 10 #連接池最大連接數(shù) max-wait: -1 #連接池最大阻塞時間 max-idle: 5 #連接池中最大空閑連接 min-idle: 1 #連接池中最小空閑連接 redis: cluster: enabled: true
2、Config配置類
@Data @Component @ConditionalOnProperty(name = "redis.cluster.enabled", havingValue = "true", matchIfMissing = false) public class RedisConfig { @Autowired RedisProperties redisProperties; // 在構建LettuceConnectionFactory時,如果不使用內置的destroyMethod,可能會導致Redis連接早于其它Bean被銷毀 @Bean(destroyMethod = "destroy") public RedisConnectionFactory newLettuceConnectionFactory() { // 配置用于開啟自適應刷新和定時刷新。如自適應刷新不開啟,Redis集群變更時將會導致連接異常 ClusterTopologyRefreshOptions clusterTopologyRefreshOptions = ClusterTopologyRefreshOptions.builder() .enablePeriodicRefresh(Duration.ofSeconds(60))// 開啟周期刷新(默認60秒) .enableAdaptiveRefreshTriggers(RefreshTrigger.ASK_REDIRECT,RefreshTrigger.UNKNOWN_NODE)// 開啟自適應刷新 .build(); ClusterClientOptions clusterClientOptions = ClusterClientOptions.builder() .topologyRefreshOptions(clusterTopologyRefreshOptions)//拓撲刷新 .disconnectedBehavior(ClientOptions.DisconnectedBehavior.REJECT_COMMANDS) .autoReconnect(true) .socketOptions(SocketOptions.builder().keepAlive(true).build()) .validateClusterNodeMembership(false)// 取消校驗集群節(jié)點的成員關系 .build(); LettuceClientConfiguration clientConfig = LettuceClientConfiguration.builder() .clientOptions(clusterClientOptions) .readFrom(ReadFrom.SLAVE_PREFERRED) .build(); return new LettuceConnectionFactory(getClusterConfiguration(), clientConfig); } private RedisClusterConfiguration getClusterConfiguration() { RedisProperties.Cluster clusterProperties = redisProperties.getCluster(); RedisClusterConfiguration config = new RedisClusterConfiguration(clusterProperties.getNodes()); if (clusterProperties.getMaxRedirects() != null) { config.setMaxRedirects(clusterProperties.getMaxRedirects()); } if (redisProperties.getPassword() != null) { config.setPassword(RedisPassword.of(redisProperties.getPassword())); } return config; } }
注意:
RedisClusterConfiguration getClusterConfiguration()需要設置Password,不然SpringBoot啟動報認證錯誤:
“io.lettuce.core.RedisCommandExecutionException: NOAUTH Authentication required”
如下:
另外,lettuce-core jar包版本不能過低,避免部分配置項無法支持,以上配置為lettuce-core-5.18.RELEASE.jar。
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關文章
Java開發(fā)之普通web項目轉為Maven項目的方法
這篇文章主要給大家介紹了關于Java開發(fā)之普通web項目轉為Maven項目的相關資料,文中通過圖文將轉換的方法步驟介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2017-12-12Java 實戰(zhàn)范例之員工管理系統(tǒng)的實現(xiàn)
讀萬卷書不如行萬里路,只學書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+vue+Springboot+ssm+mysql+maven+redis實現(xiàn)一個前后端分離的員工管理系統(tǒng),大家可以在過程中查缺補漏,提升水平2021-11-11SpringBoot調用第三方WebService接口的操作技巧(.wsdl與.asmx類型)
這篇文章主要介紹了SpringBoot調第三方WebService接口的操作代碼(.wsdl與.asmx類型 ),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-08-08