欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot整合redis修改分區(qū)的操作流程

 更新時(shí)間:2021年07月05日 15:15:05   作者:小渣筆記  
這篇文章主要介紹了springboot整合redis修改分區(qū)的操作流程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

springboot整合redis修改分區(qū)

問(wèn)題由來(lái)

最近使用springboot整合redis,一個(gè)系統(tǒng)動(dòng)態(tài)數(shù)據(jù)源連接不同數(shù)據(jù)庫(kù),緩存使用的redis,那么就需要將不同數(shù)據(jù)庫(kù)的數(shù)據(jù)緩存到redis不同的分區(qū),也就是不同的庫(kù)中。

老版解決

這里的老版指的是2.0之前的,我使用的1.5.9是ok的。

redis的配置類這里就不貼了,網(wǎng)上很多。

1.使用JedisConnectionFactory修改

@Autowired
JedisConnectionFactory jedisConnectionFactory;
jedisConnectionFactory.setDatabase(database);

2.使用redisTemplate修改

redisTemplate.getConnectionFactory().getConnection().select(database);

以上兩種方式不需要再redis配置類中特意添加bean

新版解決

這里的新版指的是2.0之后的,我用的是2.0.3

redis配置類中需要添加以下bean

    @Bean
    RedisStandaloneConfiguration redisStandaloneConfiguration() {
        RedisStandaloneConfiguration redisStandaloneConfiguration = new RedisStandaloneConfiguration();
        redisStandaloneConfiguration.setHostName("localhost");
        redisStandaloneConfiguration.setPort(6379);
        redisStandaloneConfiguration.setDatabase(0);
        return redisStandaloneConfiguration;
    }
    @Bean
    JedisConnectionFactory jedisConnectionFactory(RedisStandaloneConfiguration redisStandaloneConfiguration) {
        //redisStandaloneConfiguration.setPassword(RedisPassword.of(password));
        JedisClientConfiguration.JedisClientConfigurationBuilder jedisClientConfiguration = JedisClientConfiguration.builder();
        jedisClientConfiguration.connectTimeout(Duration.ofMillis(0));//  connection timeout
        JedisConnectionFactory factory = new JedisConnectionFactory(redisStandaloneConfiguration,
                jedisClientConfiguration.build());
        return factory;
    }

使用RedisStandaloneConfiguration修改

@Autowired
RedisStandaloneConfiguration redisStandaloneConfiguration;
redisStandaloneConfiguration.setDatabase(database);

redis分區(qū)

數(shù)據(jù)是怎樣分布在多個(gè)Redis實(shí)例上的

分區(qū)是將你的數(shù)據(jù)分布在多個(gè)Redis實(shí)例上,以至于每個(gè)實(shí)例只包含一部分?jǐn)?shù)據(jù)。

為什么分區(qū)是有用的呢

Redis分區(qū)有兩個(gè)主要目標(biāo):

  1. 它允許更大的數(shù)據(jù)庫(kù),用許多計(jì)算機(jī)的內(nèi)存總和。如果不進(jìn)行分區(qū),你將會(huì)受限于單臺(tái)計(jì)算機(jī)的內(nèi)存。
  2. 它允許將計(jì)算能力擴(kuò)展到多核和多臺(tái)計(jì)算機(jī),將網(wǎng)絡(luò)帶寬擴(kuò)展到多臺(tái)計(jì)算機(jī)和網(wǎng)絡(luò)適配器。

假設(shè)我們有4個(gè)Redis實(shí)例(R0, R1, R2, R3),其上有許多代表用戶的key,比如user:1, user:2, ... 等等,那么在存儲(chǔ)一個(gè)key的時(shí)候我們有多種方式。

