日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

redis java切片_jedis 单点配置

發布時間:2023/11/27 生活经验 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 redis java切片_jedis 单点配置 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

pom引入jar包

redis.clients

jedis

2.9.0

spring 配置

type="int" />

redis.properties配置文件

redis.ip=127.0.0.1

redis.port=6379

redis.timeout=10000

#最大分配的對象數

redis.pool.maxActive=1024

#最大能夠保持idel狀態的對象數

redis.pool.maxIdle=50

#當池內沒有返回對象時,最大等待時間

redis.pool.maxWait=2000

#當調用borrow Object方法時,是否進行有效性檢查

redis.pool.testOnBorrow=true

RedisUtil.java工具類

/**

*Class Description:

*

*/

package com.redis;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import redis.clients.jedis.ShardedJedis;

import redis.clients.jedis.ShardedJedisPool;

/**

* 連接和使用redis資源的工具類

*

* @author

*

*/

public class RedisUtil {

private static final Logger log = LoggerFactory.getLogger(RedisUtil.class);

private static int connCount = 0;// 當前連接的個數

/**

* 切片客戶端鏈接池

*/

private ShardedJedisPool shardedJedisPool;

/**

* 獲取切片客戶端鏈接池

*

* @return conn

*/

public ShardedJedis getConnFromShardedPool() {

ShardedJedis shardedJedis = null;

try {

shardedJedis = shardedJedisPool.getResource();

} catch (Exception e) {

log.error("Get ShardedJedis from ShardedJedisPool failed...", e);

e.printStackTrace();

}

return shardedJedis;

}

/**

* @功能:獲取安全切片客戶端鏈接池

*

* @return conn

*/

public ShardedJedis getSafeConnFromShardedPool() {

// 獲取不到連接時等待一秒繼續嘗試,最多嘗試20次

int maxTryCount = 20;

ShardedJedis shardedJedis = null;

for (int i = 0; i < maxTryCount; i++) {

try {

shardedJedis = shardedJedisPool.getResource();

break;

} catch (Exception e) {

// 超過最多的嘗試次數則退出

if (i == maxTryCount) {

break;

}

log.error(

"==========>>Get ShardedJedis from ShardedJedisPool failed.,第"

+ (i + 1) + "次嘗試,最多嘗試" + maxTryCount

+ ",如超過最多的嘗試次數則退出執行。", e);

e.printStackTrace();

try {

// 出現異常等待1秒鐘再次嘗試

Thread.sleep(1000);

} catch (Exception e2) {

log.error("", e);

}

}

}

if (shardedJedis != null) {

synchronized (this) {

connCount++;

log.info("Get ShardedJedis from ShardedJedisPool success.... 當前使用連接數="

+ connCount);

}

}

return shardedJedis;

}

/**

* 關閉切片客戶端鏈接

*

* @param conn

*/

public void closeConnShardedJedis(ShardedJedis shardedJedis) {

if (null != shardedJedis) {

try {

shardedJedisPool.returnResource(shardedJedis);

} catch (Exception e) {

log.error("Close shardedJedis connection failed.");

e.printStackTrace();

}

}

synchronized (this) {

connCount--;

log.info("==========>>Close ShardedJedis from ShardedJedisPool success.... 當前使用連接數="

+ connCount);

}

}

/**

* 設置數據

*

* @param conn

*/

public boolean setData(String key, String value) {

try {

ShardedJedis jedis = shardedJedisPool.getResource();

jedis.set(key, value);

shardedJedisPool.returnResource(jedis);

return true;

} catch (Exception e) {

e.printStackTrace();

}

return false;

}

/**

* 獲取數據

*

* @param conn

*/

public String getData(String key) {

String value = null;

try {

ShardedJedis jedis = shardedJedisPool.getResource();

value = jedis.get(key);

shardedJedisPool.returnResource(jedis);

return value;

} catch (Exception e) {

e.printStackTrace();

}

return value;

}

/**

* 獲取切片客戶端鏈接池

*

* @return 數據源

*/

public ShardedJedisPool getShardedJedisPool() {

return shardedJedisPool;

}

/**

* 設置切片客戶端鏈接池

*

* @return 數據源

*/

public void setShardedJedisPool(ShardedJedisPool shardedJedisPool) {

this.shardedJedisPool = shardedJedisPool;

}

}

使用方法

@Autowired

private RedisUtil redisUtil;

public static void main(String[] args) {

ShardedJedis sj = null;

try {

sj = redisUtil.getSafeConnFromShardedPool();

sj.set("testkey","testvalue");

} catch (Exception e) {

e.printStackTrace();

} finally {

if (sj != null) {

redisUtil.closeConnShardedJedis(sj);

}

}

}

總結

以上是生活随笔為你收集整理的redis java切片_jedis 单点配置的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。