IDEA快速部署Spring Boot 項目到Docker
一、IDEA 連接 Docker
我們通常使用TCP的方式連接Docker,所以我們需要配置Docker并開放端口,如果是本地虛擬機,可以簡單使用http的方式進行連接(不建議),如果你是遠程服務(wù)器,請務(wù)必采用安全的連接方式(https);
自己的虛擬機
如果是自己的虛擬機,可以不需要創(chuàng)建CA證書??梢允褂?code>http://ip:端口號的形式連接。
1?? 編輯docker.service文件
vim /usr/lib/systemd/system/docker.service
找到 [Service] 節(jié)點,修改 ExecStart 屬性,增加 -H tcp://0.0.0.0:2375
這樣相當于對外開放的是 2375 端口,當然也可以根據(jù)自己情況修改成其他的。
2?? 重新加載Docker配置生效
systemctl daemon-reload
systemctl restart docker
3?? 測試是否能訪問
#瀏覽器訪問
ip:2375/vsersion
如果訪問成功證明已配置成功。
如果無妨訪問,請檢查防火墻是否開放2375端口:
#查看防火墻開放列表 firewall-cmd --list-ports #增加2375端口 firewall-cmd --zone=public --add-port=2375/tcp --permanent #重啟防火墻 firewall-cmd --reload
4?? 通過IDEA連接
遠程服務(wù)器
**如果是遠程服務(wù)器,一定要創(chuàng)建CA證書。**使用https://ip:端口號
的形式連接。(否則你的Docekr任何人都可以推送鏡像,分分鐘取挖礦)
下面我將命令都抽離出來,方便運行。[ip]
替換為你的服務(wù)器ip
(如果想看更詳細的分步驟運行,請看[這篇文章](Docker開啟遠程安全訪問 - niceyoo - 博客園 (cnblogs.com)),但是注意其中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
重新加載daemon并重啟docker
systemctl daemon-reload
systemctl restart docker
注意,請檢查防火墻和安全組是否都開放了此端口:2375
然后將ca證書下載到本地:
配置完就可以取IDEA的Docker中進行配置:
二、Maven插件與Dockerfile
docker-maven-plugin
我們IDEA已經(jīng)可以連接Docker,我們想在package的時候,把打包鏡像推送到Docker當中,我們需要配置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"]
三、項目打包上傳鏡像
當我們執(zhí)行package
操作后,會自動將jar包作為image上傳到Docker中:
可以在IDEA右下角的服務(wù)中,找到Docker連接,查看鏡像
四、容器的創(chuàng)建與運行
容器的創(chuàng)建
先找到剛才打包的鏡像:
然后右鍵創(chuàng)建一個容器:
這里端口格式為:
主機端口:容器端口
例如你的項目在容器中是8080端口,你主機的8080已經(jīng)被占用,你可以這樣寫:
#訪問的時候 http://ip:8090/ 8090:8080
運行容器,我們可以看到對應(yīng)的日志:
環(huán)境的檢查
首先檢查服務(wù)器的防火墻:
firewall-cmd --list-ports
如果主機端口沒有開放,則開放防火墻:
firewall-cmd --zone=public --add-port=8090/tcp --permanent
#重啟防火墻
firewall-cmd --reload
PS: 如果是遠程服務(wù)器,記得配置安全組
訪問項目檢驗
訪問項目的地址,可以正常訪問即為成功
參考文章:文章來源:http://www.zghlxwxcb.cn/news/detail-409742.html
Docker開啟遠程安全訪問 - niceyoo - 博客園 (cnblogs.com)文章來源地址http://www.zghlxwxcb.cn/news/detail-409742.html
到了這里,關(guān)于IDEA快速部署Spring Boot 項目到Docker的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!