欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

IDEA快速部署Spring?Boot?項目到Docker的實現(xiàn)方法

 更新時間:2023年07月28日 08:36:39   作者:結(jié)構(gòu)化思維wz  
本文主要介紹了IDEA快速部署Spring?Boot?項目到Docker的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、IDEA 連接 Docker

我們通常使用TCP的方式連接Docker,所以我們需要配置Docker并開放端口,如果是本地虛擬機,可以簡單使用http的方式進行連接(不建議),如果你是遠程服務(wù)器,請務(wù)必采用安全的連接方式(https);

自己的虛擬機

如果是自己的虛擬機,可以不需要創(chuàng)建CA證書??梢允褂?code>http://ip:端口號的形式連接。

:one: 編輯docker.service文件

vim /usr/lib/systemd/system/docker.service

找到 [Service] 節(jié)點,修改 ExecStart 屬性,增加 -H tcp://0.0.0.0:2375

img

這樣相當(dāng)于對外開放的是 2375 端口,當(dāng)然也可以根據(jù)自己情況修改成其他的。

:two: 重新加載Docker配置生效

systemctl daemon-reload 
systemctl restart docker 

:three: 測試是否能訪問

#瀏覽器訪問
ip:2375/vsersion

如果訪問成功證明已配置成功。

如果無妨訪問,請檢查防火墻是否開放2375端口:

#查看防火墻開放列表
firewall-cmd --list-ports
#增加2375端口
firewall-cmd --zone=public --add-port=2375/tcp --permanent
#重啟防火墻
firewall-cmd --reload

:four: 通過IDEA連接

image-20230328160853784

遠程服務(wù)器

**如果是遠程服務(wù)器,一定要創(chuàng)建CA證書。**使用https://ip:端口號的形式連接。(否則你的Docekr任何人都可以推送鏡像,分分鐘取挖礦)

下面我將命令都抽離出來,方便運行。[ip]替換為你的服務(wù)器ip

(如果想看更詳細的分步驟運行,請看[這篇文章](Docker開啟遠程安全訪問),但是注意其中5.2章節(jié)的一個錯誤:extfile.cnf 這里不能用官方給的,不要DNS)

#1、創(chuàng)建CA私鑰和CA公鑰
mkdir -p /usr/local/ca
cd /usr/local/ca
#2.然后在Docker守護程序的主機上,生成CA私鑰和公鑰:執(zhí)行完后,這里會要我們輸入密碼,請牢記,例如我這里輸入wang123
openssl genrsa -aes256 -out ca-key.pem 4096
#3.補全CA證書信息,執(zhí)行后需要輸入,訪問密碼、國家、省、市、組織名稱、單位名稱、CommonName、郵箱等
openssl req -new -x509 -days 365 -key ca-key.pem -sha256 -out ca.pem
#4.生成server-key.pem
openssl genrsa -out server-key.pem 4096
#5.用CA簽署公鑰:
openssl req -subj "/CN=[ip]" -sha256 -new -key server-key.pem -out server.csr
#6.匹配白名單,允許指定的ip可以連接到服務(wù)器中的docker,這里允許所有攜帶ca的ip
echo subjectAltName = IP:[ip],IP:0.0.0.0 >> extfile.cnf
#7.將Docker守護程序密鑰的擴展使用屬性設(shè)置為僅用于服務(wù)器身份驗證:
echo extendedKeyUsage = serverAuth >> extfile.cnf
#8.生成簽名證書,執(zhí)行完后需要輸入密碼,上面我們設(shè)置的密碼(wang123)
openssl x509 -req -days 365 -sha256 -in server.csr -CA ca.pem -CAkey ca-key.pem \
  -CAcreateserial -out server-cert.pem -extfile extfile.cnf
#9. 生成客戶端的key.pem
openssl genrsa -out key.pem 4096
openssl req -subj '/CN=client' -new -key key.pem -out client.csr
#10.使秘鑰適合客戶端身份驗證
echo extendedKeyUsage = clientAuth >> extfile.cnf
echo extendedKeyUsage = clientAuth > extfile-client.cnf
#11.生成簽名證書,執(zhí)行完后需要輸入密碼
openssl x509 -req -days 365 -sha256 -in client.csr -CA ca.pem -CAkey ca-key.pem \
  -CAcreateserial -out cert.pem -extfile extfile-client.cnf
#12.刪除不需要的文件
rm -v client.csr server.csr extfile.cnf extfile-client.cnf
#13.設(shè)置權(quán)限
chmod -v 0400 ca-key.pem key.pem server-key.pem
chmod -v 0444 ca.pem server-cert.pem cert.pem
#14.歸集服務(wù)器證書
cp server-*.pem /etc/docker/
cp ca.pem /etc/docker/

創(chuàng)建完證書之后,我們需要修改Docker配置:

#使Docker守護程序僅接收來自提供CA信任的證書的客戶端的鏈接
vim /lib/systemd/system/docker.service

ExecStart 屬性值進行替換:

ExecStart=/usr/bin/dockerd --tlsverify --tlscacert=/usr/local/ca/ca.pem --tlscert=/usr/local/ca/server-cert.pem --tlskey=/usr/local/ca/server-key.pem -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock復(fù)制代碼

重新加載daemon并重啟docker

systemctl daemon-reload
systemctl restart docker

注意,請檢查防火墻和安全組是否都開放了此端口:2375

然后將ca證書下載到本地:

image-20230328163253175

配置完就可以取IDEA的Docker中進行配置:

image-20230328163212670

二、Maven插件與Dockerfile

docker-maven-plugin

我們IDEA已經(jīng)可以連接Docker,我們想在package的時候,把打包鏡像推送到Docker當(dāng)中,我們需要配置Maven插件:

