首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何添加PostgreSQL驱动程序( jar )到使用liberty-maven-plugin创建的open-liberty microprofile fat jar?

如何添加PostgreSQL驱动程序( jar )到使用liberty-maven-plugin创建的open-liberty microprofile fat jar?
EN

Stack Overflow用户
提问于 2019-12-17 14:28:14
回答 2查看 435关注 0票数 0

我正尝试在我的MicroProfile应用程序中使用PostgreSQL,但它无法加载驱动程序。我的server.xml包含以下内容:

代码语言:javascript
复制
<dataSource jndiName="jdbc/reports">
    <jdbcDriver libraryRef="PostgresLib" />
    <properties.postgresql serverName="localhost"
                           portNumber="5432"
                           databaseName="reports"
                           user="reports"
                           password="reports"/>
</dataSource>

<library id="PostgresLib">
    <fileset dir="${server.config.dir}/lib"
             includes="postgresql-42.2.9.jar"/>
</library>

我试图通过maven- folder plugin复制jar文件,但目标/liberty文件夹中没有jar文件。我猜liberty-maven-plugin以前清除过文件夹。我还在我的pom.xml中添加了以下依赖项:

代码语言:javascript
复制
<dependency>
    <groupId>org.postgresql</groupId>
    <artifactId>postgresql</artifactId>
    <version>42.2.9</version>
</dependency>

我遗漏了什么?

EN

回答 2

Stack Overflow用户

发布于 2019-12-19 02:00:57

如果PostgreSQL jar位于${server.config.dir}/lib/postgresql-42.2.9.jar,则示例配置将是正确的

但是,听起来您好像是在说PostgreSQL jar实际上打包在您的应用程序中。目前,为打包在应用程序中JDBC驱动程序定义数据源的唯一方法是配置应用程序定义的数据源( web或ejb组件上的@DataSourceDefinition或部署描述符中的<data-source> ),而不是在服务器配置中(示例中的dataSourcelibrary元素)。

例如,您可以在Servlet上配置如下内容,

代码语言:javascript
复制
@DataSourceDefinition(name = "java:app/env/jdbc/reports",
                      className = "org.postgresql.xa.PGXADataSource",
                      databaseName = "reports",
                      serverName="localhost",
                      portNumber=5432,
                      user = "reports",
                      password = "reports")
public class MyServlet extends HttpServlet {
    @Resource(lookup = "java:app/env/jdbc/reports")
    DataSource reportsDataSource;
    ...
票数 2
EN

Stack Overflow用户

发布于 2019-12-17 15:11:18

这个看起来很好。您所要做的就是在pom.xml中添加Postgres-Maven依赖项,并使用maven构建应用程序。这将告诉Maven下载Postgres库并将其添加到类路径中(不需要手动下载和复制库)。

如果您想构建一个可工作的jar文件,则应该使用maven package目标。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59368683

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档