欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring?redis使用報錯Read?timed?out排查及解決過程

 更新時間:2024年02月13日 09:55:12   作者:堅持是一種態(tài)度  
項目使用spring集成redis,偶爾會出現(xiàn)read timed out的情況,剛開始以為是網(wǎng)絡(luò)不穩(wěn)定引起的,后面發(fā)現(xiàn)影響業(yè)務(wù)測試的準(zhǔn)確性,這篇文章主要給大家介紹了關(guān)于Spring redis使用報錯Read timed out排查及解決過程的相關(guān)資料,需要的朋友可以參考下

使用場景

  • 我們使用redis作為緩存服務(wù),緩存一些業(yè)務(wù)數(shù)據(jù),如路口點位信息、渠化信息、設(shè)備信息等
  • 有一些需要實時計算的數(shù)據(jù),緩存在redis里,如實時信號周期相位、周期內(nèi)過車數(shù)量等
  • 有需要不同服務(wù)訪問的數(shù)據(jù),使用redis作為共同可訪問操作的緩存空間

報錯信息

  • 在數(shù)據(jù)庫數(shù)據(jù)變動時,需要清楚redis里的緩存,等下次查詢需要時從數(shù)據(jù)庫查詢,再寫入redis
  • 此時刪除數(shù)據(jù)報錯,核心報錯信息Read timed out,連接超時

    在這里插入圖片描述

  • 檢查了下,redis服務(wù)正常
  • 具體報錯信息,分兩個時間點的報錯,(截取部分)如下:
  • 報錯日志一JedisConnectionException:
