分布式事務(wù)數(shù)據(jù)最終一致性之serviceComb-Saga使用方法

準(zhǔn)備環(huán)境

1.安裝JDK 1.8

2.安裝Maven 3.x

3.安裝Docker

編譯

$ git clone https://github.com/apache/incubator-servicecomb-saga.git
$ cd incubator-servicecomb-saga
$ mvn clean install -DskipTests -Pdocker

如何使用

引入Saga的依賴

 <dependency>
      <groupId>org.apache.servicecomb.saga</groupId>
      <artifactId>omega-spring-starter</artifactId>
      <version>0.0.3-SNAPSHOT</version>
  </dependency>
  <dependency>
      <groupId>org.apache.servicecomb.saga</groupId>
      <artifactId>omega-transport-resttemplate</artifactId>
      <version>0.0.3-SNAPSHOT</version>
  </dependency>

注意:如果是使用https://start.spring.io/創(chuàng)建的項(xiàng)目鹏倘,那么還需要手動(dòng)添加

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>

這個(gè)依賴

最終的pom包含五個(gè)依賴

添加Saga的注解及相應(yīng)的補(bǔ)償方法

以一個(gè)轉(zhuǎn)賬應(yīng)用為例:

在應(yīng)用入口加入注解@EnableOmega來初始化omega的配置并與alpha建立連接聋伦。spring boot就直接在application上加入這個(gè)注解


@SpringBootApplication
@EnableOmega
public class Application {
  public static void main(String[] args) {
    SpringApplication.run(Application.class, args);
  }
}

在全局事務(wù)的起點(diǎn)添加@SagaStart注解

@SagaStart(timeout=10)
public boolean transferMoney(String from, String to, int amount) {
  transferOut(from, amount);
  transferIn(to, amount);
}

注意: 默認(rèn)情況下,超時(shí)設(shè)置需要顯式聲明才生效玛臂。

在子事務(wù)處添加 @Compensable 的注解并指明其對(duì)應(yīng)的補(bǔ)償方法前域。

@Compensable(timeout=5, compensationMethod="cancel")
public boolean transferOut(String from, int amount) {
  repo.reduceBalanceByUsername(from, amount);
}
public boolean cancel(String from, int amount) {
  repo.addBalanceByUsername(from, amount);
}

注意: 默認(rèn)情況下辕近,超時(shí)設(shè)置需要顯式聲明才生效。

注意: 若全局事務(wù)起點(diǎn)與子事務(wù)起點(diǎn)重合匿垄,需同時(shí)聲明 @SagaStart 和 @Compensable 的注解移宅。

對(duì)轉(zhuǎn)入服務(wù)重復(fù)第三步即可。

如何運(yùn)行

1.首先運(yùn)行postgresql

docker run -d -e "POSTGRES_DB=saga" -e "POSTGRES_USER=saga" -e "POSTGRES_PASSWORD=password" -p 5432:5432 postgres

這一步我是在linux服務(wù)器上直接運(yùn)行的年堆,因?yàn)榈谝徊轿揖幾g是在linux上編譯的吞杭,本地環(huán)境是win7,使用docker不方便

2.運(yùn)行alpha变丧。在運(yùn)行alpha前芽狗,請(qǐng)確保postgreSQL已正常啟動(dòng)。

docker run -d -p 8090:8090 \
  -e "JAVA_OPTS=-Dspring.profiles.active=prd" \
  -e "spring.datasource.url=jdbc:postgresql://{docker.host.address}:5432/saga?useSSL=false" \
  alpha-server:0.0.3-SNAPSHOT

這里注意把{docker.host.address}改成你的postpresql的地址
3.最后在你的服務(wù)里面配置omega的信息痒蓬。以yaml為例

spring:
  application:
    name: {application.name}alpha:
  cluster:
    address: {alpha.cluster.addresses}(這里注意要使用8080這個(gè)端口)

然后就可以運(yùn)行相關(guān)的微服務(wù)了童擎。

參考自:https://github.com/apache/incubator-servicecomb-saga/blob/master/docs/user_guide_zh.md
補(bǔ)充了部分自己摸索遇到的坑

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末滴劲,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子顾复,更是在濱河造成了極大的恐慌班挖,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件芯砸,死亡現(xiàn)場離奇詭異萧芙,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)假丧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門双揪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人包帚,你說我怎么就攤上這事渔期。” “怎么了渴邦?”我有些...
    開封第一講書人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵疯趟,是天一觀的道長。 經(jīng)常有香客問我谋梭,道長信峻,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任章蚣,我火速辦了婚禮站欺,結(jié)果婚禮上姨夹,老公的妹妹穿的比我還像新娘纤垂。我一直安慰自己,他們只是感情好磷账,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開白布峭沦。 她就那樣靜靜地躺著,像睡著了一般逃糟。 火紅的嫁衣襯著肌膚如雪吼鱼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,692評(píng)論 1 305
  • 那天绰咽,我揣著相機(jī)與錄音菇肃,去河邊找鬼。 笑死取募,一個(gè)胖子當(dāng)著我的面吹牛琐谤,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播玩敏,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼斗忌,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼质礼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起织阳,我...
    開封第一講書人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤眶蕉,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后唧躲,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體造挽,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年弄痹,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了刽宪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡界酒,死狀恐怖圣拄,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情毁欣,我是刑警寧澤庇谆,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站凭疮,受9級(jí)特大地震影響饭耳,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜执解,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一寞肖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧衰腌,春花似錦新蟆、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至饶囚,卻和暖如春帕翻,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背萝风。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來泰國打工嘀掸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人规惰。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓睬塌,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子衫仑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,823評(píng)論 6 342
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理梨与,服務(wù)發(fā)現(xiàn),斷路器文狱,智...
    卡卡羅2017閱讀 134,662評(píng)論 18 139
  • 序 又到了寫年終總結(jié)的時(shí)候了粥鞋。每當(dāng)這個(gè)時(shí)候思緒總是翻江倒海,因?yàn)樘脹]有反思和總結(jié)的緣故瞄崇,一年才總結(jié)一次呻粹,確實(shí)是有...
    go4it閱讀 523評(píng)論 1 6
  • 虛度光陰二十余年,此去經(jīng)年苏研,未曾忘卻初衷等浊,唯有愛在心頭,欲說還休摹蘑。 曾幾何時(shí)筹燕,浮躁拘禁的心緒歸于平靜得以釋放---...
    田野木山閱讀 137評(píng)論 0 0
  • 前言:關(guān)注簡書這么多年了,從未在這上面留下零星文字衅鹿,總覺得遺憾撒踪。我不想只當(dāng)個(gè)觀眾,也想?yún)⑴c進(jìn)來大渤。 這是第一次在簡書...
    你真當(dāng)我是浮夸吶閱讀 1,279評(píng)論 0 1