中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

Spring使用redis時的常見問題及解決方法

發布時間:2021-03-10 15:37:25 來源:億速云 閱讀:248 作者:TREX 欄目:編程語言

這篇文章主要介紹“Spring使用redis時的常見問題及解決方法”,在日常操作中,相信很多人在Spring使用redis時的常見問題及解決方法問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Spring使用redis時的常見問題及解決方法”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!


本人在spring中使用redis作為緩存時,遇到兩個坑,現在記錄如下,算是作為自己的備忘吧,文筆不好,望大家見諒;

一、配置文件

<!-- 加載Properties文件 -->
  <bean id="configurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
    <property name="locations">
      <list>
        <value>classpath*:config.properties</value>
      </list>
    </property>
    <property name="ignoreUnresolvablePlaceholders" value="true"/>
  </bean>

  <!-- 配置JedisPoolConfig實例 -->
  <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
    <!--最大空閑數,數據庫連接的最大空閑時間。超過空閑時間,數據庫連接將被標記為不可用,然后被釋放。設為0表示無限制-->
    <property name="maxIdle" value="300" />
    <!--連接池的最大數據庫連接數。設為0表示無限制-->
    <property name="maxTotal" value="600" />
    <!--最大建立連接等待時間。如果超過此時間將接到異常。設為-1表示無限制-->
    <property name="maxWaitMillis" value="1000" />
    <!--在borrow一個jedis實例時,是否提前進行alidate操作;如果為true,則得到的jedis實例均是可用的-->
    <property name="testOnBorrow" value="true" />
    <!--每次逐出檢查時 逐出的最大數目 如果為負數就是 : 1/abs(n), 默認3-->
    <property name="numTestsPerEvictionRun" value="3"/>
    <!--逐出連接的最小空閑時間 默認1800000毫秒(30分鐘)-->
    <property name="minEvictableIdleTimeMillis" value="300000"/>
    <!--逐出掃描的時間間隔(毫秒) 如果為負數,則不運行逐出線程, 默認-1-->
    <property name="timeBetweenEvictionRunsMillis" value="60000"/>
    <!--在空閑時檢查有效性, 默認false -->
    <property name="testWhileIdle" value="true" />
  </bean>

  <!-- 配置JedisConnectionFactory,類似于數據庫的連接池 -->
  <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
    <property name="hostName" value="${redis.host}"></property>
    <property name="port" value="${redis.port}"></property>
    <property name="password" value="${redis.password}"></property>
    <property name="database" value="${redis.dbIndex}"></property>
    <property name="poolConfig" ref="jedisPoolConfig"></property>
    <property name="timeout" value="100000"></property>
  </bean>

  <!-- 配置RedisTemplate -->
  <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
    <property name="connectionFactory" ref="jedisConnectionFactory"></property>
    <!--如果不配置Serializer,那么存儲的時候缺省使用String,如果用User類型存儲,那么會提示錯誤User can't cast to String!! -->
    <property name="keySerializer" >
      <bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
    </property>
    <property name="valueSerializer" >
      <bean class="org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer" />
    </property>
    <property name="hashKeySerializer">
      <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
    </property>
    <property name="hashValueSerializer">
      <bean class="org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer"/>
    </property>
    <!--開啟事務 -->
    <property name="enableTransactionSupport" value="true"></property>
  </bean>

  注:可以看到我redis的配置中,對于hash的key使用的是StringRedisSerializer序列化,而對于value使用的是GenericJackson2JsonRedisSerializer序列化。

二、坑一

// 源代碼
HashOperations ho = redisTemplate.opsForHash();
Boolean flag = ho.hasKey(“key”, "key1");
if (flag) {
  // 處理邏輯
}

  上面這段代碼,當redis中值不存在時,按照官方的說明文檔,應該返回false。但是我使用的時候,hasKey方法時而返回的是null,時而返回的false,導致空指針異常。搞了半天我也沒搞明白為啥返回false,最后沒辦法我妥協了(大神如果知道可以回復我)。

// 妥協后代碼
HashOperations ho = redisTemplate.opsForHash();
Boolean flag = ho.hasKey(“key”, "key1");
if (flag != null && flag) {
  // 處理邏輯
}

三、坑二

// 將Map放到redis的hash中
  public void putRedisHash2(){
    HashOperations ho = redisTemplate.opsForHash();
    Map<String, Boolean> tempMap = new HashMap<String, Boolean>(3){{
      put("isRegistered",false);
      put("isWeChat",false);
      put("isAliPay",false);
    }};
    ho.put("key", "key1", tempMap);
  }

  // 將Map放到redis的hash中
  public void putRedisHash3(){
    HashOperations ho = redisTemplate.opsForHash();
    Map<String, Boolean> tempMap = new HashMap<String, Boolean>(3);
    tempMap.put("isRegistered",false);
    tempMap.put("isWeChat",false);
    tempMap.put("isAliPay",false);
    ho.put("key", "key1", tempMap);
  }

  這兩個方法的功能是一樣的,但是第一個方法是在Map初始化同時將值放入其中,第二個方法是Map初始化以后將值放入其中,執行結果是一樣,但是在redis中的存儲形式完全不同。由于Hash的value使用的是GenericJackson2JsonRedisSerializer序列化,所以為了反序列化方便,它會存儲

@class“”這個字段,由于Map初始化時機不同,導致相同內容在redis中@class內容不一致,為了使用方便,推薦第二種,即在Map初始化以后將值放入其中。

Spring使用redis時的常見問題及解決方法

到此,關于“Spring使用redis時的常見問題及解決方法”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

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

AI

光泽县| 互助| 仙桃市| 康定县| 通州区| 金华市| 苏尼特左旗| 化隆| 台湾省| 金阳县| 长沙市| 闽清县| 宜兰县| 宝山区| 湖北省| 加查县| 武陟县| 蒙自县| 平安县| 建瓯市| 炎陵县| 梧州市| 洞口县| 清涧县| 甘谷县| 曲靖市| 营山县| 筠连县| 上栗县| 遂昌县| 镇安县| 南雄市| 牙克石市| 托里县| 吴川市| 宣城市| 黄大仙区| 平舆县| 尼勒克县| 咸丰县| 徐闻县|