將spring boot應(yīng)用打入docker中運(yùn)行的實(shí)現(xiàn)方法
這幾天研究了一下將spring boot應(yīng)用打入到docker中運(yùn)行,先前有一個(gè)maven插件,可以直接在src/main中建一個(gè)docker文件夾,新建一個(gè)Dockerfile文件,在進(jìn)行編譯打包之后,可以直接運(yùn)行docker插件,相當(dāng)于在對(duì)應(yīng)的docker目錄中執(zhí)行 docker build .命令,會(huì)直接將當(dāng)前應(yīng)用打成鏡像,然后運(yùn)行,十分方便,但是在個(gè)人經(jīng)過(guò)測(cè)試后發(fā)現(xiàn),這個(gè)插件并不穩(wěn)定,docker文件夾不一定每次都會(huì)打到target文件夾下,因此就會(huì)導(dǎo)致這個(gè)插件執(zhí)行起來(lái)并沒(méi)有多大用處。
因此我在后來(lái)再將spring boot應(yīng)用打成鏡像的時(shí)候,不再使用提供的docker maven插件,而是單獨(dú)在當(dāng)前項(xiàng)目的根目錄下新建一個(gè)Dockerfile文件,應(yīng)用編寫(xiě)完了之后,直接手動(dòng)執(zhí)行命令將應(yīng)用打成鏡像,具體如下。
springboot應(yīng)用
pom.xml
在這里的pom.xml中需要指定幾個(gè)倉(cāng)庫(kù),以及提供幾個(gè)插件,具體如下:
<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>cn.com</groupId>
<artifactId>springbootweb</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging>
<name>spring :: boot :: web</name>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.1.RELEASE</version>
<relativePath/>
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<docker.image.prefix>springio</docker.image.prefix>
<docker.version>0.3.8</docker.version>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
<repositories>
<repository>
<id>spring-snapshots</id>
<url>http://repo.spring.io/snapshot</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
<repository>
<id>spring-milestones</id>
<url>http://repo.spring.io/milestone</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>spring-snapshots</id>
<url>http://repo.spring.io/snapshot</url>
</pluginRepository>
<pluginRepository>
<id>spring-milestones</id>
<url>http://repo.spring.io/milestone</url>
</pluginRepository>
</pluginRepositories>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.2</version>
<configuration>
<compilerArgument>-parameters</compilerArgument>
<source>1.8</source>
<target>1.8</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.18.1</version>
<configuration>
<skipTests>true</skipTests>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<version>2.6</version>
<configuration>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<!--<version>${spring.boot.version}</version>-->
<configuration>
<mainClass>cn.com.SpringBootWebApplication</mainClass>
<layout>ZIP</layout>
</configuration>
<executions>
<execution>
<goals>
<goal>
repackage
</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<profiles>
<profile>
<id>JDK1.8</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<encoding>UTF-8</encoding>
</properties>
</profile>
</profiles>
</project>
這里的提供了幾個(gè)倉(cāng)庫(kù)的地址,原因是因?yàn)楸疚闹袑pringboot應(yīng)用打進(jìn)docker的時(shí)候,是直接將源碼一起打進(jìn)去,然后在里面進(jìn)行編譯打包之后進(jìn)行運(yùn)行,如果不提供倉(cāng)庫(kù)地址下載jar包,那么就會(huì)從中央倉(cāng)庫(kù)拉取依賴,那么速度會(huì)非常慢并且會(huì)出現(xiàn)拉取超時(shí)導(dǎo)致應(yīng)用使用不了的情況,因此提供幾個(gè)其他倉(cāng)庫(kù)地址下載依賴,另外這里有一個(gè)插件,使用這個(gè)插件后可以直接以 mvn spring-boot:run的形式運(yùn)行應(yīng)用,所以我也就沒(méi)決定使用java -jar xxx.jar的方式來(lái)運(yùn)行應(yīng)用。
Application和controller
這個(gè)springboot應(yīng)用相當(dāng)簡(jiǎn)單,提供一個(gè)簡(jiǎn)單的controller,里面有一個(gè)類似與hello world的接口,如下:
package cn.com.controllers;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.HashMap;
import java.util.Map;
/**
* Created by xiaxuan on 16/11/27.
*/
@RestController
public class IndexController {
@RequestMapping(value = "/index", produces = "application/json;charset=utf-8")
public Object index() {
Map<String, Object> result = new HashMap<String, Object>();
result.put("msg", "hello world");
return result;
}
}
提供一個(gè)簡(jiǎn)單的helloworl的方法。
以下是Application啟動(dòng)類:
package cn.com;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
* Created by xiaxuan on 16/11/27.
*/
@SpringBootApplication
public class SpringBootWebApplication {
public static void main(String[] args) {
SpringApplication.run(SpringBootWebApplication.class, args);
}
}
正常的spring boot的啟動(dòng)中,相當(dāng)簡(jiǎn)單,直接啟動(dòng)SpringBootWebApplication啟動(dòng)類即可,但是在docker容器中運(yùn)行的話,則沒(méi)有這么簡(jiǎn)單,看下下面的這個(gè)Dockerfile文件。
Dockerfile文件
Dockerfile文件也比較簡(jiǎn)單,如下:
# base image FROM java:8 # maintainer MAINTAINER bingwenwuhen bingwenwuhen@163.com # update packages and install maven RUN \ export DEBIAN_FRONTEND=noninteractive && \ sed -i 's/# \(.*multiverse$\)/\1/g' /etc/apt/sources.list && \ apt-get update && \ apt-get -y upgrade && \ apt-get install -y vim wget curl maven # attach volumes VOLUME /vol/development # create working directory RUN mkdir -p /vol/development RUN mkdir -p /vol/development/src WORKDIR /vol/development COPY ./src /vol/development/src/ COPY ./pom.xml /vol/development/ # maven exec CMD ["mvn", "clean", "install", "spring-boot:run"]
dockerfile中以java8為基礎(chǔ)鏡像,同時(shí)在基礎(chǔ)鏡像中還需要單獨(dú)安裝maven,因?yàn)樵谖覀兊膁ockerfile文件中,是將整個(gè)源碼都打進(jìn)鏡像之中,在這里沒(méi)有只將生成的jar打進(jìn)鏡像中,所以這就是之前所說(shuō)的需要在pom.xml中指定倉(cāng)庫(kù),如果不指定倉(cāng)庫(kù),則在鏡像中拉取依賴的時(shí)候,會(huì)從中央倉(cāng)庫(kù)拉取依賴,那么會(huì)非常慢,我之前試過(guò)幾次,基本拉取過(guò)程中,都超時(shí)失敗了,所以在這里指定倉(cāng)庫(kù)拉取依賴。
構(gòu)建鏡像
現(xiàn)在在目錄下面執(zhí)行命令,docker build -t="bingwenwuhen/springboot01" .構(gòu)建鏡像,如下:

