AMT Help Files
homeAMT AdminInstallation and ConfigurationRunning Control Center

Running Control Center

To access the Control Center, its backend must be running. In addition, to access the Control Center's web interface, a web server is required to host the Control Center's frontend.

Configuring the Frontend

In the example below, Nginx is used and configured to access the Control Center.

Follow the steps below to configure Nginx to host the Control Center frontend.

  1. Navigate to the Nginx/conf folder and open the nginx.conf configuration file in a text editor.
  2. Add the following blocks:
    http {
    ...

    server { ... #AMT Control Center Frontend location /control-center { alias C:\AMT\AMT-Java\Binaries\control-center-frontend; try-files $uri $uri/ /index.html =404; } #API requests from the Control Center location control-center/api { rewrite ^/control-center(.*)$ $1 break; proxy_pass https://127.0.0.1:9001; }
    ... }
    (Change the alias path to point to the Control Center frontend in the AMT environment).

  3. Save the file.

Starting the Back and Frontend

  1. Open PowerShell and run the following command to start the backend:
    java --enable-preview -jar C:\AMT\AMT-Java\Binaries\control-center-backend\control-center-server-pekko-x.x.x.jar -cf "C:\AMT\AMT-Java-Client\Config\cc-config.yaml" -lf "C:\AMT\AMT-Java\Config\AmtRuntime.lic"
  2. Open another PowerShell window and run the following command from the Nginx folder to start the frontend:
    nginx start

Running the Control Center through Docker

We will be using Rancher in our examples to manage the Docker container for the Control Center.

  1. To install Rancher, visit the Rancher website and follow their download instructions.
    • warning Rancher requires WSL: aka.ms/wslinstall.
    • info Running the following in PowerShell installs WSL2: wsl --install.
  2. Start Rancher and set runtime to "dockerd (moby)".
    • Using Kubernetes is optional. Enable Kubernetes if it's required to dynamically scale your deployment. This can be enabled later in Rancher's preferences.

The container will be a composite of the Control Center backend, frontend (through Nginx), and a system database (through PostgreSQL).

An image of the Control Center backend and frontend is necessary.

Pulling the AMT Image

Pull the image provided by Avanade using the following command:

docker pull <address>/control-center-server-java

Setting Up the Folder Structure

Set up a folder structure for the Docker container to contain the Docker compose.yaml, configuration file, and license file.

C:\AMT\amt-java-docker\
    compose.yaml
C:\AMT\amt-java-docker\config\
    cc-config.yaml
    AmtRuntime.lic

Configuring cc-config.yaml

Simple configuration file for the Control Center. This is a minimal local solution serving as an example, not suited for production environments.

Note the usage of host.docker.internal instead of localhost.

---
name: AMT Control Center Java Config
environment: DEV
node:
  host: 0.0.0.0
  restPort: 9001
systemDatabase:
  type: POSTGRES
  settings:
    name: amtsystem
    schema: amtsystem
    username: <username>
    password: <password>
    driverClassname: org.postgresql.Driver
    url: jdbc:postgresql://host.docker.internal:5432/amtsystem
    hibernateDialect: org.hibernate.dialect.PostgreSQLDialect
    connectionPoolSize: 200
authentication:
  type: OIDC
  clients:
    rest:
      settings:
        issuerURL: http://localhost:8080/realms/AMTRealm
        clientID: AMT
        returnUrl: http://localhost:4200/control-center
...

Configuring compose.yaml

Simple configuration for the Docker Compose file.

services:
  # PostgreSQL Database
  postgres:
    image: postgres:15
    container_name: amt-postgres
    environment:
      POSTGRES_DB: amtsystem
      POSTGRES_USER: <username>
      POSTGRES_PASSWORD: <password>
    ports:
      - "5432:5432"
    volumes:
      - postgres-data:/var/lib/postgresql/data
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres"]
      interval: 10s
      timeout: 5s
      retries: 5

  # Control Center Backend
  control-center-backend:
    image: amt-java/control-center-server-java
    container_name: amt-control-center-backend
    depends_on:
      postgres:
        condition: service_healthy
    ports:
      - "9001:9001"
    volumes:
      - ./config:/config:ro
    environment:
      - JAVA_OPTS=--enable-preview
    command: >
      java --enable-preview
      -jar /.../control-center-server/control-center-server-pekko.jar
      -cf /config/cc-config.yaml
      -lf /config/AmtRuntime.lic
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost:9001/health"]
      interval: 30s
      timeout: 10s
      retries: 3
      start_period: 40s

  # Control Center Frontend
  control-center-frontend:
    image: amt-java/control-center-server-angular
    container_name: amt-control-center-frontend
    ports:
      - "4200:80"
    depends_on:
      - control-center-backend

volumes:
  postgres-data:

Starting the Container

With the image pulled and the folder structure set up, run the following command from the folder containing the compose.yaml file to start the container:

docker compose up -d

To stop the container, run the following command from the same folder:

docker compose down

Contents

 Go to top