自己遇到的问题,记录一下。
1、版本问题
我seata用的是1.7,
数据库驱动是
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
<version>8.0.31</version>
<scope>runtime</scope>
</dependency>
application.yaml里配置的是
driver-class-name: com.mysql.cj.jdbc.Driver
执行会报错java.lang.NoSuchMethodException: com.mysql.cj.conf.PropertySet.getBooleanReadableProperty(java.lang.String)。
解决方法:
将数据库依赖版本降低了,修改后是
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.11</version>
</dependency>
application.yaml里配置的是
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/springcloud?serverTimezone=GMT%2B8红色部分也是新增的,原来没有。
2、我用两个微服务测试分布式事务,我把数据库的数据删除了,结果控制台就一直报错。大概意思应该是,seata去回滚了发现数据没有了。怎么着都不行,控制台不停的报错。我猜测应该是seata目录哪个地方哪个文件应该记录了seata需要回滚的事情,所以seata会一直去回滚,结果数据没有了就一直回滚失败,就一直报错。我就把seata安装包重新解压了一下,再用原来的application.yaml覆盖一下,再重启就好了。
3、我用的seata是1.7版本的,不知道为什么我的分组名称必须是这个,前面部分是我微服务的名称,后面跟着-fescar-service-group。网上查的哪些,说应该根据config.txt文件里service.vgroupMapping.default_tx_group=default来配置也根本都不行,启动都失败!