中文亚洲精品无码_熟女乱子伦免费_人人超碰人人爱国产_亚洲熟妇女综合网

當(dāng)前位置: 首頁(yè) > news >正文

精品課程網(wǎng)站建設(shè)方案安卓aso優(yōu)化工具

精品課程網(wǎng)站建設(shè)方案,安卓aso優(yōu)化工具,網(wǎng)站頁(yè)面設(shè)計(jì)的網(wǎng)址,濟(jì)南網(wǎng)站建設(shè)要多少錢參考資料: nacos的windows環(huán)境部署 seata和nacos的結(jié)合及seata開發(fā) 參考demo及資料 nacos在windows環(huán)境下的部署: nacos在windows下的部署參考文章 seata加入nacos配置: 首先下載seata安裝包:Release v1.7.0(Not Apache relea…

參考資料:

nacos的windows環(huán)境部署

seata和nacos的結(jié)合及seata開發(fā)

參考demo及資料


nacos在windows環(huán)境下的部署:

?nacos在windows下的部署參考文章


seata加入nacos配置:

  1. 首先下載seata安裝包:Release v1.7.0(Not Apache release) · apache/incubator-seata · GitHub
  2. 然后解壓,修改配置文件

打開conf/application.yml進(jìn)行修改,重點(diǎn)修改nacos部分配置


server:port: 7091spring:application:name: seata-serverlogging:config: classpath:logback-spring.xmlfile:path: ${user.home}/logs/seataextend:logstash-appender:destination: 127.0.0.1:4560kafka-appender:bootstrap-servers: 127.0.0.1:9092topic: logback_to_logstashconsole:user:username: seatapassword: seata
seata:config:# support: nacos, consul, apollo, zk, etcd3type: nacosnacos:server-addr: 127.0.0.1:8848namespace:group: SEATA_GROUPusername:password:context-path:##if use MSE Nacos with auth, mutex with username/password attribute#access-key:#secret-key:data-id: seataServer.propertiesregistry:# support: nacos, eureka, redis, zk, consul, etcd3, sofatype: nacosnacos:application: seata-serverserver-addr: 127.0.0.1:8848group: SEATA_GROUPnamespace:cluster: defaultusername:password:context-path:##if use MSE Nacos with auth, mutex with username/password attribute#access-key:#secret-key:store:# support: file 、 db 、 redismode: file
#  server:
#    service-port: 8091 #If not configured, the default is '${server.port} + 1000'security:secretKey: SeataSecretKey0c382ef121d778043159209298fd40bf3850a017tokenValidityInMilliseconds: 1800000ignore:urls: /,/**/*.css,/**/*.js,/**/*.html,/**/*.map,/**/*.svg,/**/*.png,/**/*.jpeg,/**/*.ico,/api/v1/auth/login
  1. ?然后在nacos中加入seata配置,注意ID是上述配置文件中的?seataServer.propertiesGroup與第2步中的保持一致,這里是SEATA_GROUP

#Transaction storage configuration, only for the server.
store.mode=db
store.lock.mode=db
store.session.mode=db#These configurations are required if the `store mode` is `db`.
store.db.datasource=druid
store.db.dbType=mysql
store.db.driverClassName=com.mysql.cj.jdbc.Driver
store.db.url=jdbc:mysql://127.0.0.1:3306/seata?useSSL=false&useUnicode=true&rewriteBatchedStatements=true
store.db.user=root
store.db.password=admin
store.db.minConn=5
store.db.maxConn=30
store.db.globalTable=global_table
store.db.branchTable=branch_table
store.db.distributedLockTable=distributed_lock
store.db.queryLimit=100
store.db.lockTable=lock_table
store.db.maxWait=5000
  • 然后就是創(chuàng)建上述配置文件的數(shù)據(jù)庫(kù)
-- -------------------------------- The script used when storeMode is 'db' --------------------------------
-- the table to store GlobalSession data
CREATE TABLE IF NOT EXISTS `global_table`
(`xid`                       VARCHAR(128) NOT NULL,`transaction_id`            BIGINT,`status`                    TINYINT      NOT NULL,`application_id`            VARCHAR(32),`transaction_service_group` VARCHAR(32),`transaction_name`          VARCHAR(128),`timeout`                   INT,`begin_time`                BIGINT,`application_data`          VARCHAR(2000),`gmt_create`                DATETIME,`gmt_modified`              DATETIME,PRIMARY KEY (`xid`),KEY `idx_status_gmt_modified` (`status` , `gmt_modified`),KEY `idx_transaction_id` (`transaction_id`)
) ENGINE = InnoDBDEFAULT CHARSET = utf8mb4;-- the table to store BranchSession data
CREATE TABLE IF NOT EXISTS `branch_table`
(`branch_id`         BIGINT       NOT NULL,`xid`               VARCHAR(128) NOT NULL,`transaction_id`    BIGINT,`resource_group_id` VARCHAR(32),`resource_id`       VARCHAR(256),`branch_type`       VARCHAR(8),`status`            TINYINT,`client_id`         VARCHAR(64),`application_data`  VARCHAR(2000),`gmt_create`        DATETIME(6),`gmt_modified`      DATETIME(6),PRIMARY KEY (`branch_id`),KEY `idx_xid` (`xid`)
) ENGINE = InnoDBDEFAULT CHARSET = utf8mb4;-- the table to store lock data
CREATE TABLE IF NOT EXISTS `lock_table`
(`row_key`        VARCHAR(128) NOT NULL,`xid`            VARCHAR(128),`transaction_id` BIGINT,`branch_id`      BIGINT       NOT NULL,`resource_id`    VARCHAR(256),`table_name`     VARCHAR(32),`pk`             VARCHAR(36),`status`         TINYINT      NOT NULL DEFAULT '0' COMMENT '0:locked ,1:rollbacking',`gmt_create`     DATETIME,`gmt_modified`   DATETIME,PRIMARY KEY (`row_key`),KEY `idx_status` (`status`),KEY `idx_branch_id` (`branch_id`),KEY `idx_xid` (`xid`)
) ENGINE = InnoDBDEFAULT CHARSET = utf8mb4;CREATE TABLE IF NOT EXISTS `distributed_lock`
(`lock_key`       CHAR(20) NOT NULL,`lock_value`     VARCHAR(20) NOT NULL,`expire`         BIGINT,primary key (`lock_key`)
) ENGINE = InnoDBDEFAULT CHARSET = utf8mb4;INSERT INTO `distributed_lock` (lock_key, lock_value, expire) VALUES ('AsyncCommitting', ' ', 0);
INSERT INTO `distributed_lock` (lock_key, lock_value, expire) VALUES ('RetryCommitting', ' ', 0);
INSERT INTO `distributed_lock` (lock_key, lock_value, expire) VALUES ('RetryRollbacking', ' ', 0);
INSERT INTO `distributed_lock` (lock_key, lock_value, expire) VALUES ('TxTimeoutCheck', ' ', 0);
  • 運(yùn)行bin下的bat腳本啟動(dòng)服務(wù)

  • 訪問控制面板:http://127.0.0.1:7091


代碼的相關(guān)編寫(所有的代碼會(huì)在后面貼出,這里只講關(guān)鍵代碼)

框架的搭建

????????關(guān)于微服務(wù)的搭建此處將不再贅述,可以參考本人的系列文章

? ? ? ? 同時(shí)需要集成mybatis-plus,就是上面創(chuàng)建的數(shù)據(jù)庫(kù),可以參考本人的系列文章

Seata依賴的添加

? ? ? ? 在每個(gè)微服務(wù)都加入seata依賴

<!-- 注意一定要引入對(duì)版本,要引入spring-cloud版本seata,而不是springboot版本的seata-->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-seata</artifactId><!-- 排除掉springcloud默認(rèn)的seata版本,以免版本不一致出現(xiàn)問題--><exclusions><exclusion><groupId>io.seata</groupId><artifactId>seata-spring-boot-starter</artifactId></exclusion><exclusion><groupId>io.seata</groupId><artifactId>seata-all</artifactId></exclusion></exclusions>
</dependency>
<dependency><groupId>io.seata</groupId><artifactId>seata-spring-boot-starter</artifactId><version>1.7.0</version>
</dependency>

簡(jiǎn)單的業(yè)務(wù)邏輯編寫---XA分布式事務(wù)

每個(gè)YML文件需要配置事務(wù)組和事務(wù)的類型(此處為XA)

service.vgroup-mapping下一定要有一個(gè)對(duì)應(yīng)這個(gè)名字的映射,映射到default(seata默認(rèn)的集群名稱),seata_tx_group為我們自定義的事務(wù)組,名字隨便起

data-source-proxy-mode 為所用的事務(wù)模式,默認(rèn)AT

?nacos方面,我們僅配置注冊(cè)項(xiàng),根據(jù)個(gè)人配置

#seata客戶端配置
seata:enabled: trueapplication-id: seata_txtx-service-group: seata_tx_groupservice:vgroup-mapping:seata_tx_group: defaultregistry:type: nacosnacos:application: seata-serverserver-addr: 127.0.0.1:8848namespace:group: SEATA_GROUPdata-source-proxy-mode: XA

XA模式實(shí)現(xiàn)

關(guān)于分布式事務(wù),只需要全局事務(wù)標(biāo)簽:@GlobalTransactional,每個(gè)本地事務(wù)加上@Transactional和不加效果一樣,但是建議還是加上

關(guān)于完成的源碼見參考demo

下面是demo的數(shù)據(jù)庫(kù)結(jié)構(gòu)

????????

http://www.risenshineclean.com/news/39692.html

相關(guān)文章:

  • 有做貨 物的網(wǎng)站嗎今天新聞?lì)^條新聞
  • 建設(shè)什么網(wǎng)站新品推廣活動(dòng)方案
  • 國(guó)內(nèi)做的好的電商網(wǎng)站有哪些方面百度在線使用網(wǎng)頁(yè)版
  • 自己做的網(wǎng)站可以用于百度推廣嗎線上營(yíng)銷推廣方案有哪些
  • nginx wordpress ssl網(wǎng)站排名優(yōu)化外包公司
  • 怎么做監(jiān)測(cè)網(wǎng)站的瀏覽量app推廣地推接單網(wǎng)
  • 溫州網(wǎng)站建設(shè)培訓(xùn)seoul是什么品牌
  • 廣東網(wǎng)站開發(fā)搭建搜索推廣競(jìng)價(jià)托管哪家好
  • wordpress指定分類名稱知乎關(guān)鍵詞排名優(yōu)化
  • 湖北做網(wǎng)站的一句話宣傳自己的產(chǎn)品
  • 浙江住建局官方網(wǎng)站上海職業(yè)技能培訓(xùn)機(jī)構(gòu)一覽表
  • 哈爾濱網(wǎng)站建設(shè)公司oeminc杭州seo公司哪家好
  • 微商怎么開通網(wǎng)站優(yōu)化推廣平臺(tái)
  • 個(gè)人站長(zhǎng)做哪些網(wǎng)站好開封網(wǎng)絡(luò)推廣哪家好
  • 起點(diǎn)網(wǎng)站建設(shè)百度電話客服24小時(shí)人工服務(wù)熱線
  • 建設(shè)企業(yè)網(wǎng)站包含什么軟文推廣發(fā)布
  • 網(wǎng)站建設(shè)人員配置是怎樣的泉州seo按天收費(fèi)
  • 如何購(gòu)買網(wǎng)站流量市場(chǎng)調(diào)研報(bào)告
  • 個(gè)人博客網(wǎng)站logoseo優(yōu)化工作有哪些
  • java做網(wǎng)站系統(tǒng)需要學(xué)什么新疆頭條今日頭條新聞
  • 免費(fèi)h5旅游網(wǎng)站模板網(wǎng)紅推廣
  • 北京建筑公司有哪些seo教程網(wǎng)
  • 做網(wǎng)站開發(fā)需要的英語(yǔ)水平石家莊seo公司
  • iis不能新建網(wǎng)站百度app安裝
  • wordpress 把賬號(hào)名改成昵稱公司seo排名優(yōu)化
  • 家庭寬帶做網(wǎng)站服務(wù)器嗎多合一seo插件破解版
  • 網(wǎng)站每日簽到怎么做google關(guān)鍵詞分析工具
  • 阿里云 個(gè)人網(wǎng)站 名稱google seo怎么優(yōu)化
  • 邯鄲網(wǎng)站建設(shè)推廣線上營(yíng)銷推廣方法
  • 阿里云做網(wǎng)站步驟競(jìng)價(jià)托管外包服務(wù)