真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么用Java實(shí)現(xiàn)redis連接池

這篇文章主要介紹“怎么用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)建站歡迎大家使用!

1.Redis 客戶端

1.1.Redis Desktop Manager

使用稱手的工具,做起事來(lái) 事半功倍 ,用 redis-cli 自然不錯(cuò)。我推薦一款我經(jīng)常用的 Redis 可視化工具,Redis Desktop Manager 。

2.Redis 連接池

2.2.0.連接池

池技術(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ì)

  1. 減少連接創(chuàng)建時(shí)間

連接在系統(tǒng)初始化時(shí)就創(chuàng)建完成,需要時(shí)直接從池中取用,減少了時(shí)間開銷。

  1. 簡(jiǎn)化的編程模式

當(dāng)使用連接池時(shí),每一個(gè)單獨(dú)的線程能夠像創(chuàng)建了一個(gè)自己的 JDBC 連接一樣操作。

  1. 受控的資源使用

連接池能夠控制一個(gè)模塊的資源占用率,不會(huì)讓一個(gè)模塊資源占用過高,導(dǎo)致整個(gè)系統(tǒng)崩潰。

2.1.Redis 連接池

2.1.1.前言引入

在以前沒有開源連接池時(shí),很多人自寫連接池工具,簡(jiǎn)單來(lái)說就是創(chuàng)建一個(gè)集合,存放一批連接,動(dòng)態(tài)維護(hù)著。保證每個(gè)連接都是有效的。

2.1.2.Redis 連接池

本教程涉及到的一些代碼都是 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í)用的文章!


網(wǎng)頁(yè)題目:怎么用Java實(shí)現(xiàn)redis連接池
轉(zhuǎn)載源于:http://weahome.cn/article/jsdhpg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部