最簡(jiǎn)單的一種方式是按照范圍分區(qū),即根據(jù)對(duì)象的映射范圍將數(shù)據(jù)分配到指定的Redis實(shí)例上。例如,我們規(guī)定ID為0~10000的就分到R0,10001~20000到R1,以此類推。這種方式是可以的,但是有一個(gè)缺點(diǎn)是需要一張表來(lái)維護(hù)這個(gè)映射關(guān)系。這個(gè)表需要管理起來(lái),而且每一個(gè)key都需要一個(gè)這樣的表,因此Redis中的范圍分區(qū)通常是不受歡迎的,因?yàn)樗绕渌謪^(qū)方法效率低得多。

除了范圍分區(qū)以外,另一種方法是哈希分區(qū)(hash partitioning):

第1步、取key,并應(yīng)用哈希函數(shù)將其轉(zhuǎn)換為一個(gè)數(shù)。例如,如果key是foobar,哈希函數(shù)式crc32,那么crc32(foobar)將輸出93024922。

第2步、對(duì)這個(gè)數(shù)字使用模運(yùn)算(取模)將它轉(zhuǎn)換成0到3直接的數(shù)字,這樣這個(gè)數(shù)字就可以映射到我的四個(gè)Redis實(shí)例之一。例如,93024922 % 4 = 2,因此foobar應(yīng)該存儲(chǔ)到R2實(shí)例上。

(PS:首先,對(duì)key做哈希運(yùn)算,得到一個(gè)數(shù)字,然后對(duì)這個(gè)數(shù)字取模,以決定最終數(shù)據(jù)應(yīng)該存放在哪個(gè)實(shí)例上)

分區(qū)的方法還有很多種,通過(guò)上面兩個(gè)示例,你應(yīng)該可以理解。哈希分區(qū)的一種高級(jí)形式稱為一致性哈希,由幾個(gè)Redis客戶端和代理實(shí)現(xiàn)。

不同的分區(qū)實(shí)現(xiàn)

客戶端分區(qū) : 對(duì)于一個(gè)給定的key,客戶端直接選擇正確的節(jié)點(diǎn)來(lái)進(jìn)行讀寫。許多Redis客戶端都實(shí)現(xiàn)了客戶端分區(qū)。

代理分區(qū) : 客戶端發(fā)送請(qǐng)求到一個(gè)代理,由代理來(lái)和Redis通信,代理會(huì)根據(jù)我們的配置來(lái)選擇正確的Redis實(shí)例。

查詢路由 : 你可以將你的查詢發(fā)送到任何一個(gè)Redis實(shí)例,實(shí)例會(huì)將你的查詢重定向到正確的服務(wù)器。

(PS:對(duì)于一個(gè)給定的key,分區(qū)的工作就是選擇一個(gè)正確的Redis實(shí)例,那么這個(gè)選擇的過(guò)程可以由客戶端、代理 或者 Redis實(shí)例來(lái)做)

分區(qū)的不足之處

1、涉及多個(gè)key的操作通常是不支持的。對(duì)于映射到兩個(gè)不同的Redis實(shí)例的key,你不能往這兩個(gè)上執(zhí)行插入操作。

2、涉及多個(gè)key的操作不能用Redis事務(wù)

3、分區(qū)粒度是key,因此不可能將一單個(gè)非常巨大的key(比如,一個(gè)非常大的sorted set)去切分?jǐn)?shù)據(jù)

4、當(dāng)使用分區(qū)的時(shí)候,數(shù)據(jù)處理會(huì)更復(fù)雜,對(duì)于實(shí)例你必須處理多個(gè)RDB/AOF文件,為了備份數(shù)據(jù),需要從多個(gè)實(shí)例和主機(jī)聚合持久文件。

5、增加和刪除容量(空間)變得更復(fù)雜。例如,Redis集群支持在運(yùn)行時(shí)添加和刪除節(jié)點(diǎn)的透明數(shù)據(jù)再平衡,但其他系統(tǒng)如客戶端分區(qū)和代理不支持此功能。然而,一種叫做預(yù)分片的技術(shù)在這方面有幫助。

數(shù)據(jù)存儲(chǔ)還是緩存?

