idmtools_platform_local.infrastructure.base_service_container module#

idmtools base service container.

This defined the base docker container. We use this amongst each service to build our containers as needed.

Copyright 2021, Bill & Melinda Gates Foundation. All rights reserved.

class idmtools_platform_local.infrastructure.base_service_container.BaseServiceContainer(container_name: str | None = None, image: str | None = None, client: DockerClient | None = None, config_prefix: str | None = None, network: str | None = None)[source]#

Bases: ABC

Providers base abstract class for local platform container objects/managers.

container_name: str = None#
image: str = None#
client: DockerClient = None#
config_prefix: str = None#
network: str = None#
static get_common_config(container_name: str, image: str, network: str, port_bindings: Dict | None = None, volumes: Dict | None = None, mem_limit: str | None = None, mem_reservation: str | None = None, environment: List[str] | None = None, extra_labels: Dict | None = None, **extras) dict[source]#

Returns portions of docker container configs that are common between all the different containers used within our platform.

Parameters:
  • container_name – Container name

  • image – Image to use

  • network – Network to use

  • port_bindings – Port binding

  • volumes – Volume definitions

  • mem_limit – Memory limit

  • mem_reservation – Memory reservation

  • environment – Environment vars

  • extra_labels – Extra labels to use

  • **extras

Returns:

Common configuration object to use when creating a container.

Notes

Memory strings should match those used by docker. See –memory details at https://docs.docker.com/engine/reference/run/#runtime-constraints-on-resources

get() Container | None[source]#

Get the container.

Returns:

Container if it is running.

get_or_create(spinner=None) Container[source]#

Get or Create a container.

Parameters:

spinner – Optional spinner to display

Returns:

Docker container object representing service container

ensure_container_is_running(container: Container, spinner=None) Container[source]#

Ensures is running.

Parameters:
  • container – container to check if it is running

  • spinner – Optional spinner to show we are busy while checking.

Returns:

Container

has_different_config(container, show_diff: bool = True)[source]#

Detect if the config is difference that running container.

Parameters:
  • container – Container

  • show_diff – Should we display diff

Returns:

True if there is differing configuration

get_running_config(container)[source]#

Fetches the config used to start a container.

Parameters:

container – Container to use

Returns:

The config from the running container.

static copy_config_to_container(container: Container, config: dict)[source]#

Copy the configuration used to create container to a container for future reference.

Parameters:
  • container – Target container

  • config – Config to copy

Returns:

None

create(spinner=None) Container[source]#

Create our container.

Parameters:

spinner – Optional spinner. When provided, we will use it to indicate we are busy during long-running tasks.

Returns:

Created Container.

Raises:
  • EnvironmentError - If a container tries to start with a port in use

  • ValueError - Unkown cause

Notes

  • TODO - Add Exception for environment error with doc_link

static wait_on_status(container, sleep_interval: float = 0.2, max_time: float = 2, statutes_to_wait_for: List[str] | None = None)[source]#

Wait on a container to achieve a specific status.

Parameters:
  • container – Target container

  • sleep_interval – How long to wait between checks

  • max_time – Max time to wait(default to 2 seconds)

  • statutes_to_wait_for – List of statuss to wait for. When not set, we use starting and created.

Returns:

None

stop(remove=False, container: Container | None = None)[source]#

Stop a container.

Parameters:
  • remove – When true, the container will be removed after being stopped

  • container – Container to stop

Returns:

None

restart(container: Container | None = None)[source]#

Restart a container.

Parameters:

container – Container to restart.

Returns:

None

get_logs()[source]#

Get logs from container.

Returns:

Container logs as a string.

abstract get_configuration() Dict[source]#

Get configuration.

Each sub-class should define this to provide their own specific configuration.

Returns:

Configuration dict

__init__(container_name: str | None = None, image: str | None = None, client: DockerClient | None = None, config_prefix: str | None = None, network: str | None = None) None#