《Java工程师必读手册》——Java经验之谈系列——那些年,我们见过的Java服务端“问题”(5)

简介: 《Java工程师必读手册》——Java经验之谈系列——那些年,我们见过的Java服务端“问题”(5)

接上篇:https://developer.aliyun.com/article/1228227?spm=a2c6h.13148508.setting.33.62774f0e61109O


四、 系统间交互不科学

 

1. 直接通过数据库交互

 

在一些项目中,系统间交互不通过接口调用和消息队列,而是通过数据库直接访问。问其原因,回答道:“项目工期太紧张,直接访问数据库,简单又快捷”。

 

还是以上面的采购流程为例——采购订单由库管系统发起,由采购系统负责采购,采购完成后通知库管系统,库管系统进入入库操作。采购系统采购完成后,通知库管系统数据库的代码如下:

 

image.png 

 

其中,通过rawPurchaseOrderDAO(原始采购单DAO)直接访问库管系统的数据库表,并设置原始采购单状态为已完成。

 

一般情况下,直接通过数据访问的方式是不会有问题的。但是,一旦发生竞态,就会导致数据不同步。有人会说,可以考虑使用同一分布式锁解决该问题。是的,这种解决方案没有问题,只是又在系统间共享了分布式锁。

 

1) 直接通过数据库交互的缺点

 

直接暴露数据库表,容易产生数据安全问题;

多个系统操作同一数据库表,容易造成数据库表数据混乱;

操作同一个数据库表的代码,分布在不同的系统中,不便于管理和维护;

具有数据库表这样的强关联,无法实现系统间的隔离和解耦。

 

2. 通过Dubbo接口交互

 

由于采购系统和库管系统都是内部系统,可以通过类似Dubbo的RPC接口进行交互。

 

1) 库管系统代码

 

image.png 

 

其中,库管系统通过Dubbo把PurchaseOrderServiceImpl(采购单服务实现)以PurchaseOrderService(采购单服务接口)定义的接口服务暴露给采购系统。这里,省略了Dubbo开发服务接口相关配置。

 

 

2) 采购系统代码

 

image.png

 

其中,purchaseOrderService(采购单服务)为库管系统PurchaseOrderService(采购单服务)在采购系统中的Dubbo服务客户端存根,通过该服务调用库管系统的服务接口函数finishPurchaseOrder(完成采购单函数)。

 

这样,采购系统和库管系统自己的强关联,通过Dubbo就简单地实现了系统隔离和解耦。当然,除了采用Dubbo接口外,还可以采用HTTPS、HSF、WebService等同步接口调用方式,也可以采用MetaQ等异步消息通知方式。

 

3. 常见系统间交互协议

 

1) 同步接口调用

 

同步接口调用是以一种阻塞式的接口调用机制。常见的交互协议有:

 

HTTP/HTTPS接口;

WebService接口;

Dubbo/HSF接口;

CORBA接口。

 

2) 异步消息通知

 

异步消息通知是一种通知式的信息交互机制。当系统发生某种事件时,会主动通知相应的系统。常见的交互协议有:

 

MetaQ的消息通知;

CORBA消息通知。

 

4. 常见系统间交互方式

 

1) 请求-应答

 

image.png

 

适用范围

 

适合于简单的耗时较短的接口同步调用场景,比如Dubbo接口同步调用。

 

2) 通知-确认

 

image.png 

 

适用范围

 

适合于简单的异步消息通知场景,比如MetaQ消息通知。

 

3) 请求-应答-查询-返回

 

image.png 

适用范围

 

适合于复杂的耗时较长的接口同步调用场景,比如提交作业任务并定期查询任务结果。

 

4) 请求-应答-回调

 

image.png

 

适用范围

 

适合于复杂的耗时较长的接口同步调用和异步回调相结合的场景,比如支付宝的订单支付。

 

5) 请求-应答-通知-确认

 

image.png 

 

