【发布时间】:2019-04-23 17:34:18
【问题描述】:
我在让 mysql 容器运行我的初始化脚本时遇到问题。
我有两个文件 create.sql 和 insert.sql,用于初始化数据库。
我使用命令 docker-compose.yml 创建图像,它成功运行并创建图像。
我面临两个问题。
当我运行
docker-compose up命令时,mysql容器被创建并启动成功。但是,两个初始化脚本(create.sql和insert.sql)不在数据库上运行。我明确使用
docker run命令来运行创建的mysql容器。在这种情况下,初始化脚本成功运行。
我正在使用 Docker 版本 18.09.0 和 docker-compose 版本 1.23.1 和 ubuntu 16.04 LTS
我是 docker 新手,似乎无法找出问题所在。
以下是我用来创建图像的文件。
docker-compose.yml 文件。
version: '3'
services:
demo-mysql:
image: demo-mysql
build: ./demo-mysql
volumes:
- /mnt/data/mysql-data:/var/lib/mysql
ports:
- 3306:3306
environment:
- MYSQL_ROOT_PASSWORD=root
- MYSQL_DATABASE=demo
- MYSQL_PASSWORD=root
demo-api:
image: demo-api-1.0
build: ./api
depends_on:
- demo-mysql
ports:
- 8080:8080
environment:
- DATABASE_HOST=demo-mysql
- DATABASE_USER=root
- DATABASE_PASSWORD=root
- DATABASE_NAME=demo
- DATABASE_PORT=3306
demo1-app:
image: demo1-app-1.0
build: ./demo1
depends_on:
- demo-mysql
ports:
- 8090:8090
environment:
- DATABASE_HOST=demo-mysql
- DATABASE_USER=root
- DATABASE_PASSWORD=root
- DATABASE_NAME=demo
- DATABASE_PORT=3306
以下是spring boot项目的Dockerfile
FROM java:8
VOLUME /tmp
ARG DATA_PATH=/src/main/resources
ARG APP_PORT=8080
EXPOSE ${APP_PORT}
ADD /build/libs/demo-api.jar demo-api.jar
ENTRYPOINT ["java","-jar","demo-api.jar"]
以下是我用来创建我的mysql镜像的Dockerfile
FROM mysql:5.7
ENV MYSQL_DATABASE=demo \
MYSQL_USER=root \
MYSQL_ROOT_PASSWORD=root
ADD ./1.0/create.sql /docker-entrypoint-initdb.d
ADD ./1.0/insert.sql /docker-entrypoint-initdb.d
EXPOSE 3306
【问题讨论】:
标签: mysql spring-boot docker docker-compose