目錄
- 環(huán)境說明
- Docker安裝
- Gogs安裝
- Docker中托管.NetCore服務(wù)
- Jenkins安裝
- 使用Jenkins自動化
- 總結(jié)
環(huán)境說明
- 騰訊云輕量服務(wù)器, 配置
1c 2g 6mb
,系統(tǒng)是 ubuntu 20.14
,Docker 和 Jenkins 都在這臺服務(wù)器上面,
- 群暉218+一臺,Gogs 在這臺服務(wù)器上。
Docker安裝
卸載舊的 Docker
sudo apt-get remove docker docker-engine docker.io containerd runc
更新 apt 包索引并安裝包以允許 apt 通過 HTTPS 使用存儲庫
sudo apt-get update
sudo apt-get install \
apt-transport-https \
ca-certificates \
curl \
gnupg \
lsb-release
添加 Docker 官方的 GPG 密鑰
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
安裝 Docker
sudo apt-get install docker-ce docker-ce-cli containerd.io
通過運(yùn)行 hello-world 驗(yàn)證 Docker 是否已正確安裝。輸出 Hello from Docker! 表示安裝成功
sudo docker run hello-world
不同的系統(tǒng)安裝方式可以查閱 docker 官方安裝說明
Gogs安裝
Gogs 是一款用 Go 語言開發(fā)的輕量級極易搭建的自助 Git 服務(wù)。 選擇 Gogs 主要因?yàn)樗鄬τ?Gitlab 動則幾個G的內(nèi)用暫用率來說輕太多了。Gogs 會大大減低系統(tǒng)消耗,跑起來也就占用100mb內(nèi)存。我的 Gogs 是跑在群暉上面的,效果都是一樣,都是在 Docker 中托管
拉取 Gogs 鏡像
sudo docker pull gogs/gogs
創(chuàng)建 Gogs 文件掛載路徑
啟動容器 6022 是 https,6080 是 http,可以通過 docker ps
命令來查看是否啟動成功。
docker run -d --name=my_gogs -p 6022:22 -p 6080:3000 -v /var/gogs:/data gogs/gogs
容器啟動后通過 http://xxxxxxxx:6080
進(jìn)行 Gogs 的初始配置
![](/d/20211016/3d13e321e416c4f684e76c762dabf6af.gif)
數(shù)據(jù)庫類型建議選擇 linux 自帶的 SQLite3 ,支撐十幾個人左右的團(tuán)隊使用足夠了。域名填寫 Gogs 所在服務(wù)器的域名或者 ip 地址。http 端口號和容器內(nèi)部端口一致,應(yīng)用 URL 填寫訪問 Gogs 的域名端口或 ip 端口,點(diǎn)擊安裝后注冊一個新用戶登陸即可
![](/d/20211016/48376251e36436be803effa2c4c57d0e.gif)
Gogs安裝完成后新建一個 Demo 倉庫稍后使用
![](/d/20211016/2886b7636917e5dbc43651c47883b6ef.gif)
Gogs 官方文檔
Docker中托管.NetCore服務(wù)
新建一個 WebApi 項(xiàng)目
![](/d/20211016/979b1ea9a590e9b63615814936fe04d4.gif)
項(xiàng)目中增加一個 DockerFile 文件并且簡單配置
# 指定依賴版本
FROM mcr.microsoft.com/dotnet/aspnet:5.0-buster-slim
WORKDIR /app
COPY . /publish
WORKDIR /publish
# 設(shè)置Docker容器對外暴露端口
EXPOSE 80
# 設(shè)置時區(qū)
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
&& echo 'Asia/Shanghai' >/etc/timezone
# 程序入口
ENTRYPOINT ["dotnet", "DemoWebApi.dll"]
發(fā)布Api服務(wù),如果發(fā)布文件中沒有 DockerFile 文件需要手動修改項(xiàng)目文件,發(fā)布成功后將發(fā)布文件 copy 到服務(wù)器指定的文件夾中
<ItemGroup>
<None Update="Dockerfile">
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
</None>
</ItemGroup>
進(jìn)入服務(wù)器剛 copy 的發(fā)布文件根路徑下,執(zhí)行 docker build -t {REPOSITORY}:{TAG} .
命令 通過 DockerFile 來生成 Docker 鏡像文件,REPOSITORY 是鏡像的名字,TAG 是標(biāo)簽。譬如 docker build -t demo:v1 .
![](/d/20211016/f7742d423966b75af9ccbdc1cd3de93a.gif)
![](/d/20211016/d353b78f7dd0584844e9c3a7b01c2e2b.gif)
通過 docker images
命令來查看生成的所有鏡像
![](/d/20211016/8c20c50d2a394d8b2b08fb9104a10445.gif)
鏡像生成成功后就可以通過鏡像創(chuàng)建并運(yùn)行容器了。執(zhí)行 docker run --name demoapi -dp 5009:80/tcp demo:v1
命令創(chuàng)建并運(yùn)行容器
-d:后臺運(yùn)行容器,并返回容器ID;
-p:指定端口映射,格式為:主機(jī)(宿主)端口:容器端口,容器的端口就是你程序啟動的端口,建議直接在項(xiàng)目中寫死。
-- name:容器名字
執(zhí)行后可以通過 docker ps
查看所有運(yùn)行起來的容器狀態(tài),需要查看所有容器可以使用 docker ps -a
命令
![](http://img.jbzj.com/file_images/article/202106/2021628170043867.png?202152817056)
用 postman 測試一下是否部署成功了
![](/d/20211016/5ecad950eecc0add26740c18978f99f3.gif)
列舉一些docker常用命令
docker restart {容器id}
#重啟容器
docker start {容器id}
#啟動容器
docker attach {容器id}
# 這樣進(jìn)入容器退出會導(dǎo)致容器也退出,attach 可以用戶看容器的標(biāo)準(zhǔn)輸出
docker attach {容器id} --sig-proxy=false
# 加上參數(shù)不會導(dǎo)致同期退出
docker exec -it {容器id} /bin/bash
# 進(jìn)入容器需要在容器中執(zhí)行命令需要使用 exec 命令
docker logs {容器id} -f
# 跟蹤日志輸出 -f 跟蹤日志輸出
docker rm -f {容器id}
# 刪除已經(jīng)停止的容器
docker rmi {REPOSITORY:TAG}
# 刪除指定鏡像
docker image prune
# 刪除懸空鏡像,也就是沒有被容器引用的鏡像
到這里服務(wù)已經(jīng)在 Docker 完成了托管,但是每次發(fā)布都需要 build 新的鏡像,然后停止老的容器,在創(chuàng)建一個新的容器,無形中增加了工作量。Jenkins 可以替我們完成這些工作
Jenkins安裝
Jenkins 是依賴 java 的,所以需要安裝 java 的 sdk,這里選擇 java8
sudo apt-get install openjdk-8-jdk
安裝 LTS 版本的 Jenkins
wget -q -O - https://pkg.jenkins.io/debian-stable/jenkins.io.key | sudo apt-key add -
sudo sh -c 'echo deb https://pkg.jenkins.io/debian-stable binary/ > \
/etc/apt/sources.list.d/jenkins.list'
sudo apt-get update
sudo apt-get install jenkins
查看運(yùn)行狀態(tài) systemctl status jenkins
正常會輸出如下內(nèi)容
![](/d/20211016/309afde860cb6e604e7b647a16880edd.gif)
Jenkins 默認(rèn)端口是 8080,安裝成功后通過 http://xxxx:8080
即可訪問,第一步需要先解鎖,管理員密碼會在安裝成功后輸出,也可以通過命令 cat /var/lib/jenkins/secrets/initialAdminPassword
![](/d/20211016/0eb76da1081301afef87eb017d86545d.gif)
輸入密碼后進(jìn)入初始化頁面,選擇安裝推薦插件
![](/d/20211016/e446e15e594567880168600980fb65c8.gif)
插件安裝進(jìn)度,需要一些些時間
![](/d/20211016/4de26e2d3f2fd84022837fff4532eddd.gif)
結(jié)束后創(chuàng)建管理賬號登錄即可,進(jìn)入系統(tǒng)管理,選擇插件管理,搜索gogs
插件后安裝。
![](/d/20211016/0f6af6382b2e258cf5cb369df793e482.gif)
安裝后需要重啟一下 Jenkins,訪問鏈接 http://xxxx:8080/restart
后點(diǎn)擊重啟,或者通過執(zhí)行 service jenkins restart
重啟
![](/d/20211016/652c1b07e4edc0c6fa1346e0cf79fa32.gif)
為了方便執(zhí)行腳本,需要讓 Jenkins 以 root 用戶來運(yùn)行,編輯文件 vim /etc/sysconfig/jenkins
或 vim /etc/default/jenkins
取消 JENKINS_USER
注釋,并把值設(shè)置成 JENKINS_USER="root"
后修改文件夾權(quán)限
chown -R root:root /var/lib/jenkins
chown -R root:root /var/cache/jenkins
chown -R root:root /var/log/jenkins
jenkins 常用操作
- 啟動
service jenkins start
- 重啟
service jenkins restart
或訪問 http://xxxx:8080/restart
- 停止
service jenkins stop
或訪問 http://xxxx:8080/exit
- 重新加載配置文件
http://xxxx:8080/reload
使用Jenkins自動化
因?yàn)樾枰诜?wù)器上 build 項(xiàng)目,所以需要安裝 .NetCore 環(huán)境,可以查閱 微軟官方文檔 自行安裝
把新建的項(xiàng)目推送到 Gogs 倉庫中后點(diǎn)擊倉庫高級設(shè)置
![](/d/20211016/7024a7b84f7f825d9e5be0d4f5be82d7.gif)
選擇 Web 鉤子,添加新 Gogs 的 Web 鉤子
![](/d/20211016/fa40114b9c6acaec230eedc4a90917cb.gif)
配置 Web 鉤子,推送地址前面是 Jenkins 的訪問鏈接,后面 job 名字可以自己定義,選擇只有在 push 的時候觸發(fā)鉤子,也可以自己選定事件
![](/d/20211016/91e09790a366756ff2e0efe64c027502.gif)
添加后重新點(diǎn)擊管理 Web 鉤子,選擇剛才新建的鉤子,點(diǎn)擊測試推送來驗(yàn)證是否正常,拋出的異常如果是 job 未定義說明鉤子是正常的,如果是其他的異??梢圆榭赐扑偷刂肥欠裾_,以及 Jenkins 上的 Gogs 插件是否正確安裝
![](/d/20211016/8b3939cbd71bcbb335773819f6f32e4c.gif)
回到 Jenkins 頁面,新建一個任務(wù),任務(wù)名就是之前 Gogs 里面的 job 名字,選擇構(gòu)建自由風(fēng)格的軟件項(xiàng)目
![](/d/20211016/260e13c3241cace4b2002ab5db667a4b.gif)
添加倉庫配置,Repository URL 是你的倉庫地址,點(diǎn)擊添加你的倉庫憑據(jù)信息,最后指定操作的分支
![](/d/20211016/2815a9cc832fecc51b71037cad360e5f.gif)
構(gòu)建選擇執(zhí)行shell腳本,腳本也可以放在服務(wù)器上這里調(diào)用就行,為了方便就直接寫在這里
![](/d/20211016/1c78c8d51d917fdedb4006417d35c8fd.gif)
![](/d/20211016/e87f4dc185b5e0ea8b28fe8648aeee24.gif)
# 判斷是否存在demo鏡像是否存在
docker images | grep demo &> /dev/null
if [ $? -ne 0 ]
then
# 不存在不做處理
echo "not existed demo"
else
# 如果鏡像存在默認(rèn)認(rèn)為容器也是在運(yùn)行狀態(tài)
echo "existed demo"
# 停止刪除容器和鏡像
docker stop demoapi
docker rm -f demoapi
docker rmi demo:v1
fi
# 重新build后生成鏡像并運(yùn)行容器
cd DemoWebApi/
# 發(fā)布到到指定路徑
dotnet publish -c Release -o /publish
# 進(jìn)入路徑生成鏡像后啟動容器
cd /publish
docker build -t demo:v1 .
docker run --name demoapi -dp 5009:80/tcp demo:v1
保存后點(diǎn)擊立即構(gòu)建驗(yàn)證一下,如果構(gòu)建失敗可以在控制臺輸出中查看詳細(xì)構(gòu)建過程和錯誤信息
![](/d/20211016/5185b5619a382d9ffedfe6d776c58a02.gif)
回到 Gogs 的管理 Web 鉤子頁面重新推送,成功后 Jenkins 會自動構(gòu)建發(fā)布,之后只要 Push 到 Master 分支就會自動發(fā)布
![](/d/20211016/be3e288ab9dcdbaa271317bd0a7d8aeb.gif)
![](/d/20211016/172978d0e51a24cc570d38bcf29d2a65.gif)
總結(jié)
簡單記錄了自己折騰的全過程,Jenkins 和 Docker 還有很多功能,要在使用過程中慢慢了解。
到此這篇關(guān)于Gogs+Jenkins+Docker 自動化部署.NetCore的方法步驟的文章就介紹到這了,更多相關(guān)Docker 自動化部署.NetCore內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!