欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Springboot-dubbo-fescar如何實(shí)現(xiàn)分布式事務(wù)

這篇文章給大家分享的是有關(guān)Springboot-dubbo-fescar如何實(shí)現(xiàn)分布式事務(wù)的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

成都創(chuàng)新互聯(lián)主要從事做網(wǎng)站、網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)沂水,十多年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18982081108

1、sql

CREATE TABLE `undo_log` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT,
 `branch_id` bigint(20) NOT NULL,
 `xid` varchar(100) NOT NULL,
 `rollback_info` longblob NOT NULL,
 `log_status` int(11) NOT NULL,
 `log_created` datetime NOT NULL,
 `log_modified` datetime NOT NULL,
 `ext` varchar(100) DEFAULT NULL,
 PRIMARY KEY (`id`),
 KEY `idx_unionkey` (`xid`,`branch_id`)
) ENGINE=InnoDB AUTO_INCREMENT=159 DEFAULT CHARSET=utf8;
 
DROP TABLE IF EXISTS `storage_tbl`;
CREATE TABLE `storage_tbl` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `commodity_code` varchar(255) DEFAULT NULL,
 `count` int(11) DEFAULT 0,
 PRIMARY KEY (`id`),
 UNIQUE KEY (`commodity_code`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 
DROP TABLE IF EXISTS `order_tbl`;
CREATE TABLE `order_tbl` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `user_id` varchar(255) DEFAULT NULL,
 `commodity_code` varchar(255) DEFAULT NULL,
 `count` int(11) DEFAULT 0,
 `money` int(11) DEFAULT 0,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; 
 
DROP TABLE IF EXISTS `account_tbl`;
CREATE TABLE `account_tbl` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `user_id` varchar(255) DEFAULT NULL,
 `money` int(11) DEFAULT 0,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 
INSERT INTO `storage_tbl` VALUES ('1', 'C00321', '100'); 
INSERT INTO `account_tbl` VALUES ('1', 'U100001', '9999');

2、下載fescar-server,并啟動

https://github.com/alibaba/fescar/releases

解壓

sh fescar-server.sh 8091 /home/admin/fescar/data/

win操作系統(tǒng)直接啟動

fescar-server.bat

3、下載zookeeper并啟動。

4、demo結(jié)構(gòu)

分為庫存微服務(wù)storage、賬號微服務(wù)account、訂單微服務(wù)order和購買下單的消費(fèi)者purchase。

購買流程如下,先調(diào)用storage微服務(wù)減庫存,然后調(diào)用order微服務(wù)更新賬戶余額和生成訂單。訂單微服務(wù)order也作為消費(fèi)者消費(fèi)account賬號微服務(wù),賬號微服務(wù)主要用來更新賬號余額。

5、demo地址如下

https://github.com/TalkIsCheapGiveMeMoney/springboot-dubbo-fescar.git

6、依次運(yùn)行storage微服務(wù)、account微服務(wù)和order微服務(wù)、purchase消費(fèi)者。

我們在創(chuàng)建訂單的時(shí)候模擬異常,具體類如下

package com.hcsoc.order.service; 
import com.alibaba.fescar.core.context.RootContext;
import com.hcsoc.account.api.AccountService;
import com.hcsoc.order.api.OrderService;
import com.hcsoc.order.api.bean.Order;
import lombok.Setter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.PreparedStatementCreator;
import org.springframework.jdbc.support.GeneratedKeyHolder;
import org.springframework.jdbc.support.KeyHolder;
 
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
 
@Setter
public class OrderServiceImpl implements OrderService{
 
  private static final Logger LOGGER = LoggerFactory.getLogger(OrderService.class);
  @Autowired
  private AccountService accountService;
  @Autowired
  private JdbcTemplate jdbcTemplate;
 
 
  public Order create(String userId, String commodityCode, int orderCount) {
    LOGGER.info("Order Service Begin ... xid: " + RootContext.getXID());
 
    // 計(jì)算訂單金額
    int orderMoney = calculate(commodityCode, orderCount);
 
    // 從賬戶余額扣款
    accountService.debit(userId, orderMoney);
 
    final Order order = new Order();
    order.userId = userId;
    order.commodityCode = commodityCode;
    order.count = orderCount;
    order.money = orderMoney;
    //模擬異常
    Integer.parseInt("2u");
 
    KeyHolder keyHolder = new GeneratedKeyHolder();
 
    jdbcTemplate.update(new PreparedStatementCreator() {
 
      public PreparedStatement createPreparedStatement(Connection con) throws SQLException {
        PreparedStatement pst = con.prepareStatement(
            "insert into order_tbl (user_id, commodity_code, count, money) values (?, ?, ?, ?)",
            PreparedStatement.RETURN_GENERATED_KEYS);
        pst.setObject(1, order.userId);
        pst.setObject(2, order.commodityCode);
        pst.setObject(3, order.count);
        pst.setObject(4, order.money);
        return pst;
      }
    }, keyHolder);
 
    order.id = keyHolder.getKey().longValue();
 
    LOGGER.info("Order Service End ... Created " + order);
 
    return order;
  }
 
  private int calculate(String commodityId, int orderCount) {
    return 200 * orderCount;
  }
}

在購買下單之前確認(rèn)下數(shù)據(jù)庫中的數(shù)據(jù),以便購買后對比,商品單價(jià)200.

我們看到 account_tbl 賬號表,用戶U100001賬戶余額為9999,庫存表storage_tbl,商品庫存是100.訂單表order_tbl沒有訂單數(shù)據(jù)。

下面我們執(zhí)行購買下單操作,

執(zhí)行以下url

http://127.0.0.1:9094/purchase?userId=U100001&commodityCode=C00321&orderCount=4

userId 用戶id,commodityCode  商品編號,orderCount 購買數(shù)量。

再去,返回?cái)?shù)據(jù)如下

