Spring?Data默認(rèn)值的錯誤解決
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)文章
Springmvc DispatcherServlet原理及用法解析
這篇文章主要介紹了Springmvc DispatcherServlet原理及用法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-09-09Spring Boot 實現(xiàn)Restful webservice服務(wù)端示例代碼
這篇文章主要介紹了Spring Boot 實現(xiàn)Restful webservice服務(wù)端示例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-11-11