Docker 技術(shù)發(fā)展為微服務(wù)落地提供了更加便利的環(huán)境,使用 Docker 部署 Spring Boot 其實(shí)非常簡單,這篇文章我們就來簡單學(xué)習(xí)下。
創(chuàng)新互聯(lián)長期為數(shù)千家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為武邑企業(yè)提供專業(yè)的成都網(wǎng)站制作、成都做網(wǎng)站,武邑網(wǎng)站改版等技術(shù)服務(wù)。擁有十余年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
首先構(gòu)建一個(gè)簡單的 Spring Boot 項(xiàng)目,然后給項(xiàng)目添加 Docker 支持,最后對項(xiàng)目進(jìn)行部署。
一個(gè)簡單 Spring Boot 項(xiàng)目
在 pom.xml 中 ,使用 Spring Boot 2.0 相關(guān)依賴
<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)建一個(gè) DockerController,在其中有一個(gè) index() 方法,訪問時(shí)返回: 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); } }
添加完畢后啟動項(xiàng)目,啟動成功后瀏覽器放問: http://localhost:8080/ ,頁面返回: Hello Docker! ,說明 Spring Boot 項(xiàng)目配置正常。
Spring Boot 項(xiàng)目添加 Docker 支持
在 pom.xml-properties 中添加 Docker 鏡像名稱
<properties> <docker.image.prefix>springboot</docker.image.prefix> </properties>
plugins 中添加 Docker 構(gòu)建插件:
<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 文件用來說明如何來構(gòu)建鏡像。
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"]
這個(gè) Dockerfile 文件很簡單,構(gòu)建 Jdk 基礎(chǔ)環(huán)境,添加 Spring Boot Jar 到鏡像中,簡單解釋一下:
這樣 Spring Boot 項(xiàng)目添加 Docker 依賴就完成了。
構(gòu)建打包環(huán)境
我們需要有一個(gè) Docker 環(huán)境來打包 Spring Boot 項(xiàng)目,在 Windows 搭建 Docker 環(huán)境很麻煩,因此我這里以 Centos 7 為例。
安裝 Docker 環(huán)境
安裝
yum install docker
安裝完成后,使用下面的命令來啟動 docker 服務(wù),并將其設(shè)置為開機(jī)啟動:
ervice 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 添加一下內(nèi)容
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 返回版本信息則安裝正常。
這樣整個(gè)構(gòu)建環(huán)境就配置完成了。
使用 Docker 部署 Spring Boot 項(xiàng)目
將項(xiàng)目 spring-boot-docker 拷貝服務(wù)器中,進(jìn)入項(xiàng)目路徑下進(jìn)行打包測試。
#打包 mvn package #啟動 java -jar target/spring-boot-docker-1.0.jar
看到 Spring Boot 的啟動日志后表明環(huán)境配置沒有問題,接下來我們使用 DockerFile 構(gòu)建鏡像。
mvn package docker:build
第一次構(gòu)建可能有點(diǎn)慢,當(dāng)看到以下內(nèi)容的時(shí)候表明構(gòu)建成功:
... 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 命令查看構(gòu)建好的鏡像:
docker images REPOSITORY TAG IMAGE ID CREATED SIZE springboot/spring-boot-docker latest 99ce9468da74 6 seconds ago 117.5 MB
springboot/spring-boot-docker 就是我們構(gòu)建好的鏡像,下一步就是運(yùn)行該鏡像
docker run -p 8080:8080 -t springboot/spring-boot-docker
啟動完成之后我們使用 docker ps 查看正在運(yùn)行的鏡像:
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
可以看到我們構(gòu)建的容器正在在運(yùn)行,訪問瀏覽器: http://192.168.0.x:8080/ ,返回
Hello Docker!
說明使用 Docker 部署 Spring Boot 項(xiàng)目成功!
示例代碼:https://github.com/ityouknow/spring-boot-examples
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
文章名稱:使用Docker部署SpringBoot的應(yīng)用示例
網(wǎng)頁網(wǎng)址:http://muchs.cn/article24/ghspje.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、微信小程序、網(wǎng)站設(shè)計(jì)公司、定制網(wǎng)站、定制開發(fā)、云服務(wù)器
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)