{
  "timestamp": "2019-02-01T02:54:27.422+0000",
  "status": 500,
  "error": "Internal Server Error",
  "message": "For input string: \"2u\"",
  "path": "/purchase"
}

查看上面提到的account_tbl 賬號表,用戶U100001賬戶余額為9999,庫存表storage_tbl,商品庫存是100.訂單表order_tbl沒有訂單數(shù)據(jù)。說明分布式事務(wù)成功。

我們把模擬的異常去掉,再次執(zhí)行購買操作。

http://127.0.0.1:9094/purchase?userId=U100001&commodityCode=C00321&orderCount=5

我們發(fā)現(xiàn)商品庫存由100變成了95,用戶余額由9999變成了8999,并且生成了一個(gè)訂單號,前面提到了商品的單價(jià)是200,數(shù)據(jù)正確。

其他的分布式事務(wù)框架,比如TCC和byteTcc需要操作冪等性,了解TCC和ByteTcc的應(yīng)該知道,開發(fā)工作量很大而且操作還需要冪等性,而阿里的fescar則完全不需要,而且不需要那么多的開發(fā)工作量,希望fescar越來越成熟。

感謝各位的閱讀!關(guān)于“Springboot-dubbo-fescar如何實(shí)現(xiàn)分布式事務(wù)”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

分享題目:Springboot-dubbo-fescar如何實(shí)現(xiàn)分布式事務(wù)
網(wǎng)站鏈接:http://aaarwkj.com/article44/ijhpee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、手機(jī)網(wǎng)站建設(shè)、營銷型網(wǎng)站建設(shè)、軟件開發(fā)靜態(tài)網(wǎng)站域名注冊

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設(shè)計(jì)
亚洲七七久久精品中文国产| 18禁污污网站国产| 亚洲美女高潮久久久久久久久| 人人妻人人澡人人爽人人老司机 | 操老熟女一区二区三区| 最新手机免费黄色av网站| 日本高清区一区二区三区四区五区| 伊人99热这里只有精品| 草草视频在线观看网站| 国产毛片一区二区在线| 高清欧美大片免费观看| 国产自拍精品视频免费观看| 国产特级黄色片免费看| 我要看黄色一级性生活片| 在线一区免费视频播放| 亚洲国产精品一区二区三区在线 | 久久男女激情免费视频| 亚洲五月婷婷久久综合| 少妇特黄a一区二区三区| 最美是你免费视频观看| 亚洲乱码一区二区免费版| 后入视频国产在线观看| 欧美一区二区三区蜜桃| 国产免费成人午夜免费视频| 国产剧情av专业在线观看| 日本成人精品二区在线观看| 日韩看片一区二区三区高清| 欧美精品一区二区三区黄片| 国产农村熟妇av国语对白| 亚洲中文乱码一区二区| 久久香蕉精品国产亚洲av| 欧美亚洲成人免费电影| 成人免费毛片1000部| 久久五十路六十路熟妇中出| 亚洲一区二区三区女同| av网址不卡在线免费观看| 亚洲综合色婷婷在线影院| 国产亚洲综合久久系列| 欧美成人精品欧美一级黄片| 日韩专区欧美二区国产| 国产精品国产三级国产专播|