No project description provided
Project description
nucliadb
This module contains most of the Python components for NucliaDB:
- ingest
- reader
- writer
- search
- train
NucliaDB Migrations
This module is used to manage NucliaDB Migrations.
All migrations will be provided in the migrations
folder and have a filename
that follows the structure: [sequence]_[migration name].py
.
Where sequence
is the order the migration should be run in with zero padding.
Example: 0001_migrate_data.py
.
Each migration should have the following:
from nucliadb.migrator.context import ExecutionContext
async def migrate(context: ExecutionContext) -> None:
"""
Non-kb type of migration. Migrate global data.
"""
async def migrate_kb(context: ExecutionContext, kbid: str) -> None:
"""
Migrate kb.
Must have both types of migrations.
"""
How migrations are managed
-
All migrations utilize a distributed lock to prevent simulateously running jobs
-
Global migration state:
- current version
- target version
- KBs to migrate
-
KB Migration State:
- current version
-
Migrations are currently run with a deployment and will be continuously retried on failure.
-
Running migrations in a deployment is to make sure a migration does not prevent code deployment.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Hashes for nucliadb-2.21.0.post544-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6653d6d7f45f3d229c9fb0e533c1787a9d8a948c419a6a343d8914b81cc413a6 |
|
MD5 | af25cf4db66b453e0e285418302f90f7 |
|
BLAKE2b-256 | 11d6e3e0f1fedc49c526f6631e8aff16af6a7b4a03ddcb8f9d4951c56a707d86 |