Create modified Docker image

Software prerequisites

  • Installed Docker or Docker Desktop

  • Ability to run shell scripts

Let's say we want to use the Smartstore Community Edition Docker Image, but have a self-developed or third party plugin that we also want to use. How do we get the new plugin into the Docker image?

The example is run under Windows, but it will be similar under Linux.

Download the Community Edition

We download the release of the Community Edition from GitHub. It is important that the versions of the release and the plugin are the identical.

For the Docker image we need the Linux release of Smartstore.

Download the Linux release.

We create a subfolder, name is not relevant, I simply named the folder build_my_docker_image. Here we create another folder called smartstore-linux-x64 and unpack the contents of the file into this folder.

Subfolder with unzipped Smartstore Release.

We place our own or third party plugin in the \Modules folder in the \smartstore-linux-x64 folder. Not as a zip file, but unpacked.

Now we need the Dockerfile and the script file with the instructions for creating the Docker image.

We create an empty text file in the build_my_docker_image folder with the file name Dockerfile (without an extension, just Dockerfile), copy the following content into it and save the file.

# ----------------------------------------------------------- # Creates a Docker image from an existing build artifact # ----------------------------------------------------------- ARG ASPNET_TAG=7.0 FROM mcr.microsoft.com/dotnet/aspnet:${ASPNET_TAG} EXPOSE 80 EXPOSE 443 ENV ASPNETCORE_URLS "http://+:80;https://+:443" # Copy ARG SOURCE=/smartstore-linux-x64 WORKDIR /app COPY ${SOURCE} ./ # Install wkhtmltopdf RUN apt update &&\ apt -y install wget &&\ wget https://github.com/wkhtmltopdf/packaging/releases/download/0.12.6-1/wkhtmltox_0.12.6-1.buster_amd64.deb &&\ apt -y install ./wkhtmltox_0.12.6-1.buster_amd64.deb &&\ rm ./wkhtmltox_0.12.6-1.buster_amd64.deb ENTRYPOINT ["./Smartstore.Web", "--urls", "http://0.0.0.0:80"]

We repeat the whole thing for the file dockerize.linux.nobuild.sh. So we create a new text file, copy the following content into it and save the file.

docker build -t smartstore-linux-image -f Dockerfile . echo 'Press enter to exit...'; read dummy;

With the -t switch, the image is "tagged", i.e. given a name. These can be changed by smartstore-linux-image as desired.

The result should look like this:

By running the file dockerize.linux.nobuild.sh we can create the new image.