在jboss下,如果包含ejb的jar,和要通过local接口访问ejb的war不被打包成一个ear来部署,会遇到问题。如果你的war中包含了ejb3的local接口的class,那么war在通过jndi取得ejb的引用试图将其转化成接口类型时会抛ClassCastException。而如果war中不包含local接口的class,则会抛class not found的异常。这都是由讨厌的classloader问题导致的。每个放到jboss的deploy目录里的部署单元都有自己的独立的classloader树,这两棵树在jvm的classloader里是平级的。如果war和ejb jar里都包含了某个ejb的local接口的class时,那么同一个类就分别存在于两棵classloader树中。通过jndi取得的引用的类型是ejb jar中的local接口的类型,将其转化成war里的那个local接口类型时就出错了,因为它们不是同一个类。而classloader是不能访问同级的其他的classloader下的类的,所以如果war里不包含接口的class,有会因找不到class而出错。

这种时候就是使用ear的时候,位于同一个ear里ejb jar的classloader是war的classloader的父classloader。这样,只需要部署一份接口类,war也能访问到它,因为子classloader能访问父classloader载入的类。

Share/Save/Bookmark