国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Redis Java Lettuce驅動框架原理解析

瀏覽:3日期:2022-08-19 18:05:43

Lettuce是一個高性能基于Java編寫的Redis驅動框架,底層集成了Project Reactor提供天然的反應式編程,通信框架集成了Netty使用了非阻塞IO,5.x版本之后融合了JDK1.8的異步編程特性,在保證高性能的同時提供了十分豐富易用的API,5.1版本的新特性如下:

支持Redis的新增命令ZPOPMIN, ZPOPMAX, BZPOPMIN, BZPOPMAX。 支持通過Brave模塊跟蹤Redis命令執行。 支持Redis Streams。 支持異步的主從連接。 支持異步連接池。 新增命令最多執行一次模式(禁止自動重連)。 全局命令超時設置(對異步和反應式命令也有效)。 ......等等

注意一點:Redis的版本至少需要2.6,當然越高越好,API的兼容性比較強大。

引入依賴項:

<dependency><groupId>io.lettuce</groupId><artifactId>lettuce-core</artifactId><version>5.3.4.RELEASE</version></dependency>

一、連接Redis

單機、哨兵、集群模式下連接Redis需要一個統一的標準去表示連接的細節信息,在Lettuce中這個統一的標準是RedisURI。可以通過三種方式構造一個RedisURI實例:

定制的字符串URI語法:

RedisURI uri = RedisURI.create('redis://localhost/');

使用建造器(RedisURI.Builder):

RedisURI uri = RedisURI.builder().withHost('localhost').withPort(6379).build();

直接通過構造函數實例化:

RedisURI uri = new RedisURI('localhost', 6379, 60, TimeUnit.SECONDS);

二、基本使用

Lettuce使用的時候依賴于四個主要組件:

RedisURI:連接信息。 RedisClient:Redis客戶端,特殊地,集群連接有一個定制的RedisClusterClient。 Connection:Redis連接,主要是StatefulConnection或者StatefulRedisConnection的子類,連接的類型主要由連接的具體方式(單機、哨兵、集群、訂閱發布等等)選定,比較重要。 RedisCommands:Redis命令API接口,基本上覆蓋了Redis發行版本的所有命令,提供了同步(sync)、異步(async)、反應式(reative)的調用方式,對于使用者而言,會經常跟RedisCommands系列接口打交道。

一個基本使用例子如下:

RedisURI redisUri = RedisURI.builder() // <1> 創建單機連接的連接信息 .withHost('localhost') .withPort(6379) .withTimeout(Duration.of(10, ChronoUnit.SECONDS)) .build();RedisClient redisClient = RedisClient.create(redisUri); // <2> 創建客戶端StatefulRedisConnection<String, String> connection = redisClient.connect(); // <3> 創建線程安全的連接RedisCommands<String, String> redisCommands = connection.sync();// <4> 創建同步命令SetArgs setArgs = SetArgs.Builder.nx().ex(5);String result = redisCommands.set('name', 'throwable', setArgs);result = redisCommands.get('name');System.out.println(result);// ... 其他操作connection.close(); // <5> 關閉連接redisClient.shutdown(); // <6> 關閉客戶端

關閉連接一般在應用程序停止之前操作,一個應用程序中的一個Redis驅動實例不需要太多的連接(一般情況下只需要一個連接實例就可以,如果有多個連接的需要可以考慮使用連接池,其實Redis目前處理命令的模塊是單線程,在客戶端多個連接多線程調用理論上沒有效果)。

關閉客戶端一般應用程序停止之前操作,如果條件允許的話,基于后開先閉原則,客戶端關閉應該在連接關閉之后操作。

三、Lettuce API

同步(sync):RedisCommands。 異步(async):RedisAsyncCommands。 反應式(reactive):RedisReactiveCommands。

RedisURI redisUri = RedisURI.builder() .withHost('localhost') .withPort(6379) .withTimeout(Duration.of(10, ChronoUnit.SECONDS)) .build();RedisClient client = RedisClient.create(redisUri);StatefulRedisConnection<String, String> connection = client.connect();

