docker-compose部署springboot项目包含mysql,如何创建要连接的数据库和表
时间: 2023-12-13 09:05:44 浏览: 169
docker-compose 部署 mysql服务
要使用docker-compose部署包含MySQL的Spring Boot项目,您可以按照以下步骤创建要连接的数据库和表:
1. 创建一个docker-compose.yml文件,并在其中定义您的服务。以下是一个示例:
```yaml
version: '3'
services:
mysql:
image: mysql:latest
restart: always
environment:
MYSQL_ROOT_PASSWORD: your_root_password
MYSQL_DATABASE: your_database_name
MYSQL_USER: your_username
MYSQL_PASSWORD: your_password
volumes:
- ./mysql-data:/var/lib/mysql
app:
build: .
depends_on:
- mysql
ports:
- 8080:8080
environment:
SPRING_DATASOURCE_URL: jdbc:mysql://mysql:3306/your_database_name?useSSL=false
SPRING_DATASOURCE_USERNAME: your_username
SPRING_DATASOURCE_PASSWORD: your_password
```
在上面的示例中,我们定义了两个服务:mysql和app。mysql服务使用了mysql:latest镜像,并设置了环境变量来配置MySQL的根密码、数据库名称、用户名和密码。此外,我们还将MySQL的数据目录映射到了本地的mysql-data目录。
app服务是您的Spring Boot应用程序服务。它依赖于mysql服务,并将应用程序的端口映射到主机的8080端口。还设置了Spring Boot应用程序的数据源URL、用户名和密码,以便连接到MySQL容器。
2. 在与docker-compose.yml文件相同的目录中,创建一个Dockerfile文件来构建您的Spring Boot应用程序镜像。以下是一个示例:
```Dockerfile
FROM openjdk:8-jdk-alpine
COPY target/your-app.jar app.jar
ENTRYPOINT ["java","-jar","/app.jar"]
```
在上面的示例中,我们使用了openjdk:8-jdk-alpine作为基础镜像,并将应用程序的JAR文件复制到了容器内的app.jar路径。然后,我们使用ENTRYPOINT指令来指定容器启动时运行的命令。
3. 使用以下命令构建和启动容器:
```bash
docker-compose up --build
```
这将使用docker-compose.yml文件中定义的配置构建和启动容器。MySQL容器将创建并运行,并且您的Spring Boot应用程序将在app容器中构建和启动。
4. 一旦容器启动,您可以通过访问http://localhost:8080来访问您的Spring Boot应用程序。您可以使用应用程序中定义的API来创建数据库和表。
请注意,上述示例是一个起点,您可以根据您的具体需求进行修改和扩展。
阅读全文