Spring Boot利用Docker快速部署項(xiàng)目的完整步驟
1.簡(jiǎn)介
建議閱讀本文最好對(duì)Dokcer有一些了解
首先我們先了解一下Docker是什么
Docker 屬于 Linux 容器的一種封裝,提供簡(jiǎn)單易用的容器使用接口。它是目前最流行的 Linux 容器解決方案。
Docker 將應(yīng)用程序與該程序的依賴(lài),打包在一個(gè)文件里面。運(yùn)行這個(gè)文件,就會(huì)生成一個(gè)虛擬容器。程序在這個(gè)虛擬容器里運(yùn)行,就好像在真實(shí)的物理機(jī)上運(yùn)行一樣。有了 Docker,就不用擔(dān)心環(huán)境問(wèn)題。
總體來(lái)說(shuō),Docker 的接口相當(dāng)簡(jiǎn)單,用戶(hù)可以方便地創(chuàng)建和使用容器,把自己的應(yīng)用放入容器。容器還可以進(jìn)行版本管理、復(fù)制、分享、修改,就像管理普通的代碼一樣。
Docker有什么用途
- 提供一次性的環(huán)境
- 提供彈性的云服務(wù)
- 組建微服務(wù)架構(gòu)
如何搭建Docker環(huán)境
使用yum安裝
#查看你當(dāng)前的內(nèi)核版本 uname -r #安裝 Docker yum -y install docker #啟動(dòng) Docker 后臺(tái)服務(wù) service docker start #測(cè)試運(yùn)行 hello-world,由于本地沒(méi)有hello-world這個(gè)鏡像,所以會(huì)下載一個(gè)hello-world的鏡像,并在容器內(nèi)運(yùn)行。 docker run hello-world
腳本安裝:
#確保 yum 包更新到最新 sudo yum update #執(zhí)行 Docker 安裝腳本,執(zhí)行這個(gè)腳本會(huì)添加 docker.repo 源并安裝 Docker。 curl -fsSL https://get.docker.com/ | sh #啟動(dòng) Docker 進(jìn)程 sudo service docker start #驗(yàn)證 docker 是否安裝成功并在容器中執(zhí)行一個(gè)測(cè)試的鏡像 sudo docker run hello-world
因?yàn)閲?guó)內(nèi)下載鏡像速度較慢,推薦使用替換為國(guó)內(nèi)的鏡像源
執(zhí)行命令
vim /etc/docker/daemon.json 加入以下代碼 { "registry-mirrors": ["<your accelerate address>"] }
2.創(chuàng)建項(xiàng)目
首先我們先創(chuàng)建一個(gè)SpringBoot的項(xiàng)目,這個(gè)步驟就不在重復(fù)了,可以使用IDEA構(gòu)建或者訪(fǎng)問(wèn)SpringBoot項(xiàng)目來(lái)進(jìn)行構(gòu)建項(xiàng)目。
完整的項(xiàng)目結(jié)構(gòu):
boot-docker
├── pom.xml
└── src
├── main
│ ├── java
│ │ └── com
│ │ └── example
│ │ └── bootdocker
│ │ └── BootDockerApplication.java
│ └── resources
│ ├── application.properties
│ ├── static
│ └── templates
然后創(chuàng)建一個(gè)控制器,這里不做的太復(fù)雜,主要就是來(lái)演示Docker怎么部署項(xiàng)目。
主要代碼:
啟動(dòng)然后打開(kāi)瀏覽器訪(fǎng)問(wèn)接口地址:
項(xiàng)目完成,現(xiàn)在開(kāi)始部署到Docker中。
3.部署項(xiàng)目
3.1 使用Dockerfile
在部署項(xiàng)目之前我們要先了解一下Dockerfile 是什么?
Dockfile是一種被Docker程序解釋的腳本,Dockerfile由一條一條的指令組成,每條指令對(duì)應(yīng)Linux下面的一條命令。Docker程序?qū)⑦@些Dockerfile指令翻譯真正的Linux命令。Dockerfile有自己書(shū)寫(xiě)格式和支持的命令,Docker程序解決這些命令間的依賴(lài)關(guān)系,類(lèi)似于Makefile。Docker程序?qū)⒆x取Dockerfile,根據(jù)指令生成定制的image。相比image這種黑盒子,Dockerfile這種顯而易見(jiàn)的腳本更容易被使用者接受,它明確的表明image是怎么產(chǎn)生的。有了Dockerfile,當(dāng)我們需要定制自己額外的需求時(shí),只需在Dockerfile上添加或者修改指令,重新生成image即可,省去了敲命令的麻煩。參考
我們先把項(xiàng)目進(jìn)行打包執(zhí)行,執(zhí)行。
mvn package
創(chuàng)建Dockerfile文件
touch Dockerfile
在Dockerfile中加入以下信息:
注意Dockerfile必須和Jar包在同一路徑下
FROM java:8 EXPOSE 8080 VOLUME /slm ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar RUN sh -c 'touch /boot-docker.jar' ENV JAVA_OPTS="" ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ]
- FROM 基礎(chǔ)鏡像必要,代表你的項(xiàng)目將構(gòu)建在這個(gè)基礎(chǔ)上面
- EXPOSE 允許指定端口轉(zhuǎn)發(fā)
- VOLUME 創(chuàng)建一個(gè)可以從本地主機(jī)或其他容器掛載的掛載點(diǎn),一般用來(lái)存放數(shù)據(jù)庫(kù)和需要保持的數(shù)據(jù)等。
- ADD 將文件從路徑
- ENV 可以用于為docker容器設(shè)置環(huán)境變量
- ENTRYPOINT 指定 Docker image 運(yùn)行成 instance (也就是 Docker container) 時(shí),要執(zhí)行的命令或者文件。
- CMD 和 ENTRYPOINT 都能用來(lái)指定開(kāi)始運(yùn)行的程序,而且這兩個(gè)命令都有兩種不用的語(yǔ)法:
CMD ["ls",''-l"] CMD ls -l
開(kāi)始構(gòu)建:
docker build -t boot-docker .
-t boot-docker 代表你要構(gòu)建的名字
更多參數(shù)輸入查看:docker build --help
控制臺(tái)輸出:
Sending build context to Docker daemon 16.81MB
Step 1/7 : FROM java:8
---> d23bdf5b1b1b
Step 2/7 : EXPOSE 8080
---> Using cache
---> b2445bf62da8
Step 3/7 : VOLUME /slm
---> Using cache
---> b73d0b73b868
Step 4/7 : ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar
---> Using cache
---> 2b4868aafca9
Step 5/7 : RUN sh -c 'touch /boot-docker.jar'
---> Using cache
---> 816b59f199af
Step 6/7 : ENV JAVA_OPTS=""
---> Using cache
---> 784f033b9dd6
Step 7/7 : ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ]
---> Using cache
---> 92a0da91ea19
Successfully built 92a0da91ea19
Successfully tagged bootdocker:latest
我們可以看到已經(jīng)構(gòu)建完成,Successfully built 92a0da91ea19這句話(huà)指明了剛剛構(gòu)建的鏡像ID現(xiàn)在我們可以根據(jù)這個(gè)ID來(lái)進(jìn)行操作。
輸入run命令來(lái)啟動(dòng)。
docker run -d -p 8080:8080 92a0da91ea19
控制臺(tái)輸出:
root@izz30yg92yl9i3z /# docker run -d -p 8080:8080 92a0da91ea19 62b837ac75e3d83a4be2d7b0f6edee5ff70c69a98bac4ff74c7ed6d3e70282ee root@izz30yg92yl9i3z /#
-d 表示后臺(tái)運(yùn)行
-p映射端口
已經(jīng)運(yùn)行成功訪(fǎng)問(wèn)接口。注意這里因?yàn)橛成涞搅怂拗鳈C(jī)的端口所以訪(fǎng)問(wèn)的是宿主機(jī)的IP加端口
更多參數(shù)輸入查看:docker build --help
3.2 使用Maven構(gòu)建
上面說(shuō)了使用Dockerfile構(gòu)建,現(xiàn)在使用Maven來(lái)構(gòu)建,
在pom中加入docker構(gòu)建依賴(lài)
<plugin> <!--新增的docker maven插件--> <groupId>com.spotify</groupId> <artifactId>docker-maven-plugin</artifactId> <version>0.4.13</version> <configuration> <!--鏡像名字--> <imageName>${docker.image.prefix}/${project.artifactId}</imageName> <!--DokcerFile文件地址--> <dockerDirectory>/slm/</dockerDirectory> <resources> <resource> <targetPath>/</targetPath> <directory>${project.build.directory}</directory> <include>${project.build.finalName}.jar</include> </resource> </resources> </configuration> </plugin>
注意dockerDirectory還是要設(shè)置Dockerfile文件的路徑
把項(xiàng)目復(fù)制到Linux主機(jī)中,執(zhí)行解壓命令
unzip boot-docker.zip cd boot-docker
執(zhí)行命令:
mvn package docker:build
控制臺(tái)輸出:
[INFO] Building image boot-docker/boot-docker
Step 1/7 : FROM java:8---> d23bdf5b1b1b
Step 2/7 : EXPOSE 8080---> Using cache
---> b2445bf62da8
Step 3/7 : VOLUME /slm---> Using cache
---> b73d0b73b868
Step 4/7 : ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar---> Using cache
---> 2b4868aafca9
Step 5/7 : RUN sh -c 'touch /boot-docker.jar'---> Using cache
---> 816b59f199af
Step 6/7 : ENV JAVA_OPTS=""---> Using cache
---> 784f033b9dd6
Step 7/7 : ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ]---> Using cache
---> 92a0da91ea19
ProgressMessage{id=null, status=null, stream=null, error=null, progress=null, progressDetail=null}
Successfully built 92a0da91ea19
Successfully tagged boot-docker/boot-docker:latest
[INFO] Built boot-docker/boot-docker
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 19.908s
[INFO] Finished at: Wed Jul 10 16:00:21 CST 2019
[INFO] Final Memory: 35M/86M
[INFO] ------------------------------------------------------------------------
和上面相同。啟動(dòng)
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
手動(dòng)編譯并運(yùn)行Java項(xiàng)目實(shí)現(xiàn)過(guò)程解析
這篇文章主要介紹了手動(dòng)編譯并運(yùn)行Java項(xiàng)目實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10SpringBoot項(xiàng)目中出現(xiàn)不同端口跨域問(wèn)題的解決方法
這篇文章主要介紹了SpringBoot項(xiàng)目中出現(xiàn)不同端口跨域問(wèn)題的解決方法,文中介紹了兩種解決方法,并給出了詳細(xì)的代碼供大家參考,具有一定的參考價(jià)值,需要的朋友可以參考下2024-03-03通過(guò)端口1433連接到主機(jī)127.0.0.1的 TCP/IP 連接失敗,錯(cuò)誤:“connect timed out”的解
這篇文章主要介紹了通過(guò)端口1433連接到主機(jī)127.0.0.1的 TCP/IP 連接失敗,錯(cuò)誤:“connect timed out”的解決方法,需要的朋友可以參考下2015-08-08

關(guān)于Java?float和double精度范圍大小