修改Springboot应用的application.properties文件,将mysql host改为mysql docker容器名(此处为mysql1跟docker-compose.yaml文件一致。)
spring.datasource.url=jdbc:mysql://mysql1:3306/SPPanBlog?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull
spring.datasource.username=root
spring.datasource.password=123456
在Springboot应用根目录下使用mvn package打包。
在d:/创建d:/docker目录,里面分别创建blog和mysql目录。
在d:/docker/mysql目录下创建my.cnf文件,内容如下:
[mysql]
default-character-set=utf8
[mysqld]
character-set-server=utf8
创建d:/docker/blog/Dockerfile文件,内容如下:
#基于哪个镜像
FROM java:8
# 将本地文件夹挂载到当前容器
VOLUME /tmp
# 拷贝文件到容器,也可以直接写成ADD microservice-discovery-eureka-0.0.1-SNAPSHOT.jar /app.jar
ADD SPPanBlog4SpringBoot-0.0.1-SNAPSHOT.jar /app.jar
#RUN bash -c 'touch /app.jar'
# 开放8080端口
EXPOSE 8080
# 配置容器启动后执行的命令
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
将应用jar包(此处为SPPanBlog4SpringBoot-0.0.1-SNAPSHOT.jar)拷贝到d:/docker/blog目录下。
创建d:/docker/docker-compose.yaml文件,内容如下:
mysql1:
image: mysql:5.7
volumes:
- d:/docker/mysql/my.cnf:/etc/mysql/my.cnf mysql
- d:/data/mysql:/var/lib/mysql
environment:
- MYSQL_ROOT_PASSWORD=123456
ports:
- "3306:3306"
expose:
- "3306"
blog:
build: ./blog
ports:
- "8080:8080" #端口映射
expose:
- 8080 #暴露容器端口
links:
- mysql1
进入cmd,执行下面命令
d:
cd d:/docker
docker-compose up
然后就等待image自动构建,启动后mysql应该能启动,但是应用应该无法启动,原因是未找到对应database。
通过navicat(或者其他数据库工具)连接localhost的mysql,账号root,密码:123456,然后创建SPPanBlog数据库。
执行docker ps,然后执行docker stop ,关闭对应mysql的容器。
再次执行docker-compose up,应该能执行应用。
然后通过navicat连接mysql,导入初始数据(import.sql)。
所有代码已经上传到码云上。https://gitee.com/39627020/sppanblog4springboot