將spring boot應(yīng)用打入docker中運行的實現(xiàn)方法
這幾天研究了一下將spring boot應(yīng)用打入到docker中運行,先前有一個maven插件,可以直接在src/main中建一個docker文件夾,新建一個Dockerfile文件,在進(jìn)行編譯打包之后,可以直接運行docker插件,相當(dāng)于在對應(yīng)的docker目錄中執(zhí)行 docker build .
命令,會直接將當(dāng)前應(yīng)用打成鏡像,然后運行,十分方便,但是在個人經(jīng)過測試后發(fā)現(xiàn),這個插件并不穩(wěn)定,docker文件夾不一定每次都會打到target文件夾下,因此就會導(dǎo)致這個插件執(zhí)行起來并沒有多大用處。
因此我在后來再將spring boot應(yīng)用打成鏡像的時候,不再使用提供的docker maven插件,而是單獨在當(dāng)前項目的根目錄下新建一個Dockerfile文件,應(yīng)用編寫完了之后,直接手動執(zhí)行命令將應(yīng)用打成鏡像,具體如下。
springboot應(yīng)用
pom.xml
在這里的pom.xml中需要指定幾個倉庫,以及提供幾個插件,具體如下:
<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>
這里的提供了幾個倉庫的地址,原因是因為本文中將springboot應(yīng)用打進(jìn)docker的時候,是直接將源碼一起打進(jìn)去,然后在里面進(jìn)行編譯打包之后進(jìn)行運行,如果不提供倉庫地址下載jar包,那么就會從中央倉庫拉取依賴,那么速度會非常慢并且會出現(xiàn)拉取超時導(dǎo)致應(yīng)用使用不了的情況,因此提供幾個其他倉庫地址下載依賴,另外這里有一個插件,使用這個插件后可以直接以 mvn spring-boot:run的形式運行應(yīng)用,所以我也就沒決定使用java -jar xxx.jar的方式來運行應(yīng)用。
Application和controller
這個springboot應(yīng)用相當(dāng)簡單,提供一個簡單的controller,里面有一個類似與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; } }
提供一個簡單的helloworl的方法。
以下是Application啟動類:
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)簡單,直接啟動SpringBootWebApplication啟動類即可,但是在docker容器中運行的話,則沒有這么簡單,看下下面的這個Dockerfile文件。
Dockerfile文件
Dockerfile文件也比較簡單,如下:
# 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ǔ)鏡像,同時在基礎(chǔ)鏡像中還需要單獨安裝maven,因為在我們的dockerfile文件中,是將整個源碼都打進(jìn)鏡像之中,在這里沒有只將生成的jar打進(jìn)鏡像中,所以這就是之前所說的需要在pom.xml中指定倉庫,如果不指定倉庫,則在鏡像中拉取依賴的時候,會從中央倉庫拉取依賴,那么會非常慢,我之前試過幾次,基本拉取過程中,都超時失敗了,所以在這里指定倉庫拉取依賴。
構(gòu)建鏡像
現(xiàn)在在目錄下面執(zhí)行命令,docker build -t="bingwenwuhen/springboot01" .
構(gòu)建鏡像,如下:
在打成鏡像之后,運行
docker run -d --name springboot01 -p 8080:8080 bingwenwuhe/spingboot01
以上命令為運行該鏡像生成一個容器,映射端口為8080,名字為springboot01,
現(xiàn)在docker logs xxxxx
查看容器日志:
現(xiàn)在這個容器已經(jīng)運行起來了。
請求接口
在請求接口前,需要先查看docker虛擬機(jī)的ip為多少,本機(jī)為192.168.99.100,請求接口命令為:
curl http://192.168.99.100:8080/index
響應(yīng)為:
{ "msg":"hello world" }
請求成功,以上,springboot應(yīng)用打進(jìn)docker中運行也就成功了。
問題
- 在將源碼打進(jìn)鏡像中,mvn clean install 編譯運行的時候,下載的jar包實在太多,等的時間太長,很容易中斷,所以十分不推薦這種方式的運行。
- 源碼本質(zhì)上不應(yīng)該打進(jìn)鏡像之中,只需要將運行的jar包打進(jìn)鏡像之中就可以了。
源碼
我將源碼上傳到github上,有需要的可以自己下載。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
docker運行PostgreSQL數(shù)據(jù)庫維護(hù)執(zhí)行腳本備份數(shù)據(jù)庫與更新表結(jié)構(gòu)的方法
這篇文章主要介紹了docker運行PostgreSQL數(shù)據(jù)庫維護(hù),執(zhí)行腳本備份數(shù)據(jù)庫與更新表結(jié)構(gòu),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-05-05使用Dockerfile實現(xiàn)容器內(nèi)部服務(wù)隨容器自啟動的方法
這篇文章主要介紹了使用Dockerfile實現(xiàn)容器內(nèi)部服務(wù)隨容器自啟動,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06打包docker鏡像推送到遠(yuǎn)程服務(wù)器并部署到k8s的方法步驟
本文主要介紹了打包docker鏡像推送到遠(yuǎn)程服務(wù)器并部署到k8s的方法步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11解析docker妙用SpringBoot構(gòu)建微服務(wù)實戰(zhàn)記錄
Spring Boot 是 Spring 開源組織的子項目,是 Spring 組件一站式解決方案,本文通過詳細(xì)案例給大家解析docker妙用SpringBoot構(gòu)建微服務(wù)實戰(zhàn)記錄,感興趣的朋友跟隨小編一起看看吧2021-11-11Windows Docker部署Jenkins的實現(xiàn)步驟
Jenkins是一款開源的持續(xù)集成工具,廣泛用于項目開發(fā),能提供自動構(gòu)建測試部署等功能,本文主要介紹了Windows Docker部署Jenkins的實現(xiàn)步驟,感興趣的可以了解一下2024-03-03