Redis命令API的具體實現可以直接從StatefulRedisConnection實例獲取,見其接口定義:

public interface StatefulRedisConnection<K, V> extends StatefulConnection<K, V> { boolean isMulti(); RedisCommands<K, V> sync(); RedisAsyncCommands<K, V> async(); RedisReactiveCommands<K, V> reactive();}

值得注意的是,在不指定編碼解碼器RedisCodec的前提下,RedisClient創建的StatefulRedisConnection實例一般是泛型實例StatefulRedisConnection<String,String>,也就是所有命令API的KEY和VALUE都是String類型,這種使用方式能滿足大部分的使用場景。當然,必要的時候可以定制編碼解碼器RedisCodec<K,V>。

同步API

先構建RedisCommands實例

RedisCommands<String, String> redisCommands= connection.sync();String pong = redisCommands.ping();// 返回PONGSystem.out.println('pong:' + pong);

SetArgs setArgs = SetArgs.Builder.nx().ex(5);redisCommands.set('name', 'throwable', setArgs);String value = redisCommands.get('name');System.out.println('name:' + value);

同步API在所有命令調用之后會立即返回結果。如果熟悉Jedis的話,RedisCommands的用法其實和它相差不大。

異步API

先構建RedisAsyncCommands實例:

RedisAsyncCommands<String, String> redisCommands = connection.async();

基本使用:

RedisAsyncCommands<String, String> redisCommands = connection.async();RedisFuture<String> redisFuture = redisCommands.ping();// 返回PONGSystem.out.println('pong:' + redisFuture.get());

SetArgs setArgs = SetArgs.Builder.nx().ex(5);RedisFuture<String> future = redisCommands.set('name', 'throwable', setArgs);System.out.println('name:' + future.get());

RedisAsyncCommands所有方法執行返回結果都是RedisFuture實例,而RedisFuture接口的定義如下:

public interface RedisFuture<V> extends CompletionStage<V>, Future<V> { String getError(); boolean await(long timeout, TimeUnit unit) throws InterruptedException;}

也就是,RedisFuture可以無縫使用Future或者JDK1.8中引入的CompletableFuture提供的方法。

反應式API

Lettuce引入的反應式編程框架是Project Reactor,如果沒有反應式編程經驗可以先自行了解一下Project Reactor。

構建RedisReactiveCommands實例:

RedisReactiveCommands<String, String> redisCommands = connection.reactive();

根據Project Reactor,RedisReactiveCommands的方法如果返回的結果只包含0或1個元素,那么返回值類型是Mono,如果返回的結果包含0到N(N大于0)個元素,那么返回值是Flux。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 99爱视频免费高清在线观看 | 加勒比日本| 91资源在线 | 国产精品成人免费综合 | chinese农村野战videos | 亚洲精品资源在线 | 久久久黄色片 | 欧美日一本 | 高清国产一区二区三区 | 香蕉久久久| 免费看美女无遮掩的软件 | 日韩欧美在线一级一中文字暮 | 成人午夜大片 | 91精品啪在线观看国产91九色 | 亚洲天堂网在线观看 | 亚洲综合成人网在线观看 | 欧美成人精品三级网站 | 日美三级 | 成人性版蝴蝶影院污 | 欧美成年人视频 | 国产欧美综合一区二区 | 久久人视频 | 一本色道久久爱 | 国产亚洲精品国产 | 黄在线看 | 一区三区三区不卡 | 成人小视频在线观看免费 | 亚洲精品天堂在线观看 | 2020国产微拍精品一区二区 | 欧美一级毛片欧美一级成人毛片 | 高清国产在线 | 欧美一级片免费 | 欧美日韩国产在线人成dvd | 国产成人精品一区二区免费视频 | 99精品国产成人一区二区 | 亚洲精品久久久成人 | 国产a自拍| 亚洲国产影视 | 欧美成人毛片一级在线 | 91理论片| 日本欧美片 |