91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

.NET項目在k8s中運行的Dapr持續集成方法

發布時間:2022-04-02 10:44:09 來源:億速云 閱讀:338 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“.NET項目在k8s中運行的Dapr持續集成方法”,內容詳細,步驟清晰,細節處理妥當,希望這篇“.NET項目在k8s中運行的Dapr持續集成方法”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

    注:本文中主要討論 .NET6.0項目在 k8s 中運行的 Dapr 的持續集成流程, 但實際上不是Dapr的項目部署到K8s也是相同流程,只是k8s的yaml配置文件有所不同

    流程選擇

    基于 Dapr 的項目持續集成包含以下流程

    • 編譯并打包項目

    • 構建 Dockerfile,并推送鏡像push image至私有倉庫

    • 準備 k8s 部署的配置文件

    • 通過 kubectl 部署鏡像至 k8s 中

    這里面有多種方案

    -Pipeline的操作Publish的操作優點缺點
    1. 直接BuildImage并發布1. 直接使用 Docker Build Image 2. push image 3.復制Yaml至ArtifactsK8s 直接發布 對應版本的yaml + 指定Image直接,操作簡單1. 產生大量不必要的Image 2.持續集成消耗時間較長3.每次持續集成都有Image產生
    2. Publish時再進行Build1. 僅 dotnet publish zip1. Build Image / Push Image (可選 )2. K8S 部署+指定Image單次部署減慢,多次增快部署過程會比直接接取鏡像慢
    3. 僅發布 Zip,并Build一個使用Volume的專署鏡像僅 dotnet publish zip使用編譯好的鏡像修改Volume參數跨環境部署時會導致對于文件系統依賴過重

    鑒于以上優缺點,最終我選擇了第二種折衷方案,這種方案既不影響持續集成的速度,也不會產生過多的鏡像,只是在部署時會產生多余的鏡像構建時間。

    項目結構

    每個要發布的API的 project 文件夾中增加以下文件

    dapr.yaml

    Dockerfile

    dapr.yaml

    kind: Deployment
    apiVersion: apps/v1
    metadata:
      name: demo
      namespace: dapr-api
      labels:
        app: .api
        service: demo
    spec:
      replicas: 1
      selector:
        matchLabels:
          service: demo
      template:
        metadata:
          labels:
            app: .api
            service: demo
          annotations:
            dapr.io/enabled: "true"
            dapr.io/app-id: "demo-api"
            dapr.io/app-port: "80"
            dapr.io/log-as-json: "true"
        spec:
          containers:
            - name: demo-api
              image: 倉庫地址/鏡像名:220310.13
              ports:
                - name: http
                  containerPort: 80
                  protocol: TCP
              imagePullPolicy: IfNotPresent
    ---
    kind: Service
    apiVersion: v1
    metadata:
      name: demo-api
      namespace: dapr-api
      labels:
        app: .api
        service: demo
    spec:
      type: NodePort
      selector:
        service: demo
      ports:
      - protocol: TCP
        port: 80
        targetPort: 80
        nodePort: 30004

    Dockerfile

    FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS final
    WORKDIR /app
    EXPOSE 80
    COPY ["./projectfolder", "/app"]
    ENTRYPOINT ["dotnet", "projectdll.dll"]

    這兩個文件需要每個項目不同,后面在編譯和部署流程中會用到。

    Pipelines 持續集成的配置文件

    trigger:
      batch: true
    pool:
      name: Default
    name: $(Date:yy)$(Date:MM)$(Date:dd)$(Rev:.r)
    
    variables:
        BuildConfiguration: 'Release'
    steps:
    - task: UseDotNet@2
      displayName: 'Check and Install .NET SDK 6.0'
      inputs:
        version: '6.0.x'
        includePreviewVersions: false
    
    - task: DotNetCoreCLI@2
      displayName: 'Publish to zip'
      inputs:
        command: publish
        publishWebProjects: false
        projects: './src/projectfolder/project.csproj'
        arguments: '--configuration $(BuildConfiguration) --output $(build.artifactstagingdirectory) -v n'
        zipAfterPublish: false
        workingDirectory: '$(Build.SourcesDirectory)/src'
    ## 復制上文中的兩個文件到 Artifact
    - task: CopyFiles@2
      displayName: 'Copy dapr.yaml to: $(build.artifactstagingdirectory)'
      inputs:
        SourceFolder: './src/${{ parameters.project }}/'
        Contents: |
          Dockerfile
          dapr.yaml
        TargetFolder: '$(build.artifactstagingdirectory)'
    - task: PublishBuildArtifacts@1
      displayName: 'Publish Artifact'
      inputs:
        PathtoPublish: '$(build.artifactstagingdirectory)'

    Release 發布流程配置文件

    發布流程新建兩個作業

    .NET項目在k8s中運行的Dapr持續集成方法

    作業1 Build Image

    variables:
      image: '自定義鏡像名'
    steps:
    - task: Docker@2
      displayName: buildAndPush
      inputs:
        containerRegistry: harbor
        repository: '$(image)'
        Dockerfile: '$(System.DefaultWorkingDirectory)/_dapr-demo/drop/Dockerfile'
        tags: '$(Build.BuildNumber)'

    作業2 KubeDeploy

    variables:
      image: '自定義鏡像名,與上文須一致'
    
    steps:
    - task: KubernetesManifest@0
      displayName: deploy
      inputs:
        kubernetesServiceConnection: online
        namespace: '$(ns)' ## k8s的部署目標命名空間
        strategy: canary ## 灰度部署策略
        percentage: 50
        manifests: '$(System.DefaultWorkingDirectory)/_dapr-demo/drop/dapr.yaml'
        containers: '$(harborUrl)/$(image):$(Build.BuildNumber)'

    這樣,在首次部署時執行全部管道。

    .NET項目在k8s中運行的Dapr持續集成方法

    后期回滾版本只,手動執行第二個管理即KubeDeploy即可

    .NET項目在k8s中運行的Dapr持續集成方法

    讀到這里,這篇“.NET項目在k8s中運行的Dapr持續集成方法”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    鹤庆县| 中宁县| 嵊州市| 霞浦县| 中西区| 汾阳市| 五台县| 金塔县| 信丰县| 金山区| 青海省| 织金县| 松阳县| 金塔县| 镶黄旗| 宁陵县| 探索| 勐海县| 长丰县| 弥渡县| 博客| 明星| 玉屏| 台州市| 安福县| 孟村| 德令哈市| 海兴县| 普兰店市| 大安市| 科技| 清远市| 慈利县| 汝州市| 临猗县| 左云县| 砚山县| 泗水县| 喜德县| 南城县| 和龙市|