使用dockerfile部署springboot應用

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

  準備工作:

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

         2.拉下來一個jdk鏡像 docker pull openjdk:8-jdk-alpine 

 

1.創建一個簡單的springboot項目

項目地址://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="//maven.apache.org/POM/4.0.0"
         xmlns:xsi="//www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="//maven.apache.org/POM/4.0.0 //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 //github.com/honstat/sp-web.git

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

Dockerfile 文件編寫,注意大小寫 

生成鏡像 創建容器

驗證服務 curl 127.0.0.1:8080/ping

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

好了,分享就先到這裡~