Docker 技術(shù)發(fā)展為微服務(wù)落地提供了更加便利的環(huán)境,使用 Docker 部署 Spring Boot 其實(shí)非常簡(jiǎn)單,這篇文章我們就來(lái)簡(jiǎn)單學(xué)習(xí)下。
創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括富寧網(wǎng)站建設(shè)、富寧網(wǎng)站制作、富寧網(wǎng)頁(yè)制作以及富寧網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,富寧網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到富寧省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
首先構(gòu)建一個(gè)簡(jiǎn)單的 Spring Boot 項(xiàng)目,然后給項(xiàng)目添加 Docker 支持,最后對(duì)項(xiàng)目進(jìn)行部署。
一個(gè)簡(jiǎn)單 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 和測(cè)試依賴
<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()方法,訪問(wèn)時(shí)返回:Hello Docker!
@RestController public class DockerController { @RequestMapping("/") public String index() { return "Hello Docker!"; } }
啟動(dòng)類
@SpringBootApplication public class DockerApplication { public static void main(String[] args) { SpringApplication.run(DockerApplication.class, args); } }
添加完畢后啟動(dòng)項(xiàng)目,啟動(dòng)成功后瀏覽器放問(wèn):http://localhost:8080/,頁(yè)面返回:Hello Docker!,說(shuō)明 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 文件用來(lái)說(shuō)明如何來(lái)構(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 文件很簡(jiǎn)單,構(gòu)建 Jdk 基礎(chǔ)環(huán)境,添加 Spring Boot Jar 到鏡像中,簡(jiǎn)單解釋一下:
這樣 Spring Boot 項(xiàng)目添加 Docker 依賴就完成了。
構(gòu)建打包環(huán)境
我們需要有一個(gè) Docker 環(huán)境來(lái)打包 Spring Boot 項(xiàng)目,在 Windows 搭建 Docker 環(huán)境很麻煩,因此我這里以 Centos 7 為例。
安裝 Docker 環(huán)境
安裝
yum install docker
安裝完成后,使用下面的命令來(lái)啟動(dòng) docker 服務(wù),并將其設(shè)置為開(kāi)機(jī)啟動(dòng):
service docker start chkconfig docker on #LCTT 譯注:此處采用了舊式的 sysv 語(yǔ)法,如采用CentOS 7中支持的新式 systemd 語(yǔ)法,如下: systemctl start docker.service systemctl enable docker.service
使用Docker 中國(guó)加速器
vi /etc/docker/daemon.json #添加后: { "registry-mirrors": ["https://registry.docker-cn.com"], "live-restore": true }
重新啟動(dòng)docker
systemctl restart docker
輸入docker version 返回版本信息則安裝正常。
安裝JDK
yum -y install java-1.8.0-openjdk*
配置環(huán)境變量 打開(kāi) 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 ## 移動(dòng) 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)行打包測(cè)試。
#打包 mvn package #啟動(dòng) java -jar target/spring-boot-docker-1.0.jar
看到 Spring Boot 的啟動(dòng)日志后表明環(huán)境配置沒(méi)有問(wèn)題,接下來(lái)我們使用 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
啟動(dòng)完成之后我們使用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)行,訪問(wèn)瀏覽器:http://192.168.0.x:8080/,返回
Hello Docker!
說(shuō)明使用 Docker 部署 Spring Boot 項(xiàng)目成功!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
網(wǎng)站標(biāo)題:使用Docker部署SpringBoot的實(shí)現(xiàn)方法
URL網(wǎng)址:http://aaarwkj.com/article16/jjgggg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、外貿(mào)建站、用戶體驗(yàn)、電子商務(wù)、網(wǎng)頁(yè)設(shè)計(jì)公司、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
移動(dòng)網(wǎng)站建設(shè)知識(shí)