Generic ZODB storage conversion tool
Project description
zodb-convert
Generic ZODB storage conversion tool. Copies data between any two ZODB-compatible storages.
Derived from RelStorage's zodbconvert by the Zope Foundation and Contributors, extracted as a standalone generic tool.
Installation
pip install zodb-convert
To convert between specific storage types, install their packages too:
pip install zodb-convert ZODB RelStorage # FileStorage ↔ RelStorage
pip install zodb-convert ZODB zodb-pgjsonb # FileStorage ↔ PGJsonb
Usage
Traditional config file
Create a config file (convert.conf):
<filestorage source>
path /data/Data.fs
blob-dir /data/blobs
</filestorage>
<filestorage destination>
path /backup/Data.fs
blob-dir /backup/blobs
</filestorage>
For storages that need blob wrapping:
<blobstorage source>
blob-dir /data/blobs
<filestorage>
path /data/Data.fs
</filestorage>
</blobstorage>
<filestorage destination>
path /backup/Data.fs
blob-dir /backup/blobs
</filestorage>
For third-party storages, use %import:
%import relstorage
<relstorage source>
<postgresql>
dsn dbname=zodb user=zodb
</postgresql>
</relstorage>
<filestorage destination>
path /backup/Data.fs
</filestorage>
Run:
zodb-convert convert.conf
Using existing zope.conf files
Extract storage configuration directly from Zope config files:
zodb-convert --source-zope-conf /old/etc/zope.conf --dest-zope-conf /new/etc/zope.conf
Specify which database to use (defaults to "main"):
zodb-convert --source-zope-conf zope.conf --source-db main \
--dest-zope-conf other.conf --dest-db catalog
Mixed mode
Combine traditional config with zope.conf extraction:
zodb-convert convert.conf --source-zope-conf /old/etc/zope.conf
Where convert.conf contains only the destination storage section.
Options
--dry-run— show what would be copied without making changes--incremental— resume from the last transaction in the destination-v/--verbose— increase verbosity (-vfor INFO,-vvfor DEBUG)
Source Code and Contributions
The source code is managed in a Git repository, with its main branches hosted on GitHub. Issues can be reported there too.
We'd be happy to see many forks and pull requests to make this package even better. We welcome AI-assisted contributions, but expect every contributor to fully understand and be able to explain the code they submit. Please don't send bulk auto-generated pull requests.
Maintainers are Jens Klein and the BlueDynamics Alliance developer team. We appreciate any contribution and if a release on PyPI is needed, please just contact one of us. We also offer commercial support if any training, coaching, integration or adaptations are needed.
License
ZPL-2.1 — see LICENSE.txt
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 Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file zodb_convert-1.0.0b4.tar.gz.
File metadata
- Download URL: zodb_convert-1.0.0b4.tar.gz
- Upload date:
- Size: 45.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e90bbe1bc69347e0d8a784d58953ee3cfcb16d9588e6280e80a07bfd6f92ab14
|
|
| MD5 |
0dda89305498d09cb9bb61d3be47c60a
|
|
| BLAKE2b-256 |
64088c6627cab93763e606c3cf26f721bccbd4a9d68444c204e2eeca3985296f
|
Provenance
The following attestation bundles were made for zodb_convert-1.0.0b4.tar.gz:
Publisher:
release.yaml on bluedynamics/zodb-convert
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
zodb_convert-1.0.0b4.tar.gz -
Subject digest:
e90bbe1bc69347e0d8a784d58953ee3cfcb16d9588e6280e80a07bfd6f92ab14 - Sigstore transparency entry: 1006538045
- Sigstore integration time:
-
Permalink:
bluedynamics/zodb-convert@81468165c9a9516d74a3e8cec28a0d6167eb05ae -
Branch / Tag:
refs/tags/v1.0.0b4 - Owner: https://github.com/bluedynamics
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yaml@81468165c9a9516d74a3e8cec28a0d6167eb05ae -
Trigger Event:
release
-
Statement type:
File details
Details for the file zodb_convert-1.0.0b4-py3-none-any.whl.
File metadata
- Download URL: zodb_convert-1.0.0b4-py3-none-any.whl
- Upload date:
- Size: 11.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b6adc3f0002478e457c340d601ae949c49e285e162f9384ef52fdec8fe3d92bd
|
|
| MD5 |
2c89c8c3621bf28bee1814496ee56d12
|
|
| BLAKE2b-256 |
0b12b08f7673444a0305e0f663a81a1a7d60a0a3e46fd4f71cb06909430aca73
|
Provenance
The following attestation bundles were made for zodb_convert-1.0.0b4-py3-none-any.whl:
Publisher:
release.yaml on bluedynamics/zodb-convert
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
zodb_convert-1.0.0b4-py3-none-any.whl -
Subject digest:
b6adc3f0002478e457c340d601ae949c49e285e162f9384ef52fdec8fe3d92bd - Sigstore transparency entry: 1006538047
- Sigstore integration time:
-
Permalink:
bluedynamics/zodb-convert@81468165c9a9516d74a3e8cec28a0d6167eb05ae -
Branch / Tag:
refs/tags/v1.0.0b4 - Owner: https://github.com/bluedynamics
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yaml@81468165c9a9516d74a3e8cec28a0d6167eb05ae -
Trigger Event:
release
-
Statement type: