rocketMQ5.0事务消息实战二

复制代码
func TRANSACTIONTopic() {
	// log to console
	os.Setenv("mq.consoleAppender.enabled", "true")
	golang.ResetLogger()
	topic := "TRANSACTIONTopic"

	producer, err := golang.NewProducer(&golang.Config{
		Endpoint:    Endpoint,
		Credentials: &credentials.SessionCredentials{},
	},
		golang.WithTransactionChecker(&golang.TransactionChecker{
			Check: CheckHalf, //检查half消息
		}),
		golang.WithTopics(topic),
	)
	if err != nil {
		log.Fatal(err)
	}
	// start producer
	err = producer.Start()
	if err != nil {
		log.Fatal(err)
	}
	// graceful stop producer
	defer producer.GracefulStop()
	msg := &golang.Message{Topic: topic, Body: []byte("this is a message TRANSACTION ")}
	msg.SetKeys("a", "b")
	msg.SetTag("ab")
	transaction := producer.BeginTransaction()
	resp, err := producer.SendWithTransaction(context.TODO(), msg, transaction)
	if err != nil {
		log.Fatal(err)
	}
	for i := 0; i < len(resp); i++ {
		fmt.Printf("%#v\n", resp[i])
	}
	//commit transaction message
	//TODO 本地事务执行成功
	TODOLocalTransaction()
	//提交事务
	err = transaction.Commit()
	if err != nil {
		log.Fatal(err)
	}

	time.Sleep(time.Minute * 10)
}

// 检查本地事务
func CheckHalf(msg *golang.MessageView) golang.TransactionResolution {
	log.Printf("check transaction message: %v", msg)
	CheckLocalTransaction() //检查本地事务
	return golang.COMMIT
}
func TODOLocalTransaction() bool {
	return true
}
func CheckLocalTransaction() bool {
	return true
}
第一步:producer.SendWithTransaction 发送半事务(发送成功)

第二步:TODO 本地事务执行成功 TODOLocalTransaction(执行本地事务成功)

第三步:当我们注释掉第三步commit代码,模拟提交事务异常(模拟commit事务消息失败)

第四步:rocketmq触发CheckHalf代码

check事务状态类型

复制代码
UNKNOWN  // 暂时无法判断状态,等待固定时间以后Broker端根据回查规则向生产者进行消息回查
COMMIT   //提交事务,允许消费者消费该消息
ROLLBACK //回滚事务,消息将被丢弃不允许消费。

2-3检查half检查本地事务成功,commit事务

半事务触发时间限制

相关推荐
无限进步_19 分钟前
【数据结构&C语言】对称二叉树的递归之美:镜像世界的探索
c语言·开发语言·数据结构·c++·算法·github·visual studio
CSDN_RTKLIB32 分钟前
C++取模与取余
开发语言·c++
星河耀银海1 小时前
C++开发入门——环境搭建与第一个程序
开发语言·c++·策略模式
还不秃顶的计科生1 小时前
defaultdict讲解
开发语言·javascript·ecmascript
花归去1 小时前
echarts 柱状图包含右侧进度
开发语言·前端·javascript
wjs20241 小时前
Java 数组
开发语言
码农水水1 小时前
大疆Java面试被问:TCC事务的悬挂、空回滚问题解决方案
java·开发语言·人工智能·面试·职场和发展·单元测试·php
qq_2518364571 小时前
基于java Web 个人网站系统设计与实现
java·开发语言·数据库
Eternity∞1 小时前
基于Linux系统vim编译器情况下的C语言学习
linux·c语言·开发语言·学习·vim
周末吃鱼1 小时前
Lambda作用域
java·开发语言