一维费、服務(wù)器初始化
1. Linux 服務(wù)器安裝寶塔面板
2.使用ssh root@ip 的方式遠(yuǎn)程連接
3.安裝Docker ,參考:http://www.xiefeng.org/?id=3中的Docker安裝
二、項(xiàng)目配置
1.項(xiàng)目中 eureka 配置需加上: prefer-ip-address: true 具體配置列如:
eureka:
? instance:
? ? prefer-ip-address: true #以IP地址注冊(cè)到服務(wù)中心促王,相互注冊(cè)使用IP地址
? client:
? ? serviceUrl:
? ? ? defaultZone: http://xxx.xxx.xxx.xxx :9000/eureka/ #ip+port
? ? register-with-eureka: false
? ? fetch-registry: false
2.其余微服務(wù)的yml文件中也需配置:prefer-ip-address: true 具體配置列如:
eureka:
instance:
? ? lease-renewal-interval-in-seconds: 60 #沒(méi)過(guò)60秒給注冊(cè)中心發(fā)送心跳
? ? lease-expiration-duration-in-seconds: 120 #超過(guò)120秒沒(méi)發(fā)送心跳犀盟,讓注冊(cè)中心刪除實(shí)例
? ? prefer-ip-address: true
? client:
? ? service-url:
? ? ? defaultZone: http://xxx.xxx.xxx.xxx:9000/eureka #ip+port
3.微服務(wù)的pom.xml文件,配置打包插件,具體配置列如:
<build>
? ? ? ? <finalName>${project.artifactId}</finalName>
? ? ? ? <plugins>
? ? ? ? ? ? <plugin>
? ? ? ? ? ? ? ? <groupId>org.springframework.boot</groupId>
? ? ? ? ? ? ? ? <artifactId>spring-boot-maven-plugin</artifactId>
? ? ? ? ? ? </plugin>
? ? ? ? ? ? <!-- 跳過(guò)單元測(cè)試 -->
? ? ? ? ? ? <plugin>
? ? ? ? ? ? ? ? <groupId>org.apache.maven.plugins</groupId>
? ? ? ? ? ? ? ? <artifactId>maven-surefire-plugin</artifactId>
? ? ? ? ? ? ? ? <configuration>
? ? ? ? ? ? ? ? ? ? <skipTests>true</skipTests>
? ? ? ? ? ? ? ? </configuration>
? ? ? ? ? ? </plugin>
? ? ? ? ? ? <plugin>
? ? ? ? ? ? ? ? <groupId>com.spotify</groupId>
? ? ? ? ? ? ? ? <artifactId>docker-maven-plugin</artifactId>
? ? ? ? ? ? ? ? <version>1.0.0</version>
? ? ? ? ? ? ? ? <configuration>
? ? ? ? ? ? ? ? ? ? <imageName>${project.artifactId}</imageName>
? ? ? ? ? ? ? ? ? ? <dockerDirectory>${project.basedir}</dockerDirectory>
? ? ? ? ? ? ? ? ? ? <resources>
? ? ? ? ? ? ? ? ? ? ? ? <resource>
? ? ? ? ? ? ? ? ? ? ? ? ? ? <targetPath>/</targetPath>
? ? ? ? ? ? ? ? ? ? ? ? ? ? <directory>${project.build.directory}</directory>
? ? ? ? ? ? ? ? ? ? ? ? ? ? <include>${project.build.finalName}.jar</include>
? ? ? ? ? ? ? ? ? ? ? ? </resource>
? ? ? ? ? ? ? ? ? ? </resources>
? ? ? ? ? ? ? ? </configuration>
? ? ? ? ? ? ? ? <!-- 運(yùn)行命令 mvn clean package docker:build 打包并生成docker鏡像 -->
? ? ? ? ? ? </plugin>
? ? ? ? </plugins>
? ? </build>
4.編譯項(xiàng)目并打包 ,使用idea自帶的打包方式 : 右側(cè)Maven按鈕 -> 項(xiàng)目[root]->雙擊package ->打包成功,獲取jar包;
三. 服務(wù)器創(chuàng)建文件夾(使用寶塔面板)
1.在服務(wù)器非系統(tǒng)盤(pán)符中(如果有)創(chuàng)建對(duì)應(yīng)文件夾,以項(xiàng)目為例如下:
1)? mhxs-eureka-server (eureka注冊(cè)與發(fā)現(xiàn))
2)? mhxs-web-comment-api (客戶端)
3)? mhxs-web-novel-api (客戶端)
4)? mhxs-web-user-api (客戶端)
5)? mhxs-gateway (網(wǎng)關(guān)zuul,集成了swagger2)
2.上傳對(duì)應(yīng)的jar文件到對(duì)應(yīng)對(duì)應(yīng)的文件夾中.
3.在對(duì)應(yīng)文件夾中的分別創(chuàng)建Dockerfile文件,并編輯內(nèi)容例如:
FROM java:8
MAINTAINER "維護(hù)者:ww"?
VOLUME /www/jarslogs
ADD mhxs-web-user-api-1.jar /app.jar
EXPOSE 9003
CMD java -jar /app.jar
注1:其中微服務(wù)jar包修改了版本(如:xx-1.jar,xxx-2.jar,xxx-3.jar,....),對(duì)應(yīng)文件夾下的同理修改,目的是為了方便后期版本回退.
注2:注意修改對(duì)應(yīng)的jar名稱和端口
4.編寫(xiě)創(chuàng)建鏡像的腳本文件 : build_images.sh 和 相應(yīng)jar文件夾一級(jí),具體內(nèi)容列如:
#!/usr/bin/env bash
set -eo pipefail
modules=(mhxs-eureka-server mhxs-web-comment-api mhxs-web-novel-api mhxs-web-user-api mhxs-gateway)
for module in "${modules[@]}"; do
? ? docker build -t ${module} /www/jars/${module}
done
注:其中modules中的為對(duì)應(yīng)的 jar文件夾名稱
5.使用ssh連接到linux服務(wù)器,進(jìn)入到build_image.sh 文件夾下,創(chuàng)建Docker鏡像,操作如下:
sh build_image.sh
6.查看鏡像
Docker images
7.在jar包文件夾同一層中創(chuàng)建啟動(dòng)鏡像腳本:start_services.sh具體內(nèi)容例如:
#!/bin/bash
# eureka-server服務(wù)器檢測(cè)
serverStatus=0
# 訪問(wèn)eureka注冊(cè)中心,獲取http狀態(tài)碼
CODE=`curl -I -m 10 -o /dev/null -s -w %{http_code}? http://api.badgerlibrary.com:9000`
# 判斷狀態(tài)碼為200
if [[ $CODE -eq 200 ]]; then
? ? serverStatus=1
else?
? ? serverStatus=0
fi
# eureka-server服務(wù)器異常蝇狼,啟動(dòng)服務(wù)器
if [[ $serverStatus -eq 0 ]]; then
? ? echo "eureka-server服務(wù)啟動(dòng)中......."
? ? docker run -d -p 9000:9000 mhxs-eureka-server
? ? while :
? ? ? ? do
? ? ? ? ? ? # 訪問(wèn)eureka注冊(cè)中心阅畴,獲取http狀態(tài)碼
? ? ? ? ? ? CODE=`curl -I -m 10 -o /dev/null -s -w %{http_code}? http://api.badgerlibrary.com:9000`
? ? ? ? ? ? # 判斷狀態(tài)碼為200
? ? ? ? ? ? if [[ $CODE -eq 200 ]]; then
? ? ? ? ? ? ? ? # 輸出綠色文字,并跳出循環(huán)
? ? ? ? ? ? ? ? echo -e "\033[42;34m server is ok \033[0m"
? ? ? ? ? ? ? ? break
? ? ? ? ? ? else
? ? ? ? ? ? ? ? # 暫停1秒
? ? ? ? ? ? ? ? echo -e "server is starting >>>>>>"
? ? ? ? ? ? ? ? sleep 1
? ? ? ? ? ? fi
? ? ? ? done
? ? # while結(jié)束時(shí)迅耘,也就是eureka啟動(dòng)完成后贱枣,執(zhí)行容器中的run.sh。
? ? echo -e "\033[42;34m eureka-server 啟動(dòng)成功 \033[0m"? ?
? ? sleep 1
? ? echo -e "comment 開(kāi)始啟動(dòng)"
? ? docker run -d -p 9001:9001 mhxs-web-comment-api
? ? sleep 1
? ? echo -e "novel 開(kāi)始啟動(dòng)"
? ? docker run -d -p 9002:9002 mhxs-web-novel-api
? ? sleep 1
? ? echo -e "user 開(kāi)始啟動(dòng)"
? ? docker run -d -p 9003:9003 mhxs-web-user-api
? ? sleep 1
? ? echo -e "gateway 開(kāi)始啟動(dòng)"
? ? docker run -d -p 8088:8088 mhxs-gateway?
? ? echo -e "comment/novel/user/gateway 啟動(dòng)中,請(qǐng)稍后查看:http://api.badgerlibrary.com:9000"
else
? ? echo "server 服務(wù)正常"
? ? ##### 檢測(cè)comment服務(wù)
? ? CODEComment=`curl -I -m 10 -o /dev/null -s -w %{http_code}? https://api.badgerlibrary.com/api/comment/index`
? ? # 判斷狀態(tài)碼為200
? ? if [[ $CODEComment -eq 200 ]]; then
? ? ? ? echo "comment 服務(wù)正常"
? ? else
? ? ? ? echo "comment 服務(wù)異常豹障,重啟中......."
? ? ? ? docker run -d -p 9001:9001 mhxs-web-comment-api
? ? fi
? ? sleep 1
? ? ##### 檢測(cè)novel服務(wù)
? ? CODENovel=`curl -I -m 10 -o /dev/null -s -w %{http_code}? https://api.badgerlibrary.com/api/novel/index`
? ? # 判斷狀態(tài)碼為200
? ? if [[ $CODENovel -eq 200 ]]; then
? ? ? ? echo "novel 服務(wù)正常"
? ? else
? ? ? ? echo "novel 服務(wù)異常冯事,重啟中......."
? ? ? ? docker run -d -p 9002:9002 mhxs-web-novel-api
? ? fi
? ? sleep 1
? ? ##### 檢測(cè)user服務(wù)
? ? CODEUser=`curl -I -m 10 -o /dev/null -s -w %{http_code}? https://api.badgerlibrary.com/api/user/index`
? ? # 判斷狀態(tài)碼為200
? ? if [[ $CODEUser -eq 200 ]]; then
? ? ? ? echo "user 服務(wù)正常"
? ? else
? ? ? ? echo "user 服務(wù)異常,重啟中......."
? ? ? ? docker run -d -p 9003:9003 mhxs-web-user-api
? ? fi
? ? sleep 1
? ? ##### 檢測(cè)gateway服務(wù)
? ? CODEGateway=`curl -I -m 10 -o /dev/null -s -w %{http_code}? https://api.badgerlibrary.com/doc.html`
? ? # 判斷狀態(tài)碼為200
? ? if [[ $CODEGateway -eq 200 ]]; then
? ? ? ? echo "gateway 服務(wù)正常"
? ? else
? ? ? ? echo "gateway 服務(wù)異常血公,重啟中......."
? ? ? ? docker run -d -p 8088:8088 mhxs-gateway
? ? fi?
fi
注1: 其中CODE用于檢測(cè)對(duì)應(yīng)服務(wù)是否已經(jīng)啟動(dòng)成功,需根據(jù)具體項(xiàng)目修改.
注2: 啟動(dòng)方式分為全順序啟動(dòng)和非全順序啟動(dòng)
8: 查看鏡像容器:
docker ps -a
9:更新jar:
1) docker ps -a 查看全部容器
2) docker stop CONTAINER ID CONTAINER ID CONTAINER ID .... 方式停止鏡像運(yùn)行,關(guān)閉服務(wù)
? ? 注: CONTAINER ID 為對(duì)應(yīng)容器的ID
3) docker rm CONTAINER ID CONTAINER ID CONTAINER ID .... 方式刪除鏡像容器
4) docker rmi IMAGE ID? IMAGE ID? IMAGE ID? .... 方式刪除對(duì)應(yīng)鏡像
5) docker images 查看鏡像列表,確認(rèn)需要?jiǎng)h除的鏡像全部刪除.
6) 按照對(duì)應(yīng)的1到8的步驟,更新jar。
10.查看日志缓熟,有兩種方法
1)直接通過(guò)寶塔面板可以找到對(duì)應(yīng)日志位置:
日志默認(rèn)都會(huì)以json-file的格式存儲(chǔ)于/var/lib/docker/containers/<容器id>/<容器id>-json.log下
2) 使用命令查看
docker logs -f 容器ID
-f :不間斷持續(xù)輸出