[英]Wildfly Swarm error connecting Postgres datasource on Docker container
我正在嘗試使用Wildfly Swarm,Docker和PostgreSQL作為數據庫來構建簡單的rest服務。
該應用程序在localhost(沒有docker)上運行良好。
我在使用Docker基礎結構上的數據源連接數據庫時遇到問題
這是我的docker.compose.yml
:
version: '3'
services:
web:
build: .
depends_on:
- db
db:
build: ./db
ports:
- "5432:5432"
我的Web 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
是配置我的數據源的位置:
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
命令來運行圖像。
嘗試將-Djava.net.preferIPv4Stack=true
添加到Docker入口點,即
ENTRYPOINT ["java", "-jar", "/opt/megasindico-billing-api-swarm.jar", "-Djava.net.preferIPv4Stack=true"]
並且,請復制並粘貼錯誤文本,而不要張貼屏幕截圖。 屏幕快照顯示,將來沒有人可以找到類似的問題。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.