當(dāng)Redis用作數(shù)據(jù)存儲(chǔ)時(shí),給定的key必須總是映射到相同的Redis實(shí)例。當(dāng)作為緩存時(shí),如果給定節(jié)點(diǎn)不可用它不是一個(gè)大問(wèn)題。

如果給定key的首選節(jié)點(diǎn)不可用,一致哈希實(shí)現(xiàn)通常能夠切換到其他節(jié)點(diǎn)。類似地,如果添加一個(gè)新節(jié)點(diǎn),部分新keys將開始存儲(chǔ)在新節(jié)點(diǎn)上。

  • 如果使用Redis作為緩存,使用一致哈希很容易進(jìn)行伸縮。
  • 如果Redis用作存儲(chǔ),則使用固定的keys-to-nodes映射,因此節(jié)點(diǎn)的數(shù)量必須是固定的,且不能改變。否則,就需要一個(gè)能夠在節(jié)點(diǎn)之間重新平衡key的系統(tǒng),當(dāng)前Redis集群是可以做到這一點(diǎn)的。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spring依賴注入的三種方式詳解

    Spring依賴注入的三種方式詳解

    這篇文章主要給大家介紹了三種Spring依賴注入的方式,?settter方法注入,構(gòu)造器注入以及變量(filed)?注入這三種方式,文章通過(guò)代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • Struts2源碼分析之ParametersInterceptor攔截器

    Struts2源碼分析之ParametersInterceptor攔截器

    這篇文章主要介紹了Struts2源碼分析之ParametersInterceptor攔截器,ParametersInterceptor攔截器其主要功能是把ActionContext中的請(qǐng)求參數(shù)設(shè)置到ValueStack中,,需要的朋友可以參考下
    2019-06-06
  • Mybatis Mapper接口工作原理實(shí)例解析

    Mybatis Mapper接口工作原理實(shí)例解析

    這篇文章主要介紹了Mybatis Mapper接口工作原理實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Java模擬并解決緩存穿透問(wèn)題

    Java模擬并解決緩存穿透問(wèn)題

    這篇文章主要介紹了Java模擬并解決緩存穿透問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2019-08-08
  • Java編程中的檢查型異常與非檢查型異常分析

    Java編程中的檢查型異常與非檢查型異常分析

    這篇文章主要介紹了Java編程中的未檢查型異常與非檢查型異常,以及異常的處理方式,需要的朋友可以參考下
    2017-09-09
  • java?webservice超時(shí)時(shí)間設(shè)置方法代碼

    java?webservice超時(shí)時(shí)間設(shè)置方法代碼

    當(dāng)我們使用WebService進(jìn)行調(diào)用時(shí),有時(shí)會(huì)出現(xiàn)超時(shí)的情況,下面這篇文章主要給大家介紹了關(guān)于java?webservice超時(shí)時(shí)間設(shè)置方法的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-01-01
  • Java Gradle項(xiàng)目中的資源正確獲取方式

    Java Gradle項(xiàng)目中的資源正確獲取方式

    這篇文章主要介紹了Java Gradle項(xiàng)目中的資源正確獲取方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-11-11
  • Java HashSet集合存儲(chǔ)遍歷學(xué)生對(duì)象代碼實(shí)例

    Java HashSet集合存儲(chǔ)遍歷學(xué)生對(duì)象代碼實(shí)例

    這篇文章主要介紹了Java HashSet集合存儲(chǔ)遍歷學(xué)生對(duì)象代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 如何為Spark Application指定不同的JDK版本詳解

    如何為Spark Application指定不同的JDK版本詳解

    這篇文章主要給大家介紹了關(guān)于如何為Spark Application指定不同的JDK版本的相關(guān)資料,文中通過(guò)示例代碼將解決的方法介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友下面來(lái)隨著小編一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-11-11
  • java環(huán)境搭建教程

    java環(huán)境搭建教程

    這篇文章主要為大家詳細(xì)介紹了java環(huán)境的搭建教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-03-03

最新評(píng)論