Windows Containers Support Overview

Using Docker on Windows in Codefresh

Codefresh pipelines have the option to support Windows based containers.

If you have projects in your organization based on the .NET Framework or are in transition from Windows to Linux based projects and still need to have CI/CD pipelines for Windows containers, you’ll now be able to achieve this by using Codefresh.

Note: To enable Windows builds on your Codefresh account please contact sales

Once approved, you will get access to a new runtime environment on a dedicated Windows Server version 1709 VM. This means that you will be able to run both Windows and Linux/x86 builds from the same Codefresh account by choosing the appropriate pipeline settings.

Note: For .NET Core projects you can use a standard Linux based Codefresh account. See our example. Codefresh Windows pipelines support the following Codefresh steps: Clone, Build, Push, Composition, Deploy and Freestyle. Please refer to our steps documentation to learn more about each of them.

Example

In this example we’ll perform the following steps:

  • Clone our git repository and build a .NET Framework image.
  • Run our dotnet unit tests and according to the results annotate the image accordingly.
  • Push to Dockerhub if our tests have passed.
version: '1.0'
steps:
  
  BuildingDockerImage:
    title: Building Docker Image
    type: build
    image_name: codefresh/dotnetapp
    working_directory: ./samples/dotnetapp
    tag: '${{CF_BRANCH_TAG_NORMALIZED}}'
    dockerfile: Dockerfile
 
  RunningUnitTests:
    title: Running Unit Tests
    image: '${{BuildingDockerImage}}'
    command: dotnet test
    on_success:
      metadata:
        set:
          - '${{BuildingDockerImage.imageId}}':
              - CF_QUALITY: true
              - repo_owner: '${{CF_REPO_OWNER}}'
              - repo_name: '${{CF_REPO_NAME}}'
              - branch_name: '${{CF_BRANCH}}'
              - commit_author: '${{CF_COMMIT_AUTHOR}}'
              - commit_url: '${{CF_COMMIT_URL}}'
              - commit_message: '${{CF_COMMIT_MESSAGE}}'
    on_fail:
      metadata:
        set:
          - '${{BuildingDockerImage.imageId}}':
              - CF_QUALITY: false
  
  PushingToDockerRegistry:
    title: Pushing to Docker Registry
    type: push
    candidate: '${{BuildingDockerImage}}'
    tag: '${{CF_BRANCH_TAG_NORMALIZED}}'
    registry: dockerhub

Windows docker image compatibility

You can receive the following error in your Windows pipeline:

The container operating system does not match the host operating system.

Windows docker images are only compatible with the corresponding release version of the host OS. You are not able to use a newer release version of a Windows container on an older release of Windows.

Please ensure that the image version used corresponds to the the node Windows release. For example:

FROM mcr.microsoft.com/dotnet/framework/sdk:4.8-windowsservercore-ltsc2019 is version 1809.

FROM mcr.microsoft.com/dotnet/framework/sdk:4.8-windowsservercore-1909 is version 1909.

Please reach out to the support team if you’re unsure which Windows release you’re using.

Introduction to pipelines
Creating pipelines
Codefresh YAML
Installation options