Spring Boot MySQL Docker 引起:java.net.ConnectException:连接被拒绝(连接被拒绝)

Posted

技术标签:

【中文标题】Spring Boot MySQL Docker 引起:java.net.ConnectException:连接被拒绝(连接被拒绝)【英文标题】:Spring Boot MySQL Docker Caused by: java.net.ConnectException: Connection refused (Connection refused) 【发布时间】:2020-01-19 05:05:07 【问题描述】:

如题:

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

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

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

Dockerfile:

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

【问题讨论】:

试试这个:spring.datasource.url=jdbc:mysql://mysql-standalone:3306/grades localhost 将不起作用,因为它引用了等级容器本身 为什么会这样? 您需要使用 compose 中定义的服务名称进行连接 【参考方案1】:

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

我肯定会按照@LinPy 的建议指出 MySQL 本身:

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

【讨论】:

【参考方案2】:

这应该对某人有所帮助。

确保运行以下命令使当前图像无效:

docker rmi -f <your image id>

version: '3.1'

services:

  db:
    image: mariadb:10.5.5
    restart: always
    environment:
      - MYSQL_ROOT_PASSWORD=root
      - MYSQL_DATABASE=softeasydb
      - MYSQL_USER=root
      - MYSQL_PASSWORD=root
    volumes:
      - ./db:/var/lib/mysql
    ports:
      - 3306:3306
    networks:
      - common-network   

  adminer:
    image: adminer
    restart: always
    ports:
      - 8080:8080
    networks:
      - common-network
      
  api-users:
    build: .
    depends_on: 
      - db
    ports:
      - 9090:9090   
    environment:
      - SPRING_PROFILES_ACTIVE=docker
      - DATABASE_HOST=db
      - DATABASE_USER=root
      - DATABASE_PASSWORD=root
      - DATABASE_NAME=softeasydb
      - DATABASE_PORT=3306
      - SERVER_PORT=9090
    restart: always
    networks:
      - common-network

networks:
  common-network:
      driver: bridge

【讨论】:

【参考方案3】:

在您的 docker-compose.yaml 中,您在 mysql-standalone 容器的端口映射中有错字,您需要更改以下内容:

ports:
- "33061:3306"

ports:
- "3306:3306"

【讨论】:

以上是关于Spring Boot MySQL Docker 引起:java.net.ConnectException:连接被拒绝(连接被拒绝)的主要内容,如果未能解决你的问题,请参考以下文章

(转)Spring Boot 2 :Docker Compose + Spring Boot + Nginx + Mysql 实践

Spring Boot + MySQL docker 容器

Spring Boot 2.0:Docker Compose + Spring Boot + Nginx + Mysql 实践

使用spring boot mysql docker时docker撰写问题

Spring Boot 无法连接 MySQL 并在 Docker/Docker compose 中退出

Docker:无法连接 Spring Boot 和 MYSQL