2023-03-29 10:54:38.186 ERROR 9136 --- [ntainer#7-0-C-1] c.n.r.service.IntersectionQueryService   : Exception in getIntersectionById() with cause = 'redis.clients.jedis.exceptions.JedisConnectionException: java.net.SocketTimeoutException: Read timed out' and exception = 'java.net.SocketTimeoutException: Read timed out; nested exception is redis.clients.jedis.exceptions.JedisConnectionException: java.net.SocketTimeoutException: Read timed out'

org.springframework.data.redis.RedisConnectionFailureException: java.net.SocketTimeoutException: Read timed out; nested exception is redis.clients.jedis.exceptions.JedisConnectionException: java.net.SocketTimeoutException: Read timed out
	at org.springframework.data.redis.connection.jedis.JedisExceptionConverter.convert(JedisExceptionConverter.java:65)
	at org.springframework.data.redis.connection.jedis.JedisExceptionConverter.convert(JedisExceptionConverter.java:42)
	at org.springframework.data.redis.PassThroughExceptionTranslationStrategy.translate(PassThroughExceptionTranslationStrategy.java:44)
	at org.springframework.data.redis.FallbackExceptionTranslationStrategy.translate(FallbackExceptionTranslationStrategy.java:42)
	at org.springframework.data.redis.connection.jedis.JedisConnection.convertJedisAccessException(JedisConnection.java:187)
	at org.springframework.data.redis.connection.jedis.JedisConnection.doWithJedis(JedisConnection.java:802)
  • 報錯日志二 Error while validating pooled Jedis object:
2023-08-24 09:44:23.721 ERROR 92250 --- [ns-pool-evictor] redis.clients.jedis.JedisFactory         : Error while validating pooled Jedis object.

redis.clients.jedis.exceptions.JedisConnectionException: java.net.SocketTimeoutException: Read timed out
	at redis.clients.jedis.util.RedisInputStream.ensureFill(RedisInputStream.java:205)
	at redis.clients.jedis.util.RedisInputStream.readByte(RedisInputStream.java:43)
	at redis.clients.jedis.Protocol.process(Protocol.java:162)
	at redis.clients.jedis.Protocol.read(Protocol.java:227)
	at redis.clients.jedis.Connection.readProtocolWithCheckingBroken(Connection.java:352)
	at redis.clients.jedis.Connection.getStatusCodeReply(Connection.java:270)
	at redis.clients.jedis.BinaryJedis.ping(BinaryJedis.java:380)
	at redis.clients.jedis.JedisFactory.validateObject(JedisFactory.java:214)
	at org.apache.commons.pool2.impl.GenericObjectPool.evict(GenericObjectPool.java:745)
	at org.apache.commons.pool2.impl.BaseGenericObjectPool$Evictor.run(BaseGenericObjectPool.java:160)

解決方式

  • 報錯信息很明顯,“Read timed out”超時錯誤,通常會有以下幾種可能:
  • 1、Redis服務(wù)端問題導(dǎo)致無法連接或連接出現(xiàn)問題,可以通過檢查Redis服務(wù)端日志或查看Redis服務(wù)器狀態(tài)來確認(rèn)
  • Redis未正常在運行,異常終止,或者啟動失敗
  • 未正確在程序里配置連接ip端口參數(shù),例如ip錯誤使用localhost,又不在一臺機(jī)器上
  • 2、 網(wǎng)絡(luò)連接不穩(wěn)定或延遲導(dǎo)致Redis連接超時??梢試L試更改網(wǎng)絡(luò)環(huán)境或增加Redis客戶端連接超時時間。
  • 檢查程序服務(wù)于redis之間的網(wǎng)絡(luò)是否聯(lián)通,是否存在明顯延遲
  • 可以修改Spring redis配置參數(shù),增加連接超時時間
  • Redis服務(wù)器負(fù)載過高或使用Redis的其他應(yīng)用程序占用了太多的資源,導(dǎo)致Redis無法響應(yīng)請求??梢酝ㄟ^檢查Redis服務(wù)器的負(fù)載或性能參數(shù)來確定是否存在此問題。

  • 檢查服務(wù)器情況,確保內(nèi)存和磁盤空間充足,檢查已使用內(nèi)存、剩余內(nèi)存、已使用磁盤、剩余磁盤等
  • 簡單來說,你的服務(wù)對redis的使用頻率,如果讀寫很高很頻繁、數(shù)據(jù)內(nèi)容很多,就提供比較好的服務(wù)器,或者搭建redis集群
  • 也可以優(yōu)化Spring redis配置參數(shù),增加最大線程數(shù)、空閑線程數(shù)、連接超時時間等
  • 應(yīng)用程序本身存在性能瓶頸或異常,導(dǎo)致Redis的操作時間過長??梢詸z查應(yīng)用程序代碼和運行日志,查找可能導(dǎo)致性能問題的因素

  • 如果比較大的集合對象在redis存取,會占用很多內(nèi)存,高并發(fā)情況下,可能做不到及時響應(yīng),可以只緩存必要的字段屬性
  • 大量的key值,同時加到redis里面,又在一段時間后同時失效,造成瞬時壓力過大,這要在業(yè)務(wù)上做一些隨機(jī)失效時間
  • 針對以上情況,我們可以使用不同的解決方法來解決問題。例如,可以優(yōu)化Redis服務(wù)器的配置和設(shè)置,更改Redis客戶端連接超時時間,或調(diào)整應(yīng)用程序性能等。
  • 我們此次檢查后的改動如下:
spring:
  redis:
    jedis:
      pool:
        min-idle: 10
        max-idle: 300  # 改大了
        max-wait: 30000  # 改大了
        max-active: 200  # 改大了
  • 對應(yīng)到我們的docker-compose.yml
  core-app:
    image: june
    container_name: core
    volumes:
      - /etc/localtime:/etc/localtime
    depends_on:
      - postgresql
      - redis
    environment:
      - _JAVA_OPTIONS=-Xmx6G -Xms1G
      - SERVER_PORT=8181
      - SPRING_PROFILES_ACTIVE=prod,api-docs,no-liquibase
      - SPRING_DATASOURCE_URL=jdbc:postgresql://postgresql:5432/core
      - SPRING_DATASOURCE_USERNAME=xxxx
      - SPRING_DATASOURCE_PASSWORD=xxxxxxx
      - SPRING_REDIS_HOST=redis
      - SPRING_REDIS_PASSWORD=xxxxxxxx
      - spring_redis_jedis_pool_maxIdle=300 # redis配置
      - spring_redis_jedis_pool_maxWait=30000
      - spring_redis_jedis_pool_maxActive=200
    restart: on-failure

總結(jié)

到此這篇關(guān)于Spring redis使用報錯Read timed out排查及解決過程的文章就介紹到這了,更多相關(guān)Spring redis報錯Read timed out內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • redis中刪除操作命令

    redis中刪除操作命令

    這篇文章主要介紹了redis中刪除操作命令,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Redis實戰(zhàn)記錄之限制操作頻率

    Redis實戰(zhàn)記錄之限制操作頻率

    這篇文章主要給大家介紹了關(guān)于Redis實戰(zhàn)記錄之限制操作頻率的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • redis服務(wù)器允許遠(yuǎn)程主機(jī)訪問的方法

    redis服務(wù)器允許遠(yuǎn)程主機(jī)訪問的方法

    今天小編就為大家分享一篇redis服務(wù)器允許遠(yuǎn)程主機(jī)訪問的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • Redis排查大key的3種方法小結(jié)

    Redis排查大key的3種方法小結(jié)

    本文主要介紹了Redis排查大key的3種方法小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08
  • Redis可視化連接服務(wù)器的方法

    Redis可視化連接服務(wù)器的方法

    這篇文章主要介紹了Redis可視化連接服務(wù)器的方法,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • 詳解在Redis在Centos7上的安裝部署

    詳解在Redis在Centos7上的安裝部署

    Redis是一種高級key-value數(shù)據(jù)庫。這篇文章主要介紹了詳解在Redis在Centos7上的安裝部署,有興趣的可以了解一下。
    2016-12-12
  • 為什么斷電后Redis數(shù)據(jù)不會丟失

    為什么斷電后Redis數(shù)據(jù)不會丟失

    Redis 作為一款內(nèi)存數(shù)據(jù)庫,被廣泛使用于緩存,分布式鎖等場景,那么假如斷電或者因其他因素導(dǎo)致 Reids 服務(wù)宕機(jī),在重啟之后數(shù)據(jù)會丟失嗎?本文就來介紹與一下
    2021-08-08
  • Redis IP地址的綁定的實現(xiàn)

    Redis IP地址的綁定的實現(xiàn)

    這篇文章主要介紹了Redis IP地址的綁定的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • YII2框架手動安裝Redis擴(kuò)展的過程

    YII2框架手動安裝Redis擴(kuò)展的過程

    這篇文章主要介紹了YII2框架手動安裝Redis擴(kuò)展的過程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • 淺談redis緩存在項目中的使用

    淺談redis緩存在項目中的使用

    最近由于項目需要,在系統(tǒng)緩存服務(wù)部分上用到了redis,本文就淺談下在redis緩存在項目中的使用,感興趣的小伙伴們可以參考一下
    2021-05-05

最新評論