|
EJB 学习笔记 1、ejb 基础知识 (1) 无状态会话bean 不保存客户机的会话状态 优点:使用小量的实例即可满足大量的客户。每个实例都没有标识,相互之间是等价的。 等价的无状态会话bean: 多次和一次调用的结果和效应相同。 在集群中可以负载均衡 a 机器失败,可以在b机器上重试 非等价的无状态会话bean: 如:计数器 不能自动因故障而进行切换。 (2) 有状态会话bean 保存客户机的会话状态 特点: 在有会话状态会话的bean例子中,出纳员的数量等于活动的顾客的数量,这可以简化编程模式 weblogic 通过内存复制技术 在集群中进行负载均衡 内存复制技术: 每个有会话状态的bean实例都将存储在两个服务器的内存中,一个服务器作为主服务器,另一个作为辅助服务器。 如果主失败,辅助变为主,然后自动选择别的可用的服务器作为辅助。 遗憾: 很难在servlet 和jsp中用好有状态会话bean。可能会发生并发现象,产生RemoteException weblogic 的<allow-concurrent-calls> 可以封锁任何并发的调用。 同步: 可以有选择地实现 javax.ejb.SessionSynchronization接口 afeterBegin() //进入事务时 beforeCompletion() //提交事务前,用于提交前把缓存的数据写到数据库中. afterCompletion() //提交事务后,用于释放共享资源或者更新事务提交和终止方面的统计信息. 会话bean通过其 SessionContext 对象中的 getUserTransaction() 方法,取得对UserTransaction的应用 通常 SessionContext 被存放在成员变量中 ** 记住是在调用ejb.create()方法前调用 setUserTransaction() 方法 利用对 UserTransaction 的引用会话可以使用 begin() 、commit()、rollback() 方法界定一个事务.
(3) 实体 bean: 它有一个主健作为唯一的标识符 组成部分: 由本地接口、远程接口、bean类、主健类和配置描述器组成。 本地接口: 扩展了javax.ejb.EJBHome接口,包括create()、remove()、finder 和home等方法 1)create()方法调用bean类中的ejbCreate()方法。相当于数据的insert 方法。 2)remove()方法相当于数据库的delete操作。 3)finder()方法,使客户能够查询和接收满足查询条件的实体bean的引用。每个实体bean的本地接口中都必须 有一个findByPrimaryKey() 方法 4)home 方法,类似于无状态会话bean。 主健类: 实体bean必须包括一个主健类,主健类用于标识实体bean实例,而且实体bean数据类型必须是唯一的。 主健类可以是java的基本类型String Integer 也可以是用户自定义的。 也可以是多个字段的主健的复合主健。 bean 类和bean的上下文环境: 实现javax.ejb.EJBObject 接口,其中包含业务方法的语法格式定义. bean 类实现了javax.ejb.EntityBean接口,同javax.ejb.SessionBean接口一样,EntityBean 接口包含了EJB 容器调用bean实例的语法格式. 在bean的构造器执行之后,立即调用setEntityContext() 方法,同时把bean实例的EntityContext 传递给它. bean类实现了home方法和远程接口中的业务方法,home方法是针对匿名实例的方法不应使用有关的主健值.
分为: 容器管理持久性(Container-Managerd Persistence)CMP 特点: EJB 容器自动生成,用于把实体bean的数据写入到数据库中。 优点: bean作者可以避免编写实体bean与关系数据库数据访问方面的代码。cmp将自动处理这一过程。 个性: 每一个cmp 实体bean 都有一组容器管理的字段,这些字段存储在数据库,并可从中加载.通常,每个容器管理的字段都对应于 关系数据库中的一个列. 容器管理的每个字段必须在ejb-jar.xml中定义,这使容器能够把容器管理的字段与bean类中的set和get方法进行匹配比较. 另外,bean作者可以增加另外一个cmp配置描述文件 weblogic-cmp-rdbms.xml,其中包含数据库表名和每个容器管理的字 段和相应的数据列的映射.
bean管理持久性(Bean-Managerd Persistence ) BMP 特点: 在bmp实体中,bean作者需要自己编写数据库访问代码,也就是编写JDBC代码,插入、删除和查询数据库中的实体bean数据。 优点: 可以让bean的作者完全灵活的处理实体bean的持久性数据,因为作者需要写数据访问的代码,他几乎可以使用任何持久性存 储方式ejb2.0 cmp提供实体bean之间的标准关系映射,使容器能自动管理业务对象之间的交互。 cmp拥有更多的访问控制,因此cmp比bmp有较好的性能。
(4) 消息 bean 把JMS 和EJB 成功结合在一起,集成的结果 特点:客户机不需要调用消息bean 相反: 客户机只需要发一个消息给jMS目的。 在消息到达以后,消息bean的onmessage()方法将被调用,以处理这个消息。 消息bean用于在服务器中执行异步操作。
2。EJB 组成 (1)远程接口 public interface HelloWord extents EJBObject { //EJBObject 接口方法 EJBHome getEJBHome() throws RemoteException;
Object getPrimaryKey() throws RemoteException;
void remove() throws RemoteException, RemoveException;
Handle getHandle() throws RemoteException;
boolean isIdentical(EJBObject ejbObject) throws RemoteException; } (2)本地接口 本地接口是ejb工厂,客户机可以使用本地接口创建、找出和删除ejb实例。只需写本地接口中的方法的语法调用格式 public class HelloWorldHome extends EJBHome { //EJBHome 接口方法 void remove(Handle handle) throws RemoteException, RemoveException;
void remove(Object o) throws RemoteException, RemoveException;
EJBMetaData getEJBMetaData() throws RemoteException;
HomeHandle getHomeHandle() throws RemoteException; // Home public HelloWorld create() throws CreateException, RemoteException;   |