Spring Boot利用Docker快速部署項目的完整步驟
1.簡介
建議閱讀本文最好對Dokcer有一些了解
首先我們先了解一下Docker是什么
Docker 屬于 Linux 容器的一種封裝,提供簡單易用的容器使用接口。它是目前最流行的 Linux 容器解決方案。
Docker 將應(yīng)用程序與該程序的依賴,打包在一個文件里面。運行這個文件,就會生成一個虛擬容器。程序在這個虛擬容器里運行,就好像在真實的物理機上運行一樣。有了 Docker,就不用擔心環(huán)境問題。
總體來說,Docker 的接口相當簡單,用戶可以方便地創(chuàng)建和使用容器,把自己的應(yīng)用放入容器。容器還可以進行版本管理、復(fù)制、分享、修改,就像管理普通的代碼一樣。
Docker有什么用途
- 提供一次性的環(huán)境
- 提供彈性的云服務(wù)
- 組建微服務(wù)架構(gòu)
如何搭建Docker環(huán)境
使用yum安裝
#查看你當前的內(nèi)核版本 uname -r #安裝 Docker yum -y install docker #啟動 Docker 后臺服務(wù) service docker start #測試運行 hello-world,由于本地沒有hello-world這個鏡像,所以會下載一個hello-world的鏡像,并在容器內(nèi)運行。 docker run hello-world
腳本安裝:
#確保 yum 包更新到最新 sudo yum update #執(zhí)行 Docker 安裝腳本,執(zhí)行這個腳本會添加 docker.repo 源并安裝 Docker。 curl -fsSL https://get.docker.com/ | sh #啟動 Docker 進程 sudo service docker start #驗證 docker 是否安裝成功并在容器中執(zhí)行一個測試的鏡像 sudo docker run hello-world
因為國內(nèi)下載鏡像速度較慢,推薦使用替換為國內(nèi)的鏡像源
執(zhí)行命令
vim /etc/docker/daemon.json 加入以下代碼 { "registry-mirrors": ["<your accelerate address>"] }
2.創(chuàng)建項目
首先我們先創(chuàng)建一個SpringBoot的項目,這個步驟就不在重復(fù)了,可以使用IDEA構(gòu)建或者訪問SpringBoot項目來進行構(gòu)建項目。
完整的項目結(jié)構(gòu):
boot-docker
├── pom.xml
└── src
├── main
│ ├── java
│ │ └── com
│ │ └── example
│ │ └── bootdocker
│ │ └── BootDockerApplication.java
│ └── resources
│ ├── application.properties
│ ├── static
│ └── templates
然后創(chuàng)建一個控制器,這里不做的太復(fù)雜,主要就是來演示Docker怎么部署項目。
主要代碼:
啟動然后打開瀏覽器訪問接口地址:
項目完成,現(xiàn)在開始部署到Docker中。
3.部署項目
3.1 使用Dockerfile
在部署項目之前我們要先了解一下Dockerfile 是什么?
Dockfile是一種被Docker程序解釋的腳本,Dockerfile由一條一條的指令組成,每條指令對應(yīng)Linux下面的一條命令。Docker程序?qū)⑦@些Dockerfile指令翻譯真正的Linux命令。Dockerfile有自己書寫格式和支持的命令,Docker程序解決這些命令間的依賴關(guān)系,類似于Makefile。Docker程序?qū)⒆x取Dockerfile,根據(jù)指令生成定制的image。相比image這種黑盒子,Dockerfile這種顯而易見的腳本更容易被使用者接受,它明確的表明image是怎么產(chǎn)生的。有了Dockerfile,當我們需要定制自己額外的需求時,只需在Dockerfile上添加或者修改指令,重新生成image即可,省去了敲命令的麻煩。參考
我們先把項目進行打包執(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ǔ)鏡像必要,代表你的項目將構(gòu)建在這個基礎(chǔ)上面
- EXPOSE 允許指定端口轉(zhuǎn)發(fā)
- VOLUME 創(chuàng)建一個可以從本地主機或其他容器掛載的掛載點,一般用來存放數(shù)據(jù)庫和需要保持的數(shù)據(jù)等。
- ADD 將文件從路徑
- ENV 可以用于為docker容器設(shè)置環(huán)境變量
- ENTRYPOINT 指定 Docker image 運行成 instance (也就是 Docker container) 時,要執(zhí)行的命令或者文件。
- CMD 和 ENTRYPOINT 都能用來指定開始運行的程序,而且這兩個命令都有兩種不用的語法:
CMD ["ls",''-l"] CMD ls -l
開始構(gòu)建:
docker build -t boot-docker .
-t boot-docker 代表你要構(gòu)建的名字
更多參數(shù)輸入查看:docker build --help
控制臺輸出:
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這句話指明了剛剛構(gòu)建的鏡像ID現(xiàn)在我們可以根據(jù)這個ID來進行操作。
輸入run命令來啟動。
docker run -d -p 8080:8080 92a0da91ea19
控制臺輸出:
root@izz30yg92yl9i3z /# docker run -d -p 8080:8080 92a0da91ea19 62b837ac75e3d83a4be2d7b0f6edee5ff70c69a98bac4ff74c7ed6d3e70282ee root@izz30yg92yl9i3z /#
-d 表示后臺運行
-p映射端口
已經(jīng)運行成功訪問接口。注意這里因為映射到了宿主機的端口所以訪問的是宿主機的IP加端口
更多參數(shù)輸入查看:docker build --help
3.2 使用Maven構(gòu)建
上面說了使用Dockerfile構(gòu)建,現(xiàn)在使用Maven來構(gòu)建,
在pom中加入docker構(gòu)建依賴
<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文件的路徑
把項目復(fù)制到Linux主機中,執(zhí)行解壓命令
unzip boot-docker.zip cd boot-docker
執(zhí)行命令:
mvn package docker:build
控制臺輸出:
[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] ------------------------------------------------------------------------
和上面相同。啟動
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。
相關(guān)文章
SpringBoot項目中出現(xiàn)不同端口跨域問題的解決方法
這篇文章主要介紹了SpringBoot項目中出現(xiàn)不同端口跨域問題的解決方法,文中介紹了兩種解決方法,并給出了詳細的代碼供大家參考,具有一定的參考價值,需要的朋友可以參考下2024-03-03通過端口1433連接到主機127.0.0.1的 TCP/IP 連接失敗,錯誤:“connect timed out”的解
這篇文章主要介紹了通過端口1433連接到主機127.0.0.1的 TCP/IP 連接失敗,錯誤:“connect timed out”的解決方法,需要的朋友可以參考下2015-08-08

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