【发布时间】:2020-02-11 02:53:06
【问题描述】:
我正在尝试在 docker-compose.yml 中连接 MongoDb 和 Spring Boot。
就是这样——
version: "3.7"
services:
app-server:
container_name: spring
build: .
ports:
- "8080:8080"
restart: always
depends_on:
- db
db:
container_name: mongo
image: mongo
ports:
- "27017:27017"
restart: always
volumes:
- ./datadir:/var/lib/mongo
我的 Spring Dockerfile
FROM openjdk:8-jdk-alpine
VOLUME /tmp
ARG JAR_FILE
COPY ${JAR_FILE} app.jar
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
用于构建 JAR_FILE 的 POM.xml 插件 -
<plugin>
<groupId>com.spotify</groupId>
<artifactId>dockerfile-maven-plugin</artifactId>
<version>1.3.6</version>
<executions>
<execution>
<id>build-image</id>
<phase>package</phase>
<goals>
<goal>build</goal>
</goals>
</execution>
</executions>
<configuration>
<repository>maximko/${project.artifactId}</repository>
<buildArgs>
<JAR_FILE>target/${project.build.finalName}.jar</JAR_FILE>
</buildArgs>
</configuration>
</plugin>
application.properties 文件
spring.data.mongodb.host=db
spring.data.mongodb.port=27017
spring.data.mongodb.database=HotelDB
我的问题
当我运行“maven 包”来构建我的 jar 时,我收到以下错误。我的 JAR 文件没有创建
com.mongodb.MongoSocketException: db
at com.mongodb.ServerAddress.getSocketAddress(ServerAddress.java:188) ~[mongodb-driver-core-3.8.2.jar:na]
at com.mongodb.internal.connection.SocketStreamHelper.initialize(SocketStreamHelper.java:64) ~[mongodb-driver-core-3.8.2.jar:na]
at com.mongodb.internal.connection.SocketStream.open(SocketStream.java:62) ~[mongodb-driver-core-3.8.2.jar:na]
at com.mongodb.internal.connection.InternalStreamConnection.open(InternalStreamConnection.java:126) ~[mongodb-driver-core-3.8.2.jar:na]
at com.mongodb.internal.connection.DefaultServerMonitor$ServerMonitorRunnable.run(DefaultServerMonitor.java:117) ~[mongodb-driver-core-3.8.2.jar:na]
at java.lang.Thread.run(Thread.java:748) [na:1.8.0_181]
Caused by: java.net.UnknownHostException: db
at java.net.Inet6AddressImpl.lookupAllHostAddr(Native Method) ~[na:1.8.0_181]
at java.net.InetAddress$2.lookupAllHostAddr(InetAddress.java:928) ~[na:1.8.0_181]
at java.net.InetAddress.getAddressesFromNameService(InetAddress.java:1323) ~[na:1.8.0_181]
at java.net.InetAddress.getAllByName0(InetAddress.java:1276) ~[na:1.8.0_181]
at java.net.InetAddress.getAllByName(InetAddress.java:1192) ~[na:1.8.0_181]
at java.net.InetAddress.getAllByName(InetAddress.java:1126) ~[na:1.8.0_181]
at java.net.InetAddress.getByName(InetAddress.java:1076) ~[na:1.8.0_181]
at com.mongodb.ServerAddress.getSocketAddress(ServerAddress.java:186) ~[mongodb-driver-core-3.8.2.jar:na]
... 5 common frames omitted
当我运行 docker-compose.yml 时出现以下错误 -
spring | com.mongodb.MongoSocketOpenException: Exception opening socket
spring | at com.mongodb.internal.connection.SocketStream.open(SocketStream.java:67) ~[mongodb-driver-core-3.8.2.jar!/:na]
spring | at com.mongodb.internal.connection.InternalStreamConnection.open(InternalStreamConnection.java:126) ~[mongodb-driver-core-3.8.2.jar!/:na]
spring | at com.mongodb.internal.connection.DefaultServerMonitor$ServerMonitorRunnable.run(DefaultServerMonitor.java:117) ~[mongodb-driver-core-3.8.2.jar!/:na]
spring | at java.lang.Thread.run(Thread.java:748) [na:1.8.0_212]
spring | Caused by: java.net.ConnectException: Connection refused (Connection refused)
spring | at java.net.PlainSocketImpl.socketConnect(Native Method) ~[na:1.8.0_212]
spring | at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) ~[na:1.8.0_212]
spring | at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) ~[na:1.8.0_212]
spring | at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) ~[na:1.8.0_212]
spring | at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) ~[na:1.8.0_212]
spring | at java.net.Socket.connect(Socket.java:589) ~[na:1.8.0_212]
我的问题
1) 所有这些问题都是来自“application.properties”文件,还是我在 docker-compose 文件中配置错误?
2) 我可以更改 mongoDB 的主机名吗?
3) 在运行“docker-compose.yml”之前,是否需要运行“mvn package”来构建我的 App.jar 文件?
感谢您的帮助!
【问题讨论】:
-
你如何运行你的容器?你什么时候开始构建你的应用程序?
-
@LinPy 我使用命令“docker-compose up”运行我的容器。我在 docker compose 之前构建了我的应用程序,但总是捕获此异常 Caused by: java.net.UnknownHostException: db.
-
那么,你在作曲之前是怎么做的? db 容器不在那里吗?
-
@LinPy 看起来是的。
-
请尝试以下操作:
docker-compose stop && docker-compose up db && sleep 30 && docker-compose up app-server
标签: java spring mongodb spring-boot docker