适用范围

 

适合于复杂的耗时较长的接口同步调用和异步消息通知相结合的场景,比如提交作业任务并等待完成消息通知。

 

6) 通知-确认-通知-确认

 

image.png

 

适用范围

 

适合于复杂的耗时较长的异步消息通知场景。


接下篇:https://developer.aliyun.com/article/1228222?groupCode=java

相关文章
|
2月前
|
架构师 前端开发 Java
Java开发工程师的职业规划应该是什么样的?
Java开发工程师的职业规划涵盖多个阶段,包括初入行业(0-1年)、技能提升(1-3年)、技术专家(3-5年)及管理或专家路线选择(5年以上)。各阶段设定了明确的技能要求与职业目标,从掌握Java基础、常用框架到深入研究高级技术、微服务架构乃至担任管理职务或成为技术专家。通过持续学习与实践,结合个人兴趣,Java工程师可在技术或管理领域找到合适的发展方向,最终实现职业成功。
427 83
|
30天前
|
JSON Java 开发工具
Java服务端集成Google FCM推送的注意事项和实际经验
本文分享了作者在公司APP海外发布过程中,选择Google FCM进行消息推送的集成经验。文章详细解析了Java集成FCM推送的多种实现方式,包括HTTP请求和SDK集成,并指出了通知栏消息和透传消息的区别与应用场景。同时,作者还探讨了Firebase项目的创建、配置和服务端集成的注意事项,帮助读者解决文档混乱和选择困难的问题。
55 1
|
1月前
|
JSON Java 开发工具
Java服务端集成Google FCM推送的注意事项和实际经验
公司的app要上海外,涉及到推送功能,经过综合考虑,选择Google FCM进行消息推送。 查看一些集成博客和官方文档,看的似懂非懂,迷迷惑惑。本篇文章除了将我实际集成的经验分享出来,也会对看到的博客及其中产生的疑惑、注意事项一一评论。 从官方文档和众多博客中,你会发现Java集成FCM推送有多种实现方式,会让生产生文档很乱,不知作何选择的困惑。
89 0
|
2月前
|
设计模式 架构师 Java
Java开发工程师转架构师需要学习什么
Java开发工程师转型为架构师需掌握多项技能:精通Java及框架、数据库与分布式系统;熟悉设计模式与架构模式;积累项目经验;提升沟通与领导力;持续学习新技术;培养系统设计与抽象能力;了解中间件及开发工具;并注重个人特质与职业发展。具体路径应结合个人目标与实际情况制定。
68 18
|
2月前
|
人工智能 前端开发 Java
Java开发工程师转哪个行业比较好?
Java开发工程师转哪个行业比较好?
296 2
|
3月前
|
人工智能 自然语言处理 Java
Spring AI,Spring团队开发的新组件,Java工程师快来一起体验吧
文章介绍了Spring AI,这是Spring团队开发的新组件,旨在为Java开发者提供易于集成的人工智能API,包括机器学习、自然语言处理和图像识别等功能,并通过实际代码示例展示了如何快速集成和使用这些AI技术。
Spring AI,Spring团队开发的新组件,Java工程师快来一起体验吧
|
2月前
|
小程序 前端开发 JavaScript
Java开发工程师转小程序开发的前景如何?
Java开发工程师转小程序开发的前景如何?
51 0
|
4月前
|
Java
图解java工程师学习路线
图解java工程师学习路线
244 0
|
7天前
|
Java 开发者
Java多线程编程中的常见误区与最佳实践####
本文深入剖析了Java多线程编程中开发者常遇到的几个典型误区,如对`start()`与`run()`方法的混淆使用、忽视线程安全问题、错误处理未同步的共享变量等,并针对这些问题提出了具体的解决方案和最佳实践。通过实例代码对比,直观展示了正确与错误的实现方式,旨在帮助读者构建更加健壮、高效的多线程应用程序。 ####
下一篇
无影云桌面