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事务

半事务触发时间限制

相关推荐
念何架构之路1 小时前
Go进阶之panic
开发语言·后端·golang
先跑起来再说1 小时前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
亓才孓1 小时前
[Properties]写配置文件前,必须初始化Properties(引用变量没执行有效对象,调用方法会报空指针错误)
开发语言·python
傻乐u兔1 小时前
C语言进阶————指针3
c语言·开发语言
两点王爷1 小时前
Java基础面试题——【Java语言特性】
java·开发语言
Swift社区2 小时前
Gunicorn 与 Uvicorn 部署 Python 后端详解
开发语言·python·gunicorn
码农阿豪2 小时前
Python Flask应用中文件处理与异常处理的实践指南
开发语言·python·flask
岁岁种桃花儿2 小时前
CentOS7 彻底卸载所有JDK/JRE + 重新安装JDK8(实操完整版,解决kafka/jps报错)
java·开发语言·kafka
csbysj20202 小时前
AngularJS 模块
开发语言
独好紫罗兰2 小时前
对python的再认识-基于数据结构进行-a003-列表-排序
开发语言·数据结构·python