將 Docker Scout 與 Circle CI 整合


以下示例在 CircleCI 中觸發時執行。觸發後,它會檢出“docker/scout-demo-service:latest”映象和標籤,然後使用 Docker Scout 建立 CVE 報告。

將以下內容新增到 .circleci/config.yml 檔案中。

首先,設定工作流程的其餘部分。將以下內容新增到 YAML 檔案中

version: 2.1

jobs:
  build:
    docker:
      - image: cimg/base:stable
    environment:
      IMAGE_TAG: docker/scout-demo-service:latest

這定義了工作流程使用的容器映象以及映象的環境變數。

將以下內容新增到 YAML 檔案中,以定義工作流程的步驟

steps:
  # Checkout the repository files
  - checkout
  
  # Set up a separate Docker environment to run `docker` commands in
  - setup_remote_docker:
      version: 20.10.24

  # Install Docker Scout and login to Docker Hub
  - run:
      name: Install Docker Scout
      command: |
        env
        curl -sSfL https://raw.githubusercontent.com/docker/scout-cli/main/install.sh | sh -s -- -b /home/circleci/bin
        echo $DOCKER_HUB_PAT | docker login -u $DOCKER_HUB_USER --password-stdin

  # Build the Docker image
  - run:
      name: Build Docker image
      command: docker build -t $IMAGE_TAG .
  
  # Run Docker Scout          
  - run:
      name: Scan image for CVEs
      command: |
        docker-scout cves $IMAGE_TAG --exit-code --only-severity critical,high

這會檢出儲存庫檔案,然後設定一個單獨的 Docker 環境來執行命令。

它會安裝 Docker Scout,登入 Docker Hub,構建 Docker 映象,然後執行 Docker Scout 生成 CVE 報告。它只顯示嚴重或高危漏洞。

最後,為工作流程和工作流程的作業新增名稱

workflows:
  build-docker-image:
    jobs:
      - build