java - 在 payara micro war 文件中包含到 POSTGRES 的数据库连接的正确方法

标签 java glassfish jndi payara

我设法使用以下文件部署和使用 JPA 连接。 目前这可行,但并不理想。

连接应使用 postgres 池驱动程序和 JNDI 数据源,而不是 web.xml 中的数据源。

What is the best practice way of deploying a database connection in a JEE container.

这是我当前的设置,使用不使用池驱动程序的全局连接。

persistence.xml

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<persistence xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             version="2.1"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">

    <persistence-unit name="pcc" transaction-type="JTA">
        <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
        <jta-data-source>java:global/pccData</jta-data-source>
        <exclude-unlisted-classes>false</exclude-unlisted-classes>
        <properties>
            <property name="eclipselink.deploy-on-startup" value="true"/>
            <property name="eclipselink.logging.level" value="INFO"/>
            <property name="eclipselink.logging.level.sql" value="CONFIG"/>
            <property name="eclipselink.jdbc.fetch-size" value="1000"/>
            <property name="eclipselink.jdbc.cache-statements" value="true"/>
            <property name="eclipselink.persistence-context.flush-mode" value="commit"/>
            <property name="eclipselink.ddl-generation.output-mode" value="database"/>
        </properties>
    </persistence-unit>

</persistence>

web.xml
我确信 PGSimpleDataSource 不是推荐的方法

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1">
  <display-name>PCC Web Application</display-name>
  <data-source>
    <name>java:global/pccData</name>
    <class-name>org.postgresql.ds.PGSimpleDataSource</class-name>
    <server-name>localhost</server-name>
    <port-number>5432</port-number>
    <database-name>pcc</database-name>
    <user>postgres</user>
    <password>postgres</password>
    <property>
      <name>fish.payara.slow-query-threshold-in-seconds</name>
      <value>5</value>
    </property>
  </data-source>
</web-app>

最佳答案

回答您的问题:

What is the best practice way of deploying a database connection in a JEE container?

差不多就是这样了。

它不需要比您当前的设置更复杂。我假设您已经看过官方 Payara-Examples 存储库,但如果没有,那里有一个 JPA 示例,其配置与您的问题中的配置完全相同:
https://github.com/payara/Payara-Examples/blob/master/Payara-Micro/jpa-datasource-example/ReadMe.md

作为配置 Payara Micro 的一般要点,您可以将其视为不同包中的 Payara 服务器,因此,如果您仍然不确定某些事情并希望以与更传统的服务器相同的方式执行操作那么你就可以做到。

--postbootcommandfile--postdeploycommandfile 选项,允许您针对 Payara Micro 运行 asadmin 命令并像配置它一样Payara服务器。

对于您的连接池示例,如果您确实想在服务器中定义它(实际上,像您已经完成的那样在 web.xml 中定义它更便携,并且将是我的首选选项),那么您可以启动一个普通 Payara 服务器,单击按钮在管理控制台中启用 asadmin 命令记录,然后使用 GUI 进行更改。然后,必要的命令将转储到一个文件中,供您稍后应用于 Payara Micro。

Payara Micro 还会转储一个临时目录(可通过 --rootDir 控制,默认情况下与 java.io.tmpdir 具有相同的值),以便您始终可以看到通过检查该目录结构中的domain.xml,配置更改如何影响它。这为您提供了某种形式的手动验证。

关于java - 在 payara micro war 文件中包含到 POSTGRES 的数据库连接的正确方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51515570/

相关文章:

tomcat - 如何配置 Maven 配置文件以在 tomcat 或来自 netbeans 6.9.1 的 glassfish 上运行 webapps

Jetty 中的 javax.naming.NameNotFoundException 但 Tomcat 中没有。怎么解决?

java - Tomcat 更新 context.xml 但不应该

java - 序列化抽象类的问题

java - 如何通过 Groovy 获取文件 build.gradle 的完整路径?

java - STS(Spring Tool Suite) 未打开

java - "javax.naming.NoInitialContextException"是什么意思?

java - 如何从另一个类的 void 方法获取结果

java - OpenMQ 和 JMX - 是否可以查询消息?

java - Glassfish 4.1.1 - 使用我自己的证书的 DAS 抛出 "j_security_check"错误