Docker學習(三)java應用docker部署

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

mike啥都想搞

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章