需求
在之前的文章中“[DevOps]如何用VSTS持续集成到Github仓库”
我们有讲述如何将vsts中的代码编译推送到github中,这一篇我们来完善,如果有人给你开源项目推送了代码,你审核后,如何自动将代码推送回vsts,从而实现双同步。
准备工作
首先你要生成一个key,登录到你的vsts中。进入“Security”菜单栏。
data:image/s3,"s3://crabby-images/8088c/8088c55dd599d73648cdf3754a4d72c64146e443" alt="img_1acee10580acd87404a82c5a9b5fbcb9.png"
生成密钥
点击Add,添加一个密钥。
data:image/s3,"s3://crabby-images/fcba1/fcba1e9bc6ee6e6c2b31625e570abc8f17c79822" alt="img_76bba13a8edfb691590e8f98664a18c7.png"
image.png
注意:此处生成的密钥,请自行保存,因为你刷新页面后,此处的密钥就不会再出现。同时密钥是有失效时间的。所以请注意。
创建一个任务
回到我们的“Build and Release”菜单栏,创建一个新的task。
data:image/s3,"s3://crabby-images/15e7a/15e7a10768577d0f82262fae4ada91295da411b7" alt="img_d426217770ebac21f5a09eea350cf6d5.png"
image.png
点击新增“Empty process”取个名字叫做“SyncFromGithub”,选择队列为“Host”,
data:image/s3,"s3://crabby-images/3f511/3f5110bd5a786dca621c36d40f4f98a0c9a0b876" alt="img_575dcb38a249b5451129af790c3677b2.png"
image.png
然后选择获取代码源,然后进行github授权,选择你对应的仓库。
data:image/s3,"s3://crabby-images/fbff9/fbff9b9a037832fb642798efa581befa8a84016e" alt="img_094cdd4082a88bbf2bd761c19c0f526b.png"
image.png
回到Phase,新增一个cmd,命令行
data:image/s3,"s3://crabby-images/23047/23047c35eb07b62060f4441e9f5d273e71c1fb58" alt="img_5162d03d745b3380942272af23b9b28d.png"
image.png
data:image/s3,"s3://crabby-images/c9341/c93410ab6f4ec472680f8204ba1037c5ba34da7a" alt="img_94c79fa3a4335d52011e0801027c756a.png"
命令行.png
在第一个命令行中填入以下代码。其中$(vststoken)为参数名称,我们待会儿说。
pull https://$(vststoken)@52ABP.visualstudio.com/_git/52ABP.School master
我们先拉取下vsts中仓库的代码。
data:image/s3,"s3://crabby-images/1b66d/1b66d09074092067c7db6ec298f74401fcb1d987" alt="img_5d6ceca0c113f757f53ded19841c86fa.png"
image.png
然后再添加一个命令行工具。
push https://$(vststoken)@52ABP.visualstudio.com/_git/52ABP.School head:master
然后再将代码推送到服务vsts中。
参数的设置
我们之前要的token值,用于授权验证,打开“Variables”菜单栏,
新建一个vststoken的名称。将刚刚生成的token值,输入到value中。
data:image/s3,"s3://crabby-images/29588/2958842dd919b967f34223ed63a48949f6a3f701" alt="img_ffed59219d4fa3dc8057fdf4ecbe422d.png"
image.png
如上图,加锁后。会启用掩码。这样的话就安全不少。
设置触发器
然后就跟之前的课程一样,设置下触发器。
data:image/s3,"s3://crabby-images/e19b8/e19b800b3e7cc304ca484c7d6480458ada83f488" alt="img_9eb7e2736cecb5c7557bcd2e6c10ba1b.png"
image.png
到options中启用标记,如下图
data:image/s3,"s3://crabby-images/cf54f/cf54f4cd20f62047bc5e398adea49753ded5c5e4" alt="img_449521d1e3f8d9b29e5a5aefc89a5847.png"
image.png
生成任务规则
$(BuildDefinitionName)$(SourceBranchName)$(Date:yyyyMMdd)$(Rev:.r)
最后,右上角保存并添加到队列中即可。
END
最后的结果就是这样!
data:image/s3,"s3://crabby-images/3b8a3/3b8a34ad6c69d69cf48cd3956393727dbf8c4c13" alt="img_0fe401e6b222e5d746185854f1b66687.png"
image.png
GitHub仓库:https://github.com/52ABP/52ABP.School
视频课程
最近我录制的.net core 入门已经发布有兴趣的可以去了解。
https://mp.weixin.qq.com/s/riPvwXpKe5LuPu0hQfXS9A