首页 > 解决方案 > 在payara微战争文件中包含与POSTGRES的数据库连接的正确方法

问题描述

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

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

在 JEE 容器中部署数据库连接的最佳实践方式是什么。

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

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>

标签: javaglassfishjndipayara

解决方案


要回答您的问题:

在 JEE 容器中部署数据库连接的最佳实践方式是什么?

这差不多。

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

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

有一些选项可以让您对 Payara Micro 运行命令--postbootcommandfile并像 Payara Server 一样对其进行配置。--postdeploycommandfileasadmin

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

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


推荐阅读