查看原文
其他

Azure DevOps+Docker+ASP.NET Core实现CI/CD

DotNet 2021-09-23

(给DotNet加星标,提升.Net技能

转自:GuZhenYin
cnblogs.com/GuZhenYin/p/13441395.html

前言


本文主要是讲解如何使用Azure DevOps+Docker 来实现持续集成ASP.NET Core项目(当然 也可以是任意项目).


打算用三个篇幅来记录完整的全过程


CI/CD简介


首先,我们先来简单的介绍一下什么是CI/CD


  • CI全拼Continuous Integration 持续集成


  • 我们的开发每天基本都会提交多次代码到主干上,这个时候如果需要编译或者打包,就会做一些重复性的动作,就可以用持续集成环境来操作。


  • 有集成了,就肯定少不了它的好基友,没错就是CD。


  • CD全拼是Continuous Deployment,是持续部署。


  • CD还有个小号,交持续交付,英文全称是Continuous delivery,缩写也是CD。


  • CI/CD优点是,重复的工作用自动化来代替、减少时间成本、减少版本发布时间。


Azure DevOps简介


作为.NET的开发者,微软一直都是比较有爱的..从免费强大的IDE到人工智能ML.NET 基本上都提供了免费的入门版本,今天主要介绍的就是Azure DevOps.


Azure DevOps的前身其实大家都熟悉就是TFS,Azure DevOps是由TFS转为线上Online的产品.


它基本上提供了CI/CD所需要的全部功能。唯一的问题是在国内没有服务器,最近的服务器在香港。


Azure DevOps提供无限免费的私有仓库,以及最多5个contributor(贡献者)账号和无限的stakeholder(参与者)账号,注册即可使用.


本文的CI/CD概念图


 

这里的代理服务池和各类服务器 都是采用阿里云的CentOS7.0+系统.


正文


1、提交代码到Azure DevOps Repos 


首先我们创建一个项目(选择使用GIT作为版本控制工具),进入项目中我们可以看到Repos菜单下如图:



其实就是提供了一个GIT的仓库地址,提交代码即可.


2、创建代理服务器池


其实这里就直接可以用官方提供的代理服务器来进行CI和CD了,但是会有诸多不便,也不方便自己管理.


点击菜单最下面的Project Settings,如图:


 

找到Agent pools



创建一个新的自托管的代理服务器池



3、创建代理服务器


点进去上一步创建的代理服务器池,找到agent


创建一个自己的代理服务器


可以看到微软给我们提供了多种平台版本的代理服务器客户端 这里我们选择linux然后下载复制tar包地址:


 

回到我们自己阿里云服务器.


(1)、安装打包编译需要的支持环境Docker

CentOS安装Docker我就不详细描述了,百度一大把资料.


(2)、安装代码拉取的工具GIT


需要注意的是CentOS自带的GIT只有1.8+版本,需要升级到2.0+版本才能连接Azure DevOps


具体升级方式可以参考:https://blog.csdn.net/qq_28903377/article/details/86148687


这篇文章的安装目录是/usr/local/git/bin  记得自己的安装目录/usr/local/git/bin


(3)、安装agent代理服务器客户端


执行命令 创建一个文件夹,并进入这个文件夹


mkdir myagent && cd myagent


下载微软提供给我们的agent代理服务器客户端


wget https://vstsagentpackage.azureedge.net/agent/2.172.2/vsts-agent-linux-x64-2.172.2.tar.gz


 解压

tar -zxvf vsts-agent-linux-x64-2.172.2.tar.gz


运行配置代理服务器:


./config.sh


这里可能会出现一些错误提示:Must not run with sudo


具体的解决方案请参考https://github.com/microsoft/azure-pipelines-agent/pull/1713/commits/15a5beea684fa35172d661f3253b93e210409fbb


注意:代理服务器是基于.NET CORE3.1编写,所以需要相应的运行环境,如果没有,请运行如下命令:


./bin/installdependencies.sh to install


创建自己的访问令牌 (PAT) 进行身份验证(这里一定要操作,后面需要使用)


点击右上角选择access Token



创建一个新的令牌




这里为了方便,我直接选择了Full access授权这个Token可以访问所有的内容.


然后会得到一个Token字符串,记得复制保存,因为后面就查不到了,只能重新生成


解决环境问题,创建完Token后,我们继续运行配置:



  • 输入【Y】接受Team Explorer Everywhere许可协议;


  • 输入服务器URL,即项目的Azure的地址;


  • 输入身份验证类型,这里直接回车,选择默认的PAT;


  • 输入个人访问令牌,即PAT;


  • 连接服务器成功后,输入创建好的代理池;


  • 默认代理名称,也可以进行修改;


  • 因为我之前已经创建过了,所以是否替换的选择选择了【Y】;


  • 输入工作文件夹,直接回车,选择默认的【_work】;

 

这样就完成了我们的代理服务器的配置工作.


然后运行启动命令:


./run.sh


这个时候我们应该就能在网页上看到我们的代理服务器上线了如图:



4、采用服务的形式运行代理服务器


上面我们的代理服务器虽然上线了,但是在linux中是主线程的形式,退出就关闭了..


我们需要修改为服务的形式来运行.


运行命令安装服务:


sudo ./svc.sh install


启动服务:


sudo ./svc.sh start


查看服务状态:


sudo ./svc.sh status


停止服务:


sudo ./svc.sh stop


更新环境变量(当你有其他插件安装或者更新时)


./env.sh
sudo ./svc.sh stop
sudo ./svc.sh start


后记


本篇主要讲解了如何创建自己的代理服务器池,下一篇我们主要讲解如何创建一个管道来自动编译和打包我们的项目。


- EOF -



推荐阅读  点击标题可跳转

IdentityServer4 客户端授权模式(Client Credentials)

.NET hbase client--终于浮出水面的轮子

.NET Core HttpClient使用


看完本文有收获?请转发分享给更多人

关注「DotNet」加星标,提升.Net技能 

好文章,我在看❤️

: . Video Mini Program Like ,轻点两下取消赞 Wow ,轻点两下取消在看

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存