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

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

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

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

源碼解析

直接使用 Spring Data Cassandra 操作時,實際依賴 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í)行讀寫操作時,都會使用 LOCAL_ONE。運行時配置調(diào)試截圖:

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

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

為何Cassandra driver 默認(rèn)使用 LOCAL_ONE?其實是最合適的,因為只有一臺機器,讀寫都只能命中一臺。但產(chǎn)線上的 Cassandra 大多都是多數(shù)據(jù)中心多節(jié)點的,備份數(shù)大于1。所以讀寫都用 LOCAL_ONE 就會出現(xià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())
}

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

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

    java的package和import機制原理解析

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

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

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

    Springmvc DispatcherServlet原理及用法解析

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

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

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

    JNI語言基本知識

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

    Java SpringMVC異步處理詳解

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

最新評論