Docker撰写。网络。 Spring Boot和MySQL连接

时间:2017-05-16 11:35:43

标签: mysql spring docker docker-compose

我尝试将spring boot web app连接到数据库容器。 我可以从网络ping数据库容器。但是web无法通过暴露的3307端口连接到db。但是我可以通过内部容器端口3306连接到db。项目非常简单。什么是错的?

这是我的 docker-compose.yml

    version: '3'
services:
  db:
    build:
      context: ./db
      dockerfile: Dockerfile
    image: db
    ports:
      - "3307:3306"
    volumes:
      - demo_volume:/var/lib/mysql
    networks:
      - my-backend

  web:
    build:
      context: ./web
      dockerfile: Dockerfile
    image: web
    depends_on:
      - db
    ports:
      - "18080:8080"
    networks:
      - my-backend
    environment:
      - DATABASE_HOST=db
      - DATABASE_USER=user
      - DATABASE_PASSWORD=password
      - DATABASE_NAME=demo
      - DATABASE_PORT=3307
      - SPRING_PROFILES_ACTIVE=container
      - DEBUG=true

volumes:
  demo_volume:
    driver: local

networks:
  my-backend:
    driver: bridge

这很简单。

我的 application.yml 表示有效个人资料 - 容器

spring:
  profiles:
    container
  datasource:
    url: jdbc:mysql://${DATABASE_HOST}:${DATABASE_PORT}/${DATABASE_NAME}?characterEncoding=UTF-8
    username: ${DATABASE_USER}
    password: ${DATABASE_PASSWORD}
    driver-class-name: com.mysql.jdbc.Driver
  jpa:
    database-platform: org.hibernate.dialect.MySQLDialect

也很简单

db Dockerfile

FROM mysql:5.7

ENV MYSQL_ROOT_PASSWORD=admin
ENV MYSQL_DATABASE=demo
ENV MYSQL_USER=user
ENV MYSQL_PASSWORD=password

ADD dump.sql /docker-entrypoint-initdb.d/

web Dockerfile

FROM java:8-jre
COPY ./web.jar /app/web.jar
CMD ["java", "-jar", "/app/web.jar"]
CMD ["java", "-Xmx200m", "-Djava.security.egd=file:/dev/./urandom", "-jar", "/app/web.jar"]

2 个答案:

答案 0 :(得分:1)

关于Docker文档,同一桥接网络(用户定义)中的所有容器都通过其内部端口进行通信。用图像isolated_bridge_network

解释

如果您希望您的容器应该可以从外部网络获得,那么您应该发布端口。发布 - 表示您应将内部端口映射到外部环境。见图像 published_ports_from_isolated_bridge_network

答案 1 :(得分:-1)

您应该链接Container以使其正常工作。

web:
build:
  context: ./web
  dockerfile: Dockerfile
image: web
depends_on:
  - db
ports:
  - "18080:8080"
networks:
  - my-backend
environment:
  - DATABASE_HOST=db
  - DATABASE_USER=user
  - DATABASE_PASSWORD=password
  - DATABASE_NAME=demo
  - DATABASE_PORT=3307
  - SPRING_PROFILES_ACTIVE=container
  - DEBUG=true
links:
  - db

现在你的web容器/ etc / hosts里面应该有一个db Container

的条目