问题一:Seata用mybatisplus的批量插入方法报SQL错误,说违反协议,有遇到过吗?
Seata用mybatisplus的批量插入方法报SQL错误,说违反协议,有遇到过吗?
参考回答:
这种不支持,支持insert into values(),()这种
关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/598418
问题二:Seata 生产环境中业务跑在k8s上,seata是部署在k8s集群里还是放在外部同一vpc网络中?
Seata 生产环境中业务跑在k8s上,seata是部署在k8s集群里还是放在外部同一vpc网络中?
参考回答:
跟你们自己的架构有关,是否基建统一都是单独vpc的。
关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/598417
问题三:seata仓库文档中看不懂如何安装crd和operator怎么办?
seata仓库文档中看不懂如何安装crd和operator怎么办?
https://github.com/apache/incubator-seata-k8s
这个仓库里提供了一些例子,但是看不懂能指点一下么?
参考回答:
operator 部署的 server 存储模式是 raft,不需要配置数据库
关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/597694
问题四:seata有没有k8s部署的案例?
seata有没有k8s部署的案例?
参考回答:
这个仓库里提供了一些例子 https://github.com/apache/incubator-seata-k8s 可以选择使用 operator 或不使用
关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/597691
问题五:怎么使用Seata框架,来保证事务的隔离性?
怎么使用Seata框架,来保证事务的隔离性?
参考回答:
因seata一阶段本地事务已提交,为防止其他事务脏读脏写需要加强隔离。
1.脏读 select语句加for update,代理方法增加@GlobalLock+@Transactional或@GlobalTransaction
2.脏写 必须使用@GlobalTransaction
注:如果你查询的业务的接口没有GlobalTransactional 包裹,也就是这个方法上压根没有分布式事务的需求,这时你可以在方法上标注@GlobalLock+@Transactional 注解,并且在查询语句上加 for update。 如果你查询的接口在事务链路上外层有GlobalTransactional注解,那么你查询的语句只要加for update就行。设计这个注解的原因是在没有这个注解之前,需要查询分布式事务读已提交的数据,但业务本身不需要分布式事务。 若使用GlobalTransactional注解就会增加一些没用的额外的rpc开销比如begin 返回xid,提交事务等。GlobalLock简化了rpc过程,使其做到更高的性能。
关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/597689