91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

springboot2整合lettuce啟動卡住問題的解決方法是什么

發布時間:2021-12-27 11:32:42 來源:億速云 閱讀:289 作者:柒染 欄目:開發技術

本篇文章給大家分享的是有關springboot2整合lettuce啟動卡住問題的解決方法是什么,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

前言

EasyCache升級兼容 Springboot2,有個業務系統啟動總是會卡住,最后拋出超時異常,如下:

java.util.concurrent.TimeoutException: null

	at java.util.concurrent.FutureTask.get(FutureTask.java:205)

.....

springboot 版本是 2.2.x,springCloudVersion 版本是 2.2.x, lettuce版本是5.2.x,如果使用jedis客戶端沒有,所以問題一定是出在lettuce。

分析原因

如果是線上發生這個問題會使用 jstack 查看線程的情況,在本地idea調試就更加方便了,查看線程發現lettuce的線程被Blocked,dump出的部分信息如下:

"lettuce-kqueueEventLoop-7-1@14257" daemon prio=5 tid=0x4c nid=NA waiting for monitor entry

  java.lang.Thread.State: BLOCKED

 waiting for main@1 to release lock on <0x38a5> (a java.util.concurrent.ConcurrentHashMap)

  at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:208)

  at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:321)

  ....

看第一行的報錯是在獲取Bean的時候阻塞了,說明有地方獲取Bean的時候沒有釋放鎖。在這地方打斷點發現是 spring-cloud-sleuth 的 SamplerAutoConfiguration獲取bean的時候有鎖沒有釋放。源代碼如下

protected static class RefreshScopedSamplerConfiguration {
	public Sampler defaultTraceSampler(SamplerProperties config) {
		return samplerFromProps(config);
	}
}

@RefreshScope 獲取代理類的時候如果是@PostConstruct的方法,bean是加載不到,所以導致一直沒有釋放鎖。所以猜想,容器還沒有啟動完成的時候,有地方調用了lettuce的Bean,導致循環依賴。

坑的復現及解決辦法

運行下面這段代碼,錯誤就出現了,和業務系統出現的問題一模一樣,也驗證了上面的猜想。解決辦法是在容器啟動之后在調用init方法。(實測使用InitializingBean時也會出現該問題)

public class SpringDataTestService {
    private StringRedisTemplate stringRedisTemplate;
    //@EventListener(MainContextRefreshedEvent.class)
    public void init() {
        String s = stringRedisTemplate.opsForValue().get("gateway:ab-test:config");
        System.out.println(s);
    }
}

以上就是springboot2整合lettuce啟動卡住問題的解決方法是什么,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

大邑县| 定西市| 台山市| 沁阳市| 黄骅市| 于都县| 巢湖市| 宣城市| 龙江县| 临邑县| 松溪县| 西贡区| 久治县| 德保县| 明水县| 名山县| 新建县| 库车县| 清流县| 新竹市| 莱州市| 四川省| 尼木县| 洛宁县| 广南县| 于田县| 增城市| 台北市| 吴桥县| 安国市| 南安市| 泉州市| 胶南市| 虹口区| 扎赉特旗| 东兰县| 广宁县| 盐边县| 定结县| 江川县| 甘孜县|