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.
- client: DockerClient = 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_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