gpt4 book ai didi

mysql - Spring Boot MySQL Docker Caused by : java.net.ConnectException: Connection refused(连接被拒绝)

转载 作者:行者123 更新时间:2023-11-30 21:27:53 38 4
gpt4 key购买 nike

如标题所示:

Caused by: java.net.ConnectException: Connection refused (Connection refused)

这在前一段时间对我有用,但不幸的是现在不行了。我执行的脚本包含:

mvn clean install -> docker-compose build -> docker-compose up

docker 文件:

FROM openjdk:8
ADD target/grades.jar grades.jar
EXPOSE 8080
ENTRYPOINT ["java", "-jar", "grades.jar"]

docker-compose.yaml

version: '3'

services:
mysql-standalone:
image: mysql:latest
environment:
- MYSQL_ROOT_PASSWORD=password
- MYSQL_DATABASE=grades
- MYSQL_USER=root
- MYSQL_PASSWORD=password
ports:
- "33061:3306"
volumes:
- /data/mysql
grades:
image: grades
build:
context: ./
dockerfile: Dockerfile
depends_on:
- mysql-standalone
ports:
- 8080:8080
volumes:
- /data/grades

和application.properties:

spring.datasource.url=jdbc:mysql://${MYSQL_HOST:localhost}:${MYSQL_PORT:3306}/${MYSQL_DB:aws_eb_db}
spring.datasource.username=${MYSQL_USERNAME:root}
spring.datasource.password=${MYSQL_PASSWORD:password}
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect

最佳答案

localhost 对你的 Docker 容器来说不是主机的 localhost(你的 Docker 容器所在的那个)。基本上它指向您的 Docker 容器本身,而 MySQL 不在其中。因此,当您将 MySQL 的 3306 端口映射到主机的 3306 端口时,您必须指向您的 MySQL 实例或容器的主机。

我肯定会像@LinPy 建议的那样指向 MySQL 本身:

spring.datasource.url=jdbc:mysql://mysql-standalone:3306/grades

关于mysql - Spring Boot MySQL Docker Caused by : java.net.ConnectException: Connection refused(连接被拒绝),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57989392/

38 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com