Linux+Docker+SpringBoot+IDEA一鍵自動化部署的詳細(xì)步驟
Linux+Docker+SpringBoot+IDEA一鍵自動化部署的步驟
記錄從打包到服務(wù)器配置上線全流程
安裝docker
詳細(xì)步驟請戳這里
用yum源安裝用yum源安裝查看是否已安裝docker列表
yum list installed | grep docke
安裝docker
yum -y install docker
-y表示不詢問安裝,直到安裝成功,安裝完后再次查看安裝列表
開放2375端口,開啟遠(yuǎn)程訪問
vim /usr/lib/systemd/system/docker.service
這行:
ExecStart=/usr/bin/dockerd-current
替換為:
ExecStart=/usr/bin/dockerd-current -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock
重新加載docker配置
systemctl daemon-reload // 1,重新加載配置文件systemctl restart docker // 2,重啟docker
查看端口是否開啟
netstat -nptl
直接curl看是否生效
curl http://127.0.0.1:2375/version
雖然開放此端口打包程序很方便,但是會導(dǎo)致一些安全問題,因此 可以限制訪問IP來解決,在云服務(wù)器中設(shè)置安全組即可
IDEA鏈接docker
第一步,遠(yuǎn)程鏈接docker:
成功后可見:
打鏡像包
大致流程如下,采用maven綁定的方式進(jìn)行打包鏡像,然后根據(jù)該鏡像建立一個docker容器,啟動容器,即可首先我們先創(chuàng)建一個DockerFile,路徑參考:
DockerFile文件內(nèi)容如下:
FROM java:8VOLUME /tmp#docker-day1-1.0.jar為項(xiàng)目打包為jar包的名字,app.jar為別名ADD docker-day1-1.0.jar app.jar#運(yùn)行的時候?qū)ν馓峁┑亩丝谀J(rèn)是8090,即便你在這里聲明了3000也不會改變默認(rèn)的端口8090EXPOSE 8090ENTRYPOINT ['java','-Djava.security.egd=file:/dev/./urandom','-jar','/app.jar']
然后在pom文件里面配置docker-maven-plugin插件,在plugins節(jié)點(diǎn)下,添加一個plugin,內(nèi)容如下:
<!--使用docker-maven-plugin插件--> <plugin> <groupId>com.spotify</groupId> <artifactId>docker-maven-plugin</artifactId> <version>1.0.0</version> <!--將插件綁定在某個phase執(zhí)行--> <executions> <execution> <id>build-image</id> <!--將插件綁定在package這個phase上。也就是說,用戶只需執(zhí)行mvn package ,就會自動執(zhí)行mvn docker:build--> <phase>package</phase> <goals> <goal>build</goal> </goals> </execution> </executions> <configuration> <!--指定生成的鏡像名--> <imageName>jason/${project.artifactId}</imageName> <!--指定標(biāo)簽--> <imageTags> <imageTag>latest</imageTag> </imageTags> <!--指定 Dockerfile 路徑--> <dockerDirectory>${project.basedir}/src/main/resources/docker</dockerDirectory> <!--指定遠(yuǎn)程 docker api地址--> <dockerHost>http://58.87.113.58:2375</dockerHost> <!--這里是復(fù)制 jar 包到 docker 容器指定目錄配置 --> <resources> <resource> <targetPath>/</targetPath> <!--jar 包所在的路徑 此處配置的 即對應(yīng) target 目錄--> <directory>${project.build.directory}</directory> <!--需要包含的 jar包 ,這里對應(yīng)的是 Dockerfile中添加的文件名 --> <include>${project.build.finalName}.jar</include> </resource> </resources> </configuration> </plugin>
配置完成,現(xiàn)在使用maven package,即可將我們的jar包打成docker鏡像,可以使用idea右側(cè)的快捷方式,也可以使用命令:
mvn package
完成后,我們會在這里看見我們剛打好的鏡像包
運(yùn)行該鏡像,需要使用到docker的容器來承載它,我們右鍵創(chuàng)建
設(shè)置鏡像名稱,設(shè)置IP映射即可,我這里項(xiàng)目的port是8090,容器對外開放設(shè)置為8091
設(shè)置完之后我們點(diǎn)擊Run,訪問我們提前寫好的測試接口,測試結(jié)果
那么問題來了,我們開發(fā)的時候改完代碼就需要發(fā)布一次,不可能每次都先點(diǎn)一下package然后再run是吧,這樣多撈啊,我們把這兩個步驟串起來,不就行了嗎繼續(xù)編輯我們剛剛的配置,添加一個maven步驟即可
那么我們再次修改代碼后,再點(diǎn)擊Run,即可在線上看到最新的程序了,至此一個簡單的一鍵部署就完成了
附:java源碼下載
到此這篇關(guān)于Linux+Docker+SpringBoot+IDEA一鍵自動化部署的詳細(xì)步驟的文章就介紹到這了,更多相關(guān)Linux+Docker+SpringBoot+IDEA一鍵自動化部署內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. IntelliJ IDEA設(shè)置默認(rèn)瀏覽器的方法2. idea設(shè)置提示不區(qū)分大小寫的方法3. HTTP協(xié)議常用的請求頭和響應(yīng)頭響應(yīng)詳解說明(學(xué)習(xí))4. IntelliJ IDEA創(chuàng)建web項(xiàng)目的方法5. VMware中如何安裝Ubuntu6. docker容器調(diào)用yum報錯的解決辦法7. .NET SkiaSharp 生成二維碼驗(yàn)證碼及指定區(qū)域截取方法實(shí)現(xiàn)8. CentOS郵件服務(wù)器搭建系列—— POP / IMAP 服務(wù)器的構(gòu)建( Dovecot )9. css代碼優(yōu)化的12個技巧10. django創(chuàng)建css文件夾的具體方法