在打成鏡像之后,運(yùn)行
docker run -d --name springboot01 -p 8080:8080 bingwenwuhe/spingboot01
以上命令為運(yùn)行該鏡像生成一個(gè)容器,映射端口為8080,名字為springboot01,
現(xiàn)在docker logs xxxxx查看容器日志:

現(xiàn)在這個(gè)容器已經(jīng)運(yùn)行起來(lái)了。
請(qǐng)求接口
在請(qǐng)求接口前,需要先查看docker虛擬機(jī)的ip為多少,本機(jī)為192.168.99.100,請(qǐng)求接口命令為:
curl http://192.168.99.100:8080/index
響應(yīng)為:
{
"msg":"hello world"
}
請(qǐng)求成功,以上,springboot應(yīng)用打進(jìn)docker中運(yùn)行也就成功了。
問(wèn)題
- 在將源碼打進(jìn)鏡像中,mvn clean install 編譯運(yùn)行的時(shí)候,下載的jar包實(shí)在太多,等的時(shí)間太長(zhǎng),很容易中斷,所以十分不推薦這種方式的運(yùn)行。
- 源碼本質(zhì)上不應(yīng)該打進(jìn)鏡像之中,只需要將運(yùn)行的jar包打進(jìn)鏡像之中就可以了。
源碼
我將源碼上傳到github上,有需要的可以自己下載。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Docker Machine創(chuàng)建Azure虛擬主機(jī)
這篇文章主要為大家詳細(xì)介紹了Docker Machine創(chuàng)建Azure虛擬主機(jī)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
Docker搭建PHP運(yùn)行環(huán)境完整步驟(圖文教程)
PHP是一種廣泛使用的編程語(yǔ)言,被用于Web開(kāi)發(fā)和服務(wù)器管理等各種用途,而Docker則是一種非常流行的容器化平臺(tái),可以方便地管理應(yīng)用程序和環(huán)境,這篇文章主要給大家介紹了關(guān)于Docker搭建PHP運(yùn)行環(huán)境的完整步驟,需要的朋友可以參考下2023-09-09
docker run 運(yùn)行容器自動(dòng)結(jié)束的解決
這篇文章主要介紹了docker run 運(yùn)行容器自動(dòng)結(jié)束的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11
Docker快速部署gitlab+gitlab-runner實(shí)例
這篇文章主要介紹了Docker快速部署gitlab+gitlab-runner實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
Docker Desktop啟用Kubernetes 1.25 的過(guò)程記錄
這篇文章主要介紹了Docker Desktop啟用Kubernetes 1.25 的過(guò)程記錄,安裝 Docker 之前需要你在 BIOS 中開(kāi)啟虛擬化,同時(shí)基于你的宿主程序的選擇,你還需要執(zhí)行相關(guān)的操作,需要的朋友可以參考下2022-10-10
Docker部署Zookeeper分布式協(xié)調(diào)器的實(shí)現(xiàn)
Zookeeper是分布式數(shù)據(jù)一致性的關(guān)鍵技術(shù),支持單機(jī)和集群部署,集群部署需奇數(shù)節(jié)點(diǎn),,通過(guò)Docker部署方便,支持配置文件映射和動(dòng)態(tài)角色變更,感興趣的可以了解一下2024-11-11
詳解利用ELK搭建Docker容器化應(yīng)用日志中心
這篇文章主要介紹了詳解利用ELK搭建Docker容器化應(yīng)用日志中心,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04

