idea快速實現(xiàn)將SpringBoot項目打包Docker鏡像并部署
1.修改docker的配置文件
修改文件信息路徑如下:
/etc/docker/daemon.json
在配置文件中添加以下內(nèi)容:
"hosts": ["tcp://0.0.0.0:2375", "unix:///var/run/docker.sock"]
注意:如果沒有這個daemon.json,就自己在/etc/docker/目錄下創(chuàng)建一個
touch daemon.json
tcp是開啟遠程訪問,unix是本機訪問,不開啟本機訪問,在服務器上使用時會有以下錯誤:
Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
修改完成之后依次執(zhí)行以下命令:
#重新加載配置文件 systemctl daemon-reload # 重啟服務 systemctl restart docker.service # 查看端口是否開啟 默認端口2375 netstat -anp|grep 2375
2.配置端口開放
依次執(zhí)行以下命令
添加指定需要開放的端口: firewall-cmd --zone=public --add-port=2375/tcp --permanent 重載入添加的端口: firewall-cmd --reload 查詢指定端口是否開啟成功: firewall-cmd --query-port=2375/tcp
注意:以上配置全是在防火墻開啟的情況下進行,如果未開啟系統(tǒng)防火墻,則無需以上配置,比如我的服務器就 沒有配置防火墻,運行時則顯示以下信息:
最后我們看看我們的配置是否生效
curl http://127.0.0.1:2375/info
如果出現(xiàn) 以下信息則說明配置成功
3.IDEA安裝Docker插件
如果你的idea版本較高,則內(nèi)置了docker插件
如果沒有也不要擔心,我們自行安裝即可
4.IDEA配置docker
注意:我上面的192.168.1.2是我自己的服務器Ip,只需修改成你的docker所在服務器ip即可
點擊Apply之后會在你的service中彈出
點擊連接,我們就會發(fā)現(xiàn)我們docker配置的容器信息
5.SpringBoot整合Docker配置
5.1 安裝pom依賴
安裝插件:Docker-maven-plugin
<!--docker-maven-plugin插件打包--> <plugin> <groupId>com.spotify</groupId> <artifactId>docker-maven-plugin</artifactId> <version>1.0.0</version> <configuration> <!--鏡像名稱--> <imageName>${project.artifactId}</imageName> <!--指定標簽--> <imageTags> <imageTag>latest</imageTag> </imageTags> <!--基礎鏡像jdk1.8--> <baseImage>java</baseImage> <!--制作者提供本人信息--> <maintainer>ninesun@qq.com</maintainer> <!--切換到Root目錄--> <workdir>/ROOT</workdir> <cmd>["java", "-version"]</cmd> <entryPoint>["java", "-jar", "${project.build.finalName}.jar"]</entryPoint> <!--指定DockerFile路徑--> <!-- <dockerDirectory>${project.basedir}/src/main/docker</dockerDirectory>--> <!--指定遠程docker api地址--> <dockerHost>http://192.168.1.2:2375</dockerHost> <!-- 這里是復制 jar 包到 docker 容器指定目錄配置 --> <resources> <resource> <targetPath>/ROOT</targetPath> <!--用于指定需要復制的根目錄--> <directory>${project.build.directory}</directory> <!--用于指定需要復制的jar文件--> <include>${project.build.finalName}.jar</include> </resource> </resources> </configuration> </plugin>
我所有的maven配置如下:
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.6.6</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>docker</artifactId> <version>0.0.1-SNAPSHOT</version> <name>docker</name> <description>docker</description> <properties> <java.version>11</java.version> <maven.test.skip>true</maven.test.skip> <maven.javadoc.skip>true</maven.javadoc.skip> </properties> <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> <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>${project.artifactId}</imageName> <!--指定標簽--> <imageTags> <imageTag>latest</imageTag> </imageTags> <!--基礎鏡像jdk1.8--> <baseImage>java</baseImage> <!--制作者提供本人信息--> <maintainer>ninesun@qq.com</maintainer> <!--切換到Root目錄--> <workdir>/ROOT</workdir> <cmd>["java", "-version"]</cmd> <entryPoint>["java", "-jar", "${project.build.finalName}.jar"]</entryPoint> <!--指定DockerFile路徑--> <!-- <dockerDirectory>${project.basedir}/src/main/docker</dockerDirectory>--> <!--指定遠程docker api地址--> <dockerHost>http://192.168.1.2:2375</dockerHost> <!-- 這里是復制 jar 包到 docker 容器指定目錄配置 --> <resources> <resource> <targetPath>/ROOT</targetPath> <!--用于指定需要復制的根目錄--> <directory>${project.build.directory}</directory> <!--用于指定需要復制的jar文件--> <include>${project.build.finalName}.jar</include> </resource> </resources> </configuration> </plugin> </plugins> </build> </project>
注意:在我們拉取插件成功之后,我們會發(fā)現(xiàn)目錄結構變成如下所示 :
我們需要刪除一個啟動類,否則會導致打包失敗,我將DockerApplication直接刪除了
5.2 build鏡像
在build鏡像之前,我們需要先進行項目的打包操作
通過cmd進入到我們的項目目錄
執(zhí)行
mvn docker:build
出現(xiàn) 以下信息表示打包成功
接下來回到我們的idea,可以看到
這個就是我們打包好的鏡像
在服務器上執(zhí)行
docker images
也可以看到該鏡像的信息
5.3 啟動鏡像
在我們服務器內(nèi)執(zhí)行
docker run -d --name idea-docker-test -p 8089:8080 docker
注:我之所以暴露出8089端口,只要是因為8080沖突了,自己看自己的情況改就好
接下來我們訪問一下我們寫的測試接口:
可以看到已經(jīng)部署成功,同時也可訪問成功了
我們可以看到在 Idea里也可看到我們剛剛啟動成功的鏡像以及輸出的日志了
到此這篇關于idea快速實現(xiàn)將SpringBoot項目打包Docker鏡像并部署的文章就介紹到這了,更多相關SpringBoot打包Docker鏡像部署內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
logback如何去掉DubboMonitor煩人的INFO日志
這篇文章主要介紹了logback如何去掉DubboMonitor煩人的INFO日志方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07spring的TransactionSynchronizationAdapter事務源碼解析
這篇文章主要介紹了spring的TransactionSynchronizationAdapter事務源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09Mybatis-Plus同時使用邏輯刪除和唯一索引的問題及解決辦法(報數(shù)據(jù)重復Duplicate entry的
在開發(fā)中,我們經(jīng)常會有邏輯刪除和唯一索引同時使用的情況,但當使用mybatis plus時,如果同時使用邏輯刪除和唯一索引,會報數(shù)據(jù)重復Duplicate entry的問題,如何解決這個問題呢,小編給大家分享Mybatis-Plus同時使用邏輯刪除和唯一索引的問題及解決辦法,一起看看吧2023-11-11Java ScheduledExecutorService的具體使用
ScheduledExecutorService有線程池的特性,也可以實現(xiàn)任務循環(huán)執(zhí)行,本文主要介紹了Java ScheduledExecutorService的具體使用,具有一定的參考價值,感興趣的可以了解一下2023-05-05舉例說明JAVA調(diào)用第三方接口的GET/POST/PUT請求方式
在日常工作和學習中,有很多地方都需要發(fā)送請求,這篇文章主要給大家介紹了關于JAVA調(diào)用第三方接口的GET/POST/PUT請求方式的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-01-01Java實現(xiàn)將Object轉(zhuǎn)換成指定Class對象的操作代碼
這篇文章主要介紹了Java實現(xiàn)將Object轉(zhuǎn)換成指定Class對象的操作,在Java中,將Object轉(zhuǎn)換為指定類型的Class對象實際上是兩個不同概念的操作,由于你提到的“將Object轉(zhuǎn)換成指定Class對象”可能有些混淆,我將分別展示這兩種操作的示例代碼,需要的朋友可以參考下2024-09-09java中的equals()和toString()方法實例詳解
這篇文章主要介紹了java中的equals()和toString()方法實例詳解的相關資料,這里舉例說明,并附實例代碼,和實現(xiàn)效果圖,需要的朋友可以參考下2016-11-11教你用java?stream對集合中的對象按指定字段進行分組并統(tǒng)計
這篇文章主要給大家介紹了關于用java?stream對集合中的對象按指定字段進行分組并統(tǒng)計的相關資料,本文主要介紹了如何利用Java的Stream流來實現(xiàn)在list集合中,對具有相同name屬性的對象進行匯總計算的需求,需要的朋友可以參考下2024-10-10