Deployment Guide

Seata Beginner Deployment Guide

Seata has three roles: TC, TM and RM. TC (Server side) is deployed as a separate server, while TM and RM (Client side) are integrated by the business system.

Resource Directory Introduction

Click to view. You can also select the corresponding resource directory according to the version branch.

-client

Store client-side sql script (including undo_log table) and parameter configuration. -config-center Each configuration center parameter import script, config.txt (including server and client, formerly known as nacos-config.txt) is a genernal parameter file.

  • server

Store server-side database script (including lock_table, branch_table and global_table) and container configuration.

Precautions

  • seata-spring-boot-starter
  1. It has the built-in GlobalTransactionScanner automatic initialization function. If initialization is implemented externally, please refer to SeataAutoConfiguration to ensure that the dependencies loads orderly.
  2. Data source automatic proxy is turned on by default, and it can be turned off by configuring seata.enable-auto-data-source-proxy: false.
  • spring-cloud-starter-alibaba-seata

View release notes.
2.1.0 embeds seata-all 0.7.1, 2.1.1 embeds seata-all 0.9.0, 2.2.0 embeds seata-spring-boot-starter 1.0.0, 2.2.1 embeds seata-spring- boot-starter 1.1.0

  1. Solutions for 2.1.0 and 2.1.1 compatible starter:
  2. In the @SpringBootApplication annotation, exclude com.alibaba.cloud.seata.GlobalTransactionAutoConfiguration in spring-cloud-starter-alibaba-seata
  • Recommendations for spring-cloud-starter-alibaba-seata dependency configuration
  1. <dependency>
  2. <groupId>io.seata</groupId>
  3. <artifactId>seata-spring-boot-starter</artifactId>
  4. </dependency>
  5. <dependency>
  6. <groupId>com.alibaba.cloud</groupId>
  7. <artifactId>spring-cloud-starter-alibaba-seata</artifactId>
  8. <exclusions>
  9. <exclusion>
  10. <groupId>io.seata</groupId>
  11. <artifactId>seata-spring-boot-starter</artifactId>
  12. </exclusion>
  13. </exclusions>
  14. </dependency>

Start Server

There are currently three server-side storage modes (store.mode): file, db, redis, raft. The file mode does not need to be changed and can be started directly. The following specifically explains the db and redis startup steps.

Note: The file mode is a stand-alone mode. The global transaction session information is read and written in the memory and the local file root.data is persisted. So the performance is quite well;

The db mode is a high-availability mode. Global transaction session information is shared through db, but the corresponding performance is poor;

The redis mode is supported by Seata-Server 1.3 and above. It has high performance and risks losing transaction information. Please configure the redis persistence configuration suitable for the current scenario in advance.

Step 1: Startup package

  • Click to download.
  • Official DingTalk group (Group Number: 23171167, 1st group is already full, including 5,000 people, 2nd group, group 3: 32033786,group 4: 60170003910), QQ group (Group Number: 254657148, group 2: 216012363). Please download packages in the group sharing file.1

Step 2: Create table (db only)

Global transaction session information consists of three pieces of content, that is global transaction—>branch transaction—>global lock, corresponding to the tables global_table, branch_table, and lock_table.

Step 3: Modify store.mode

Startup package: seata—>conf—>application.yml, modify store.mode=”db” or “redis” Source code: root directory—>seata-server—>resources—>application.yml, modify store.mode=”db” or “redis”

Step 4: Modify database connection|redis attribute configuration

Startup package: seata—>conf—>application.example.yml comes with additional configuration, copy its db|redis related configuration to application.yml, and modify store.db or store.redis related properties. Source code: Root directory—>seata-server—>resources—>application.example.yml comes with additional configuration, copy its db|redis related configuration to application.yml, and modify store.db or store.redis related Attributes.

Step 5: Start

  • Source code startup: execute the main method in ServerApplication.java
  • Command to start: seata-server.sh -h 127.0.0.1 -p 8091 -m db
  1. -h: IP registered to the registration center
  2. -p: Server rpc listening port
  3. -m: Global transaction session information storage mode, file, db, redis. Read startup parameters first (Seata-Server 1.3 and above supports redis)
  4. -n: Server node. When there are multiple servers, each node needs to be distinguished to generate transactionIds in different intervals to avoid conflicts.
  5. -e: Multi-environment configuration please refers to https://seata.apache.org/docs/ops/multi-configuration-isolation/.

Note: It is recommended to allocate 2G of heap memory and 1G of off-heap memory.

Business system integration Client

  • Depends on seata-all.
  • Depends on seata-spring-boot-starter, supporting yml and properties configuration (.conf can be deleted), and relies on seata-all internally.
  • Depends on spring-cloud-alibaba-seata, integrates seata internally, and implements xid transfer.

Step 2: Create undo_log table and configure parameters (AT mode only)

