Wildfly Swarm错误连接Docker容器上的Postgres数据源

时间:2017-07-18 21:03:37

标签: java jpa docker wildfly microservices

我正在尝试使用Wildfly Swarm,Docker和PostgreSQL构建一个简单的休息服务作为数据库。

该应用程序适用于localhost(没有docker)。

我在使用docker基础设施上的数据源连接数据库时遇到问题

这是我的docker.compose.yml

version: '3'

services:

  web:
    build: .
    depends_on:
      - db

  db:
    build: ./db
    ports:
      - "5432:5432"

我的网站Dockerfile

FROM fabric8/java-jboss-openjdk8-jdk:1.2.3

ENV AB_OFF true

ADD megasindico-billing-api-swarm.jar /opt/megasindico-billing-api-swarm.jar

EXPOSE 8080

ENTRYPOINT ["java", "-jar", "/opt/megasindico-billing-api-swarm.jar"]

PostgreSQL Dockerfile

FROM postgres:9.4-alpine

ENV POSTGRES_USER=admin
ENV POSTGRES_PASSWORD=admin

project-defaults.yml是配置我的DataSource的地方:

swarm:
  datasources:
    data-sources:
      ### [datasource]
      megasindico-billing-ds:
        driver-name: postgresql
        connection-url: jdbc:postgresql://db/postgres
        user-name: admin
        password: admin

以下是persistence.xml的样子:

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

    <persistence-unit name="megasindico-billing-ds" transaction-type="RESOURCE_LOCAL">

        <provider>org.hibernate.ejb.HibernatePersistence</provider>

        <properties>
            <property name="hibernate.hbm2ddl.auto" value="create-drop" />
            <property name="hibernate.show_sql" value="true" />
            <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect" />
            <property name="hibernate.hbm2ddl.import_files" value="scripts/reset.sql"/>
            <property name="hibernate.connection.useUnicode" value="true" />
            <property name="hibernate.connection.characterEncoding" value="UTF-8" />
        </properties>

    </persistence-unit>

</persistence>

该应用程序是使用mvn clean package命令构建的。

要构建图像,我使用build.sh文件:

#!/usr/bin/env bash

# Copy jar file to this directory
cp ../target/megasindico-billing-api-swarm.jar megasindico-billing-api-swarm.jar

# Build Docker image
docker-compose build

# Remove temp file
rm -rf megasindico-billing-api-swarm.jar

之后我执行docker-compose up命令来运行图像。

我得到的错误是这些: error part 1

error part 2

1 个答案:

答案 0 :(得分:2)

尝试将-Djava.net.preferIPv4Stack=true添加到Docker入口点,即

ENTRYPOINT ["java", "-jar", "/opt/megasindico-billing-api-swarm.jar", "-Djava.net.preferIPv4Stack=true"]

请复制并粘贴错误文本,而不是发布屏幕截图。没有人在将来搜索类似的问题就能找到它,因为它是一个屏幕截图。