[转载]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

相关文章

基于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

vue2实践:el-table实现由用户自己控制行数的动态表格

需求 项目中需要提供一个动态表单,如图: 当我点击添加时,便添加一行;点击右边的删除时,便删除这一行。 至少要有一行数据,但是没有上限。 思路 这种每一行的数据固定,但是不定行数的,很容易想到使用el-table来实现,它可以循环读取:data所绑定的数组,来生成行数据,不同的是: 1、table里面的每一个cell,需要放置一个input来支持用户编辑。 2、最后一列放置两个b

【HarmonyOS】-TaskPool和Worker的对比实践

ArkTS提供了TaskPool与Worker两种多线程并发方案,下面我们将从其工作原理、使用效果对比两种方案的差异,进而选择适用于ArkTS图片编辑场景的并发方案。 TaskPool与Worker工作原理 TaskPool与Worker两种多线程并发能力均是基于 Actor并发模型实现的。Worker主、子线程通过收发消息进行通信;TaskPool基于Worker做了更多场景化的功能封装,例

vue2实践:第一个非正规的自定义组件-动态表单对话框

前言 vue一个很重要的概念就是组件,作为一个没有经历过前几代前端开发的我来说,不太能理解它所带来的“进步”,但是,将它与后端c++、java类比,我感觉,组件就像是这些语言中的类和对象的概念,通过封装好的组件(类),可以通过挂载的方式,非常方便的调用其提供的功能,而不必重新写一遍实现逻辑。 我们常用的element UI就是由饿了么所提供的组件库,但是在项目开发中,我们可能还需要额外地定义一

《C++中的移动构造函数与移动赋值运算符:解锁高效编程的最佳实践》

在 C++的编程世界中,移动构造函数和移动赋值运算符是提升程序性能和效率的重要工具。理解并正确运用它们,可以让我们的代码更加高效、简洁和优雅。 一、引言 随着现代软件系统的日益复杂和对性能要求的不断提高,C++程序员需要不断探索新的技术和方法来优化代码。移动构造函数和移动赋值运算符的出现,为解决资源管理和性能优化问题提供了有力的手段。它们允许我们在不进行不必要的复制操作的情况下,高效地转移资源

提问的智慧(转载)

此文让我受益良多。值得一读,大家如果也觉得不错就一起来推~~~   ---------------------------------      在黑客世界里,当提出一个技术问题时,你能得到怎样的回答?这取决于挖出答案的难度,同样取决于你提问的方法。本指南旨在帮助你提高发问技巧,以获取你最想要的答案。       首先你必须明白,黑客们只偏爱艰巨的任务,或者能激发他们