Step 3: Data source proxy (coexistence of automatic and manual configuration is not supported)

  1. If using seata-all

    • Starting from version 0.9.0, seata supports automatic proxy data sources.

      1. 1.1.0: seata-all cancels the attribute configuration and switches it to the annotation @EnableAutoDataSourceProxy, and you can choose jdk proxy or cglib proxy
      2. 1.0.0: client.support.spring.datasource.autoproxy=true
      3. 0.9.0: support.spring.datasource.autoproxy=true

      If XA mode is used, @EnableAutoDataSourceProxy(dataSourceProxyMode = "XA")

    • For manual configuration, please refer to the example below

      1. @Primary
      2. @Bean("dataSource")
      3. public DataSource dataSource(DataSource druidDataSource) {
      4. //AT agent (choose one of the two)
      5. return new DataSourceProxy(druidDataSource);
      6. //XA proxy
      7. return new DataSourceProxyXA(druidDataSource)
      8. }
  2. If using seata-starter

    • When using automatic proxy data sources, you need to adjust the configuration file if you use XA mode application.properties

      1. seata.data-source-proxy-mode=XA

      application.yml

      1. seata:
      2. data-source-proxy-mode: XA
    • How to turn off the data source automatic proxy of seata-spring-boot-starter? application.properties

      1. seata.enable-auto-data-source-proxy=false

      application.yml

      1. seata:
      2. enable-auto-data-source-proxy: false

Step 4: Initialize GlobalTransactionScanner

  • Manual
  1. @Bean
  2. public GlobalTransactionScanner globalTransactionScanner() {
  3. String applicationName = this.applicationContext.getEnvironment().getProperty("spring.application.name");
  4. String txServiceGroup = this.seataProperties.getTxServiceGroup();
  5. if (StringUtils.isEmpty(txServiceGroup)) {
  6. txServiceGroup = applicationName + "-fescar-service-group";
  7. this.seataProperties.setTxServiceGroup(txServiceGroup);
  8. }
  9. return new GlobalTransactionScanner(applicationName, txServiceGroup);
  10. }
  • Automatic
    You can introduce seata-spring-boot-starter, spring-cloud-starter-alibaba-seata and other jars

Step 5: Implement xid cross-service transfer

  • Manual
    Refer to the various rpc implementation modules under the source code integration folder.
  • Automatic
    SpringCloud users can introduce spring-cloud-starter-alibaba-seata, and xid transfer has been implemented internally.

Business use

Annotation interception

Global affairs

  1. @GetMapping(value = "testCommit")
  2. @GlobalTransactional
  3. public Object testCommit(@RequestParam(name = "id",defaultValue = "1") Integer id,
  4. @RequestParam(name = "sum", defaultValue = "1") Integer sum) {
  5. Boolean ok = productService.reduceStock(id, sum);
  6. if (ok) {
  7. LocalDateTime now = LocalDateTime.now();
  8. Orders orders = new Orders();
  9. orders.setCreateTime(now);
  10. orders.setProductId(id);
  11. orders.setReplaceTime(now);
  12. orders.setSum(sum);
  13. orderService.save(orders);
  14. return "ok";
  15. } else {
  16. return "fail";
  17. }
  18. }

TCC

  1. /**
  2. * Define two-phase commit: name = bean name of the tcc (globally unique), commitMethod = commit (the two-phase confirmation method) and rollbackMethod = rollback (the two-phase cancellation method)
  3. * useTCCFence=true (enable anti-hanging)
  4. * BusinessActionContextParameter annotation passes parameters to the second stage
  5. *
  6. * @param params - input parameters
  7. * @return String
  8. */
  9. @TwoPhaseBusinessAction(name = "beanName", commitMethod = "commit", rollbackMethod = "rollback", useTCCFence = true)
  10. public void insert(@BusinessActionContextParameter(paramName = "params") Map<String, String> params) {
  11. logger.info("此处可以预留资源,或者利用tcc的特点,与AT混用,二阶段时利用一阶段在此处存放的消息,通过二阶段发出,比如redis,mq等操作");
  12. }
  13. /**
  14. * The confirmation method can be named differently, but it must be consistent with commitMethod. The context can pass the parameters of the try method.
  15. *
  16. * @param context context
  17. * @return boolean
  18. */
  19. public void commit(BusinessActionContext context) {
  20. logger.info("预留资源真正处理,或者发出mq消息和redis入库");
  21. }
  22. /**
  23. * Two-stage cancellation method
  24. *
  25. * @param context context
  26. * @return boolean
  27. */
  28. public void rollback(BusinessActionContext context) {
  29. logger.info("预留资源释放,或清除一阶段准备让二阶段提交时发出的消息缓存");
  30. }

Pointcut expression

Global affairs

  1. @Bean
  2. public AspectTransactionalInterceptor aspectTransactionalInterceptor () {
  3. return new AspectTransactionalInterceptor();
  4. }
  5. @Bean
  6. public Advisor txAdviceAdvisor(AspectTransactionalInterceptor aspectTransactionalInterceptor ) {
  7. AspectJExpressionPointcut pointcut = new AspectJExpressionPointcut();
  8. pointcut.setExpression("Configure pointcut expression to enable global transaction interceptor");
  9. return new DefaultPointcutAdvisor(pointcut, aspectTransactionalInterceptor);
  10. }