<plugin><!--制作docker鏡像的maven插件-->
   <groupId>com.spotify</groupId>
   <artifactId>docker-maven-plugin</artifactId>
   <version>1.2.2</version>
   <executions>
      <execution>
         <id>build-image</id>
         <phase>package</phase>
         <goals>
            <goal>build</goal>
         </goals>
      </execution>
   </executions>
   <configuration>
      <imageName>${project.artifactId}</imageName><!--鏡像名-->
      <imageTags>
         <imageTag>latest</imageTag>
      </imageTags>
      <dockerCertPath>./ca</dockerCertPath><!--證書所在的目錄-->
      <dockerDirectory>${project.basedir}</dockerDirectory><!--Dockerfile所在的目錄-->
      <dockerHost>https://ip:2375</dockerHost><!--docker所在的宿主機地址-->
      <resources>
         <resource><!--這里配置的就是打包后jar所在的位置-->
            <targetPath>/</targetPath>
            <directory>${project.build.directory}</directory>
            <include>${project.build.finalName}.jar</include>
         </resource>
      </resources>
   </configuration>
</plugin>

Dockerfile

FROM java:8
#作者
MAINTAINER wangze
#掛在
VOLUME /tmp
#將jar包添加到容器中并更名
ADD project-manage-service-0.0.1-SNAPSHOT.jar pms.jar
#運行jar
RUN bash -c 'touch /pms.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/pms.jar"]

三、項目打包上傳鏡像

當(dāng)我們執(zhí)行package操作后,會自動將jar包作為image上傳到Docker中:

image-20230328163820463

可以在IDEA右下角的服務(wù)中,找到Docker連接,查看鏡像

image-20230328163958744

四、容器的創(chuàng)建與運行

容器的創(chuàng)建

先找到剛才打包的鏡像:

image-20230328115451996

然后右鍵創(chuàng)建一個容器:

這里端口格式為:主機端口:容器端口

例如你的項目在容器中是8080端口,你主機的8080已經(jīng)被占用,你可以這樣寫:

#訪問的時候 http://ip:8090/
8090:8080

image-20230328130613849

運行容器,我們可以看到對應(yīng)的日志:

image-20230328130552226

環(huán)境的檢查

首先檢查服務(wù)器的防火墻:

firewall-cmd --list-ports

如果主機端口沒有開放,則開放防火墻:

firewall-cmd --zone=public --add-port=8090/tcp --permanent
#重啟防火墻
firewall-cmd --reload

PS: 如果是遠程服務(wù)器,記得配置安全組

訪問項目檢驗

訪問項目的地址,可以正常訪問,即為成功發(fā)布

參考文章:

Docker開啟遠程安全訪問

到此這篇關(guān)于IDEA快速部署Spring Boot 項目到Docker的實現(xiàn)方法的文章就介紹到這了,更多相關(guān)IDEA部署Spring Boot到Docker內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java?Web開發(fā)環(huán)境配置詳解

    Java?Web開發(fā)環(huán)境配置詳解

    這篇文章主要介紹了Java?Web開發(fā)環(huán)境配置詳解,對初學(xué)者是個必備的過程,有需要的可以了解一下
    2016-11-11
  • Java批量修改文件名的實例代碼

    Java批量修改文件名的實例代碼

    幾天前在163公開課上下了一些mp4視頻文件。發(fā)現(xiàn)課程名和文件名不對應(yīng),想到編個程序批量修改。先分析網(wǎng)頁源代碼將課程名和文件名一一對應(yīng),存儲在一個文件里,然后使用Java讀取該文件進而修改文件名。
    2013-04-04
  • JDK集合源碼之解析TreeMap(二)

    JDK集合源碼之解析TreeMap(二)

    下面小編就為大家?guī)硪黄獪\談java中的TreeMap 排序與TreeSet 排序。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-07-07
  • Java正則表達式匹配不到結(jié)果的解決

    Java正則表達式匹配不到結(jié)果的解決

    這篇文章主要介紹了Java正則表達式匹配不到結(jié)果的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • SpringBoot跨域Jsonp和Cors的方法

    SpringBoot跨域Jsonp和Cors的方法

    這篇文章主要介紹了SpringBoot跨域Jsonp和Cors的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • java實現(xiàn)MD5加密方法匯總

    java實現(xiàn)MD5加密方法匯總

    本文給大家匯總介紹了2種java實現(xiàn)MD5加密的方法,非常的實用,這里分享給大家,學(xué)習(xí)下其中的思路,對大家學(xué)習(xí)java非常有幫助。
    2015-10-10
  • java中static的用法及注意點

    java中static的用法及注意點

    在本篇文章里小編給大家整理的是一篇關(guān)于java中static的用法及注意點,有興趣的朋友們可以學(xué)習(xí)下。
    2021-03-03
  • Java 反射機制實例詳解

    Java 反射機制實例詳解

    這篇文章主要介紹了Java 反射機制實例詳解的相關(guān)資料,這里對java中反射機制進行了詳細的分析,需要的朋友可以參考下
    2017-09-09
  • java中優(yōu)化大量if...else...方法總結(jié)

    java中優(yōu)化大量if...else...方法總結(jié)

    在我們平時的開發(fā)過程中,經(jīng)常可能會出現(xiàn)大量If else的場景,代碼顯的很臃腫,非常不優(yōu)雅,下面這篇文章主要給大家介紹了關(guān)于java中優(yōu)化大量if...else...方法的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • 詳解java開發(fā)webservice的幾種方式

    詳解java開發(fā)webservice的幾種方式

    webservice的應(yīng)用已經(jīng)越來越廣泛了,下面介紹幾種在Java體系中開發(fā)webservice的方式,有興趣的可以了解一下。
    2016-11-11

最新評論