SpringCloud Alibaba 系列文章已經寫了 16 篇了,基本框架大體完成,業務相關的邏輯還需要根據項目本身的業務進行梳理改造。
今天將是本系列的最後一篇 - SpringCloud 容器化部署(理論上最後一篇,不排除後面會對相關組件進行升級)
開啓 Docker 遠程訪問
由於我是在 windows 上進行開發沒有安裝 docker,所以需要找一臺安裝好 docker 的服務器並開啓遠程訪問。使用 mac 的同學請忽略。
-
打開 docker 配置文件
vi /lib/systemd/system/docker.service
-
開放 2376 端口
找到ExecStart=/usr/bin/dockerd
所在行,在後面追加-H tcp://0.0.0.0:2376 -H unix:///var/run/docker.sock
,修改完成的效果如下:
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock -H tcp://0.0.0.0:2376 -H unix:///var/run/docker.sock
- 重啓 docker 服務
systemctl daemon-reload
systemctl restart docker.service
- 使用 netstat 查看端口
netstat -nptl
- 訪問/info,確定端口正常開放
curl http://127.0.0.1:2376/info
docker-maven-plugin 構建 docker 鏡像
在開始打包之前一定要先在bom
和common
模塊執行mvn clean install
命令,否則打包不成功。
看過本系列文章的人一定也知道 docker 和 docker-compose 的相關指令了,這裏就不再說明。
- 在需要構建組件的模塊引入 docker-maven-plugin 插件
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>1.2.2</version>
<configuration>
<imageName>${project.artifactId}</imageName>
<imageTags>
<imageTag>latest</imageTag>
</imageTags>
<!--指定Dockerfile路徑-->
<dockerDirectory>${project.basedir}/src/main/docker</dockerDirectory>
<dockerHost>http://xxx.xx.xx.xx:2376</dockerHost>
<resources>
<resource>
<targetPath>/</targetPath>
<!--${project.basedir}/target-->
<directory>${project.build.directory}</directory>
<!--${project.artifactId}-${project.version}-->
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
這裏端口與前面開放的端口保持一致。
- 在模塊的
src/main/docker
目錄下建立 Dockerfile 文件
FROM openjdk:8-jdk-alpine
VOLUME /tmp
ADD cloud-gateway-1.0.0.jar app.jar
RUN sh -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
每個模塊需要自行修改 ADD
指令
- 在模塊下執行如下命令構建 docker 鏡像
mvn clean package docker:build -DskipTests
執行效果如下:
- 構建完成後登陸服務器查看 docker 鏡像
docker images
- 啓動鏡像,帶上
--rm
指令便於刪除容器。
docker run -d -p 5000:5000 --rm auth-service
docker run -d -p 8010:8010 --rm account-service
docker run -d -p 8090:8090 --rm cloud-gateway
- 查看是否正常啓動
- 使用 postman 進行測試
服務正常響應!
使用 docker-compose 啓動
- 創建
cloud-service.yml
文件編排鏡像
version: "3"
services:
auth-service:
container_name: auth-service
image: auth-service:latest
ports:
- "5000:5000"
restart: always
cloud-gateway:
container_name: cloud-gateway
image: cloud-gateway:latest
ports:
- "8090:8090"
restart: always
account-service:
container_name: account-service
image: account-service:latest
ports:
- "8010:8010"
restart: always
- 將文件上傳至服務器,使用如下腳本啓動服務
docker-compose -f cloud-service up
- 使用 postman 進行測試
SpringCloud 的容器化部署還是比較簡單的,你還不來試一下?