[转载]EJB 倡导者: 什么是最佳实践?

2024-02-21 18:20

本文主要是介绍[转载]EJB 倡导者: 什么是最佳实践?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

EJB 倡导者: 什么是最佳实践?


在本文中,我们首先通过读者提出的问题解释了“最佳实践”的整体理念,接着介绍了有关应用程序体系结构的新知识,最后说明了 Enterprise JavaBeans™ 这一强大概念尚未得到大家广泛采用的原因。

摘自 IBM WebSphere 开发者技术期刊

在每个专栏中,EJB 倡导者都采用独特的前后衔接的对话方式与实际客户和开发人员进行交流,并在期间针对某一大家关注的设计问题推荐解决方案。其中并没有介绍任何确定性的细节,也没有提出“新颖的”或专有的体系结构。有关详细信息,请参见 EJB 倡导者简介

很多人不相信“最佳”这一理念

亲爱的 EJB 倡导者:

不客气地说,我不相信“最佳”实践这一理念。您自己在第一篇文章 中说,“没有不好的模式,只有不好的模式应用。”难道最佳实践仅仅是说说而已?

署名:
For Better or For Worse


blue_rule.gif
c.gif
c.gif
u_bold.gif回页首


最佳总是相对于某个问题和上下文而言的

亲爱的 For Better or For Worse:

感谢您就最佳理念提出的看法和问题。我表示非常理解。在这些讨论中,我发现很多人对“最佳”一词颇为不满,因为这个词显示出高人一等的优越感,就如同说我的实践比任何其他人的都要好一样。

事实上,这远非我之本意。最佳并非要拿“您”的实践与“我”的实践进行比较,而是针对一组需求对两种以上用于解决某个问题的方法所进行的比较。

例如,我们来看人们最早使用的策略之一:

"分而治之"

这一简单的语句运用了两种方法来解决一个问题:a) “分解”和 b) “解决”。但是您不会问到底是“分解”好还是“解决”好。真正的问题在于,何时停止分解而开始解决最佳。最佳实践的目的就是描述每种方法的最佳应用时机。因此,在这种情况下,对这一策略的“更好”(更完整地描述)措词可能是这样的:

"问题复杂时就分解,问题简单时就解决".

这句话意味着将两种方法运用于解决同一复杂问题,因为最终可以将复杂问题分解为足够简单的子问题。当然,您也可以先不进行分解而直接“解决”一个简单的问题。下图更清楚地说明了最佳实践的迭代(及常见的并行)特性。它将问题视为棱形,而将运用的解决方法视为矩形。连接问题和方法的弧线上的标签描述了在给定决策点上使用不同于其他方法的某一方法的原因:


图 1. 最佳实践的本质
图 1. 最佳实践的本质

进一步说,哪一种是最佳的呢,是无状态会话 Bean、有状态会话 Bean、实体 Bean,还是消息驱动 Bean?当然,答案要依赖于具体应用的需求。是需要立即响应,还是只需“即发即弃 (Fire and Forget)”请求?如果需要立即响应,那么是否需要“记住”请求发送的顺序或者要求请求间没有相互依赖性呢?针对这些需求,EJB 组件集能够客观地进行比较,从而找到针对实际应用情况的最佳方案。但是偶尔也会遇到某个复杂企业应用需要用到所有这些组件的情况。

还有一点需要强调的是:所谓的最佳是飘忽不定的。由于情况的不同,例如语言和平台在不断地发生变化,因此针对所要解决的问题而提出的最佳实践也会经常改变。EJB 倡导者的上一篇文章详细地比较了 EJB 3 规范与目前的规范,您可以根据这些规范来考虑问题,从而找到一个折衷的方案。

针对实际企业需求探索如何最好地使用 EJB 组件是本 EJB 倡导者系列的真正目的。

希望这对您有所帮助。

好的,就先到此为止,
您的 EJB 倡导者


blue_rule.gif
c.gif
c.gif
u_bold.gif回页首


如何对待不断变化的最佳实践?

亲爱的 EJB 倡导者:

非常感谢您花时间阐明最佳实践的意义。我也认为将其称为最佳听起来有些傲慢自大,而且我非常赞同将最佳实践看作针对具体问题简单地将一种方法与另一种方法进行比较这一理念。

但是,您最后关于情况变化的观点引出了一个有趣的话题:既然 EJB 规范也在不断改变,为何我们还要费尽周折学习关于 EJB 2 组件的最佳实践?此外,我还担心一个问题,EJB 3 是否将存在足够长的时间,谁能够给我保证?

