溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用Docker部署Spring Boot項目

發(fā)布時間:2021-06-29 14:15:22 來源:億速云 閱讀:155 作者:chen 欄目:云計算

本篇內容介紹了“怎么用Docker部署Spring Boot項目”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

Docker 技術發(fā)展為微服務落地提供了更加便利的環(huán)境,使用 Docker 部署 Spring Boot 其實非常簡單,這篇文章我們就來簡單學習下。

首先構建一個簡單的 Spring Boot 項目,然后給項目添加 Docker 支持,最后對項目進行部署。

一個簡單 Spring Boot 項目

pom.xml 中 ,使用 Spring Boot 2.0 相關依賴

<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.0.RELEASE</version>
</parent>

添加 web 和測試依賴

<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>

創(chuàng)建一個 DockerController,在其中有一個index()方法,訪問時返回:Hello Docker!

@RestController
public class DockerController {

   @RequestMapping("/")
   public String index() {
       return "Hello Docker!";
   }
}

啟動類

@SpringBootApplication
public class DockerApplication {

public static void main(String[] args) {
SpringApplication.run(DockerApplication.class, args);
}
}

添加完畢后啟動項目,啟動成功后瀏覽器訪問:http://localhost:8080/,頁面返回:Hello Docker!,說明 Spring Boot 項目配置正常。

Spring Boot 項目添加 Docker 支持

pom.xml-properties中添加 Docker 鏡像名稱

<properties>
<docker.image.prefix>springboot</docker.image.prefix>
</properties>

plugins 中添加 Docker 構建插件:

<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<!-- Docker maven plugin -->
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>1.0.0</version>
<configuration>
<imageName>${docker.image.prefix}/${project.artifactId}</imageName>
<dockerDirectory>src/main/docker</dockerDirectory>
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
<!-- Docker maven plugin -->
</plugins>
</build>

在目錄src/main/docker下創(chuàng)建 Dockerfile 文件,Dockerfile 文件用來說明如何來構建鏡像。

FROM openjdk:8-jdk-alpine
VOLUME /tmp
ADD spring-boot-docker-1.0.jar app.jar
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

這個 Dockerfile 文件很簡單,構建 Jdk 基礎環(huán)境,添加 Spring Boot Jar 到鏡像中,簡單解釋一下:

  • FROM ,表示使用 Jdk8 環(huán)境 為基礎鏡像,如果鏡像不是本地的會從 DockerHub 進行下載
  • VOLUME ,VOLUME 指向了一個/tmp的目錄,由于 Spring Boot 使用內置的Tomcat容器,Tomcat 默認使用/tmp作為工作目錄。這個命令的效果是:在宿主機的/var/lib/docker目錄下創(chuàng)建一個臨時文件并把它鏈接到容器中的/tmp目錄
  • ADD ,拷貝文件并且重命名
  • ENTRYPOINT ,為了縮短 Tomcat 的啟動時間,添加java.security.egd的系統(tǒng)屬性指向/dev/urandom作為 ENTRYPOINT

這樣 Spring Boot 項目添加 Docker 依賴就完成了。

構建打包環(huán)境

我們需要有一個 Docker 環(huán)境來打包 Spring Boot 項目,在 Windows 搭建 Docker 環(huán)境很麻煩,因此我這里以 Centos 7 為例。

安裝 Docker 環(huán)境

安裝

yum install docker

安裝完成后,使用下面的命令來啟動 docker 服務,并將其設置為開機啟動:

service docker start
chkconfig docker on

#LCTT 譯注:此處采用了舊式的 sysv 語法,如采用CentOS 7中支持的新式 systemd 語法,如下:
systemctl  start docker.service
systemctl  enable docker.service

使用Docker 中國加速器

vi  /etc/docker/daemon.json

#添加后:
{
   "registry-mirrors": ["https://registry.docker-cn.com"],
   "live-restore": true
}

重新啟動docker

systemctl restart docker

輸入docker version 返回版本信息則安裝正常。

安裝JDK

yum -y install java-1.8.0-openjdk*

配置環(huán)境變量 打開 vim /etc/profile添加一下內容

export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.161-0.b14.el7_4.x86_64
export PATH=$PATH:$JAVA_HOME/bin

修改完成之后,使其生效

source /etc/profile

輸入java -version 返回版本信息則安裝正常。

安裝MAVEN

下載:http://mirrors.shu.edu.cn/apache/maven/maven-3/3.5.2/binaries/apache-maven-3.5.2-bin.tar.gz

## 解壓
tar vxf apache-maven-3.5.2-bin.tar.gz
## 移動
mv apache-maven-3.5.2 /usr/local/maven3

修改環(huán)境變量, 在/etc/profile中添加以下幾行

MAVEN_HOME=/usr/local/maven3
export MAVEN_HOME
export PATH=${PATH}:${MAVEN_HOME}/bin

記得執(zhí)行source /etc/profile使環(huán)境變量生效。

輸入mvn -version 返回版本信息則安裝正常。

這樣整個構建環(huán)境就配置完成了。

使用 Docker 部署 Spring Boot 項目

將項目 spring-boot-docker 拷貝服務器中,進入項目路徑下進行打包測試。

#打包
mvn package
#啟動
java -jar target/spring-boot-docker-1.0.jar

看到 Spring Boot 的啟動日志后表明環(huán)境配置沒有問題,接下來我們使用 DockerFile 構建鏡像。

mvn package docker:build

第一次構建可能有點慢,當看到以下內容的時候表明構建成功:

...
Step 1 : FROM openjdk:8-jdk-alpine
---> 224765a6bdbe
Step 2 : VOLUME /tmp
---> Using cache
---> b4e86cc8654e
Step 3 : ADD spring-boot-docker-1.0.jar app.jar
---> a20fe75963ab
Removing intermediate container 593ee5e1ea51
Step 4 : ENTRYPOINT java -Djava.security.egd=file:/dev/./urandom -jar /app.jar
---> Running in 85d558a10cd4
---> 7102f08b5e95
Removing intermediate container 85d558a10cd4
Successfully built 7102f08b5e95
[INFO] Built springboot/spring-boot-docker
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 54.346 s
[INFO] Finished at: 2018-03-13T16:20:15+08:00
[INFO] Final Memory: 42M/182M
[INFO] ------------------------------------------------------------------------

使用docker images命令查看構建好的鏡像:

docker images
REPOSITORY                      TAG                 IMAGE ID            CREATED             SIZE
springboot/spring-boot-docker   latest              99ce9468da74        6 seconds ago       117.5 MB

springboot/spring-boot-docker 就是我們構建好的鏡像,下一步就是運行該鏡像

docker run -p 8080:8080 -t springboot/spring-boot-docker

啟動完成之后我們使用docker ps查看正在運行的鏡像:

docker ps
CONTAINER ID        IMAGE                           COMMAND                  CREATED             STATUS              PORTS                    NAMES
049570da86a9        springboot/spring-boot-docker   "java -Djava.security"   30 seconds ago      Up 27 seconds       0.0.0.0:8080->8080/tcp   determined_mahavira

可以看到我們構建的容器正在在運行,訪問瀏覽器:http://192.168.0.x:8080/,返回

Hello Docker!

說明使用 Docker 部署 Spring Boot 項目成功!

示例代碼 :https://github.com/ityouknow/spring-boot-examples

“怎么用Docker部署Spring Boot項目”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注億速云網(wǎng)站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI