我們之前寫的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 [email protected]
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啥都想搞
,一起交流學習