当前位置: 首页 > news >正文

做网站找哪家公司好自媒体发稿

做网站找哪家公司好,自媒体发稿,wordpress分页链接设置,做物流的网站有哪些功能前言 传统单体架构下,所有的功能模块都在一个应用下,所有的代码和业务逻辑都在同一个应用下实现,所以保证数据的一致性就很简单,保证相关操作都在同一个本地事务下就可以了。 但是在微服务架构下,将一个应用拆分成了…

前言

传统单体架构下,所有的功能模块都在一个应用下,所有的代码和业务逻辑都在同一个应用下实现,所以保证数据的一致性就很简单,保证相关操作都在同一个本地事务下就可以了。

但是在微服务架构下,将一个应用拆分成了多个独立的服务,每个服务都能有自己的数据库,服务间通信都是通过远程调用实现,实现一个功能可能需要由几个不同的服务来共同实现。这就会带来一个问题,不同的服务之间无法做到使用同一个事务,这就无法保证数据的一致性了。

解决分布式事务的问题,一劳永逸的方式就是直接使用 Seata,Seata 是一个开源的分布式事务解决方案,用于解决分布式系统中的数据一致性问题。但是,引入 Seata 实在是太重了,在实际工作中接触过的系统,并没有那么多的业务需要使用到分布式事务,为了解决那么一两个业务的问题却要为整个系统引入分布式事务服务,代价实在是太大了。而且,相关的业务实际上只需要保证数据的最终一致性,不用保证强一致性,所以在实践可以使用本地消息表的方案来解决分布式事务问题。

本地消息表方案

如果系统中只有少数服务需要用到分布式事务,那么直接在该服务下创建一张本地消息表,结合消息队列,就能够实现数据的最终一致性了。

表设计

本地消息表的设计如下

字段类型注释
idlongid
msg_typevarchar消息类型
biz_idvarchar业务唯一标志
contenttext消息体
statevarchar状态(待发送,已消费)
create_timedatetime创建时间
update_timedatetime更新时间

时序图

plantuml

@startuml
'https://plantuml.com/sequence-diagramautonumberparticipant Scheduled_Task
database DB_A
participant Service_A
queue Queue
participant Service_B
database DB_Bgroup Service_A本地事务DB_A <- Service_A: 写本地业务数据DB_A <- Service_A: 写本地消息数据
endService_A -> Queue: 发送消息
note left
发送消息放到事务外
防止由于网络延迟出现
Service_A认为发送失败导致事务回滚
而实际上MQ收到了消息
Service_B也消费了消息
从而出现数据不一致的情况
end noteQueue -> Service_B: 消费消息Service_B -> Service_B: 幂等判断
note right
防止重复消费消息
end notegroup Service_B本地事务Service_B -> DB_B: 写本地业务数据
endgroup 更新本地消息表状态Scheduled_Task <- Service_B: 更新本地消息表状态Scheduled_Task -> DB_A: 更新本地消息表状态
end
note right
这里即使失败了也无所谓
两个服务的数据已经一致了
没有更新消息状态,定时任务会重新投递
Service_B做好幂等处理
等下次消费再去修改消息状态即可
end noteloop 定时任务Scheduled_Task -> DB_A: 查询未成功投递的消息Scheduled_Task -> Queue: 重新投递
end@enduml

消息服务方案

本地消息表只只用系统中只有少量业务需要实现分布式事务的情况,如果系统中的绝大多数服务都存在分布式事务的业务场景,为每个服务都创建一张本地消息表显然很麻烦,难以维护。

用到的地方多,实际上就可以考虑上 Seata 了,专业的事要交给专业的服务来做。不过这里也可以改进一下本地消息表的方案,增加一个专门处理分布式事务消息的消息服务和消息库。

表设计

表设计同上面一样,消息服务只不过将所有本地消息表合并成一张表了

只不过 state 字段需要多一个状态来区分

在本地消息表方案中,由于写Service_A业务和创建消息是在同一个事务中,它们要么同时成功,要么同时失败,所以两个状态(待发送,已消费)就能表示整个消息的生命周期。

  1. 待发送状态,则表示Service_A业务和消息同时写入库成功,等待Service_B消费消息
  2. 已消费状态,则表示Service_B已经成功消费了消息

在消息服务方案中,写业务和创建消息不在同一个事务中,所以需要再加一个状态(发送中)

  1. 待发送状态,则表示刚创建消息,此时Service_A还没有写库
  2. 发送中状态:则表示Service_A已经写库成功,等待Service_B消费消息
  3. 已消费状态,则表示Service_B已经成功消费了消息

时序图

plantuml

@startuml
'https://plantuml.com/sequence-diagramautonumberdatabase DB_A
participant Service_A
participant Service_Msg
database DB_Msg
queue Queue
participant Service_B
database DB_Bgroup 创建消息Service_A -> Service_Msg: 创建消息note left: 生成业务idService_Msg -> DB_Msg: 创建消息note left: 消息状态:待发送Service_A <- Service_Msg: 返回消息ID
endgroup Service_A本地事务DB_A <- Service_A: 写本地业务数据
endService_A -> Service_Msg: 发送消息
note left: 携带消息ID
Service_Msg -> DB_Msg: 更新消息状态
note right: 消息状态:发送中
Service_Msg -> Queue: 发送消息
Queue -> Service_B: 消费消息Service_B -> Service_B: 幂等判断group Service_B本地事务Service_B -> DB_B: 写本地业务数据
endgroup 更新消息状态Service_Msg <- Service_B: 更新消息状态Service_Msg -> DB_Msg: 更新消息状态note right: 消息状态:已消费
endloop 定时任务Service_Msg -> DB_Msg: 查询状态为发送中的消息Service_Msg -> Queue: 重新投递
end@enduml
http://www.zhongyajixie.com/news/50520.html

相关文章:

  • 网站建设制作设计推广优化加强服务保障 满足群众急需需求
  • 学做网站学费百度云下载
  • ps在线图片编辑搜索优化推广公司
  • 简单大气的网站竞价账户托管的公司有哪些
  • 建设银行网站登录不上长沙网站seo源头厂家
  • wordpress 插入图片 边框肥城市区seo关键词排名
  • 互联网建站公司一个网站的seo优化有哪些
  • 12306网站是哪家公司做开发的营销技巧在线完整免费观看
  • 美橙建站靠谱吗个人做外贸怎样起步
  • 中山网站建设文化策划书北京优化网站方法
  • 各个做网站的有什么区别长沙seo优化服务
  • 自己做网站的准备工作哪里有整站优化
  • 南宁网站建设怎么做推广网站
  • 做网站页面多少钱无锡百度正规公司
  • 网页制作 页面链接其他网站 站长seo查询工具
  • 网站设计二级页面怎么做信息流推广渠道有哪些
  • 如何做网站优化seo产品营销策略有哪些
  • 网站统计代码b2b平台推广网站
  • 宿迁市住房和城乡建设局海口百度seo公司
  • 有做火币网这种网站的吗百度帐号注册
  • 做网站涉及到哪些百度网盘电话人工服务
  • 湛江网站建设方案报价广告营销
  • 提高网站排名怎么做企业文化
  • 求哪位大神发人和动物做愛视频网站收录查询 站长工具
  • 手机端网站开发源码沈阳网页建站模板
  • 链家准备做贝壳网站河北网站seo外包
  • 视频制作软件哪个好用武汉百度推广优化
  • 镇江网站建设远航网络搜索引擎优化培训免费咨询
  • 有了网站怎么做优化上海app定制开发公司
  • 网站怎么做图片动态图片不显示了google推广专员招聘