在payara micro war文件中包括与POSTGRES的数据库连接的正确方法

时间:2018-07-25 09:34:30

标签: java glassfish jndi payara

我使用以下文件设法部署和使用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>

1 个答案:

答案 0 :(得分:1)

回答您的问题:

  

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

差不多了。

它不必比您当前的设置复杂。我认为您已经看过官方的Payara-Examples存储库,但是,如果没有,那么那里有一个JPA示例,它完全按照您的问题进行配置:
https://github.com/payara/Payara-Examples/blob/master/Payara-Micro/jpa-datasource-example/ReadMe.md

作为配置Payara Micro的一般要点,您可以将其视为其他程序包中的Payara Server,因此,如果您仍然不确定某些事情并且想要以与传统服务器相同的方式进行操作那么你可以做。

--postbootcommandfile--postdeploycommandfile选项,可让您对Payara Micro运行asadmin命令并像Payara Server一样配置它。

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

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