溫馨提示×

溫馨提示×

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

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

遷Aliyun Redis遇到的坑分析

發(fā)布時間:2021-11-15 15:39:08 來源:億速云 閱讀:120 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要介紹“遷Aliyun Redis遇到的坑分析”,在日常操作中,相信很多人在遷Aliyun Redis遇到的坑分析問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”遷Aliyun Redis遇到的坑分析”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

背景:

從自建 redis(CacheCloud)到遷移到 aliyun redis

1. 踩“坑”一

問題:
平常小伙伴們在項目中可能用到redis key expire nofity的場景(比如:處理延時任務(wù)等),但是發(fā)現(xiàn)遷移后 key 過期通知總是比未遷移之前的時間慢一個數(shù)量級(基本上分鐘級別,社區(qū)版基本上秒級別),及時在很少的 key 情況也是一樣的;之前也和 aliyun support 小伙伴溝通過,給出反饋都一個星期多了~
定位:
了解過 redis 的過期策略以及淘汰策略的小伙伴,應(yīng)該都知道針對惰性刪除測試,是遍歷整個 db,隨機選取 20 個 key(默認),淘汰;但是,aliyun redis(使用的是 4.x 版本)的默認 db 數(shù)是 256(社區(qū)版的是 16)
解決:
調(diào)整項目 redis db 數(shù)為16

2. 踩“坑”二

問題:
遷移后的 redis,在域名(aliyun redis 針對社區(qū)版的主從,哨兵,集群模式等暴露出一個域名)指向 ip 發(fā)生變化的時候,客戶端通過域名訪問的時候,依然解析指向的是老的 ip,導(dǎo)致連接不上 redis~
定位:
查看 JedisConnectionFactory 的源碼可以發(fā)現(xiàn)(以集群為例),在初始化 afterPropertiesSet 時,已經(jīng)將域名解析成對應(yīng)的 ip 緩存起來了,故之后域名切換 ip 后,依然訪問的是之前的 ip

private JedisCluster createCluster() {

		JedisCluster cluster = createCluster(this.clusterConfig, getPoolConfig());
		JedisClusterConnection.JedisClusterTopologyProvider topologyProvider = new JedisClusterConnection.JedisClusterTopologyProvider(cluster);
		this.clusterCommandExecutor = new ClusterCommandExecutor(topologyProvider,
				new JedisClusterConnection.JedisClusterNodeResourceProvider(cluster, topologyProvider), EXCEPTION_TRANSLATION);
		return cluster;
	}

遷Aliyun Redis遇到的坑分析

解決:
切換域名 ip 后重啟服務(wù)

到此,關(guān)于“遷Aliyun Redis遇到的坑分析”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI