這篇文章主要介紹“怎么用Java實(shí)現(xiàn)redis連接池”,在日常操作中,相信很多人在怎么用Java實(shí)現(xiàn)redis連接池問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”怎么用Java實(shí)現(xiàn)redis連接池”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了潯陽(yáng)免費(fèi)建站歡迎大家使用!
使用稱手的工具,做起事來(lái)
事半功倍
,用
redis-cli
自然不錯(cuò)。我推薦一款我經(jīng)常用的
Redis
可視化工具,Redis Desktop Manager
。
池技術(shù)被廣泛使用在系統(tǒng)開發(fā)中,像
JDBC
連接池、線程池等。連連接池是創(chuàng)建和管理一個(gè)連接的緩沖池的技術(shù),這些連接準(zhǔn)備好被任何需要它們的線程使用。
在處理一個(gè)任務(wù)時(shí),我們大多情況要在數(shù)毫秒級(jí)別就完成,如果重復(fù)創(chuàng)建、關(guān)閉資源,會(huì)占用較長(zhǎng)時(shí)間和大量系統(tǒng)資源。
使用連接池優(yōu)勢(shì)
減少連接創(chuàng)建時(shí)間
連接在系統(tǒng)初始化時(shí)就創(chuàng)建完成,需要時(shí)直接從池中取用,減少了時(shí)間開銷。
簡(jiǎn)化的編程模式
當(dāng)使用連接池時(shí),每一個(gè)單獨(dú)的線程能夠像創(chuàng)建了一個(gè)自己的 JDBC 連接一樣操作。
受控的資源使用
連接池能夠控制一個(gè)模塊的資源占用率,不會(huì)讓一個(gè)模塊資源占用過高,導(dǎo)致整個(gè)系統(tǒng)崩潰。
在以前沒有開源連接池時(shí),很多人自寫連接池工具,簡(jiǎn)單來(lái)說就是創(chuàng)建一個(gè)集合,存放一批連接,動(dòng)態(tài)維護(hù)著。保證每個(gè)連接都是有效的。
本教程涉及到的一些代碼都是 Java 語(yǔ)言編寫。
maven
依賴,引入
pom.xml
文件
pom.xml
redis.clients jedis 3.3.0
RedisUtil.java
public final class RedisUtil { //IP 地址 private static String ADDR = "127.0.0.1"; //端口號(hào) private static int PORT = 6379; //redis 服務(wù)端密碼 private static String PWD = "123456"; //可用連接實(shí)例最大數(shù)目,默認(rèn)為 8,若賦值 -1,表示不被限制 private static Integer MAX_TOTAL = 1024; //控制一個(gè)連接池最多有多少個(gè)狀態(tài)為空閑的 jedis 實(shí)例,默認(rèn)值為 8 private static Integer MAX_IDLE = 200; //等待可用連接最大的等待時(shí)間,單位 ms,默認(rèn)值 -1,表示永不超時(shí),若等待超時(shí)拋出 JedisConnectionException private static Integer MAX_WAIT_MILLIS = 10000; //超時(shí) private static Integer TIMEOUT = 10000; //在用一個(gè) jedis 實(shí)例時(shí),是否提前進(jìn)行 validate 操作,若結(jié)果為 true 則 jedis 實(shí)例可用 private static Boolean TEST_ON_BORROW = true; //jedis 連接池 private static JedisPool jedisPool = null; /** * 初始化 jedis 連接池的靜態(tài)塊,RedisPool 第一次類加載時(shí)執(zhí)行,以后便不再執(zhí)行 */ static { try { JedisPoolConfig conf = new JedisPoolConfig(); /* * 高版本 jedis jar 中 JedisPoolConfig 沒有 setMaxActive 和 setMaxWait 屬性,因?yàn)楣俜皆诟甙姹?nbsp; * 中啟用了此方法,用以下兩個(gè)屬性替換 * maxActive ==> maxTotal * maxWait ==> maxWaitMillis */ //設(shè)置連接實(shí)例最大數(shù)目 conf.setMaxTotal(MAX_TOTAL); //設(shè)置最多多少空閑的 jedis 實(shí)例 conf.setMaxIdle(MAX_IDLE); //設(shè)置等待可用連接的最大時(shí)間 conf.setMaxWaitMillis(MAX_WAIT_MILLIS); //設(shè)置是否提前進(jìn)行測(cè)試借用 conf.setTestOnBorrow(TEST_ON_BORROW); //新建 jedis 連接池 jedisPool = new JedisPool(conf, ADDR, PORT, TIMEOUT, PWD); } catch (Exception e) { e.printStackTrace(); } } /* * 獲取 jedis 實(shí)例來(lái)操作數(shù)據(jù),每次使用完要將連接返回給連接池 jedis.close() * @return */ public synchronized static Jedis getRedis() { try { if(jedisPool != null) { //獲取 jedis 實(shí)例 Jedis jedis = jedisPool.getResource(); return jedis; } else{ System.out.println("沒有找到 Jedis 連接池!"); return null; } } catch (Exception e) { e.printStackTrace(); return null; } } /* * 用來(lái)回收 Jedis 對(duì)象資源,用戶需要用到此方法釋放資源,否則一直占用資源,在新版本中,`returnResource(jedis) 將被廢棄不推薦使用,`直接調(diào)用 `jedis.close();` 歸還連接到連接池。 * @param Jedis jedis */ public synchronized static void returnJedis(Jedis jedis) { try { if(jedis != null) { //回收 jedis 對(duì)象資源 jedisPool.returnResource(jedis); System.out.println("Jedis 被成功回收!"); } } catch (Exception e) { e.printStackTrace(); } } }
到此,關(guān)于“怎么用Java實(shí)現(xiàn)redis連接池”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!