Azure Container Setup
  • 11 Aug 2021
  • 2 Minutes to read
  • Dark
    Light
  This documentation version is deprecated, please click here for the latest version.

Azure Container Setup

  • Dark
    Light

Article summary

Overview

The following document demonstrates how to configure a Decisions Docker Image to run a single Azure Container or ACI (Azure Container Instance). 

Note on Document 
Note that this document does not cover Container orchestration via such services as AKS (Azure Kubernetes Service). 

Requirements 

Before proceeding with the instructions provided by this document, ensure that the following prerequisites are met:

  • Decisions should be installed on an Azure VM (see Installing on Azure for additional information). 
  • .NET SDK 2.2 must be installed on the Decisions VM. 
    Additional Information on .NET SDK 2.2 
    The current version of .NET SDK can be confirmed by running the following CMD command: "dotnet --list-sdks".

    To download the Windows installer for .NET SDK 2.2, see Download .Net Core 2.2.
  • Docker Module must be installed in Decisions.

Setup 

  1. After installing the Docker Module, open DecisionsServerInstaller.exe and select RESTART SERVICE.
  2. After the Restart process completes, open the Azure Quickstart Center then click Start under Deploy and run a container-based app
  3. From the Deploy and run a container-based app screen, click Create under Deploy and run a container-based app with Azure Container Instances.
  4. From the Create container instance window, leave all values default except for the following which should be configured as follows, then click Next: Networking
    • Resource group: Set this to the Resource Group that the Decisions VM is located on. 
    • Container name:  Provide the desired name. 
    • Region: Match this value to the Region of the Decisions VM. 
    • Image source: Set this to Docker Hubor other registry.  
    • Image: Set to "decisionscore/unstablie:latest". 
    • OS type: Set to Linux.
  5.  From the next page, set Networking type to Public and provide the desired DNS name label. Then, click Next: Advanced
  6. Define the environment variables for the Container Instance so that it knows which Database (the one that Decisions was installed against), as well as the desired Decisions Account used for Container to Application communication; then, click Review + create
    Note on Container Instance Variables 
    The following chart represents how each of the Container Instance's Environment variables should be defined.
    Note that if the default Docker Admin Account "docker@decisions.com" with the password "docker" is used, then SETTING_USERNAME  and SETTING_PASSWORD may be left alone.
    KeyValue
    SETTING_DATABASE_CONNECTIONPoints to the Decisions Database,
    SETTING_PORTAL_BASE_URLhttp://decisionsIPorDNSname/decisions
    SETTING_SHM_BASE_URLhttp://decisionsIPorDNSname/decisions/Primary/REST
    SETTING_TAKE_REQUESTStrue
    SETTING_USERNAMEAdminEmail*
    SETTING_PASSWORDAdminPassword*


Deployment/Testing 

After selecting Review + create, Azure should begin to deploy the Container Instance.

To test this new Container Instance: 

  1. Log in to Decisions and confirm that the Container Instance(s) are properly connected by verifying that values populate in the Report located under the System > Administration > Containers Folder
    Container Logs 
    If the Report fails to populate, check the Container Logs for any errors that indicate that the Container failed to start/communciate, Do so by navigating to the Logs tab under Container Instance resource in Azure on the Containers page. 


  2. After successful deployment, access the Container's available REST Endpoint Definitions via the Container's IP by navigating to http://containerip/swagger
  3. Use the Request Formation Information on Swagger to confirm that the Container is able to execute a Flow/Rule via a REST Call; use the ID of a Flow/Rule created in Decisions to confirm. 
    Additional Information 
    For more information on how to execute a Flow/Rule via REST, see Calling a Flow as a REST Service.


Was this article helpful?