.NET实现CI/CD运行镜像,自动化部署

Posted dotNET跨平台

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了.NET实现CI/CD运行镜像,自动化部署相关的知识,希望对你有一定的参考价值。

(一重山,两重山。)

书接上文,在上回中我们说到了《【Azure + Core】实现CI/CD(一)构建镜像并推送仓库

今天我们继续往下说,说下CD(持续部署)的流程,也是很简单。这里先贴下上篇文章末尾留的小问题,在CD的时候遇到了个错误,打开日志是这样的,大家可以先看看,后续会解答:

1$ 添加Release管道

和CI类似,还是在Pipelines(管道)的Release(发布)中,新建一个Pipeline:

选择一个空模板:

将鼠标放到Artifacts(制品)模块上,点击添加一个Artifact,此时右侧唤起编辑窗口,

选择build,然后选择构建的管道源

然后可以开启自动构建,只要提交代码的时候,便会触发CI的Build操作,接着便立即触发CD的Release操作,整个流程一气呵成

配置好了Artifact,你可以称它为制品,然后就可以配置task任务了。

2$ 配置Agent代理

将鼠标放到右侧的Stage 1选项上,可以看到有三块功能选择,分别是:

①、重命名Stage(阶段);

②、添加一个新的Stage;

③、编辑task(任务);

点击任务链接,配置Agent Job(代理工作),这里有两点需要注意:

1、代理池,说白了就是部署的地方,目前可以默认即可,以后需要用自己的服务器;

2、agent specification(代理规格),就是服务器规格配置;

请注意!这里默认的是vs2019规格,是windows环境的,如果不改的话,就会出现文章开头的错误,Docker不能运行的平台问题。所以直接选Linux即可

3$ 配置Task任务

点击上边的加号,筛选docker的task模板

在新唤起的编辑页,编辑命令即可,Docker有三个类型,对应不同的命令类型,

我们第一步需要先删除旧的容器,所以直接用run命令即可,所以Task的版本用0.*:

还是和上篇一样,需要选择容器Registry地址,然后就是配置一个action(行为),增加一个删除镜像的命令

rm -f xxxx

4$ 配置其他的Stage阶段

仿造上边第一步删除旧容器的阶段步骤,再建一个运行容器的Stage,整体流程一致,不再细说,配置图如下:

用的是Task版本为1.*的Docker容器配置,使用自定义的DockerRegistry,配置镜像名,支持自定义,比如我加了前缀,也可以指定端口。

点击Save(保存),一套简单的持续集成管道就建好了

手动触发,create release,就可以看到详细的过程:

等一段时间后,就可以看到效果了,但是这样是不行的,因为我们还没有自己的IP。

5$ 其他问题

一、如何预览效果

上边我们说到了一个地方,就是代理池(Agent Pool),这个东西就是配置我们的服务器地址的,也就是宿主机,配置好以后就可以看效果了。

当然,也可以直接对接k8s,效果也是一样的,等我后续的文章吧。

二、如何自定义Docker Registry

目前这两篇文章可以看出来,用的是DockerHub作为服务仓库地址,如何使用自己的私库或者Azure上的呢,也是等我后续的文章吧。

下次再见咯。

以上是关于.NET实现CI/CD运行镜像,自动化部署的主要内容,如果未能解决你的问题,请参考以下文章

为了实现CI/CD,先来定制一个Docker镜像实战精华篇

为了实现CI/CD,先来定制一个Docker镜像实战精华篇

为了实现CI/CD,先来定制一个Docker镜像实战精华篇

Jenkins + Gitlab + harbor + Kubernetes实现CI/CD

Jenkins + Gitlab + harbor + Kubernetes实现CI/CD

如何用Docker实现PHP命令行程序的CI/CD