Docker持續集成
本章我們要實現的是通過我們往代碼倉庫push代碼后,我們將每次的push進行一次docker自動化打包發布到docker hub中,發布到之后我將進行部署環節,我們將通過ssh方式將我們的.NET應用程序pull並run到我們的雲服務器上。
Dockerfile 如下所示:
#See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging.
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
WORKDIR /src
COPY ["WebApplication1/WebApplication1.csproj", "WebApplication1/"]
RUN dotnet restore "WebApplication1/WebApplication1.csproj"
COPY . .
WORKDIR "/src/WebApplication1"
RUN dotnet build "WebApplication1.csproj" -c Release -o /app/build
FROM build AS publish
RUN dotnet publish "WebApplication1.csproj" -c Release -o /app/publish
FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "WebApplication1.dll"]
pipeline配置
這個環節我們將推送docker鏡像到dockerhub中,關於pipeline的配置可以參考一下前兩章對於dockerhub推送都有介紹
# ASP.NET Core
# Build and test ASP.NET Core projects targeting .NET Core.
# Add steps that run tests, create a NuGet package, deploy, and more:
# https://docs.microsoft.com/azure/devops/pipelines/languages/dotnet-core
trigger:
- demo04
pool:
vmImage: 'ubuntu-latest'
variables:
buildConfiguration: 'Release'
steps:
- task: UseDotNet@2
inputs:
packageType: 'sdk'
version: '3.x'
- task: DotNetCoreCLI@2
inputs:
command: 'restore'
feedsToUse: 'select'
- task: DotNetCoreCLI@2
inputs:
command: 'build'
- task: DotNetCoreCLI@2
inputs:
command: 'publish'
publishWebProjects: true
- task: Docker@2
inputs:
containerRegistry: 'DockerHub'
repository: '$(repository)'
command: 'buildAndPush'
Dockerfile: 'WebApplication1/Dockerfile'
buildContext: '.'
tags: 'latest'
在雲服務上自動部署應用程序
第一步我們需要先去service connection中區創建一個ssh的連接信息,以用於后續的操作。
接下來我們需要創建一個 release pipeline 用於我們部署的操作,如下圖所示:
下圖的四個task向我們展示了部署階段的操作步驟.
- 刪除容器
我們先去看我們服務器當中的容器是否存在,如果該容器不存在則我們跳出該操作,如果存在我們則去刪除指定的容器.
#判斷是否存在containername容器
docker ps | grep containername&> /dev/null
#如果存在,則Remove
if [ $? -ne 0 ]
then
echo "containername container not exist continue.. "
else
echo "remove containername container"
docker rm containername -f
fi
- 刪除鏡像
查看服務器指定的鏡像是否存在,如果不存在則跳出該操作,否則我們將刪除指定的鏡像
#判斷是否存在name鏡像
docker images | grep name&> /dev/null
#如果不存在,則跳出
if [ $? -ne 0 ]
then
echo "image does not exist , continue..."
else
echo "image exists !!! remove it"
docker rmi --force name
fi
- 拉取鏡像
拉取指定的鏡像到服務器
docker pull hueifeng/test:latest
- 運行鏡像
運行拉取的鏡像hueifeng/test
,並將其命名為name
,對外開放端口8108端口
.
docker run --restart unless-stopped -p 8108:80 --name name -d hueifeng/test
Other
推薦閱讀的Azure DevOps教程