将JBoss下开发的EJB3.0数据库应用迁移到WebLogic10.3的注意事项
来源:互联网 发布:全职美工招聘 编辑:程序博客网 时间:2024/06/05 01:53
之前的EJB3.0及WebService开发是在JBoss下的,现在把项目迁移到Weblogic10.3下,发现会出现很多莫名其妙的问题。
1.EJB3.0客户端调用
在调用JBoss开发的EJB3.0的客户端上,需要配置一个名为jndi.proterties的文件,其内容包括:
java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
java.naming.factory.url.pkgs=org.jboss.naming:org.jnp.interfaces
#服务所在的ip地址,可以设为其它ip
java.naming.provider.url=IP地址
而如果EJB3.0是在Weblogic10.3下开发的,则要将第二句改为:
java.naming.factory.url.pkgs=weblogic.jndi.WLInitialContextFactory
2.数据源配置
JBoss下配置的数据源主要是在JBoss_Home\server\default\deploy目录下的xxx-xxx-ds.xml下进行的,只要在项目的persistence.xml下配置相应的JNDI即可。
在Weblogic10.3下,则需要在控制台的“服务-JDBC-数据源”中新建数据源(包括JNDI、数据库产品、数据库驱动、数据库帐号密码、哪个数据库等……),配置完后还要修改项目的persistence.xml,即在其中添加:
<provider>org.apache.openjpa.persistence.PersistenceProviderImpl</provider><!--这句好像可以不加的-->
<property name="openjpa.ConnectionURL" value="数据库连接URL"></property>
<property name="openjpa.ConnectionUserName" value="数据库帐号"></property>
<property name="openjpa.ConnectionPassword" value="数据库口令"></property>
<property name="openjpa.ConnectionDriverName" value="数据库驱动类名" />
缺少上面4句可能会引发org.apache.openjpa.persistence.ArgumentException: A JDBC Driver or DataSource class name must be specified in the ConnectionDriverName property.的异常。
3.JPQL
在JBoss下正常运行的JPQL,放到Weblogic10.3下却总是会有奇怪的异常,如
EJB Exception: : <openjpa-1.1.1-SNAPSHOT-r422266:891341 nonfatal user error> org.apache.openjpa.persistence.ArgumentException: Encountered "from" at character 1, but expected: ["DELETE", "SELECT", "UPDATE"].
对于这个异常,容易理解:说JPQL语句缺少"DELETE", "SELECT", "UPDATE"等关键字。
原来在JBoss容器中,我们可以写这样的JPQL查询语句:
from Room r where r.roomType=?1
但在Weblogic下却必须写成:
select r from Room r where r.roomType=?1
还有这个更奇怪的异常:
Caused by: java.lang.Exception: org.apache.openjpa.lib.jdbc.ReportingSQLException: ORA-00955: 名称已由现有对象使用
{stmnt 4024035 CREATE TABLE OPENJPA_SEQUENCE_TABLE (ID NUMBER NOT NULL, SEQUENCE_VALUE NUMBER, PRIMARY KEY (ID))} [code=955, state=42000]
这个异常是发生在执行EntityManager的persist()方法。我上网查了一下,看到一位网友写道:
-------------------------------------------------------------
OpenJPA uses OPENJPA_SEQUENCE_TABLE to generate primary keys for entities that use datastore identity or application identity with auto-generation strategy. The table is created automatically when persistence.xml configuration specifies to build the schema.
<property name="openjpa.jdbc.SynchrnozieMappings" value="buildSchema"/>
The other option is to create the table directly via DDL:
CREATE TABLE openjpa_sequence_table (ID tinyint(4) NOT NULL, SEQUENCE_VALUE bigint(20) default NULL, PRIMARY KEY (ID))
-------------------------------------------------------------
大概是说OpenJPA(Weblogic使用的JPA)在你使用自增的主键生成策略时,需要一张名为openjpa_sequence_table的数据表。如果你在persistence.xml中配置了<property name="openjpa.jdbc.SynchrnozieMappings" value="buildSchema"/>,那么这张表就会自动给你创建。你也可以采用其它方法,即通过DDL直接给数据库添加这张表。我们之所以抛出上面那异常,就是既没有配置<property name="openjpa.jdbc.SynchrnozieMappings" value="buildSchema"/>,也没有给数据库创建这张表。只要做了这一步,OpenJPA就能正常插入记录了。
4.WebService
在JBoss下发布的Web服务,其wsdl的名称与Weblogic10.3也有些不同。
前者默认是:机器:端口/项目名/xxx?wsdl,而后者却默认变成了:机器:端口/xxx/xxxService?wsdl
- 将JBoss下开发的EJB3.0数据库应用迁移到WebLogic10.3的注意事项
- Weblogic10+EJB3.0下的MDB遇到问题及解决
- 从websphere6.1迁移到weblogic10.3的问题总结
- Tomcat6 迁移到 WebLogic10 遇到的问题.
- JBoss下的EJB3开发无状态会话Bean
- JBoss下的EJB3开发无状态会话Bean
- EJB应用从WebLogic到JBoss的迁移方法
- EJB应用从WebLogic到JBoss的迁移方法
- Eclipse配置JBOSS进行EJB3.0的开发
- 基于jboss的ejb3开发入门总结
- 如何设置基于weblogic10的EJB3.0的JNDI
- weblogic10+eclipse 开发ejb3
- 将数据从MySQL迁移到Oracle的注意事项
- 将数据从MySQL迁移到Oracle的注意事项
- 将数据从MySQL迁移到Oracle的注意事项
- 将数据从MySQL迁移到Oracle的注意事项
- 在Jboss下将Itracker从Oracle数据库上移植到MySql数据库上的流程
- 项目从weblogic10.0.2迁移到weblogic10.3.6遇到的问题
- 【转】C#线程池用法
- 阿里云服务(一)——OSS
- 阿里云ECS linux下tomcat7.0+JDK1.6服务器简单搭建方法
- 几种控制器映射介绍
- tabbar 的选取图片设置问题
- 将JBoss下开发的EJB3.0数据库应用迁移到WebLogic10.3的注意事项
- TinyXML:一个优秀的C++ XML解析器
- 高级非递归线段树模板
- 记录:使用AFNetworking网络包遇到的问题【百度后得到答案】
- 操作分区表对global和local索引的影响
- 如何修改TOMCAT的默认主页为你自己项目的主页
- linux关闭nvidia独显的方法
- 2805: 验证数学猜想。
- Tomcat SSL配置大全