EJB基本概念和使用

这篇具有很好参考价值的文章主要介绍了EJB基本概念和使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、EJB是什么?

  1. EJB是sun的JavaEE服务器端组件模型,是一种规范,设计目标与核心应用是部署分布式应用程序。
  2. EJB2.0过于复杂,EJB3.0的推出减轻了开发人员进行底层开发的工作量,它取消或最小化了很多(以前这些是必须实现)回调方法的实现,并且降低了实体Bean及O/R映射模型的复杂性。
  3. EJB大概是J2EE架构中唯一一个没有兑现其能够简单开发并提高生产力承诺的组件。

二、EJB3.0新特性

相比EJB3以前的版本而言,增加了两个新特性:元数据注解(Annotation) 和依赖注入(Injection),而元数据注解以最大限度的使部署描述符从冗余繁杂中脱离出来。

三、EJB体系结构

EnterpriseBean和Serializable接口一样,是一个标记性接口。用于标记一个类为一个Bean。它有三种实现:SessionBeanEntityBeanMessageDrivenBean

SessionBean:它是对业务逻辑的封装,类似于我们经常写的Service层。它可以以local, remote, webservice 服务的方式被client调用。

EntityBean:它是对数据库对象的封装,一个EntityBean,就是数据库的一条记录。

MessageDrivenBean:一个messageDrivenBean其实就是一个javax.jms.MessageListener。在JMS中有MessageConsumer,它支持两种接收消息的方式:同步接收采用MessageConsumer#receive()方法,异步接收则是为MessageConsumer设置一个MessageListener,一旦接收到消息,就调用listener#onMessage()。

四、SessionBean

1、SessionBean服务组件

SessionBean服务端有三大组件Home、EJbObject、SessionBean。

SessionBean是我们编写业务逻辑的地方。譬如数据库操作,进行计算等等。但是它对于客户端是不可见的,一个SessionBean实例的创建、销毁、激活、钝化等都是由EJB容器来管理的。

EJBObject:你可以将EJBObject看作是SessionBean对象的Proxy。需要将你的业务方法同样在EJBObject中复制一份。例如有一个HelloSessionBean#sayHello(str) 业务,如果要将该业务方法暴露出去给Client使用,与之对应的HelloEJBObject中必然得包含#sayHello(str)方法。也就是说Client需要使用EJBObject来达到与SessionBean交互的。

Home:这个名字起的怪异,我们可以将其理解为一个SessionBean的Factory。EJB容器通过Home对象来创建SessionBean对象,并装配出它的代理对象(EJBObject对象)。这是它的唯一用途。

2、Remote与Local

对于Home,和EJBObject,它们俩个都分为两类:Remote,Local。

Remote模式的,主要用于不在同一个JVM进程里,而在同一个进程里使用时,只需要使用Local模式的即可,这样选择自然是为了性能考虑。

3、Client访问处理流程(很容易看出Local性能好在哪里)

3.1 Remote模式下SessionBean 的访问流程

1、客户端通过JNDI获取到Home对象(EJBHome)的引用

2、客户端使用homeRef#create()方法来创建出EJBObject的Stub。

2.1)客户端底层使用Socket通信将次过程发给服务端Skeleton。

2.2)Skeleton调用服务端的Home对象的create方法,分配SessionBean对象(可能是新创建一个,也可能是从对象池中取一个,具体怎样依赖于是否是Stateful的),同时为该SessionBean对象生成一个代理对象(EJBObject实例),然后返回代理对象的引用。

2.3)客户端拿到EJBObject的引用就是Stub对象。

3、客户端访问业务

3.1) 客户端底层使用Socket通信将次过程发给服务端Skeleton。

3.2)Skeleton根据请求找到该EJBObject,调用与之关联的SessionBean的相应的业务。返回结果

3.3)客户端得到调用结果

3.2 Local模型下SessionBean的访问流程

1、客户端通过JNDI获取到Home对象(EJBLocalHome)的引用

2、客户端使用homeRef#create()方法来创建出EJBLocalObject(怎么创建也要依赖于是否的Stateful的)

3、客户端访问业务

五、常用注解

**@Stateless:**标记类把Java类声明为一个无状态会话bean

**@EJB:**表示注入实例,EJB注入和Resource注入相比,EJB注入只是针对于EJB而言,而Resource注入即是对所有的文件都可以进行注入。

**@Remove:**为会话 Bean 声明远程业务接口。用在接口上时,将该接口指定为远程业务接口。在这种情况下,不提供任何 value()。用在方法上,通过这个注解来说明在调用这个方法之后bean的实例将被清除掉。

**@Local:**用在 Bean 类上时,为会话 Bean 声明本地业务接口。用在接口上时,将该接口指定为本地业务接口。在这种情况下,不提供任何 value()。如:@Local(LawsuitService.class)

**@Stateful:**有状态会话 Bean 的组件定义注释。

**@Timeout:**指定无状态会话 Bean 类或消息驱动 Bean 类上接收该 Bean 的 EJB 计时器过期的方法。

**@TransactionAttribute:**在 TYPE-level 应用时,为会话或消息驱动 Bean 的所有业务方法指定默认事务属性。在方法级应用时,仅为该方法指定事务属性。

如:@TransactionAttribute(TransactionAttributeType.SUPPORTS)、

@TransactionAttribute(TransactionAttributeType.REQUIRED)。

