MyCat的XA事务研究及字符集问题

本文介绍了MyCAT1.4开发版引入的XA事务支持,详细描述了如何在手动事务模式下启用和使用XA事务,以及与本地事务的交互规则。同时提及了字符集配置,包括对utf8mb4的支持。
摘要由CSDN通过智能技术生成

MyCAT 1.4 开发版,初步实现了XA事务,关注这个高级技术的同学可以编译代码并测试其正确性。。
在手动事务模式下,可以执行  set xa=on开启XA事务支持
目前实现了不跨分片的SQL的XA事务,测试过程如下

mysql> set autocommit=0;
Query OK, 0 rows affected (0.00 sec)
mysql>  set xa=on;
Query OK, 0 rows affected (0.00 sec)
mysql> update travelrecord set days=3 where id=1;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 0  Warnings: 0
mysql> commit;
Query OK, 0 rows affected (0.00 sec)

XA事务状态
XA事务在以下状态下进展:
1.    使用XA START来启动一个XA事务,并把它放入ACTIVE状态。
2.    对于一个ACTIVE XA事务,发布构成事务的SQL语句,然后发布一个XA END语句。XA END把事务放入IDLE状态。
3.    对于一个IDLE XA事务,您可以发布一个XA PREPARE语句或一个XA COMMIT…ONE PHASE语句:
·         XA PREPARE把事务放入PREPARED状态。在此点上的XA RECOVER语句将在其输出中包括事务的xid值,因为XA RECOVER会列出处于PREPARED状态的所有XA事务。
·         XA COMMIT…ONE PHASE用于预备和提交事务。xid值将不会被XA RECOVER列出,因为事务终止。
4.    对于一个PREPARED XA事务,您可以发布一个XA COMMIT语句来提交和终止事务,或者发布XA ROLLBACK来回滚并终止事务。
下面是一个简单的XA事务,该事务把一行作为一个全局事务的一部分插入一个表中。

mysql> XA START 'xatest';
Query OK, 0 rows affected (0.00 sec)
 
mysql> INSERT INTO mytable (i) VALUES(10);
Query OK, 1 row affected (0.04 sec)
 
mysql> XA END 'xatest';
Query OK, 0 rows affected (0.00 sec)
 
mysql> XA PREPARE 'xatest';
Query OK, 0 rows affected (0.00 sec)
 
mysql> XA COMMIT 'xatest';
Query OK, 0 rows affected (0.00 sec)


根据一个给定的客户端连接的语境,XA事务和本地(非XA)事务互相排斥。举例说明,如果已经发布了XA START来开始一项XA事务,则本地事务不会被启动,直到XA事务已经被提交或被 回滚为止。相反的,如果已经使用START TRANSACTION启动一个本地事务,则XA语句不能被使用,直到该事务被提交或被 回滚为止。

字符集问题
mycat在server.xml 中配置属性charset可以决定客户端的字符集,默认为utf8,建议后端数据库也保持一致
1.4开发版本开始支持Mysql字符集utf8mb4,此字符集需要在MySQL Server端设置为id=99如:

<charset  name="utf8mb4">
  <collation name="utf8mb4_general_ci"    id="99">
</charset>  

9066监控端口运行 show @@connection ,在字符集这一列中,包括字符集和id值,如utf8:33 就是标准的UTF8,而uft8:99则表明为utf8mb4

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小小哭包

创作不易,给作者加个鸡腿吧

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值