seata+eureka+mybatis-plus+dynamic-datasource+oracle分布式事务方案实现踩坑


1、查询资料中的一个大坑

https://www.jianshu.com/p/45940a29de7a?utm_campaign=hugo(网友教程)

https://github.com/seata/seata-samples/tree/master/springcloud-eureka-feign-mybatis-seata(官方教程)

不知道因为版本的原因还是seata对驼峰和横线转换的问题,file.conf文件中的db-type和driver-class-name这类横线连接符的字段并不能被seata识别,最终换成了驼峰命令法才正常启动了。

2、dynamic-datasource是一个数据源代理,需要实现seata代理dynamic-datasource,dynamic-datasource代理druid三级代理。配置方式参考dynamic-datasource官网最新关于seata的案例

3、seata在每个分库中需要undo_log表,在官方的示例代码中用的是MySQL数据库,适配Oracle数据库需要为将undo_log表的表名和字段名都改为大写(报错找不到表),需要为UNDO_LOG表加名称为UNDO_LOG_SEQ的序列(报错找不到序列

参考资料:https://github.com/seata/seata/issues/1639

4、seata框架在file.conf中默认的序列化方式是jackson,oracle的timestamp字段不支持jackson序列化方式,要么加手动序列化的代码,要么在file.conf中将序列化方式更换为kryo

在工程中引入kryo依赖:

    de.javakaffee

    kryo-serializers

    0.45

    com.esotericsoftware

    kryo

    4.0.2

5、用docker-compose实现的一个seata-server:

链接:https://pan.baidu.com/s/1vrYhUdl4PXzq-CYt25iDPg

提取码:lhov

你可能感兴趣的:(seata+eureka+mybatis-plus+dynamic-datasource+oracle分布式事务方案实现踩坑)