Build your own Docker images for the most recent versions of Sitecore. See IMAGES.md for all images currently available. You can also use this repository (preferably from a fork) from you own build server and have it build and push images to your own private Docker registry.
Jump to the How to use section to get started.
- This repository was created to help consolidate efforts around Sitecore and Docker.
- The code and examples found in this repository are created and maintained by the Community, unsupported by Sitecore.
- Official statement from Sitecore on running in containers, see https://kb.sitecore.net/articles/161310.
Please see CHANGELOG.md.
Please see IMAGES.md.
Please see CONTRIBUTING.md.
This repository can build multiple Windows versions. Read more about Windows Container Version Compatibility.
Here is the convention used for Sitecore image tags:
[REGISTRY/]sitecore-<TOPOLOGY>[-VARIANT]-<ROLE>:<SITECORE_VERSION>-<OS_VERSION>
Example:
registry.example.com/sitecore-xm-cm:9.2.0-windowsservercore-1903
\__________________/ \____________/ \___/ \____________________/
| | | |
registry/org/user repository sc version os version
.\Build.ps1 -SitecoreUsername "YOUR dev.sitecore.net USERNAME" -SitecorePassword "YOUR dev.sitecore.net PASSWORD"
This will:
- Download any missing packages into
.\packages
, if you have another location with files already present you can callBuild.ps1
with the parameter-InstallSourcePath
. - Build all images of latest Sitecore version on latest LTSC (Long Term Support Channel) Windows version.
Images will always be saved locally but not pushed to any remote registries by default. See Setting up automated builds for details on how to do this.
When completed then...
For Sitecore 9.3.x:
- Run
Set-LicenseEnvironmentVariable.ps1 -Path C:\license\license.xml
(use thePersistForCurrentUser
switch to persist the license for future sessions). This will gzip and base64 encode the license file content and save it in$env:SITECORE_LICENSE
. - Switch directory to
.\windows\tests\9.3.x\
and then run any of the docker-compose files, for example an XM with:docker-compose --file .\docker-compose.xm.yml up
9.3 docker images still supports mounting the license file inside the container, if for some reason you need to use this method please see License file volume mount configuration for 9.3 docker images
For Sitecore 9.2.x:
- Place your Sitecore license file at
C:\license\license.xml
, or override location using the environment variableLICENSE_PATH
like so:$env:LICENSE_PATH="D:\my\sitecore\licenses"
- Switch directory to
.\windows\tests\9.2.x\
and then run any of the docker-compose files, for example an XM with:docker-compose --file .\docker-compose.xm.yml up
IMPORTANT: When switching between versions, variants or topologies you need to clear the data folders, you can use the
.\windows\tests\*.*.*\Clean-Data.ps1
script to do so.
- A private Docker repository. Any will do, but the easiest is to use a Azure Container Registry.
- A file location that your build agents can reach to store downloads from https://dev.sitecore.net/.
- Latest Windows 10 or Windows Server 2019 with Hyper-V and Containers features installed.
- Latest stable Docker engine and cli.
- PowerShell Core so you can use the PowerShell module.
- Latest stable Docker engine and cli.
- Trigger a build on changes to
master
- to get new versions. - Trigger once a week - to get base images updated when Microsoft releases patched images.
Example:
# required, change if you need to build images in other folders such as ".\linux" or ".\legacy"
$imagesPath = (Join-Path $PSScriptRoot "\windows")
# optional, default value is ".\packages". Can be on local machine or a file share.
$installSourcePath = (Join-Path $PSScriptRoot "\packages")
# optional, on Docker Hub it's your username or organization, else it's the hostname of your
# own registry. This parameter is optional but you will not be able to push images to a
# remote registry without.
#
# PLEASE NOTE: DO NOT SPECIFY A PUBLIC REGISTRY!
#
$registry = "YOUR REGISTRY NAME" `
# Ensure that the private registry connection is authenticated. eg. Azure Container Registry
# az acr login --name $registry
# or
# docker login
# optional, default value is the latest Sitecore version on latest LTSC version
# of Windows. Set to for example "*" for build everything or "*:9.1.1*1903", "*:9.2.0*1903" to
# only build 9.1.1 and 9.2.0 on Windows 1903.
$tags = "*"
# required
$sitecoreUsername = "YOUR dev.sitecore.net USERNAME"
# required
$sitecorePassword = "YOUR dev.sitecore.net PASSWORD"
# import builder module
Import-Module (Join-Path $PSScriptRoot "\modules\SitecoreImageBuilder") -Force
# restore packages needed for the build, only files missing in $installSourcePath will be downloaded
SitecoreImageBuilder\Invoke-PackageRestore `
-Path $imagesPath `
-Destination $installSourcePath `
-Tags $tags `
-SitecoreUsername $sitecoreUsername `
-SitecorePassword $sitecorePassword
# build and push images
SitecoreImageBuilder\Invoke-Build `
-Path $imagesPath `
-InstallSourcePath $installSourcePath `
-Registry $registry `
-Tags $tags
We now have a few scripts that can be used as ENTRYPOINT
for development and production use. Using the ENTRYPOINT
scripts that supports log steaming enables you to observe Sitecore log entries in the STDOUT
of containers in the foreground or by using commands such as docker container logs
or docker container attach
.
C:\tools\entrypoints\iis\Production.ps1
features:
- Adds an UDP appender to all default log4net loggers.
- Starts
ServiceMonitor.exe
in the background. - Starts
filebeat.exe
in the foreground and outputting toSTDOUT
. - FileBeat inputs configured:
- IIS access logs, disabled by default, can be switched using environment variable:
ENTRYPOINT_STDOUT_IIS_ACCESS_LOG_ENABLED=true
- IIS error logs, disabled by default, can be switched using environment variable:
ENTRYPOINT_STDOUT_IIS_ERROR_LOG_ENABLED=true
- Sitecore logs, enabled by default, can be switched using environment variable:
ENTRYPOINT_STDOUT_SITECORE_LOG_ENABLED=false
- IIS access logs, disabled by default, can be switched using environment variable:
C:\tools\entrypoints\iis\Development.ps1
features:
- Same as
Production.ps1
. - Starts the Visual Studio Remote Debugger
msvsmon.exe
in the background if the Visual Studio Remote Debugger directory is mounted intoC:\remote_debugger
. - Starts the
Watch-Directory.ps1
script in the background if a directory is mounted intoC:\src
.- To customize parameters you can use
WatchDirectoryParameters
and give it a hashtable, example:entrypoint: powershell.exe -Command "& C:\\tools\\entrypoints\\iis\\Development.ps1 -WatchDirectoryParameters @{ Path = 'C:\\src'; Destination = 'C:\\inetpub\\wwwroot'; ExcludeFiles = @('Web.config'); }"
- To customize parameters you can use
See the cm
and cd
service in windows/tests/9.3.x/docker-compose.xm.yml for configuration examples.
Please note that this is enabled from Sitecore v9.3.0.
C:\tools\entrypoints\worker\Development.ps1
features:
- Starts the
Watch-Directory.ps1
script in the background if a directory is mounted intoC:\src
.- To customize parameters you can use
WatchDirectoryParameters
and give it a hashtable, example:entrypoint: powershell.exe -Command "& C:\\tools\\entrypoints\\worker\\Development.ps1 -WatchDirectoryParameters @{ Path = 'C:\\src'; Destination = 'C:\\worker'; }"
- To customize parameters you can use
C:\tools\entrypoints\sitecore-xc-engine\Production.ps1
features:
- Adds a UDP log appender
- Starts
ServiceMonitor.exe
in the background. - Starts
filebeat.exe
in the foreground and outputting toSTDOUT
. - FileBeat inputs configured:
- IIS access logs, disabled by default, can be switched using environment variable:
ENTRYPOINT_STDOUT_IIS_ACCESS_LOG_ENABLED=true
- IIS error logs, disabled by default, can be switched using environment variable:
ENTRYPOINT_STDOUT_IIS_ERROR_LOG_ENABLED=true
- Commerce Engine logs, enabled by default, can be switched using environment variable:
ENTRYPOINT_STDOUT_ENGINE_LOG_ENABLED=false
- IIS access logs, disabled by default, can be switched using environment variable:
C:\tools\entrypoints\sitecore-xc-engine\Development.ps1
features:
- Same as
Production.ps1
. - Starts the Visual Studio Remote Debugger
msvsmon.exe
in the background if the Visual Studio Remote Debugger directory is mounted intoC:\remote_debugger
. - Starts the
Watch-Directory.ps1
script in the background if a directory is mounted intoC:\src
.- To customize parameters you can use
WatchDirectoryParameters
and give it a hashtable, example:entrypoint: powershell.exe -Command "& C:\\tools\\entrypoints\\sitecore-xc-engine\\Development.ps1 -WatchDirectoryParameters @{ Path = 'C:\\src'; Destination = 'C:\\inetpub\\wwwroot'; ExcludeFiles = @('Web.config'); }"
- To customize parameters you can use
See the commerce-authoring
service in windows/tests/9.3.x/docker-compose.xc.yml for configuration examples.
Experimental Publishing Service (not automatically build because of missing prerequisites from Sitecore)
The 'Download-PS-Prerequisites.ps1' script will download the regular Sitecore Publishing Module package, and convert the asset into the proper WDP package by using Sitecore Sitecore Azure Toolkit.
Azure Toolkit has also prerequisites, see (https://doc.sitecore.com/developers/sat/20/sitecore-azure-toolkit/en/getting-started-with-the-sitecore-azure-toolkit.html)
Add -ExperimentalTagBehavior Include `
# required powershell 5.0
# required
$sitecoreUsername = "YOUR dev.sitecore.net USERNAME"
# required
$sitecorePassword = "YOUR dev.sitecore.net PASSWORD"
# restore packages needed for the build, only files missing in $installSourcePath will be downloaded
Download-PS-Prerequisites.ps1 `
-SitecoreUsername $sitecoreUsername `
-SitecorePassword $sitecorePassword
# required, build with ExperimentalTagBehavior parameter
# restore packages needed for the build
SitecoreImageBuilder\Invoke-PackageRestore `
-Path $imagesPath `
-Destination $installSourcePath `
-Tags $tags `
-ExperimentalTagBehavior Include `
-SitecoreUsername $sitecoreUsername `
-SitecorePassword $sitecorePassword
# build and push images
SitecoreImageBuilder\Invoke-Build `
-Path $imagesPath `
-InstallSourcePath $installSourcePath `
-Registry $registry `
-Tags $tags, `
-ExperimentalTagBehavior Include
If you've been using the license file mounted approach in 9.2 docker images, you can still continue using the same approach in 9.3 docker images. Follow these steps
- Place your Sitecore license file at
C:\license\license.xml
, or override location using the environment variableLICENSE_PATH
like so:$env:LICENSE_PATH="D:\my\sitecore\licenses"
- Switch directory to
.\windows\tests\9.3.x\
and then run any of the docker-compose files, for example an XM with:docker-compose --file .\docker-compose.xm.yml up
after the docker compose file has been updated following the instruction below
- Add a new volume mount configuration using the environment variable
LICENSE_PATH
to a folder inside the container, for exampleC:\license
- Add a new environment variable
SITECORE_LICENSE_LOCATION
that point to the license file path inside the container, for example:C:\license\license.xml
cm:
environment:
SITECORE_LICENSE_LOCATION: C:\license\license.xml
volumes:
- ${LICENSE_PATH}:C:\license
- Add a new volume mount configuration using the environment variable
LICENSE_PATH
to a folder inside the container, for exampleC:\license
- Add a new environment variable
SITECORE_LICENSE_LOCATION
that point to the license file folder path inside the container, for example:C:\license
xconnect:
environment:
SITECORE_LICENSE_LOCATION: C:\license
volumes:
- ${LICENSE_PATH}:C:\license
Its recommended to clean up you Docker engine hosts (developer workstations, build agents etc.) regularly.
To remove unused images (dangling images created during build):
docker image prune --force
TIP: If you need to clean up everything you can add the option
--all
to above prune command or rundocker system prune --all --force
. Beware that both will remove all images.