應用在Redis重啟、網絡閃斷並恢復正常后,應用必須能夠自恢復,下面以Java語言的jedis客戶端為例說明:
1、作為發布者
Jedis對象不能作為單例,網絡閃斷后該Jedis對象無法自恢復。應該每次發布消息時,從JedisPool中取Jedis對象,再調用set方法。
2、作為訂閱者
當網絡閃斷后psubscribe()方法不再阻塞並拋出異常,所以可以使用while循環,在循環內部處理異常,代碼如下:
while(true){ Jedis redis = this.jedisPool.getResource(); try{ redis.psubscribe(this, channelArray); }catch(JedisConnectionException e){ logger.warn("Exception :", e); logger.warn("Exit redis psubscribe, retry after 1 second"); }catch(Exception e){ logger.error("Exception:", e); } try{ Thread.sleep(1000); }catch(Exception unused){ } try{ if(redis != null){ redis.close(); } }catch(Exception unused){ } }