在 PROD 和 TEST 中的数据库的 JNDI 名称之间切换
Switch between JNDI names for databases in PROD and TEST
我正在开发 Maven EJB 模块。
我的 EJB 都使用这样的持久性上下文:
@PersistenceContext(unitName = "dk.mycontext")
private EntityManager em;
效果很好。问题是当我想从测试更改为在我的应用程序服务器上实际部署时。
我正在使用 JUnit 进行测试,运行 所有测试都在 Payara Embedded 上进行。嵌入式 Payara 使用此格式进行 JNDI 查找(在我的 persistence.xml 文件中):
<jta-data-source>java:app/jdbc/druid</jta-data-source>
测试时发现数据源
当我将编译后的模块部署到我成熟的 Payara 服务器时,它抱怨找不到数据源:
javax.naming.NameNotFoundException: No object bound to name java:app/jdbc/druid
因为它期望 JNDI 是这样的:
jdbc/druid
这是我直接在服务器上定义 JNDI 名称的格式。问题是 - 据我所知 - payara 服务器不会接受
的命名约定
java:app/jdbc/druid
至少管理界面不会验证它。
我该如何控制这种疯狂的行为?我不是第一个遇到这个问题的人,但我一直无法找到解决这个问题的可行方法。
我可以使用 Maven 控制命名吗?
使用 maven 配置文件:
persistence.xml
...
<jta-data-source>${datasource}</jta-data-source>
...
pom.xml
<properties>
<datasource>java:app/jdbc/druid</datasource>
</properties>
<profiles>
<profile>
<id>release</id>
<properties>
<datasource>jdbc/druid</datasource>
</properties>
</profile>
</profiles>
我正在开发 Maven EJB 模块。
我的 EJB 都使用这样的持久性上下文:
@PersistenceContext(unitName = "dk.mycontext")
private EntityManager em;
效果很好。问题是当我想从测试更改为在我的应用程序服务器上实际部署时。
我正在使用 JUnit 进行测试,运行 所有测试都在 Payara Embedded 上进行。嵌入式 Payara 使用此格式进行 JNDI 查找(在我的 persistence.xml 文件中):
<jta-data-source>java:app/jdbc/druid</jta-data-source>
测试时发现数据源
当我将编译后的模块部署到我成熟的 Payara 服务器时,它抱怨找不到数据源:
javax.naming.NameNotFoundException: No object bound to name java:app/jdbc/druid
因为它期望 JNDI 是这样的:
jdbc/druid
这是我直接在服务器上定义 JNDI 名称的格式。问题是 - 据我所知 - payara 服务器不会接受
的命名约定java:app/jdbc/druid
至少管理界面不会验证它。
我该如何控制这种疯狂的行为?我不是第一个遇到这个问题的人,但我一直无法找到解决这个问题的可行方法。
我可以使用 Maven 控制命名吗?
使用 maven 配置文件:
persistence.xml
...
<jta-data-source>${datasource}</jta-data-source>
...
pom.xml
<properties>
<datasource>java:app/jdbc/druid</datasource>
</properties>
<profiles>
<profile>
<id>release</id>
<properties>
<datasource>jdbc/druid</datasource>
</properties>
</profile>
</profiles>