Spring Boot Redis客戶端遠(yuǎn)程操作實(shí)現(xiàn)過程解析
在Spring Boot 1.x中默認(rèn)是Jedis作為客戶端,但是在Spring Boot2.x后,默認(rèn)就是Lettuce
Redis的遠(yuǎn)程連接,默認(rèn)是不支持的,需要手動(dòng)開啟
修改config文件:
注釋掉bind:127.0.0.1
開啟密碼校驗(yàn),去掉requireprass的注釋
使用jedis客戶端:
jedis的GitHub地址:https://github.com/xetorthio/jedis
如何遠(yuǎn)程連接:
//構(gòu)造一個(gè)jedis對象 Jedis jedis=new Jedis("127.0.0.1"); //有密碼的話要認(rèn)證 jedis.auth("root"); //測試是否連接成功 String ping =jedis.ping(); //返回pong表示成功 System.out.println(ping);
jedis中的方法API和redis中的操作數(shù)據(jù)的命令一致,所以使用起來很方便。
在實(shí)際應(yīng)用中,Jedis實(shí)例一般用連接池獲取,因?yàn)閖ava本來就是多線程的,而jedis對象不是線程安全的,所以要使用連接池,從連接池中獲取Jedis,用完之后再還給連接池。保證他的線程是安全的。
如何創(chuàng)建Jedis連接池
//1.構(gòu)造一個(gè)jedis連接池 JedisPool pool=new JedisPool("127.0.0.1",6379); //2.從連接池中獲取一個(gè)jedis連接 Jedis jedis=pool.getResource(); //3.測試是否連接成功 String ping =jedis.ping(); //返回pong表示成功 System.out.println(ping); //4.歸還連接 jedis.close();
如果第三步,也就是我們的業(yè)務(wù)代碼出問題的話,是無法進(jìn)行到第四步的,我們可以做一個(gè)優(yōu)化,在業(yè)務(wù)代碼塊中try catch給close加一個(gè)finally,并在finally中判斷jedis不為空的情況下給他歸還。這樣的話,就可以保證每次都?xì)w還jedis對象了。
但是這種的明顯感覺很臃腫,而且約束性不強(qiáng),因此可以再優(yōu)化,就是以接口和接口實(shí)現(xiàn)的形式去處理,需要調(diào)用的時(shí)候再去實(shí)現(xiàn)這個(gè)接口:
創(chuàng)建接口:
public interface CallJedis { void call(Jedis jedis); }
創(chuàng)建接口的實(shí)現(xiàn)
public class Redis { private JedisPool pool; public Redis() { GenericObjectPoolConfig config = new GenericObjectPoolConfig(); //連接池最大空閑數(shù) config.setMaxIdle(300); //最大連接數(shù) config.setMaxTotal(1000); //連接最大等待時(shí)間,如果是 -1 表示沒有限制 config.setMaxWaitMillis(30000); //在空閑時(shí)檢查有效性 config.setTestOnBorrow(true); /** * 1. Redis 地址 * 2. Redis 端口 * 3. 連接超時(shí)時(shí)間 * 4. 密碼 */ pool = new JedisPool(config, "192.168.91.128", 6379, 30000, "root"); } public void execute(CallJedis callJedis) { try (Jedis jedis = pool.getResource()) { callJedis.call(jedis); } } }
調(diào)用接口:
Redis redis = new Redis(); redis.execute(jedis -> { System.out.println(jedis.ping()); });
使用Lettuce客戶端:
GitHub地址:https://github.com/lettuce-io/lettuce-core
Lettuce和Jedis比較
Jedis在實(shí)現(xiàn)過程中是直接連接redis的,在多個(gè)線程之間共享一個(gè)jedis實(shí)例,是線程不安全的,如果想在多線程場景下使用jedis,就得使用連接池,這樣,每個(gè)線程都有自己的jedis實(shí)例,但是有一個(gè)弊端,就是會(huì)消耗過多的物理資源。
Lettuce是線程安全的,因?yàn)槭褂昧薔etty NIO框架構(gòu)建。支持同步,異步,以及響應(yīng)調(diào)用,多個(gè)線程可以共享一個(gè)Lettuce實(shí)例,不用擔(dān)心多線程的并發(fā)問題。
在java中如何使用:
1.添加依賴。
2.測試
//創(chuàng)建連接root是密碼,127.0.0.1是服務(wù)端地址 RedisClient redisClient =RedisClient.create("redis://root@127.0.0.1"); //創(chuàng)建連接通道 StatefulRedisConnection<String, String> connect = redisClient.connect(); //獲取同步調(diào)用對象 RedisCommands<String, String> sync = connect.sync(); //賦值 sync.set("name", "zl"); //取值 String name = sync.get("name"); //測試 System.out.println(name); }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
淺談Spring裝配Bean之組件掃描和自動(dòng)裝配
本篇文章主要介紹了淺談Spring裝配Bean之組件掃描和自動(dòng)裝配,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10java實(shí)現(xiàn)web實(shí)時(shí)消息推送的七種方案
這篇文章主要為大家介紹了java實(shí)現(xiàn)web實(shí)時(shí)消息推送的七種方案示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07Springboot實(shí)現(xiàn)前后端分離excel下載
這篇文章主要介紹了Springboot實(shí)現(xiàn)前后端分離excel下載,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11Java設(shè)計(jì)模式之解釋器模式_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
解釋器模式是一個(gè)比較少用的模式,本人之前也沒有用過這個(gè)模式。下面我們就來一起看一下解釋器模式2017-08-08Java容器ArrayList知識點(diǎn)總結(jié)
本篇文章給大家分享了Java容器ArrayList的相關(guān)知識點(diǎn),對此有需要的朋友可以跟著學(xué)習(xí)參考下。2018-05-05Dubbo異步調(diào)用的實(shí)現(xiàn)介紹
dubbo默認(rèn)使用同步的方式調(diào)用。但在有些特殊的場景下,我們可能希望異步調(diào)用dubbo接口,從而避免不必要的等待時(shí)間,這時(shí)候我們就需要用到異步。那么dubbo的異步是如何實(shí)現(xiàn)的呢?下面就來看看這個(gè)問題2022-09-09服務(wù)性能優(yōu)化之mybatis-plus開啟與關(guān)閉SQL日志打印方法
這篇文章主要介紹了在Mybatis-plus中開啟和關(guān)閉控制臺(tái)SQL日志打印,在`application.properties`文件中,可以通過配置來實(shí)現(xiàn)SQL日志的開啟和關(guān)閉,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-12-12mybatis學(xué)習(xí)之路mysql批量新增數(shù)據(jù)的方法
這篇文章主要介紹了mybatis學(xué)習(xí)之路mysql批量新增數(shù)據(jù)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02