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

Spring?Data默認(rèn)值的錯(cuò)誤解決

 更新時(shí)間:2023年01月17日 16:08:14   作者:JavaEdge.  
本文主要介紹了Spring?Data默認(rèn)值的錯(cuò)誤解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

Spring Data有很多配置的默認(rèn)值,但不一定都適合你。如一個(gè)依賴(lài)Cassandra 的項(xiàng)目,有時(shí)寫(xiě)入數(shù)據(jù)后,并不能立馬讀到。這種錯(cuò)誤并沒(méi)有什么報(bào)錯(cuò),一切都是正常的,就是讀不到數(shù)據(jù)。

源碼解析

直接使用 Spring Data Cassandra 操作時(shí),實(shí)際依賴(lài) Cassandra driver 內(nèi)部的配置文件,目錄:

.m2\repository\com\datastax\oss\java-driver-core\4.6.1\java-driver-core-4.6.1.jar!\reference.conf

很多默認(rèn)配置,很重要配置是 Consistency,driver中默認(rèn)為 LOCAL_ONE:

basic.request {
 

  # The consistency level.
  #
  # Required: yes
  # Modifiable at runtime: yes, the new value will be used for requests issued after the change.
  # Overridable in a profile: yes
  consistency = LOCAL_ONE
 
//省略其他非關(guān)鍵配置 
}

執(zhí)行讀寫(xiě)操作時(shí),都會(huì)使用 LOCAL_ONE。運(yùn)行時(shí)配置調(diào)試截圖:

Cassandra 使用核心原則:使R(讀)+W(寫(xiě))>N,即讀和寫(xiě)的節(jié)點(diǎn)數(shù)之和大于備份數(shù)。

設(shè)數(shù)據(jù)備份 3 份,待寫(xiě)入數(shù)據(jù)分別存儲(chǔ)在 A、B、C 節(jié)點(diǎn)。常見(jiàn)搭配是 R(讀)和 W(寫(xiě))的一致性都是 LOCAL_QURAM,這樣可以保證能及時(shí)讀到寫(xiě)入的數(shù)據(jù);而假設(shè)在這種情況下,讀寫(xiě)都用 LOCAL_ONE,則可能發(fā)生這樣的情況:用戶(hù)寫(xiě)入一個(gè)節(jié)點(diǎn) A 就返回,但用戶(hù) B 立馬讀的節(jié)點(diǎn)是 C,由于是LOCAL_ONE 一致性,則讀完 C 就可立馬返回。此時(shí),就會(huì)出現(xiàn)數(shù)據(jù)讀取可能落空case。

為何Cassandra driver 默認(rèn)使用 LOCAL_ONE?其實(shí)是最合適的,因?yàn)橹挥幸慌_(tái)機(jī)器,讀寫(xiě)都只能命中一臺(tái)。但產(chǎn)線上的 Cassandra 大多都是多數(shù)據(jù)中心多節(jié)點(diǎn)的,備份數(shù)大于1。所以讀寫(xiě)都用 LOCAL_ONE 就會(huì)出現(xiàn)問(wèn)題。

修正

修改默認(rèn)值,以 consistency 為例。

@Override
protected SessionBuilderConfigurer getSessionBuilderConfigurer() {
    return cqlSessionBuilder -> {
        DefaultProgrammaticDriverConfigLoaderBuilder defaultProgrammaticDriverConfigLoaderBuilder = new DefaultProgrammaticDriverConfigLoaderBuilder();
        driverConfigLoaderBuilderCustomizer().customize(defaultProgrammaticDriverConfigLoaderBuilder);
        cqlSessionBuilder.withConfigLoader(defaultProgrammaticDriverConfigLoaderBuilder.build());
        return cqlSessionBuilder;
    };
}

@Bean
public DriverConfigLoaderBuilderCustomizer driverConfigLoaderBuilderCustomizer() {
    return loaderBuilder -> loaderBuilder
            .withString(REQUEST_CONSISTENCY, ConsistencyLevel.LOCAL_QUORUM.name())
}

將一致性級(jí)別從 LOCAL_ONE 改成了 LOCAL_QUARM,符合實(shí)際產(chǎn)品部署和應(yīng)用情況。

到此這篇關(guān)于Spring Data默認(rèn)值的錯(cuò)誤解決的文章就介紹到這了,更多相關(guān)Spring Data默認(rèn)值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java搜索與圖論之DFS和BFS算法詳解

    Java搜索與圖論之DFS和BFS算法詳解

    DFS指在進(jìn)行算法運(yùn)算時(shí),優(yōu)先將該路徑的當(dāng)前路徑執(zhí)行完畢,執(zhí)行完畢或失敗后向上回溯嘗試其他途徑。BFS指在進(jìn)行算法運(yùn)算時(shí),優(yōu)先將當(dāng)前路徑點(diǎn)的所有情況羅列出來(lái),然后根據(jù)羅列出來(lái)的情況羅列下一層。本文介紹了二者的實(shí)現(xiàn)與應(yīng)用,需要的可以參考一下
    2022-11-11
  • Java圖形界面GUI布局方式(小結(jié))

    Java圖形界面GUI布局方式(小結(jié))

    這篇文章主要介紹了Java圖形界面GUI布局方式(小結(jié)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • shiro攔截認(rèn)證的全過(guò)程記錄

    shiro攔截認(rèn)證的全過(guò)程記錄

    Apache?Shiro是一個(gè)強(qiáng)大且易用的Java安全框架,執(zhí)行身份驗(yàn)證、授權(quán)、密碼和會(huì)話管理,下面這篇文章主要給大家介紹了關(guān)于shiro攔截認(rèn)證的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • 超詳細(xì)的Java 問(wèn)題排查工具單

    超詳細(xì)的Java 問(wèn)題排查工具單

    這篇文章主要介紹了超詳細(xì)的Java 問(wèn)題排查工具單,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • java的package和import機(jī)制原理解析

    java的package和import機(jī)制原理解析

    這篇文章主要介紹了java的package和import機(jī)制原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • JVM參數(shù)-Xms和-Xmx的作用及說(shuō)明

    JVM參數(shù)-Xms和-Xmx的作用及說(shuō)明

    這篇文章主要介紹了JVM參數(shù)-Xms和-Xmx的作用及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Springmvc DispatcherServlet原理及用法解析

    Springmvc DispatcherServlet原理及用法解析

    這篇文章主要介紹了Springmvc DispatcherServlet原理及用法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Spring Boot 實(shí)現(xiàn)Restful webservice服務(wù)端示例代碼

    Spring Boot 實(shí)現(xiàn)Restful webservice服務(wù)端示例代碼

    這篇文章主要介紹了Spring Boot 實(shí)現(xiàn)Restful webservice服務(wù)端示例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-11-11
  • JNI語(yǔ)言基本知識(shí)

    JNI語(yǔ)言基本知識(shí)

    JNI是Java Native Interface的縮寫(xiě),它提供了若干的API實(shí)現(xiàn)了Java和其他語(yǔ)言的通信(主要是C&C++)。接下來(lái)通過(guò)本文給大家分享jni 基礎(chǔ)知識(shí),感興趣的朋友一起看看吧
    2017-10-10
  • Java SpringMVC異步處理詳解

    Java SpringMVC異步處理詳解

    這篇文章主要介紹了Java springmvc的處理異步,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2021-10-10

最新評(píng)論