spring cloud mybatis seate集成

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://gudepeng.github.io/note/2019/11/29/seate/
demo样例:https://github.com/gudepeng/demoproject/tree/master/seata-servicea

一.客户端

1.引包

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-seata</artifactId>
    <version>2.1.1.RELEASE</version>
</dependency>

2.编写配置类

@Configuration
public class DataSourceConfig {

    @Bean
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource druidDataSource() {
        DruidDataSource druidDataSource = new DruidDataSource();
        return druidDataSource;
    }

    @Primary
    @Bean("dataSource")
    public DataSourceProxy dataSource(DataSource druidDataSource) {
        return new DataSourceProxy(druidDataSource);
    }

    @Bean
    public SqlSessionFactory sqlSessionFactory(DataSourceProxy dataSourceProxy) throws Exception {
        SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();
        factoryBean.setDataSource(dataSourceProxy);
        factoryBean.setMapperLocations(new PathMatchingResourcePatternResolver()
            .getResources("classpath*:/mapper/*.xml"));
        return factoryBean.getObject();
    }
}

3.修改启动类

@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)

4.在需要开启分布式事物的方法上添加注解

@GlobalTransactional

二.服务端

1.下载seata-server

[seata-server]{https://github.com/seata/seata/releases}

2.修改配置文件(本文以nacos为样例,store记录为mysql)

修改conf下的registry.conf

registry {
  # file 、nacos 、eureka、redis、zk、consul、etcd3、sofa
  type = "nacos"

  nacos {
    serverAddr = "localhost"
    namespace = "piblic"
    cluster = "default"
  }
}

config {
  # file、nacos 、apollo、zk、consul、etcd3
  type = "nacos"

  nacos {
    serverAddr = "localhost"
    #namespace为空,否则后面会报找不到store.db.driver-class-name找不到
    namespace = ""
  }
}

修改registry下的type为nacos,配置nacos的serverAddr为你nacos服务的地址,不要带http和端口号。它会默认去连你的8858端口,如需修改端口,请修改nacos-config.sh文件中的端口

拷贝registry.conf到每个使用seata服务的resources下

修改conf下nacos-config.txt

store.mode=db
store.db.datasource=dbcp
store.db.db-type=mysql
store.db.driver-class-name=com.mysql.jdbc.Driver
store.db.url=jdbc:mysql://127.0.0.1:3306/seata?useUnicode=true
store.db.user=mysql
store.db.password=mysql

修改store.mode为db,修改对应db配置文件为你自己的mysql。修改service.vgroupmapping.mytesttxgroup=default属性0.9.0.1版本后:mytesttx_group修改为自己的服务名(spring.application.name) "-seata-service-group"0.9.0.1版本前:mytesttx_group修改为自己的服务名(spring.application.name) "-fescar-service-group"可以spring-cloud-alibaba-seata项目下的GlobalTransactionAutoConfiguration累中看到

GlobalTransactionAutoConfiguration

有多少个服务需要使用seata就要添加多少个ervice.vgroup_mapping

执行nacos-config.sh $Nacos-Server-IP($Nacos-Server-IP为你nacos服务的ip地址),在一步骤是把nacos-config.txt中的配置更新到nacos上,如果nacos-config.txt重新修改,就要重新执行该命令。或者登陆到nacos的管理界面直接进行修改。

之后添加,删除,修改服务,在nacos配置上作对应修改即可

3.创建表

在上一步骤中store.db.url的database中执行建表语句(conf下db_store.sql)

在每一个业务库中执行建表语句(conf下dbundolog.sql)

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring CloudMyBatis 升级为 MyBatis Plus,步骤如下: 1. 引入 MyBatis Plus 的依赖:在 pom.xml 文件中添加以下依赖。 ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.0</version> </dependency> ``` 2. 修改 Mapper 接口:使用 MyBatis Plus 提供的 BaseMapper 接口替换原有的 Mapper 接口。例如: ```java public interface UserMapper extends BaseMapper<User> { } ``` 3. 修改实体类:使用 MyBatis Plus 提供的注解替换原有的注解。例如: ```java @Data public class User { @TableId(type = IdType.AUTO) private Long id; private String name; private Integer age; private String email; } ``` 4. 修改配置文件:在 application.yaml 或 application.properties 文件中添加以下配置。 ```yaml mybatis-plus: mapper-locations: classpath*:mapper/**/*.xml configuration: map-underscore-to-camel-case: true ``` 5. 使用 MyBatis Plus 提供的 API:例如,使用 BaseMapper 提供的方法进行 CRUD 操作。 ```java @Service public class UserService { @Autowired private UserMapper userMapper; public void saveOrUpdate(User user) { if (user.getId() == null) { userMapper.insert(user); } else { userMapper.updateById(user); } } public void deleteById(Long id) { userMapper.deleteById(id); } public User getById(Long id) { return userMapper.selectById(id); } public List<User> list() { return userMapper.selectList(null); } } ``` 注意:在升级过程中,如果你使用了 MyBatis 原生的注解和 API,需要进行相应的修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值