Spring?Data默認(rèn)值的錯(cuò)誤解決
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)文章
JVM參數(shù)-Xms和-Xmx的作用及說(shuō)明
這篇文章主要介紹了JVM參數(shù)-Xms和-Xmx的作用及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08Springmvc DispatcherServlet原理及用法解析
這篇文章主要介紹了Springmvc DispatcherServlet原理及用法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09Spring Boot 實(shí)現(xiàn)Restful webservice服務(wù)端示例代碼
這篇文章主要介紹了Spring Boot 實(shí)現(xiàn)Restful webservice服務(wù)端示例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-11-11