前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Azure DevOps+Docker+Asp.NET Core 实现CI/CD(二.创建CI持续集成管道)

Azure DevOps+Docker+Asp.NET Core 实现CI/CD(二.创建CI持续集成管道)

作者头像
GuZhenYin
发布2020-08-11 14:45:10
6330
发布2020-08-11 14:45:10
举报
文章被收录于专栏:GuZhenYinGuZhenYin

前言

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

今天我们废话不多说 直接开始正文

正文

昨天我们创建了自己的代理服务器(其实也可以用Azure提供的免费代理服务器,就是要排队,而且比较慢,限制比较多..)

今天我们来讲讲如何创建自己的持续集成管道.

今天大致的流程图如下:

1. 创建私有Docker Registry

首先我们需要到自己需要持续集成的服务器上 安装Docker Registry来获取我们的docker image

安装Docker..我这就不说了.主要讲讲如何安装Docker Registry

直接拉取registry镜像:

docker pull registry

查看是否存在镜像:

拉取到镜像后,我们直接Run 命令:

docker run -itd -v /data/registry:/var/lib/registry -p 8082:5000 --restart=always --name registry registry:latest

这里的8082是你映射外网的端口.

运行命令查看是否运行成功:

curl http://127.0.0.1:8082/v2/_catalog

这里显示{}就表示运行成功了,我这个是因为有项目了...所以打码了..

(注意:正式环境的Docker Registry部署请设置用户密码,毕竟是对外的端口)

2. 创建Service connections(服务连接)

点击项目下的配置按钮:

找到Service connections

创建一个新的连接, 这里我们选择上一步创建的Docker Registry

填写刚刚创建好的Docker Registry地址与密码.

这一步就算完成了,下一步我们将来使用它.

3. 创建持续集成管道

我们找到Pipelines菜单

点击创建新的管道

选择自己的项目代码托管的地方,这里我们选择上篇文章代码提交的地方Azure Repos Git

选中自己需要集成的项目:

配置管道,我们选择Docker

选择项目中的dockerFile文件位置:

我测试项目的DockerFile文件如下,大家可自行参考(纯空项目啥也没有):

FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443

FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build
RUN mkdir -p /app
WORKDIR /src
COPY . .
RUN dotnet restore "WebApplication1.csproj"
RUN dotnet build "WebApplication1.csproj" -c Release -o /app

FROM build AS publish
RUN dotnet publish "WebApplication1.csproj" -c Release -o /app

FROM base AS final
WORKDIR /app
COPY --from=publish /app .
ENTRYPOINT ["dotnet", "WebApplication1.dll"]

编辑配置我们的Pipeline YAML(这里开始,很重要):

将默认的Pool名改为我们昨天自行创建配置的Pool

修改为

创建持续集成的步骤Steps,点击右边的按钮可以打开图形化配置界面

这里我们添加三个步骤如下(这是我自己的配置,各位请通过下面的图形化配置 添加自己的步骤):

    steps:

      - task: Docker@2
        inputs:
          containerRegistry: 'TestDocker'
          command: 'login'
      - task: Docker@2
        inputs:
          containerRegistry: 'TestDocker'
          repository: '$(Build.Repository.Name)'
          command: 'build'
          Dockerfile: '$(Build.SourcesDirectory)/WebApplication1/WebApplication1/Dockerfile'
      - task: Docker@2
        inputs:
          containerRegistry: 'TestDocker'
          repository: '$(Build.Repository.Name)'
          command: 'push'

登陆,buid 最后Push我们的镜像.

添加好步骤之后,我们直接保存我们的管道.

4. 提交代码查看是否持续集成

我们修改一下首页的代码,并提交到Master主干:

可以发现,我们的管道已经监控到了主干的变化,开始运行

可以看到,管道自动push了版本号为42的镜像.

我们上持续集成服务器看看,有没有.

持续集成成功!

后记

我们下一篇来讲如何CD 持续部署与持续交付.

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-08-06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 今天大致的流程图如下:
  • 1. 创建私有Docker Registry
  • 2. 创建Service connections(服务连接)
  • 3. 创建持续集成管道
    • 将默认的Pool名改为我们昨天自行创建配置的Pool
      • 持续集成成功!
  • 4. 提交代码查看是否持续集成
相关产品与服务
容器镜像服务
容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档