Skip to content

Latest commit

 

History

History
143 lines (77 loc) · 4.84 KB

Instructions_1_Linux_Mac.md

File metadata and controls

143 lines (77 loc) · 4.84 KB

Instructions for Docker in Umbraco Part on Linux and Mac

These instructions are specific to Linux and Mac, which needs to be done in a slightly different order, since you can't create the Umbraco site without having the database in place, since LocalDB does not work outsider Windows.

1 - Setup the Database Container

Follow these instructions to setup the database container. Start with copying the entire UmbData folder from Files/UmbData into the Root.

Amend the Dockerfile

Replace the existing Dockerfile with the following

FROM mcr.microsoft.com/mssql/server:2019-GDR1-ubuntu-16.04

ENV ACCEPT_EULA=Y
ENV SA_PASSWORD=SQL_password123
ENV MSSQL_PID=Express

USER root

RUN mkdir /var/opt/sqlserver

RUN chown mssql /var/opt/sqlserver

ENV MSSQL_BACKUP_DIR="/var/opt/sqlserver"
ENV MSSQL_DATA_DIR="/var/opt/sqlserver"
ENV MSSQL_LOG_DIR="/var/opt/sqlserver"

COPY setup.sql /
COPY startup.sh /

ENTRYPOINT [ "/bin/bash", "startup.sh" ]
CMD [ "/opt/mssql/bin/sqlservr" ]

Amend the setup.sql file with the following. This change will create an empty database instead of restoring one.

USE [master]
GO

IF NOT EXISTS (SELECT * FROM sys.databases WHERE name = 'UmbracoDb')
BEGIN

    CREATE DATABASE [UmbracoDb];

END;
GO

USE UmbracoDb;

Build the database image.

Create a docker image for the database with the tag umbdata. Note : tags need to be lower case.

docker build --tag=umbdata ./UmbData

Run the database container with the ame umbdata. We're using a non-standard port in case you have a local SQL server.

docker run --name umbdata -p 1400:1433 --volume sqlserver:/var/opt/sqlserver -d umbdata

2 - Creating a new Umbraco Website

These are the instructions for Windows. If you are on a mac or linux machine you will need to follow the intructions in Instructions_1_linux_mac.md.

Ensure we have the latest Umbraco templates

dotnet new -i Umbraco.Templates

Set the SDK Version being used and Create solution/project

dotnet new globaljson --sdk-version 5.0.404
dotnet new sln --name UmbDock

Start a new Umbraco website project

dotnet new Umbraco -n UmbDock --friendly-name "Admin User" --email "[email protected]" --password "1234567890" --connection-string "Server=localhost,1400;Database=UmbracoDb;User Id=sa;Password=SQL_password123;"

Add the project to the solution, and install a starter kit

dotnet sln add UmbDock
dotnet add UmbDock package Clean

Modify csProj

Edit the csproj file to change following element:

<!-- Force windows to use ICU. Otherwise Windows 10 2019H1+ will do it, but older windows 10 and most if not all winodws servers will run NLS -->
<ItemGroup Condition="'$(OS)' == 'Windows_NT'">
    <PackageReference Include="Microsoft.ICU.ICU4C.Runtime" Version="68.2.0.9" />
    <RuntimeHostConfigurationOption Include="System.Globalization.AppLocalIcu" Value="68.2" />
</ItemGroup>

Without this step, the project won't compile on Linux, but will compile in windows - This is needed even if you are using windows, since eventually the application will run in a docker container on Linux.

Now Run the site

This will also connect to the database container we previously created.

dotnet run --project UmbDock

In the output you willl see which port the site is running on. You should be able to browse to that site on any browser. You need to complete this step so that the databases are created.

3 - Convert the website into a container

Create the Dockerfile

Copy the Docker file by from /Files/Umbdata/UmbDock/Dockerfile to UmbDock/Dockerfile.

Network

We need to define a custom bridge network to run this application under

docker network create -d bridge umbNet

We will then connect our existing container to that network

docker network connect umbNet umbdata

Connectionstring for Application Container

Create a staging config file on the website called appsettings.Staging.json by copying the existing appsettings.Development.json file.

Amend the connectionstring with the following. You will need the non-standard port setting

"umbracoDbDSN": "Server=umbdata;Database=UmbracoDb;User Id=sa;Password=SQL_password123;"

Create the website container image

We've got our site, now we need to build an image which can be used to host the application. From the UmbDock folder run the following

docker build --tag=umbdock ./UmbDock

To run a single local instance

docker run --name umbdock -p 8000:80 -v media:/app/wwwroot/media -v logs:/app/umbraco/Logs -e ASPNETCORE_ENVIRONMENT='Staging' --network=umbNet -d umbdock

References

Slides : https://docs.google.com/presentation/d/1RhfTbOapkVlpEyAjJs80bQEh4oOKxCMD7Y8lyB3sL7E/