我们之前写的java微服务部署服务器都比较麻烦,需要先在服务器装好java,配置好环境变量,然后上传war,jar包到服务器部署。尤其是之前没有使用springboot的时候还要安装tomact,今天就来说说使用docker部署。
准备java服务
pom文件:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.6.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.mike</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
启动类:
package com.mike.demo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}
编写一个简单的api接口:
package com.mike.demo;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/api")
public class Hello {
@GetMapping("/say/{word}")
public String say(@PathVariable("word") String word) {
return String.format("heelo,%s", word);
}
}
编写dockerfile
Dockerfile:
FROM java:8
MAINTAINER mike 342746156@qq.com
COPY target/demo-0.0.1-SNAPSHOT.jar hello.jar
ENTRYPOINT ["java","-jar","/hello.jar"]
EXPOSE 8080
Dockerfile 指定了构建docker镜像的步骤。
FROM:第一层我们需要一个jdk,我们申明使用 java:8, docker引擎会帮我们自动从公共仓库下载,并当道我们的运行容器环境中。
MAINTAINER: 申明了作者,可以不写
COPY:把maven打包好的jar添加到容器中并重命名为 hello.jar
ENTRYPOINT: 要执行的命令以及参数。 使用java -jar 启动我们的应用
EXPOSE:暴漏容器中的8080端口。这样我们就可以映射宿主机的端口到8080端口,从而访问容器中的应用了
开始制作镜像
我们首先要在工程目录使用mvn install 生成应用的jar包,在target目录下会有生成的jar包。本地maven仓库中也有我们的jar包。
现在开始制作镜像。在Dockerfile所在目录执行docker命令:
docker build -t mike-hello .
注意 . 表示当前目录,不可少。这样我们的镜像就制作成功了。运行docker 命令:
docker images
就可以看到我们构建好的镜像,但是我们的应用还没有启动起来。接下来就用这个镜像启动一个容器运行我们的应用
启动镜像
运行docker命令:
docker run -d -p 127.0.0.1:8080:8080 mike-hello
-d声明后台守护进程的方式运行, -p声明宿主机和容器内部的端口映射,将宿主机本地的8080端口映射到容器内部8080端口,在制作镜像的时候我们就将8080端口暴漏出来了。现在运行docker命令:
docker ps
就可以看到当前启动的容器,就会看到我们的应用了。现在测试一下,在宿主机上访问:http://localhost:8080/api/say/docker
看到返回消息: heelo,docker。测试成功
现在我们进入容器内部看看:
docker exec -ti 我们的容器id bash
这样就可以查看容器中的目录,使用curl命令测试下容器内部我们的应用
curl http://localhost:8080/api/say/docker
一样可以看到我们的消息正常返回,现在如果你想在部署一个,那么就很简单了:
docker run -d -p 127.0.0.1:8081:8080 mike-hello
docker run -d -p 127.0.0.1:8082:8080 mike-hello
docker run -d -p 127.0.0.1:8083:8080 mike-hello
总结
docker简化了我们的应用部署,只要制作好了镜像,你想部署多少,都是一个命令就搞定,不用去在重复配置一次应用环境。而且借助私有仓库,你可以直接在其他多个服务器也依靠一条命令居马上启动一个应用。现在我们已经简单掌握了如何去使用docker,但是构建部署还是要自己去输命令搞,还是有点麻烦,我们只想写完自己的代码上传代码到仓库,剩下的就一键搞定。那么下节课就来使用jenkins来实现CICD,彻底解放你。
欢迎关注我的公中号:mike啥都想搞
,一起交流学习
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。