Cloud Operations
Production CATRancherDatadog
  • Welcome
  • Fundamental Concepts
    • Authoring
    • Reportability
    • Knowledge Modules
    • Synchronization
    • Mirth & Message Queuing
    • Glossary
  • Operations Handbook
    • Achieving Steady State
    • Leveraging Kubernetes
    • Triaging Issues
    • Escalation Policy
    • Playbooks
      • Sync-all (Redeploy) Knowledge Modules
  • Deployments
    • Methodology
    • Bill of Materials
      • AIMS Production
        • 2025
          • 2025-02-12
          • 2025-03-19
          • 2025-04-30
          • 2025-06-25
        • 2024
          • 2024-01-31
          • 2024-04-03
          • 2024-04-03 [PATCH]
          • 2024-06-05 [patched 05/31]
          • 2024-06-10 [PATCH TO 2024-06-05]
          • 2024-06-20 [PATCH TO 2024-06-05]
          • 2024-08-14
          • 2024-08-26 [PATCH TO 2024-08-14]
          • 2024-10-16
          • 2024-12-11
          • 2024-12-11 [PATCH 1]
        • 2023
          • 2023-02-22
          • 2023-02-22 Patch 01
          • 2023-05-18
          • 2023-07-26
          • 2023-10-04
          • 2023-11-15
        • 2022
          • 2022-12-14
          • 2022-11-09
          • 2022-09-28
          • 2022-08-18
          • 2022-07-13
          • 2022-06-15
          • 2022-05-16
          • 2022-05-02
          • 2022-04-27
          • 2022-04-21
          • 2022-04-14
          • 2022-04-13
          • 2022-04-12
          • 2022-03-14
          • 2022-02-16
          • 2022-1-27
          • 2022-01-24
          • 2022-01-06
        • 2021
          • 2021-12-06
          • 2021-11-29
          • 2021-11-17
      • AIMS PRR
        • 2023
          • 2023-02-22
          • 2023-02-22 Patch 01
          • 2023-05-18
          • 2023-07-26
          • 2023-10-04
          • 2023-11-15
        • 2022
          • 2022-12-14
          • 2022-11-09
          • 2022-09-28
          • 2022-08-18
          • 2022-07-13
          • 2022-06-15
          • 2022-05-16
          • 2022-05-02
          • 2022-04-27
          • 2022-04-21
          • 2022-04-14
          • 2022-04-13
          • 2022-04-12
          • 2022-01-06
        • 2021
          • 2021-12-06
          • 2021-11-29
          • 2021-11-17
        • 2024
          • 2024-01-31
          • 2024-04-03
          • 2024-04-03 [PATCH]
          • 2024-06-05 [patched 05/31]
          • 2024-06-10 [PATCH TO 2024-06-05]
          • 2024-06-20 [PATCH TO 2024-06-05]
          • 2024-08-14
          • 2024-08-26 [PATCH TO 2024-08-14]
          • 2024-10-16
          • 2024-12-11
          • 2024-12-11 [PATCH 1]
        • 2025
          • 2025-02-12
          • 2025-03-19
          • 2025-04-30
          • 2025-06-25
      • AIMS Onboarding
        • 2023
          • 2023-02-22
          • 2023-02-22 Patch 01
          • 2023-05-18
          • 2023-07-26
          • 2023-10-04
          • 2023-11-15
        • 2022
          • 2022-12-14
          • 2022-11-09
          • 2022-09-28
          • 2022-08-18
          • 2022-07-13
          • 2022-06-15
          • 2022-05-16
          • 2022-05-02
          • 2022-04-27
          • 2022-04-21
          • 2022-04-14
          • 2022-04-13
          • 2022-04-12
          • 2022-04-04
          • 2022-01-06
        • 2021
          • 2021-12-06
          • 2021-11-29
          • 2021-11-17
        • 2024
          • 2024-01-31
          • 2024-04-03
          • 2024-04-03 [PATCH]
          • 2024-06-05 [patched 05/31]
          • 2024-06-10 [PATCH TO 2024-06-05]
          • 2024-06-20 [PATCH TO 2024-06-05]
          • 2024-08-14
          • 2024-08-26 [PATCH TO 2024-08-14]
          • 2024-10-16
          • 2024-12-11
          • 2024-12-11 [PATCH 1]
        • 2025
          • 2025-02-12
          • 2025-03-19
          • 2025-04-30
          • 2025-06-25
      • Archived Environments
        • AIMS Sandbox
          • 2022-01-06
          • 2021-12-06
          • 2021-11-29
          • 2021-11-17
          • 2021-09-21
          • 2021-09-20
          • 2021-08-27
          • 2021-07-01
          • 2021-06-21
          • 2021-06-07
          • 2021-06-17
          • 2021-05-26
  • Architecture
    • Overview
    • Diagrams
      • HLN Hosted Environments
    • Data State
      • Authoring Database
      • Cloud Storage Buckets
      • Document Database
    • Kubernetes
      • Services
      • Workloads
        • Common Sidecars
          • 🚮GC Logging for Java
          • 🪢Cloud SQL Proxy
        • DSS
          • DSS Preflight Container
          • DSS Container
        • DSUS
          • DSUS Container
        • MTS
          • MTS Container
        • OUS
          • OUS Container
        • RGS
          • RGS Container
        • RRS
          • RRS Container
        • SS
          • SS Container
        • SSCS
          • SSCS Container
        • VCS
          • VCS Container
        • In-Development
          • EIS
          • FHIR
    • Web Applications
      • CAT
  • GitBook Resources
    • Workload Template
      • Container Template