**@Interceptors:**声明类或方法的拦截器的有序列表。

**@Lock:**方法声明一个并发锁的单例bean具有容器管理的并发。

**@Schedule(排程器):**计划时间为自动建立一个超时计划基于一个时间表达式。

**@Startup:**标记一个单例在应用初始化期间。

**@ConcurrencyManagement:**声明单例或有状态bean的并发管理类型

六、EJB的使用

1.依赖导入:

pom.xml

     <dependencies>  
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-web-api</artifactId>
            <version>7.0</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>

2.代码示例:文章来源地址https://www.toymoban.com/news/detail-653222.html

@Stateless
//不写默认本地@Local

public class ProdMgr {

    @EJB//注入prodService,如果出现多个ProdService接口的实现类可以使用name属性区分
    private ProdService service;


    public String getName() {
        
       String name = service.prod.getName();
        
        return name;
    }

到了这里,关于EJB基本概念和使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Pytorch基本概念和使用方法

    目录 1 Adam及优化器optimizer(Adam、SGD等)是如何选用的? 1)Momentum 2)RMSProp 3)Adam 2 Pytorch的使用以及Pytorch在以后学习工作中的应用场景。 1)Pytorch的使用 2)应用场景 3 不同的数据、数据集加载方式以及加载后各部分的调用处理方式。如DataLoder的使用、datasets内置数据集的使

    2024年02月07日
    浏览(33)
  • TensorFlow 的基本概念和使用场景

    TensorFlow 是 Google 开源的机器学习框架,它支持使用数据流图(Data Flow Graph)的方式进行计算,以实现大规模分布式机器学习应用。TensorFlow 在深度学习、自然语言处理、计算机视觉等领域有广泛应用。 TensorFlow 中的重要概念包括: 张量(Tensor):TensorFlow 中的基本数据类型,

    2024年02月11日
    浏览(24)
  • Git的基本概念和使用方式

    Git 是一个分布式版本控制系统,用于跟踪文件的变化并协调多人在同一个项目中的工作。它可以帮助团队协作开发,管理代码版本,以及追踪文件的修改历史。 Git 的基本概念包括仓库(repository)、分支(branch)、提交(commit)、合并(merge)、拉取(pull)和推送(push)。

    2024年04月27日
    浏览(26)
  • Git 的基本概念和使用方式。

    Git 是一种分布式版本控制系统,它跟踪文件的变化,允许用户在任何时间点恢复文件到之前的状态,或是比较文件之间的差异。这里是 Git 的基本概念和使用方式: 仓库(Repository):Git 仓库是用来存储项目文件和历史版本的地方。每个仓库都有一个.git目录,它包含了所有的

    2024年02月13日
    浏览(28)
  • Git 的基本概念和使用方式

    Git 是一种源代码管理工具,它可以帮助开发人员跟踪和管理代码变更,协作开发,以及管理分支和版本。 Git的基本概念包括: 版本控制:Git可以记录代码的历史版本,包括每次变更的内容、时间和作者等信息。 分支管理:Git可以创建和管理代码库中的分支,开发人员可以在

    2024年02月10日
    浏览(25)
  • 【Docker】Docker 的基本概念和优势,基本命令及使用例子

    Docker 是一种轻量级的容器化解决方案,能够快速地创建、部署和运行应用程序。以下是一些 Docker 的基本概念和优势: 基本概念: 1.镜像:一个 Docker 镜像是一个可执行的文件,其中包含了运行应用程序所需要的一切。 2.容器:一个 Docker 容器是一个镜像的运行时实例。 3.仓

    2024年02月11日
    浏览(28)
  • 解释 Git 的基本概念和使用方式

    Git是一个分布式版本控制系统,它可以记录文件的变化历史,便于团队协作和版本管理。以下是Git的基本概念和使用方式: 仓库(Repository):Git可以管理一个或多个仓库,每个仓库保存了一个或多个文件的版本历史记录。可以在本地创建仓库,也可以使用远程仓库。 提交(

    2024年02月10日
    浏览(28)
  • 解释 Git 的基本概念和使用方式。

    Git是一个版本控制工具,可以追踪文件的修改历史和不同版本,以便于团队合作和项目的管理。 下面是Git的一些基本概念和使用方式: 仓库(Repository):Git中存储代码的地方,包含了代码的历史记录和分支。 分支(Branch):代码历史记录的不同分支,可用于多人协作开发、

    2024年02月11日
    浏览(37)
  • Pytorch 的基本概念和使用场景介绍

    PyTorch是Facebook人工智能研究院(FAIR)开发的一个开源机器学习库,它使用Python语言编写,支持动态计算图和分布式训练。PyTorch的特点是灵活、易用、高效,并且在研究和实际应用中得到了广泛的应用。 PyTorch将张量作为基本数据结构,类似于NumPy中的数组。张量可以是多维数

    2024年02月10日
    浏览(26)
  • 介绍 TensorFlow 的基本概念和使用场景。

    TensorFlow(简称TF)是由Google开发的开源机器学习框架,它具有强大的数值计算和深度学习功能,广泛用于构建、训练和部署机器学习模型。以下是TensorFlow的基本概念和使用场景: 基本概念 : 张量(Tensor) :TensorFlow的核心数据结构是张量,它是多维数组,类似于NumPy数组。

    2024年02月09日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包