Mininum requirement for resources
Kubernetes Linux cluster 2CPU, 7GB RAM. 3 node cluster is recommended for production environment.
SQL Server 2016 or later.
Prerequisites
- Install Kubenetes CLI tool - kubectl. Instructions can be found here: https://kubernetes.io/docs/tasks/tools/install-kubectl/
- SQL Server connection string
- SSL certificate and private key without password
- Request the container registry login from IQX for pulling OneList images
- SMTP server login and email address if email approval channel is enabled
- Generate the Machine key and encode it to a base64 string for each environment
- Download these Yaml files
Deployment steps
Open a command prompt from the folder that contains the YAML deployment files. Flow steps below to deploy OneList.
1. Create the Kubernetes namespace
Run the command below to create the "onelist" namespace.
kubectl create namespace onelist
2. Create ConfigMap and Secret
These Kubernetes ConfigMap and Secret defines the required environment variables that are used by OneList services. Open the "config.yaml" in notepad and update the following fields with the actual value.
- RoleManager__MachineKey
This is a base64 string representing a bit array of 44 bytes. - Database__ConnectionString
The value is the SQL Server connection string. The name of the databases will be automatically specified by the services. - Smtp__UserName
- Smtp__Password
- ASPNETCORE_ENVIRONMENT
The value specifies the environment. It can be one of the following Production, Dev, QA. - Smtp__From
This is the sender email address of notifications from OneList - Smtp__Host
This is the SMTP server OneList use to send notifications. - Smtp__Port
This is the port of SMTP server. - Smtp__UseSsl
Define if SMTP server uses SSL connection.
Save the "config.yaml" file then run the command below.
kubectl apply -f config.yaml --namespace onelist
3. Create the Secrete for pulling OneList images
Replace placeholders in the command below and run it.
kubectl create secret docker-registry iqx.acr --docker-server=https://iqxbusiness.azurecr.io --docker-username=ACR_USERNAME --docker-password=ACR_PASSWORD --docker-email=YOUR_EMAIL_ADDRESS --namespace onelist
4. Create the TLS secrete
Run the command below.
kubectl create secret tls tls.onelist --cert YOURCERTIFICATEFILE --key YOURKEYFILE --namespace onelist
5. Deploy OneList containers for the apps and services
Run the 2 commands below.
kubectl appy -f onelist6-deployment.yaml --namespace onelist
kubectl appy -f onelist6-service.yaml --namespace onelist
6. Create Nginx ingress service
Run the 2 commands below.
kubectl create -f ingress-nginx-controller.yaml --namespace onelist
kubectl create -f onelist6-ingress.yaml --namespace onelist
Upgrade image version
Upgrade all applications
You need to know the namespace where OneList applications are deployed before proceeding with this upgrade. Download the upgrade.ps1 file. Run the command below.
powershell -f upgrade.ps1 -n namespaceofonelistapp -v x.x.x
Upgrade a single application
If image version update is required, use the command below as a template and apply proper parameters to update image version of applications.
kubectl set image deployment/onelistserver onelistserver=iqxbuild.azurecr.io/iqx.onelist.server:v6.2.2 -n namespaceofonelistapp
Parameters:
- deployment/onelistserver is the deployment name.
- onelistserver=iqxbuild.azurecr.io/iqx.onelist.server:v6.2.2. onelistserver is the container name.iqxbuild.azurecr.io/iqx.onelist.server is the image name.v6.2.2 is the version to be updated.