golang分布式事务解决方案 如何使用消息队列解决分布式事务?
如何使用消息队列解决分布式事务?
有两种选择。
Scheme 1 Local message transaction table
生产者需要添加一个事务消息表。具体步骤如下:[1。生产者执行业务逻辑并将事务记录插入到消息表中。这两个操作在一个本地事务中
2。启动后台线程定期轮询消息表并将消息发送到消息队列
3。删除消息表中的消息,直到发送成功。
方案2需要消息队列支持,业务端提供回溯接口
1。生产端将准备好的消息发送到消息队列
2。在本地事务中,业务逻辑
3。根据执行结果确认或取消准备好的消息
4。消息队列将确保准备好的消息被确认或取消,并且消息队列将不断地向生产端请求执行结果,这要求生产端提供类似的回调函数。
在方案2中,消息队列取代了方案1中的消息表和后台线程轮询功能,但并非所有消息队列都支持此功能。支持Rocketmq。
方案1的开发工作量大,外部依赖性小
方案2的开发工作量小,但依赖于特定的消息队列。
Go语言现在的前景怎么样?
我学过Java和golang。Java已经使用了5年,我对Java的生态、工业语言和无数解决方案有着深刻的感受。无论您是从事互联网还是传统行业的开发,java开发总能解决很多问题。国内巨头阿里巴巴将java推向了极致。作为一种新的语音语言,golang的简单语法极低很难上手,他的生态也在逐步改善,比如docker etcd kubernetes Tidb、beego甚至阿里巴巴都在中国推出了Dubbo go。今天头条、比力、滴滴等中国公司的技术堆栈已经逐渐从Java变成了golang。不是Java不好,而是golang非常简单。如果您开发一个包含20行代码的web应用程序,Java可能需要您了解完整的技术栈,比如spring引导栈,而golang只需要您了解httprouter。RPC框架的支持并不比Java好多少。去cicd领域完全是玩Java。毕竟,docker和kubernetes是由golang编写的,它们自然得到无缝支持。Golang的并发模型也领先于Java。Gorouting是为并发而生的,所以现在学习golang是一个很好的选择,但是golang也有它自己的优点它的缺点是项目管理和包依赖管理不如Java,通用支持也不是很好。与Java的生态相比,go的国内生态还很欠缺。另外,爪哇的就业比哥朗简单,因为差距很大,但哥朗的就业工资并不低于爪哇。因此,从语言的角度看,golang优于Java,生态上低于Java,理论上比Java有着光明的前景,这要看国内的发展趋势,所以建议大家学习
目前,可能性不大。至于未来,要看谷歌能否继续支持围棋。目前,围棋语言的开发人员说,它是简单,快速,安全,并发,快乐编程和开源。然而,围棋语言缺乏方向性和“集成商”的尝试,很容易导致围棋学不到猫和狗,围棋语言将减少到四种。
Java似乎永远不会过时。尽管Java最初是在20世纪90年代为交互式电视设计的,但今天的Java为企业应用程序、Android移动应用程序开发和所有其他功能提供了动力。
Java本身的跨平台、安全性、健壮性、简单性非常适合企业开发。此外,这些年来,各种组织贡献了各种生态环境,比如各种开源框架,比如spring family bucket。Java在今天取得了巨大的成就,spring无疑做出了很大的贡献。据不完全统计,世界上运行Java程序的设备有几十亿台。
Java最大的问题是臃肿的框架。以前配置一个开发环境需要半天的时间。现在springboot在一定程度上改善了这种情况。
总之,Java优势突出,生态完善,技术成熟。虽然go非常好,但要在短时间内取代Java是不可能的。
golang分布式事务解决方案 go分布式 python web开发框架
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。