使用dockerfile部署springboot應用

2022-06-24 06:00:13

本章簡單展示如何最短時間 把springboot應用打包成映象並建立成容器。

  準備工作:

         1.安裝docker ,保證執行docker version沒有問題

         2.拉下來一個jdk映象 docker pull openjdk:8-jdk-alpine 

 

1.建立一個簡單的springboot專案

專案地址:https://github.com/honstat/sp-web.git

 

 

 

 

@RestController
public class HelloController {
    @RequestMapping("/ping")
    public String ping(){
        return "ok";
    }
}

 

App.class

@SpringBootApplication
public class App{
    public static void main(String[] args) {
        new SpringApplicationBuilder(App.class).run(args);
    }
}
View Code

 

application.yaml

server:
  port: 9098

spring:
  application:
    name: sp-web
View Code

 

直接啟動存取

curl 127.0.0.1:9098/ping 能返回ok

應用算是建立好了,接下來是打包

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>

    <groupId>org.example</groupId>
    <artifactId>sp-web</artifactId>
    <version>1.0</version>
    <packaging>jar</packaging>
    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>2.6.5</version>
<!--            <exclusions>-->
<!--                <exclusion>-->
<!--                    <groupId>org.springframework.boot</groupId>-->
<!--                    <artifactId>spring-boot-starter-tomcat</artifactId>-->
<!--                </exclusion>-->
<!--            </exclusions>-->
        </dependency>
    </dependencies>
    <build>
        <finalName>sp-web</finalName>
<!--        <plugins>-->
<!--            <plugin>-->
<!--                <artifactId>maven-war-plugin</artifactId>-->
<!--                <version>3.0.0</version>-->
<!--&lt;!&ndash;                <configuration>&ndash;&gt;-->
<!--&lt;!&ndash;                    &lt;!&ndash;如果想在沒有web.xml檔案的情況下構建WAR,請設定為false。&ndash;&gt;&ndash;&gt;-->
<!--&lt;!&ndash;                    <failOnMissingWebXml>false</failOnMissingWebXml>&ndash;&gt;-->
<!--&lt;!&ndash;                </configuration>&ndash;&gt;-->
<!--            </plugin>-->
<!--        </plugins>-->
        <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <version> 2.6.1</version>
            <executions>
                <execution>
                    <goals>
                        <goal>repackage</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
        </plugins>
    </build>
</project>
View Code

ps:註釋的部分 是打成war包的設定,目前是打jar包

2.打jar包

 

jar包啟動方式

java -jar sp-web.jar

 

 

 

 

 

 

 3.準備製作Dockerfile

   1.建立一個目錄,把jar包複製到dockers資料夾

     mkdir dockers

     cd dockers

   建立Dockerfile檔案

     touch Dockerfile

    拖到idea裡面開啟,開始編輯Dockerfile

    

 

FROM openjdk:8-jdk-alpine
ADD ./sp-web.jar /app.jar
ENTRYPOINT ["java","-jar","app.jar"]

 

解釋一下,

第1行 FROM指令是拉取基礎的映象支援,這個springboot服務依賴jdk,必填的,如果基礎映象本地沒有 docker images 列表找不到 就先docker pull xx 下來

第2行 ADD指令是把資料夾中的jar包 複製到映象根目錄下,到此映象打包指令結束了

第3行 ENTRYPOINT 是在參加容器時執行的,作用是啟動jar包,埠號在程式碼設定中指定了,這裡不需要指定

 

4.製作映象

在有Dockerfile檔案的目錄中執行命令

docker build 是生成映象

-t webapp1.0 其中webapp1.0是指定映象檔名稱 有需要可以改名

. 是在當前檔案中找Dockerfile檔案,如果不在這個目錄可以指定 -f /xx/Dockerfile

 

 

 

到此映象生成完了,執行docker images指令檢視

 

 

 

5.建立容器,執行web服務

先檢視一遍 docker ps 代表檢視正在執行的容器,目前暫無容器執行

 

 

 

docker run --name webapp -p 8080:9098 webapp1.0

 

 

 建立容器的時候 會執行Dockerfile檔案中的

ENTRYPOINT ["java","-jar","app.jar"]
所以web服務立即就跑起來了

呼叫web服務介面 curl 127.0.0.1:8080/ping

 

 

 

總結 

本文先提醒大家做了準備工作安裝docker 和拉下來基礎映象,為什麼拉這個映象,因為它小才100多M,而如果用tomcat做基礎映象,會變成接近600M 相當誇張。

然後建立簡單的springboot應用,如果想用現成的,可以把我寫的demo拉下來 git clone https://github.com/honstat/sp-web.git

接下來需要打包 生成.jar檔案 ,其中需要注意pom檔案的maven-plungin

Dockerfile 檔案編寫,注意大小寫 

生成映象 建立容器

驗證服務 curl 127.0.0.1:8080/ping

Dockerfile的好處就是一次編寫 到處執行,基本不受環境限制。

好了,分享就先到這裡~