本發(fā)明實施例涉及一種通信技術(shù)領(lǐng)域,特別是一種計算機應(yīng)用、數(shù)據(jù)存儲方法、微服務(wù)和微數(shù)據(jù)庫。
背景技術(shù):
微服務(wù)是一些協(xié)同工作的小而自治的服務(wù),一個微服務(wù)就是一個獨立的實體。它可以獨立的部署在paas(platformasaservice,平臺即服務(wù))上,也可以作為一個操作系統(tǒng)進程存在。
微服務(wù)之間通過網(wǎng)絡(luò)調(diào)用進行通信,從而加強了服務(wù)之間的隔離性,避免緊耦合,它們可以彼此之間獨立進行修改,并且某一個服務(wù)的部署不會引起該服務(wù)的消費方的變動。
在一個計算機應(yīng)用中,如果其中一部分需要做性能提升,可以使用性能更好的技術(shù)棧來重構(gòu)和部署這一部分,而不會對其他部分產(chǎn)生影響。微服務(wù)可以幫助更快地采用新技術(shù)來提高系統(tǒng)的性能。
隨著領(lǐng)域驅(qū)動設(shè)計、持續(xù)交付、按需虛擬化、基礎(chǔ)設(shè)施自動化、大型集群系統(tǒng)這些技術(shù)的流行,微服務(wù)應(yīng)運而生。從前在一個單塊服務(wù)內(nèi),隨著新功能的增加,代碼庫會越變越大,以至于選擇在什么地方做修改都很困難,而且龐大的單塊服務(wù)只能作為一個整體進行擴展。即使服務(wù)中只有一小部分存在性能問題,也需要對整個單塊服務(wù)進行修改擴展。而且在有相當(dāng)數(shù)量行代碼的單塊服務(wù)中,即使只修改了一行代碼,也需要重新部署整個應(yīng)用程序才能夠發(fā)布該變更,導(dǎo)致這種部署的影響很大、風(fēng)險很高。
在這種背景下,微服務(wù)技術(shù)體現(xiàn)了它對比以往龐大單塊服務(wù)的巨大優(yōu)勢。
采用微服務(wù)技術(shù)來構(gòu)建部署系統(tǒng)具有上述的優(yōu)點,但是采用微服務(wù)技術(shù)也存在以下的缺點:
采用微服務(wù)技術(shù)來構(gòu)建部署系統(tǒng),需要訪問數(shù)據(jù)庫數(shù)據(jù)和數(shù)據(jù)持久化的微服務(wù)需要通過接口讀寫數(shù)據(jù)庫。
對數(shù)據(jù)庫的部署存在兩種情況:1.部署一個共享的數(shù)據(jù)庫,所有微服務(wù)均訪問讀寫這個共享的數(shù)據(jù)庫來實現(xiàn)數(shù)據(jù)持久化;2.每個需要數(shù)據(jù)持久化的微服務(wù)維護一個自己的數(shù)據(jù)庫,該數(shù)據(jù)庫中存儲整個系統(tǒng)的數(shù)據(jù)庫的一個副本。
圖1為現(xiàn)有技術(shù)中計算機應(yīng)用的共享數(shù)據(jù)庫示意圖。
如圖1所示,在情況1中,由于所有微服務(wù)共享一個數(shù)據(jù)庫,該數(shù)據(jù)庫的內(nèi)部實現(xiàn)細(xì)節(jié)是可見的,如果其中某個微服務(wù)為了更好的表示數(shù)據(jù)或者增加可維護性而修改表結(jié)構(gòu)的話,就可能導(dǎo)致其他微服務(wù)無法正常訪問數(shù)據(jù)庫中的數(shù)據(jù),這通常需要做大量的回歸測試來保證功能的正確性。其次,所有微服務(wù)都和特定類型的數(shù)據(jù)庫綁定,無法實現(xiàn)松耦合。
在情況2中,雖然克服了情況1中所出現(xiàn)的耦合問題,但是卻導(dǎo)致了每個微服務(wù)維護了一個相當(dāng)龐大的數(shù)據(jù)庫,整個系統(tǒng)的數(shù)據(jù)冗余程度過高。而且,同步所有數(shù)據(jù)庫也會產(chǎn)生相當(dāng)大的資源占用問題。
因此,現(xiàn)有技術(shù)中微服務(wù)的數(shù)據(jù)庫通常需要做大量的回歸測試,造成維護困難的問題,或者各微服務(wù)的數(shù)據(jù)庫數(shù)據(jù)冗余程度過高,同步所有數(shù)據(jù)庫造成的資源浪費的問題。
目前,現(xiàn)有技術(shù)還沒有相應(yīng)的方法來實現(xiàn)易于維護且高效利用資源的數(shù)據(jù)存儲方案。
技術(shù)實現(xiàn)要素:
針對現(xiàn)有技術(shù)的缺陷,本發(fā)明實施例提供一種計算機應(yīng)用、數(shù)據(jù)存儲方法、微服務(wù)和微數(shù)據(jù)庫。
一方面,本發(fā)明實施例提供一種計算機應(yīng)用,所述計算機應(yīng)用由若干個微服務(wù)實現(xiàn),每個微服務(wù)包括專屬的微數(shù)據(jù)庫,每個微數(shù)據(jù)庫只存儲對應(yīng)微服務(wù)功能的數(shù)據(jù),不同的微數(shù)據(jù)庫中的數(shù)據(jù)至少包括一個相同的屬性,每個屬性僅存在一個主節(jié)點,所述主節(jié)點為具有所述屬性的更新權(quán)限的微服務(wù),且存在至少一個從節(jié)點,所述從節(jié)點為不具有所述屬性的更新權(quán)限的微服務(wù),其中,所述主節(jié)點對該屬性進行讀數(shù)據(jù)或更新數(shù)據(jù)的操作,所述從節(jié)點對該屬性進行讀數(shù)據(jù)操作。
另一方面,本發(fā)明實施例提供一種數(shù)據(jù)存儲方法,所述方法適用于上述的計算機應(yīng)用,包括:
主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作;
主節(jié)點向至少一個從節(jié)點發(fā)送事件,所述事件包括所述主節(jié)點對所述屬性的記錄進行更新操作,使得所述從節(jié)點接收所述事件,根據(jù)所述事件,對從節(jié)點的微數(shù)據(jù)庫進行同步更新。
另一方面,本發(fā)明實施例還提供一種微服務(wù),包括存儲器、處理器、總線以及存儲在存儲器上并可在處理器上運行的計算機程序,所述處理器執(zhí)行所述程序時實現(xiàn)以上方法。
另一方面,本發(fā)明實施例還提供一種計算機可讀存儲介質(zhì),其上存儲有計算機程序,所述程序被處理器執(zhí)行時實現(xiàn)如上方法。
另一方面,本發(fā)明實施例還提供一種微數(shù)據(jù)庫,所述微數(shù)據(jù)庫是微服務(wù)的專屬的微數(shù)據(jù)庫,每個微數(shù)據(jù)庫只存儲對應(yīng)微服務(wù)功能的數(shù)據(jù),不同的微數(shù)據(jù)庫中的數(shù)據(jù)至少包括一個相同的屬性,每個屬性僅存在一個主節(jié)點,所述主節(jié)點為具有所述屬性的更新權(quán)限的微服務(wù),且存在至少一個從節(jié)點,所述從節(jié)點為不具有所述屬性的更新權(quán)限的微服務(wù),其中,所述主節(jié)點對該屬性進行讀數(shù)據(jù)或更新數(shù)據(jù)的操作,所述從節(jié)點對該屬性進行讀數(shù)據(jù)操作。
另一方面,本發(fā)明實施例還提供一種微服務(wù),包括上述微數(shù)據(jù)庫。
由上述技術(shù)方案可知,本發(fā)明實施例提供的計算機應(yīng)用、數(shù)據(jù)存儲方法、微服務(wù)和微數(shù)據(jù)庫,所述方法通過計算機應(yīng)用中各微服務(wù)擁有屬于自己的一個微數(shù)據(jù)庫,且將一個屬性的更新權(quán)限僅賦予主節(jié)點,使得從節(jié)點根據(jù)更新的事件進行同步更新,從而可占用較少的資源就能夠維護計算機應(yīng)用中各微數(shù)據(jù)庫的一致性。
附圖說明
圖1為現(xiàn)有技術(shù)中計算機應(yīng)用的共享數(shù)據(jù)庫示意圖;
圖2為本發(fā)明一實施例提供的一種計算機應(yīng)用的結(jié)構(gòu)示意圖;
圖3為本發(fā)明又一實施例提供的一種數(shù)據(jù)存儲方法的流程示意圖;
圖4為本發(fā)明又一實施例提供的一種數(shù)據(jù)存儲方法的流程示意圖;
圖5為本發(fā)明又一實施例提供的一種數(shù)據(jù)存儲方法的流程示意圖;
圖6為本發(fā)明又一實施例提供的一種計算機應(yīng)用的結(jié)構(gòu)示意圖;
圖7為本發(fā)明又一實施例提供的一種計算機應(yīng)用的結(jié)構(gòu)示意圖;
圖8為本發(fā)明又一實施例提供的一種微服務(wù)的結(jié)構(gòu)示意圖。
具體實施方式
為使本發(fā)明實施例的目的、技術(shù)方案和優(yōu)點更加清楚,下面將結(jié)合本發(fā)明實施例中的附圖,對本發(fā)明實施例中的技術(shù)方案進行清楚地描述,顯然,所描述的實施例是本發(fā)明實施例一部分實施例,而不是全部的實施例。
在本實施例中,微服務(wù)是一種新型軟件架構(gòu),就是把一個大型的單個應(yīng)用程序和服務(wù)拆分為數(shù)十個的支持微服務(wù)的節(jié)點。微服務(wù)可以是計算機,也可以是進程,可提供一個功能。
計算機應(yīng)用是一個網(wǎng)絡(luò)應(yīng)用系統(tǒng),所述計算機應(yīng)用由若干個微服務(wù)實現(xiàn)。
圖2示出了本發(fā)明實施例提供的一種計算機應(yīng)用的結(jié)構(gòu)示意圖。
在本計算機應(yīng)用中,每個微服務(wù)包括專屬的微數(shù)據(jù)庫,每個微數(shù)據(jù)庫只存儲對應(yīng)微服務(wù)功能的數(shù)據(jù),不同的微數(shù)據(jù)庫中的數(shù)據(jù)至少包括一個相同的屬性,每個屬性僅存在一個主節(jié)點,所述主節(jié)點為具有所述屬性的更新權(quán)限的微服務(wù),且存在至少一個從節(jié)點,所述從節(jié)點為不具有所述屬性的更新權(quán)限的微服務(wù),其中,所述主節(jié)點對該屬性進行讀數(shù)據(jù)或更新數(shù)據(jù)的操作,所述從節(jié)點對該屬性進行讀數(shù)據(jù)操作。
在本實施例中,在計算機應(yīng)用中引入微數(shù)據(jù)庫的概念。
微數(shù)據(jù)庫技術(shù)是本發(fā)明提出的一種不同于現(xiàn)有技術(shù)中數(shù)據(jù)庫持久化技術(shù)的新概念。微數(shù)據(jù)庫是指每個計算機應(yīng)用中的節(jié)點維護自己的一個數(shù)據(jù)庫,在每個微服務(wù)自己的微數(shù)據(jù)庫中,只維護完成自己功能所需要讀寫的那部分?jǐn)?shù)據(jù)。
其中,所述微數(shù)據(jù)庫包括多個表,每個表包括多個列,一個列稱為一個屬性,每個屬性包括多個記錄。
可選地,對于計算機應(yīng)用中,所有微數(shù)據(jù)庫中表的每一個屬性,存在且僅有一個微服務(wù)節(jié)點為其master,即所述主節(jié)點,其余需要讀寫此屬性的微服務(wù)節(jié)點均為該屬性的slave,即所述從節(jié)點,只能由master負(fù)責(zé)對該屬性下的記錄進行更新操作。
應(yīng)當(dāng)說明的是,每個屬性具有master和slave,而微服務(wù)之間沒有主從關(guān)系。
如圖2所示,舉例來說,微服務(wù)a的微數(shù)據(jù)庫中的屬性x的master為微服務(wù)b,微服務(wù)a和微服務(wù)c為屬性x的slave,微服務(wù)b的微數(shù)據(jù)庫中的屬性y的master為微服務(wù)a,微服務(wù)b和微服務(wù)c為屬性y的slave。
本實施例提供的計算機應(yīng)用,至少具有以下技術(shù)效果:
通過計算機應(yīng)用中各微服務(wù)擁有屬于自己的一個微數(shù)據(jù)庫,且將一個屬性的更新權(quán)限僅賦予主節(jié)點,使得從節(jié)點根據(jù)更新的事件進行同步更新,從而可占用較少的資源就能夠維護計算機應(yīng)用中各微數(shù)據(jù)庫的一致性。
圖3示出了本發(fā)明實施例提供的一種數(shù)據(jù)存儲方法的流程示意圖。
參照圖2和圖3,本發(fā)明實施例提供的方法適用于上述的計算機應(yīng)用,具體包括以下步驟:
步驟11、主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作。
具體地,每個屬性有且只有一個主節(jié)點,可以有若干個從節(jié)點。對于某個屬性的主節(jié)點,可以對該屬性進行讀數(shù)據(jù)和更新已存在數(shù)據(jù)的操作。對于某個屬性的從節(jié)點,可以對該屬性進行讀數(shù)據(jù)操作,不可以進行追加新數(shù)據(jù)和更新已存在數(shù)據(jù)的操作。當(dāng)某個屬性的主節(jié)點對該屬性進行寫操作,即更新操作時,包括追加新數(shù)據(jù)和更新已存在數(shù)據(jù),主節(jié)點在正常完成本節(jié)點的寫操作。
步驟12、主節(jié)點向至少一個從節(jié)點發(fā)送事件,所述事件包括所述主節(jié)點對所述屬性的記錄進行更新操作,使得所述從節(jié)點接收所述事件,根據(jù)所述事件,對從節(jié)點的微數(shù)據(jù)庫進行同步更新。
在主節(jié)點在正常完成本節(jié)點的寫操作后,會將對該屬性的寫操作以事件的方式通知該屬性的從節(jié)點,當(dāng)從節(jié)點接收到寫操作事件后,執(zhí)行與該屬性相關(guān)的修改操作,完成更新。
其中,主節(jié)點向發(fā)送事件的手段可采用現(xiàn)有技術(shù)中的點對點的數(shù)據(jù)傳遞方式。
所述主節(jié)點的微數(shù)據(jù)庫和所述從節(jié)點的微數(shù)據(jù)庫均為維護對應(yīng)的微服務(wù)的數(shù)據(jù)存儲設(shè)備,且由于只有屬性的主節(jié)點具有所述屬性的更新權(quán)限,其他從節(jié)點需對應(yīng)進行同步更新,以維護各微數(shù)據(jù)庫的一致性。
可選地,所述從節(jié)點根據(jù)所述事件,對從節(jié)點的微數(shù)據(jù)庫進行同步更新,所述從節(jié)點的微數(shù)據(jù)庫是維護對應(yīng)的從節(jié)點功能的數(shù)據(jù)存儲設(shè)備。也就是說,所述屬性的slave則需要與所述屬性的master保持同步,維持計算機應(yīng)用內(nèi)各微服務(wù)中數(shù)據(jù)庫的一致性。
應(yīng)當(dāng)說明的是,微數(shù)據(jù)庫不同于現(xiàn)有技術(shù)中水平分片和垂直分片的分布式數(shù)據(jù)庫,水平分片和垂直分片的分布式數(shù)據(jù)庫只是實現(xiàn)了對龐大單個數(shù)據(jù)庫的分片,其本質(zhì)上還是一個所有微服務(wù)共享的數(shù)據(jù)庫,并不能解決微服務(wù)數(shù)據(jù)持久化中存在的高耦合、維護數(shù)據(jù)庫之間的一致性會占用過量資源的問題,而系統(tǒng)內(nèi)每個微服務(wù)節(jié)點擁有屬于自己的一個微數(shù)據(jù)庫,所述微數(shù)據(jù)庫維護所述微服務(wù)完成自己功能所需要讀寫的那部分?jǐn)?shù)據(jù)。
可以理解的是,計算機應(yīng)用中各微服務(wù)擁有屬于自己的一個微數(shù)據(jù)庫,當(dāng)屬性的主節(jié)點進行更新時,所述屬性的從節(jié)點僅需更新所述屬性,即可實現(xiàn)各微數(shù)據(jù)庫的同步。
本實施例提供的數(shù)據(jù)存儲方法,至少具有以下技術(shù)效果:
通過計算機應(yīng)用中各微服務(wù)擁有屬于自己的一個微數(shù)據(jù)庫,且將一個屬性的更新權(quán)限僅賦予主節(jié)點,使得從節(jié)點根據(jù)更新的事件進行同步更新,從而可占用較少的資源就能夠維護計算機應(yīng)用中各微數(shù)據(jù)庫的一致性。
圖4示出了本發(fā)明又一實施例提供的一種數(shù)據(jù)存儲方法的流程示意圖。
參照圖4,在上述實施例的基礎(chǔ)上,本實施例提供的數(shù)據(jù)存儲方法。所述步驟11之前,所述方法還包括:
步驟10、所述主節(jié)點接收所述從節(jié)點發(fā)送的更新請求,用于請求所述主節(jié)點對所述主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作。
當(dāng)某一屬性的slave需要更新一條記錄,所述slave需向所述屬性的master發(fā)送更新請求,用于請求master對所述主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作,在主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中所述屬性的記錄進行更新操作后,再向?qū)傩詫?yīng)的各slave發(fā)送事件,使得slave接收所述事件,并對從節(jié)點的微數(shù)據(jù)庫進行更新。
在本實施例中,由于計算機應(yīng)用中對于某一屬性,只有master可對有關(guān)此屬性的記錄項進行更新,保證了只有一個入口,從而可進一步保證master和所有slave間的數(shù)據(jù)一致性,而不會出現(xiàn)因為分別維護各自的微數(shù)據(jù)庫造成的數(shù)據(jù)不一致。
可選地,所述主節(jié)點接收到所述從節(jié)點發(fā)送的更新請求后,對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作之前,所述方法還包括:
所述主節(jié)點從對應(yīng)的所述主節(jié)點的微數(shù)據(jù)庫中讀取所述記錄。
具體地,計算機應(yīng)用中各微服務(wù)節(jié)點維護自己的一個微數(shù)據(jù)庫,所述微數(shù)據(jù)庫維護對應(yīng)的微服務(wù)節(jié)點完成自己功能所需要讀寫的那部分?jǐn)?shù)據(jù)。
在所述主節(jié)點讀取運行所需數(shù)據(jù)時,可從對應(yīng)的所述主節(jié)點的微數(shù)據(jù)庫中讀取所述記錄。相應(yīng)地,在所述從節(jié)點讀取運行所需數(shù)據(jù)時,可從對應(yīng)的所述從節(jié)點的微數(shù)據(jù)庫中讀取所述記錄。
可選地,所述主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作,具體為對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行增加、修改或刪除。
具體地,所述系統(tǒng)內(nèi)某一屬性的master需要增加一條記錄,所述slave需向所述屬性的master發(fā)送增加所述記錄的消息,通知該master向自己的數(shù)據(jù)庫增加所述記錄。
所述系統(tǒng)內(nèi)某一屬性的master需要修改一條記錄,所述slave需向所述屬性的master發(fā)送修改所述記錄的消息,通知該master修改自己的數(shù)據(jù)庫中的所述記錄。
所述系統(tǒng)內(nèi)某一屬性的master需要刪除一條記錄,所述slave需向所述屬性的master發(fā)送刪除所述記錄的消息,通知該master向自己的數(shù)據(jù)庫刪除所述記錄。
可選地,所述主節(jié)點接收所述從節(jié)點發(fā)送的所述更新請求,具體為對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行增加、修改或刪除。
具體地,所述系統(tǒng)內(nèi)某一屬性的slave需要增加一條記錄,所述slave需向所述屬性的master發(fā)送增加所述記錄的消息,通知該master在主節(jié)點的微數(shù)據(jù)庫增加所述記錄。
所述系統(tǒng)內(nèi)某一屬性的slave需要修改一條記錄,所述slave需向所述屬性的master發(fā)送修改所述記錄的消息,通知該master修改主節(jié)點的微數(shù)據(jù)庫中的所述記錄。
所述系統(tǒng)內(nèi)某一屬性的slave需要刪除一條記錄,所述slave需向所述屬性的master發(fā)送刪除所述記錄的消息,通知該master刪除主節(jié)點的微數(shù)據(jù)庫中的所述記錄。
也就是說,當(dāng)一個從節(jié)點接收到某個屬性的增/刪/改請求時,并不能直接執(zhí)行修改操作,從節(jié)點將對應(yīng)的修改請求消息發(fā)送到主節(jié)點,使主節(jié)點執(zhí)行相應(yīng)的修改操作,將對該屬性的寫操作發(fā)送到該屬性的從節(jié)點,從節(jié)點執(zhí)行與該屬性相關(guān)的修改操作,完成更新。
本實施例提供的數(shù)據(jù)存儲方法,至少具有以下技術(shù)效果:
通過所述主節(jié)點接收所述從節(jié)點發(fā)送的更新請求,對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作,保證一個屬性只有主節(jié)點可進行更新,從而可進一步保證主節(jié)點和從節(jié)點間的數(shù)據(jù)一致性。
圖5示出了本發(fā)明又一實施例提供的一種數(shù)據(jù)存儲方法的流程示意圖。
參照圖5,在上述實施例的基礎(chǔ)上,所述步驟12,所述主節(jié)點向至少一個從節(jié)點發(fā)送事件的方式可有多種,本實施例舉例說明其中一種。
所述步驟12具體為:
步驟12’、所述主節(jié)點向發(fā)布訂閱系統(tǒng)發(fā)送事件,使得發(fā)布訂閱系統(tǒng)向所述從節(jié)點發(fā)送所述事件。
可選地,發(fā)布訂閱系統(tǒng)負(fù)責(zé)存儲所述事件,主要用來解決高并發(fā)下減輕數(shù)據(jù)庫的壓力以及解決線程阻塞問題。
圖6示出了本發(fā)明又一實施例提供的一種計算機應(yīng)用的結(jié)構(gòu)示意圖。
如圖6所示,所述主節(jié)點a向發(fā)布訂閱系統(tǒng)發(fā)送所述事件,使得各從節(jié)點b和c接收所述事件。
圖7示出了本發(fā)明又一實施例提供的一種計算機應(yīng)用的結(jié)構(gòu)示意圖。
如圖7所示,所述從節(jié)點c向發(fā)布訂閱系統(tǒng)發(fā)送請求,用于請求主節(jié)點a更新屬性,使得主節(jié)點a接收所述請求,所述主節(jié)點的微數(shù)據(jù)庫進行屬性更新,更新再向發(fā)布訂閱系統(tǒng)發(fā)送所述事件,使得從節(jié)點b和c接收所述事件,對所述從節(jié)點的微數(shù)據(jù)庫進行同步更新。
在步驟12’之前,所述方法還包括:
所述主節(jié)點向所述發(fā)布訂閱系統(tǒng)發(fā)送設(shè)置請求,使得所述主節(jié)點能夠向所述發(fā)布訂閱系統(tǒng)發(fā)布或訂閱所述事件。
發(fā)布-訂閱模式包括生產(chǎn)者以及消費者,即發(fā)布方和訂閱方,其主要特點就是每一個消息可以有多個消費者。生產(chǎn)者把消息發(fā)送到一個主題(topic)中,消息代理將消息發(fā)布給訂閱該主題的每一個消費者。
發(fā)布-訂閱模式的主要特點就是每一個消息可以有多個消費者。生產(chǎn)者把消息發(fā)送到一個主題(topic)中,消息代理將消息發(fā)布給訂閱該主題的每一個消費者。
所述發(fā)布-訂閱系統(tǒng)中,每一個屬性為一個主題(topic),所述master作為生產(chǎn)者將自己數(shù)據(jù)庫里記錄變化這一事件發(fā)送到對應(yīng)的主題中。每個屬性的所有slave會作為消費者訂閱對應(yīng)的主題。相應(yīng)地,每個屬性的master會作為消費者訂閱所有針對這一屬性的更新請求。
所述master在增加或更新所述記錄時,將這一事件發(fā)送到發(fā)布-訂閱系統(tǒng)中。所述事件存儲于發(fā)布-訂閱系統(tǒng)中等待被訂閱所述事件對應(yīng)的主題的作為消費者的slave消費。當(dāng)所述slave消費所述事件時,會根據(jù)所述事件同步自己的數(shù)據(jù)庫來保持與所述master的數(shù)據(jù)庫的一致性。
也就是說,當(dāng)某個屬性的主節(jié)點對該屬性進行寫操作,包括追加新數(shù)據(jù)和更新已存在數(shù)據(jù)時,主節(jié)點在正常完成本節(jié)點的寫操作后,會將對該屬性的寫操作以事件的方式發(fā)送到發(fā)布訂閱系統(tǒng),該屬性的從節(jié)點通過訂閱以該屬性為主題的修改消息,當(dāng)接收到某屬性主節(jié)點發(fā)布的寫操作事件后,發(fā)布訂閱系統(tǒng)會將該事件轉(zhuǎn)發(fā)給該屬性的從節(jié)點。從節(jié)點執(zhí)行與該屬性相關(guān)的修改操作,完成更新。
當(dāng)一個從節(jié)點接收到某個屬性修改請求時,并不能直接執(zhí)行修改操作,從節(jié)點發(fā)布以該屬性為主題的修改請求消息到發(fā)布訂閱系統(tǒng),主節(jié)點通過訂閱該消息接收到修改請求,執(zhí)行相應(yīng)的修改操作,將對該屬性的寫操作以事件的方式發(fā)送到發(fā)布訂閱系統(tǒng)并進一步發(fā)送到該屬性的從節(jié)點,從節(jié)點執(zhí)行與該屬性相關(guān)的修改操作,完成更新。
可選地,若所述主節(jié)點的微數(shù)據(jù)庫存儲的記錄丟失后,所述主節(jié)點接收發(fā)布訂閱系統(tǒng)中發(fā)送的備份事件,并根據(jù)所述備份事件進行所述主節(jié)點的微數(shù)據(jù)庫的恢復(fù),其中,所述備份事件是所述發(fā)布訂閱系統(tǒng)接收所述主節(jié)點發(fā)送的所述事件時存儲的事件。
當(dāng)某一微服務(wù)節(jié)點失效后,即使數(shù)據(jù)庫中數(shù)據(jù)丟失,也可以通過發(fā)布-訂閱系統(tǒng)中存儲的事件來恢復(fù)數(shù)據(jù)庫,提高了系統(tǒng)的可用性。
本實施例提供的數(shù)據(jù)存儲方法,至少具有以下技術(shù)效果:
通過發(fā)布訂閱系統(tǒng)來傳遞主節(jié)點以從節(jié)點間的事件,可提高傳遞效率。
為了更充分理解本發(fā)明的技術(shù)內(nèi)容,在上述實施例的基礎(chǔ)上,本實施例提供的數(shù)據(jù)存儲方法,可應(yīng)用于多種場景中,本實施例以學(xué)校學(xué)生信息管理場景為例進行說明。
學(xué)校學(xué)生信息管理場景中,本實施例提供的數(shù)據(jù)存儲方法應(yīng)用于學(xué)校學(xué)生信息管理系統(tǒng)中。
參閱圖2,其中微服務(wù)a為學(xué)生基本信息服務(wù),微服務(wù)b為學(xué)生成績管理服務(wù),微服務(wù)c為學(xué)生成績報告單郵寄服務(wù)。
其中,微服務(wù)a的數(shù)據(jù)庫維護學(xué)生的學(xué)號、姓名、家庭住址信息,微服務(wù)b的數(shù)據(jù)庫維護學(xué)生的學(xué)號、成績信息,微服務(wù)c的數(shù)據(jù)庫維護學(xué)生的學(xué)號、成績、家庭住址信息。上述微服務(wù)均未維護系統(tǒng)內(nèi)的所有屬性,數(shù)據(jù)冗余度極低。
表1為學(xué)校學(xué)生信息管理系統(tǒng)內(nèi)的數(shù)據(jù)關(guān)系。
如表1所示,微服務(wù)節(jié)點a是學(xué)生的學(xué)號、姓名、家庭住址的master,微服務(wù)b是學(xué)生成績的master。微服務(wù)b是學(xué)生學(xué)號的slave,微服務(wù)c是學(xué)生學(xué)號、成績和家庭住址的slave。
表2為學(xué)校學(xué)生信息管理系統(tǒng)內(nèi)發(fā)布-訂閱情況。
如表2所示,作為學(xué)生學(xué)號的slave的微服務(wù)b向發(fā)布-訂閱系統(tǒng)訂閱了學(xué)號這一屬性,作為學(xué)生學(xué)號、成績和家庭住址的slave的微服務(wù)c,向發(fā)布-訂閱系統(tǒng)訂閱了學(xué)生學(xué)號、成績和家庭住址屬性。相應(yīng)地,各屬性的master需要向發(fā)布-訂閱系統(tǒng)訂閱針對該屬性的修改請求。
如圖6所示,當(dāng)需要向系統(tǒng)內(nèi)注冊一名新生的基本信息時,微服務(wù)a作為學(xué)生的學(xué)號、姓名、家庭住址的master,直接向自己的數(shù)據(jù)庫添加一條新的記錄,并將這個事件發(fā)送到發(fā)布-訂閱系統(tǒng)的學(xué)號、姓名、家庭住址三個主題中。
此時,微服務(wù)b和c會從訂閱了的主題中消費這個事件,相應(yīng)地,微服務(wù)b會向自己的數(shù)據(jù)庫中增加一條帶有新的學(xué)號的記錄,而微服務(wù)c會向自己的數(shù)據(jù)庫中增加一條帶有新的學(xué)號和對應(yīng)家庭住址的記錄。實現(xiàn)了系統(tǒng)內(nèi)數(shù)據(jù)的一致性。
當(dāng)需要向系統(tǒng)更新一條學(xué)生成績記錄時,微服務(wù)b作為學(xué)生成績的master,直接向自己的數(shù)據(jù)庫中更新一條學(xué)生成績記錄,并將這個事件發(fā)送到發(fā)布-訂閱系統(tǒng)的成績這一主題中。
此時,微服務(wù)c因為訂閱了成績這一主題會消費所述事件,向自己的數(shù)據(jù)庫中更新對應(yīng)的學(xué)生的成績記錄。實現(xiàn)了系統(tǒng)內(nèi)數(shù)據(jù)的一致性。
如圖7所示,當(dāng)使用微服務(wù)c的負(fù)責(zé)郵寄學(xué)生成績的老師發(fā)現(xiàn)其中一個學(xué)生的成績錄入錯誤需要修改時,因為微服務(wù)c并不是學(xué)生成績的master,修改成績屬性下的記錄項就需要向成績屬性的master(微服務(wù)b)請求,讓微服務(wù)b作為學(xué)生成績的master來修改自己數(shù)據(jù)庫中對應(yīng)的一條記錄,所以微服務(wù)c向發(fā)布-訂閱系統(tǒng)發(fā)送了一條修改成績的請求。微服務(wù)b作為成績修改請求的消費者,從發(fā)布-訂閱系統(tǒng)收到來自微服務(wù)c的修改請求,向自己的數(shù)據(jù)庫中更新自己數(shù)據(jù)庫中對應(yīng)的一條記錄,并將這個事件發(fā)送到發(fā)布-訂閱系統(tǒng)的成績這一主題中。微服務(wù)c因為訂閱了成績這一主題會消費所述事件,向自己的數(shù)據(jù)庫中更新對應(yīng)的學(xué)生的成績記錄。實現(xiàn)了系統(tǒng)內(nèi)數(shù)據(jù)的一致性,完成了對學(xué)生成績的更新操作。
當(dāng)某一微服務(wù)失效后,即使數(shù)據(jù)庫中數(shù)據(jù)丟失,也可以通過發(fā)布-訂閱系統(tǒng)中存儲的事件來恢復(fù)數(shù)據(jù)庫,提高了系統(tǒng)的可用性。
如果微服務(wù)c失效,重啟后,它可以根據(jù)發(fā)布-訂閱系統(tǒng)中持久化過的事件進行恢復(fù),例如微服務(wù)a向系統(tǒng)中添加學(xué)生信息,微服務(wù)b向系統(tǒng)中更新學(xué)生信息的事件。由于發(fā)布-訂閱系統(tǒng)的時間特性,所有事件是有序的,根據(jù)所述順序就能恢復(fù)到數(shù)據(jù)庫原有的狀態(tài)。
本實施例提供的數(shù)據(jù)存儲方法,至少具有以下技術(shù)效果:
(1)松耦合。每個微服務(wù)擁有屬于自己的數(shù)據(jù)庫,各自可以選擇不同的數(shù)據(jù)庫技術(shù)以及定義自己的數(shù)據(jù)庫的數(shù)據(jù)模型和表結(jié)構(gòu)。每個微服務(wù)不需要知道其他微服務(wù)的數(shù)據(jù)庫的內(nèi)部實現(xiàn)細(xì)節(jié),如果其中某個微服務(wù)為了更好的表示數(shù)據(jù)或者增加可維護性而修改表結(jié)構(gòu)的話,不會對其他微服務(wù)產(chǎn)生影響。
(2)數(shù)據(jù)冗余度低。每個微服務(wù)不需要維護一個相當(dāng)龐大的數(shù)據(jù)庫,整個系統(tǒng)的數(shù)據(jù)冗余程度低。
(3)維護一致性成本低。其中某一微服務(wù)更新一條記錄,所述記錄只會影響訂閱了涉及該記錄中屬性的微服務(wù),而不需要對系統(tǒng)內(nèi)所有微服務(wù)的數(shù)據(jù)庫進行同步。
(4)可擴展性高。如果系統(tǒng)中只有某個微服務(wù)存在性能問題,只需要對該微服務(wù)進行修改擴展。且只需要重新部署所述微服務(wù)就能夠發(fā)布該變更,這種部署風(fēng)險性小。如果想要在系統(tǒng)中加入新的微服務(wù),新的微服務(wù)只需要向發(fā)布-訂閱系統(tǒng)訂閱所需的屬性即可。
(5)當(dāng)某一微服務(wù)失效后,即使數(shù)據(jù)庫中數(shù)據(jù)丟失,也可以通過發(fā)布-訂閱系統(tǒng)中存儲的事件來恢復(fù)數(shù)據(jù)庫,提高了系統(tǒng)的可用性。
圖8示出了本發(fā)明又一實施例提供的一種微服務(wù)的結(jié)構(gòu)示意圖。
參照圖8,所述微服務(wù)包括存儲器91、處理器92以及存儲在存儲器91上并可在處理器上運行的計算機程序。
所述處理器92用于調(diào)用所述存儲器91中的程序指令,以執(zhí)行所述程序時實現(xiàn)如下的方法。
所述方法適用于計算機應(yīng)用中,所述計算機應(yīng)用由若干個微服務(wù)實現(xiàn),每個微服務(wù)包括專屬的微數(shù)據(jù)庫,每個微數(shù)據(jù)庫只存儲對應(yīng)微服務(wù)功能的數(shù)據(jù),不同的微數(shù)據(jù)庫中的數(shù)據(jù)至少包括一個相同的屬性,每個屬性僅存在一個主節(jié)點,所述主節(jié)點為具有所述屬性的更新權(quán)限的微服務(wù),且存在至少一個從節(jié)點,所述從節(jié)點為不具有所述屬性的更新權(quán)限的微服務(wù),其中,所述主節(jié)點對該屬性進行讀數(shù)據(jù)或更新數(shù)據(jù)的操作,所述從節(jié)點對該屬性進行讀數(shù)據(jù)操作。
對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作;
主向至少一個從節(jié)點發(fā)送事件,所述事件包括所述主節(jié)點對所述屬性的記錄進行更新操作,使得所述從節(jié)點接收所述事件,根據(jù)所述事件,對從節(jié)點的微數(shù)據(jù)庫進行同步更新。
所述主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作之前,還包括所述主節(jié)點從對應(yīng)的所述主節(jié)點的微數(shù)據(jù)庫中讀取所述記錄。
所述主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作,具體為對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行增加、修改或刪除。
所述主節(jié)點向至少一個從節(jié)點發(fā)送事件,使得所述從節(jié)點接收所述事件,具體為:
所述主節(jié)點向發(fā)布訂閱系統(tǒng)發(fā)送事件,使得發(fā)布訂閱系統(tǒng)向所述從節(jié)點發(fā)送所述事件。
所述主節(jié)點向發(fā)布訂閱系統(tǒng)發(fā)送事件,使得發(fā)布訂閱系統(tǒng)向所述從節(jié)點發(fā)送所述事件之前,所述方法還包括:
所述主節(jié)點向所述發(fā)布訂閱系統(tǒng)發(fā)送設(shè)置請求,使得所述主節(jié)點能夠向所述發(fā)布訂閱系統(tǒng)發(fā)布或訂閱所述事件。
若所述主節(jié)點的微數(shù)據(jù)庫存儲的記錄丟失后,所述主節(jié)點接收發(fā)布訂閱系統(tǒng)中發(fā)送的備份事件,并根據(jù)所述備份事件進行所述主節(jié)點的微數(shù)據(jù)庫的恢復(fù),其中,所述備份事件是所述發(fā)布訂閱系統(tǒng)接收所述主節(jié)點發(fā)送的所述事件時存儲的事件。
所述主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作之前,還包括:
所述主節(jié)點接收所述從節(jié)點發(fā)送的更新請求,用于請求所述主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作。
本實施例提供的微服務(wù),可用于執(zhí)行上述方法實施例的方法對應(yīng)的程序,本實施不再贅述。
本實施例提供的微服務(wù),至少具有以下技術(shù)效果:
通過所述處理器執(zhí)行所述程序時實現(xiàn)對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作,向至少一個從節(jié)點發(fā)送事件,使得所述從節(jié)點根據(jù)所述事件,對從節(jié)點的微數(shù)據(jù)庫進行同步更新從而可占用較少的資源就能夠維護計算機應(yīng)用中各微數(shù)據(jù)庫的一致性。
本發(fā)明又一實施例提供的一種計算機可讀存儲介質(zhì),所述計算機可讀存儲介質(zhì)上存儲有計算機程序,所述程序被處理器執(zhí)行時實現(xiàn)如下步驟:
對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作;
主向至少一個從節(jié)點發(fā)送事件,所述事件包括所述主節(jié)點對所述屬性的記錄進行更新操作,使得所述從節(jié)點接收所述事件,根據(jù)所述事件,對從節(jié)點的微數(shù)據(jù)庫進行同步更新。
所述主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作之前,還包括所述主節(jié)點從對應(yīng)的所述主節(jié)點的微數(shù)據(jù)庫中讀取所述記錄。
所述主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作,具體為對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行增加、修改或刪除。
所述主節(jié)點向至少一個從節(jié)點發(fā)送事件,使得所述從節(jié)點接收所述事件,具體為:
所述主節(jié)點向發(fā)布訂閱系統(tǒng)發(fā)送事件,使得發(fā)布訂閱系統(tǒng)向所述從節(jié)點發(fā)送所述事件。
所述主節(jié)點向發(fā)布訂閱系統(tǒng)發(fā)送事件,使得發(fā)布訂閱系統(tǒng)向所述從節(jié)點發(fā)送所述事件之前,所述方法還包括:
所述主節(jié)點向所述發(fā)布訂閱系統(tǒng)發(fā)送設(shè)置請求,使得所述主節(jié)點能夠向所述發(fā)布訂閱系統(tǒng)發(fā)布或訂閱所述事件。
若所述主節(jié)點的微數(shù)據(jù)庫存儲的記錄丟失后,所述主節(jié)點接收發(fā)布訂閱系統(tǒng)中發(fā)送的備份事件,并根據(jù)所述備份事件進行所述主節(jié)點的微數(shù)據(jù)庫的恢復(fù),其中,所述備份事件是所述發(fā)布訂閱系統(tǒng)接收所述主節(jié)點發(fā)送的所述事件時存儲的事件。
所述主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作之前,還包括:
所述主節(jié)點接收所述從節(jié)點發(fā)送的更新請求,用于請求所述主節(jié)點對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作。
本實施例提供的計算機可讀存儲介質(zhì),所述程序被處理器執(zhí)行時實現(xiàn)上述方法實施例的方法,本實施不再贅述。
本實施例提供的計算機可讀存儲介質(zhì),至少具有以下技術(shù)效果:
通過所述處理器執(zhí)行所述程序時實現(xiàn)對主節(jié)點的微數(shù)據(jù)庫中屬性的記錄進行更新操作,向至少一個從節(jié)點發(fā)送事件,使得所述從節(jié)點根據(jù)所述事件,對從節(jié)點的微數(shù)據(jù)庫進行同步更新從而可占用較少的資源就能夠維護計算機應(yīng)用中各微數(shù)據(jù)庫的一致性。
本發(fā)明又一實施例提供的一種微數(shù)據(jù)庫,所述微數(shù)據(jù)庫是微服務(wù)的專屬的微數(shù)據(jù)庫,每個微數(shù)據(jù)庫只存儲對應(yīng)微服務(wù)功能的數(shù)據(jù),不同的微數(shù)據(jù)庫中的數(shù)據(jù)至少包括一個相同的屬性,每個屬性僅存在一個主節(jié)點,所述主節(jié)點為具有所述屬性的更新權(quán)限的微服務(wù),且存在至少一個從節(jié)點,所述從節(jié)點為不具有所述屬性的更新權(quán)限的微服務(wù),其中,所述主節(jié)點對該屬性進行讀數(shù)據(jù)或更新數(shù)據(jù)的操作,所述從節(jié)點對該屬性進行讀數(shù)據(jù)操作。
應(yīng)當(dāng)說明的是,微數(shù)據(jù)庫不同于現(xiàn)有技術(shù)中水平分片和垂直分片的分布式數(shù)據(jù)庫,水平分片和垂直分片的分布式數(shù)據(jù)庫只是實現(xiàn)了對龐大單個數(shù)據(jù)庫的分片,其本質(zhì)上還是一個所有微服務(wù)共享的數(shù)據(jù)庫,并不能解決微服務(wù)數(shù)據(jù)持久化中存在的高耦合、維護數(shù)據(jù)庫之間的一致性會占用過量資源的問題,而系統(tǒng)內(nèi)每個微服務(wù)節(jié)點擁有屬于自己的一個微數(shù)據(jù)庫,所述微數(shù)據(jù)庫維護所述微服務(wù)完成自己功能所需要讀寫的那部分?jǐn)?shù)據(jù)。
本實施例提供的微數(shù)據(jù)庫,可實現(xiàn)上述方法實施例的方法,本實施不再贅述。
本實施例提供的微數(shù)據(jù)庫,至少具有以下技術(shù)效果:
各微服務(wù)擁有屬于自己的一個微數(shù)據(jù)庫,當(dāng)屬性的主節(jié)點進行更新時,所述屬性的從節(jié)點僅需更新所述屬性,即可實現(xiàn)各微數(shù)據(jù)庫的同步。
本發(fā)明又一實施例提供的一種微服務(wù),包括一種微數(shù)據(jù)庫。
其中,所述微數(shù)據(jù)庫是微服務(wù)的專屬的微數(shù)據(jù)庫,每個微數(shù)據(jù)庫只存儲對應(yīng)微服務(wù)功能的數(shù)據(jù),不同的微數(shù)據(jù)庫中的數(shù)據(jù)至少包括一個相同的屬性,每個屬性僅存在一個主節(jié)點,所述主節(jié)點為具有所述屬性的更新權(quán)限的微服務(wù),且存在至少一個從節(jié)點,所述從節(jié)點為不具有所述屬性的更新權(quán)限的微服務(wù),其中,所述主節(jié)點對該屬性進行讀數(shù)據(jù)或更新數(shù)據(jù)的操作,所述從節(jié)點對該屬性進行讀數(shù)據(jù)操作。
本實施例提供的微服務(wù),所述微服務(wù)可實現(xiàn)上述方法實施例的方法,本實施不再贅述。
本實施例提供的微服務(wù),至少具有以下技術(shù)效果:
各微服務(wù)擁有屬于自己的一個微數(shù)據(jù)庫,當(dāng)屬性的主節(jié)點進行更新時,所述屬性的從節(jié)點僅需更新所述屬性,即可實現(xiàn)各微數(shù)據(jù)庫的同步。
最后應(yīng)說明的是:以上實施例僅用以說明本發(fā)明實施例的技術(shù)方案,而非對其限制;盡管參照前述實施例對本發(fā)明實施例進行了詳細(xì)的說明,本領(lǐng)域的普通技術(shù)人員應(yīng)當(dāng)理解:其依然可以對前述各實施例所記載的技術(shù)方案進行修改,或者對其中部分技術(shù)特征進行等同替換;而這些修改或者替換,并不使相應(yīng)技術(shù)方案的本質(zhì)脫離本發(fā)明實施例各實施例技術(shù)方案的精神和范圍。