Powered by GitBook
On this page
  • Overview
  • Service Mesh
  • Interactions
  • Placement
  • Pod Specification
  • Attributes
  • Containers
  • Volumes
  • Workload Definition
  • Workload Identity
  1. Architecture
  2. Kubernetes
  3. Workloads

DSS

Decision Support Service

PreviousCloud SQL ProxyNextDSS Preflight Container

Last updated 2 years ago

Overview

The Decision Support Service (DSS) contains one-or-more instances of OpenCDS, an open-source clinical decision support application modified by HLN for the purpose of RCKMS.

DSS utilizes authored Knowledge Modules, populated in container memory, to perform deterministic operations, such as constructing the reportability response.

Service Mesh

Interactions

  • Cloud Storage Buckets, which the DSS Preflight Container downloads all Knowledge Module binaries from as part of it's startup routine.

  • Communications with OUS to register DSS instances, and perform a webhook operation with each invocation to determine if the populated Knowledge Module is the latest authored version available.

  • SS invokes DSS to perform deterministic operations for a valid eCR.

Placement

Workload should be deployed to both the and environments.

In the authoring environment, DSS is populated with both TEST and PRODUCTION Knowledge Modules, and runs both a testing-mode and production-mode OpenCDS instance. DSS is invoked by means of the Shared Service Submission Tool (SST) in CAT-RCKMS.

In the reportability environment, DSS is only populated with PRODUCTION Knowledge Modules, and only runs the production-mode OpenCDS instance. DSS is invoked by the Shared Service (SS) once it has a valid payload and identified the jurisdictions (and by extension, the Knowledge Modules) necessary for determining a reportability response.

For details on replica counts and resource configurations on a per-environment basis, see the section below.

Pod Specification

Attributes

Parameter
Value

Name

decision-support-service

Restart Policy

Always

Termination Grace Period (seconds)

90

Tolerations (optional for AIMS environments)

N/A

Containers

Volumes

This pod requires two volumes:

  • A volume named dss-pf, of type empty_dir with the medium parameter left blank or set to an empty string (""). This is used by the DSS Preflight init container, which pulls all necessary Knowledge Modules from the designated cloud storage bucket to optimize first-run performance of DSS.

Workload Definition

Reportability Environment

Provision workload as a Kubernetes Deployment resource, with RollingUpdate strategy and the following attributes for nominal operation state:

Parameter
Value

Replicas

35

Minimum Ready Seconds

45

Maximum Surge

10

Maximum Unavailable

0

Authoring Environment

Provision workload as a Kubernetes Deployment resource, with RollingUpdate strategy and the following attributes for nominal operation state:

Parameter
Value

Replicas

1

Minimum Ready Seconds

45

Maximum Surge

1

Maximum Unavailable

0

Provision workload as a Kubernetes Deployment resource, with RollingUpdate strategy and the following attributes for nominal operation state:

Parameter
Value

Replicas

1

Minimum Ready Seconds

45

Maximum Surge

1

Maximum Unavailable

0

Workload Identity

When the is enabled, logging events from the startup script execution can be captured by replicating the configuration of the GC Logging for Java sidecar, changing both the container name (e.g. probe-logger) and second command argument to "tail -F -v /hln/diagnostics/rckms-dss-startup-probe.log".

A volume named java-diag, of type empty_dir with the medium parameter left blank or set to an empty string (""). This is used by the .

A Kubernetes Service Account named decision-support-service should be associated with this workload, for bindings specified in .

DSS Container
DSS Preflight Container
🚮GC Logging for Java
Java GC Logging common sidecar container
authoring
reportability
Workload Definition
containers
DSS Container Startup Probe