谢谢。
For Better or For Worse


blue_rule.gif
c.gif
c.gif
u_bold.gif回页首


关注通用设计原则和要求

亲爱的 For Better or For Worse:

诚然,事物不断地发生改变让人感到灰心,但是既然您和 EJB 倡导者一样都经历了过去的 COBOL 时代,那么您会意识到下面这句谚语背后的真义:“三十年河东,三十年河西。”还有一句对老手不会起什么安慰作用的格言是“江山易改,本性难移”(如果我以前用过这句格言,请您谅解)。

很抱歉使用这些民谚。我的观点是,当今的企业应用遇到的大多数问题与我们以往遇到的问题是相同的。计算机的运算速度永远不够快,内存或硬盘永远不够用,屏幕也永远不够大。因此,大多数用于构建解决方案的最佳实践都是相同的。

例如,今天用于设计“瘦客户端”应用的最佳实践与二十年前的最佳实践基本相同。主要的不同之处在于,屏幕不再是“绿颜色”的(并且并不仅有文本)。除了语言与平台的差异外,通用设计原则是相同的:将用于屏幕呈现的逻辑(“视图”)与获取和/设置数据的函数中的逻辑(“模型”)相分离。

下面是另一个示例。在 EJB 2 规范之前,总是认为在实体 Bean 周围使用会话 Bean Facade 是最佳的。有了 EJB 2 之后,“Home”实体可用于相同的目的——当存在一个代表用户角色的实体时,便不再需要额外的会话 Bean 组件。无论如何,常用的最佳实践是避免直接将持久层公开给客户,而应提供一个 Facade 来代替。创建 Facade 的细节可能会发生改变,但使用它一定是最佳实践,这适用于任何您能想象到的语言和平台――甚至是 COBOL CICS 应用!

这些示例说明,只要您能够首先关注通用设计原则,然后再考虑如何在某一平台上实现此原则的细节,就不会误入歧途。我忍不住想起了另一句古谚。获得最佳实践的方法就是应用策略:

"功能决定形式"

换言之,学习有关最佳实践的知识(即使是旧知识)总是值得的,因为每种方法的背后都隐含一条通用原则,这有助于您满足特定的需求。通常仅需要对需求的某一方面进行抽象(如用户不得不使用的平台和语言)。

Java Enterprise Edition (JEE) 规范之所以重要,是因为发明者们充分考虑到与企业应用相关的需求。不仅是功能部分,而且包括非功能部分,如可靠性、可用性、效率、可维护性及可移植性。在每个组件和 API 背后都隐含一条通用设计原则,这使得该组件能够最好地应用于满足这些需求。在本系列中,我们已经研究了许多这样的原则,例如,EJB 组件如何将业务逻辑与提供本地或远程部署、安全、事务、持久化及异步调用相分离。此外,如果您还还记得,Java 是一种与平台无关、“编写一次,到处运行”的语言,有助于与其他语言编写的组件集成,那么对于构建实际的企业级应用,您还有什么要求呢?

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/374079/viewspace-130321/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/374079/viewspace-130321/

这篇关于[转载]EJB 倡导者: 什么是最佳实践?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/732660

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

Docker集成CI/CD的项目实践

《Docker集成CI/CD的项目实践》本文主要介绍了Docker集成CI/CD的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、引言1.1 什么是 CI/CD?1.2 docker 在 CI/CD 中的作用二、Docke

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

Prometheus与Grafana在DevOps中的应用与最佳实践

Prometheus 与 Grafana 在 DevOps 中的应用与最佳实践 随着 DevOps 文化和实践的普及,监控和可视化工具已成为 DevOps 工具链中不可或缺的部分。Prometheus 和 Grafana 是其中最受欢迎的开源监控解决方案之一,它们的结合能够为系统和应用程序提供全面的监控、告警和可视化展示。本篇文章将详细探讨 Prometheus 和 Grafana 在 DevO

springboot整合swagger2之最佳实践

来源:https://blog.lqdev.cn/2018/07/21/springboot/chapter-ten/ Swagger是一款RESTful接口的文档在线自动生成、功能测试功能框架。 一个规范和完整的框架,用于生成、描述、调用和可视化RESTful风格的Web服务,加上swagger-ui,可以有很好的呈现。 SpringBoot集成 pom <!--swagge