Docker容器化spring boot應(yīng)用詳解
前置條件
容器化spring boot應(yīng)用所需環(huán)境:
- jdk 1.8 +
- maven 3.0 +
我們的需求是:使用maven打包,將spring boot應(yīng)用制作成docker鏡像并上傳到docker hub。在其他機(jī)器上,可以直接docker pull并運(yùn)行容器。
創(chuàng)建spring boot應(yīng)用
spring boot 包結(jié)構(gòu)為:
└── src
└── main
└── java
└── me
└── ithakar
創(chuàng)建spring boot Application主類,src/main/java/me/ithakar/Application.java
package me.ithakar;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@SpringBootApplication
@RestController
public class Application {
@RequestMapping("/")
public String home() {
return "docker app running";
}
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
pom.xml:
<?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>me.ithakar</groupId>
<artifactId>docker-app</artifactId>
<version>0.1.0</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.3.RELEASE</version>
</parent>
<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>
打包并啟動應(yīng)用
mvn package && java -jar target/docker-app-0.1.0.jar
訪問 http://localhost:8080/ ,獲得響應(yīng):
docker app running
則spring boot應(yīng)用啟動成功
創(chuàng)建Dockerfile文件
Dockerfile是一個文本文件,類似shell腳本,其內(nèi)包含了一條條的指令。每一條指令的內(nèi)容,就是描述對應(yīng)的鏡像層應(yīng)當(dāng)如何構(gòu)建。
Dockerfile位置:src/main/docker/Dockerfile
FROM frolvlad/alpine-oraclejdk8:slim VOLUME /tmp ADD docker-app-0.1.0.jar app.jar RUN sh -c 'touch /app.jar' ENV JAVA_OPTS="" ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /app.jar" ]
- FROM 命令指定基礎(chǔ)鏡像,以一個鏡像為基礎(chǔ),在其上進(jìn)行定制。在這里我們的基礎(chǔ)鏡像是frolvlad/alpine-oraclejdk8:slim。
- VOLUME 定義匿名卷。對于可能需要操作數(shù)據(jù)庫類需要保存動態(tài)數(shù)據(jù)的應(yīng)用,其數(shù)據(jù)文件應(yīng)該保存在主句的卷,而不是容器的儲存層。在這里我們是將其掛載在了/tmp這個位置,從而保證了容器的無狀態(tài)化。
- ADD 命令是較高級的復(fù)制命令,將jar包復(fù)制到/app.jar
- ENTRYPOINT 容器運(yùn)行后默認(rèn)執(zhí)行的命令
添加maven docker插件
docker maven插件是為了方便java開發(fā)者,由spotify公司開發(fā)的一款maven插件。添加以下代碼至pom.xml文件中。
<properties>
<docker.image.prefix>ithaka</docker.image.prefix>
</properties>
<build>
<plugins>
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>0.4.11</version>
<configuration>
<imageName>${docker.image.prefix}/${project.artifactId}:${project.version}</imageName>
<dockerDirectory>src/main/docker</dockerDirectory>
<pushImage>true</pushImage>
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
</plugins>
</build>
注意,docker.image.prefix中的ithaka為我的docker hub 賬戶,使用時將其換成自己的
使用maven命令打包應(yīng)用、構(gòu)建docker鏡像并上傳鏡像到docker hub:
mvn package docker:build -DpushImage
此時我們將得到一個報錯:
[ERROR] Failed to execute goal com.spotify:docker-maven-plugin:0.4.11:build (default-cli) on project docker-app: Exception caught: denied: requested access to the resource is denied
這是因為我們在maven中push時,并沒有包含docker的用戶信息,所以權(quán)限校驗失敗。
解決方法為,在maven全局setting.xml配置中,添加docker hub server信息
<server>
<id>docker-hub</id>
<username>ithaka</username>
<password>密碼</password>
<configuration>
<email>郵箱</email>
</configuration>
</server>
在pom.xml中的docker-maven-plugi插件中,指定server
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<configuration>
<serverId>docker-hub</serverId>
</configuration>
</plugin>
再繼續(xù)執(zhí)行
mvn package docker:build -DpushImage
出現(xiàn)
The push refers to a repository [docker.io/ithaka/docker-app]
8c02854cd300: Pushed
a03c3b5dbe04: Pushed
8018d52798bb: Pushed
1e6468b956ae: Pushed
3fb66f713c9f: Pushed0.0.1: digest: sha256:63456345745755577c19103dcf4838894e34d45a68a1ec23b2f69d6f059 size: 1375
即為上傳docker hub成功。
啟動docker容器
在另外一臺機(jī)器上,執(zhí)行命令
docker run -p 8080:8080 -t ithaka/docker-app
訪問http://ip:8080/ ,獲得響應(yīng):
docker app running
docker應(yīng)用啟動成功
參考文檔:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 使用Docker部署Spring Boot的應(yīng)用示例
- 使用Docker部署 spring-boot maven應(yīng)用的方法
- Docker部署SpringBoot應(yīng)用的實現(xiàn)步驟
- 詳解在Docker容器中運(yùn)行Spring Boot應(yīng)用
- Spring Boot應(yīng)用發(fā)布到Docker的實現(xiàn)
- 詳解如何將Spring Boot應(yīng)用跑在Docker容器中
- 將spring boot應(yīng)用打入docker中運(yùn)行的實現(xiàn)方法
- Spring Boot應(yīng)用Docker化的步驟詳解
- Docker化Spring Boot應(yīng)用的實踐
相關(guān)文章
啟動docker錯誤systemctl status docker.service問題及解決
文章討論了啟動Docker和執(zhí)行docker ps命令失敗的問題,但docker -v顯示成功,解決辦法包括在阿里云容器鏡像中找到鏡像加速器或使用公共鏡像地址,默認(rèn)情況下,Docker使用官方地址2025-01-01
k3d入門指南之在Docker中運(yùn)行K3s的詳細(xì)教程
在本文中,我們將簡單了解k3d,這是一款可讓您在安裝了Docker的任何地方運(yùn)行一次性Kubernetes集群的工具,此外在本文中我們還將探討在使用k3d中可能會出現(xiàn)的一切問題,感興趣的朋友跟隨小編一起看看吧2021-05-05
maven構(gòu)建docker鏡像push到鏡像倉庫方式
這篇文章主要介紹了maven構(gòu)建docker鏡像push到鏡像倉庫方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11
樹莓派4b ubuntu19 server 安裝docker-ce的安裝步驟
這篇文章主要介紹了樹莓派4b ubuntu19 server 安裝docker-ce的安裝步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
修改Docker鏡像默認(rèn)存儲位置的方法(解決方法)
這篇文章主要介紹了修改Docker鏡像默認(rèn)存儲位置的方法,如果上面運(yùn)行 Docker 服務(wù),經(jīng)過長時間的使用,會使原本就比較大的分區(qū)越來越不夠用。如何更好地的處理這個問題呢,本文給出解決方案,需要的朋友一起看看吧2021-04-04
Docker安裝部署分布式數(shù)據(jù)庫?OceanBase的詳細(xì)過程
這篇文章主要介紹了Docker安裝部署分布式數(shù)據(jù)庫?OceanBase,快速的體驗 OceanBase 的自動化部署過程,及了解 OceanBase 集群安裝成功后的目錄特點(diǎn)和使用方法,需要的朋友可以參考下2022-06-06

