Packaging and versioning
DiracX is a comprehensive Python package, composed of several interconnected submodules. It's designed to provide robust and versatile functionalities, primarily through these key components:
-
User-Facing Components:
diracx
: This is the primary interface for users, integrating both the Command Line Interface (CLI) and Python API.diracx-routers
: Serves as the server component, offering HTTPS endpoints.diracx-tasks
: Handles operations executed by DiracX servers, either periodically or upon request.
-
Containerization:
- Each component is available as a container image, packaging DiracX along with all necessary dependencies.
Python Modules
DiracX is structured into various modules, each serving a distinct purpose:
diracx-core
: The foundational code base, utilized by all other DiracX modules.diracx-db
: Focuses on database functionalities.diracx-routers
: Implements a FastAPI application.diracx-client
: A client auto-generated from the OpenAPI specification indiracx-routers
.diracx-api
: Provides higher-level operations building ondiracx-client
.diracx-cli
: The command line interface (dirac
).diracx
: A metapackage offeringdiracx-client
,diracx-api
, anddiracx-cli
.
These modules are each implemented as a native Python namespace package.
The direct dependencies between the submodules are as follows:
┌──────┐
┌──────┤ core ├─────────┐
│ └──────┘ │
┌──▼─┐ ┌────▼───┐
│ db ├─────┐ │ client │
└─┬──┘ │ └────┬───┘
┌────▼────┐ │ ┌──▼──┐
│ routers │ │ ┌────────┤ api │
└─────────┘ │ │ └──┬──┘
┌─▼───▼─┐ ┌──▼──┐
│ tasks │ │ cli │
└───────┘ └─────┘
Versioning Strategy
- Currently, and as long as
DIRAC
anddiracx
coexist, we employ a versioning format ofv0.<major>.<patch>.
- We only support using the same version across all
diracx-*
packages. - The client and server versions can vary, but the client version is always communicated to the server. Incompatibly old client versions may lead to request rejections, prompting a client update. (TODO: https://github.com/DIRACGrid/diracx/issues/258)
Container Images
DiracX utilizes a structured approach to containerization:
-
Base Image:
- All container images start from
diracx/base
.
- All container images start from
-
Specialized Base Images:
diracx/services-base
diracx/tasks-base
diracx/client-base
-
Image Versioning and Building:
- Images are built periodically (e.g., every Monday) and tagged as
YYYY.MM.DD.P
. - A DiracX release triggers the creation of new
DiracXService
,diracx/tasks
, anddiracx/client
images, based on specificdiracx/base
tags. - This approach ensures stability in production environments.
- For testing purposes, the
latest
base images are used, with dependencies installed viapip install
.
- Images are built periodically (e.g., every Monday) and tagged as
See this diagram for an example of how this looks in practice:
┌──────────────────────────┐
┌─ ────┤ diracx/base:YYYY.MM.DD.P ├─────┐
│ └──────────────────────────┘ │
│ │
┌────────────────▼──────────────────┐ ┌────────────────▼───────────────┐
│ diracx/services-base:YYYY.MM.DD.P │ │ diracx/tasks-base:YYYY.MM.DD.P │
└────────────────┬──────────────────┘ └────────────────┬───────────────┘
│ │
┌───────────▼────────────┐ ┌──────────▼──────────┐
│ diracx/services:v0.X.Y │ │ diracx/tasks:v0.X.Y │
└────────────────────────┘ └─────────────────────┘
Dependencies
- There is a noted duplication between
setup.cfg
andenvironment.yaml
. - The
diracx/base
image is built from a Dockerfile withenvironment.yml
, primarily defining the Python version anddirac_environment.yaml
containing the DIRAC specific dependencies. The latter is there as a "temporary" thing. - The
diracx/services-base
anddiracx/tasks-base
images extenddiracx/base
with additional Dockerfiles andenvironment.yml
, tailored to their specific needs. - The
diracx/services
anddiracx/tasks
images are further built upon their respective base images, adding necessary diracx packages throughpip install --no-dependencies
.
Entrypoint
TODO: document the entry point
Extensions
- Extensions will extend one or more of
diracx
,diracx-routers
,diracx-tasks
images (e.g.mydiracx
,mydiracx-routers
,mydiracx-tasks
). - Extensions provide a corresponding container image based on a specific release of the corresponding DiracX image.