使用docker部署springboot应用

来源:互联网 发布:用fidder抓包篡改数据 编辑:程序博客网 时间:2024/05/23 00:07

修改Springboot应用的application.properties文件,将mysql host改为mysql docker容器名(此处为mysql1跟docker-compose.yaml文件一致。)

spring.datasource.url=jdbc:mysql://mysql1:3306/SPPanBlog?characterEncoding=utf8&zeroDateTimeBehavior=convertToNullspring.datasource.username=rootspring.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.jarADD 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:/dockerdocker-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

原创粉丝点击