av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

Spring Boot Redis客戶端遠(yuǎn)程操作實現(xiàn)過程解析

瀏覽:42日期:2023-09-12 08:33:53

在Spring Boot 1.x中默認(rèn)是Jedis作為客戶端,但是在Spring Boot2.x后,默認(rèn)就是Lettuce

Redis的遠(yuǎn)程連接,默認(rèn)是不支持的,需要手動開啟

修改config文件:

注釋掉bind:127.0.0.1

開啟密碼校驗,去掉requireprass的注釋

使用jedis客戶端:

jedis的GitHub地址:https://github.com/xetorthio/jedis

如何遠(yuǎn)程連接:

//構(gòu)造一個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ù)的命令一致,所以使用起來很方便。

在實際應(yīng)用中,Jedis實例一般用連接池獲取,因為java本來就是多線程的,而jedis對象不是線程安全的,所以要使用連接池,從連接池中獲取Jedis,用完之后再還給連接池。保證他的線程是安全的。

如何創(chuàng)建Jedis連接池

//1.構(gòu)造一個jedis連接池JedisPool pool=new JedisPool('127.0.0.1',6379);//2.從連接池中獲取一個jedis連接Jedis jedis=pool.getResource();//3.測試是否連接成功String ping =jedis.ping();//返回pong表示成功System.out.println(ping);//4.歸還連接jedis.close();

如果第三步,也就是我們的業(yè)務(wù)代碼出問題的話,是無法進行到第四步的,我們可以做一個優(yōu)化,在業(yè)務(wù)代碼塊中try catch給close加一個finally,并在finally中判斷jedis不為空的情況下給他歸還。這樣的話,就可以保證每次都?xì)w還jedis對象了。

但是這種的明顯感覺很臃腫,而且約束性不強,因此可以再優(yōu)化,就是以接口和接口實現(xiàn)的形式去處理,需要調(diào)用的時候再去實現(xiàn)這個接口:

創(chuàng)建接口:

public interface CallJedis { void call(Jedis jedis);}

創(chuàng)建接口的實現(xiàn)

public class Redis { private JedisPool pool; public Redis() { GenericObjectPoolConfig config = new GenericObjectPoolConfig(); //連接池最大空閑數(shù) config.setMaxIdle(300); //最大連接數(shù) config.setMaxTotal(1000); //連接最大等待時間,如果是 -1 表示沒有限制 config.setMaxWaitMillis(30000); //在空閑時檢查有效性 config.setTestOnBorrow(true); /** * 1. Redis 地址 * 2. Redis 端口 * 3. 連接超時時間 * 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在實現(xiàn)過程中是直接連接redis的,在多個線程之間共享一個jedis實例,是線程不安全的,如果想在多線程場景下使用jedis,就得使用連接池,這樣,每個線程都有自己的jedis實例,但是有一個弊端,就是會消耗過多的物理資源。

Lettuce是線程安全的,因為使用了Netty NIO框架構(gòu)建。支持同步,異步,以及響應(yīng)調(diào)用,多個線程可以共享一個Lettuce實例,不用擔(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í)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 亚洲一区二区中文字幕在线观看 | 超碰在线影院 | 亚洲91| 欧美一极视频 | 国产美女精品视频 | 爱草在线 | 精品在线观看一区 | 日本又色又爽又黄又高潮 | 99热国产精品| 日韩av中文 | 国产成人免费视频网站高清观看视频 | 欧美日韩在线一区二区 | jvid精品资源在线观看 | 亚洲视频在线观看 | 亚洲国产成人精品女人 | 午夜色婷婷 | 久在线精品视频 | 国产欧美精品一区 | 91视频a | 亚洲欧美另类在线观看 | 欧美日韩成人影院 | 91精品国产欧美一区二区 | 国产精品国产a | 免费国产一区 | 欧美精品影院 | 久草www| 国产一级淫片免费视频 | 国产日韩精品一区二区三区 | 涩涩视频在线看 | 成人深夜福利网站 | 国产精品久久国产精品 | 精品久久精品 | aaa在线| 中文字幕亚洲区一区二 | 久久精品国产99国产精品 | 日本黄色免费视频 | 亚洲色图插插插 | 中文字幕在线观看www | 精品视频一区二区三区在线观看 | 日韩在线免费视频 | 在线视频第一页 |