Skip to main content

Migrator from proprietary and legacy databases into PostgreSQL

Project description

credativ-pg-migrator

Logo

credativ-pg-migrator is a solution for the migration of databases from legacy systems to PostgreSQL. It is is written in Python in multiple classes and modules. For practical usage and examples refer to the tests directory. There you can find working examples of the migration process for different databases.

Main features

  • Pure python solution, uses only standard libraries, structured in modules, written in object-oriented style in classes
  • Currently supported source databases are:
    • IBM dDB2 LUW
    • Informix
    • MS SQL Server
    • MySQL/MariaDB (engines with INFORMATION_SCHEMA)
    • Oracle
    • PostgreSQL (mainly for special use cases)
    • SQL Anywhere
    • Sybase ASE
  • Supports migration of tables, column constraints and defaults, data, primary keys, secondary indexes, foreign keys, functions/procedures, triggers and views from source to target database
  • If tables have sequences, migrator sets current values of sequences on the target database
  • Migration of views is currently only in rudimentary version, just replacing source schema names in code with target schema names
  • Conversion and migration of functions, procedures, triggers currently fully works for Informix. Can be added on demand for other databases too.
  • Migrator allows customizable substitutions of data types, default values of columns, calls of remote objects.
  • User can also define limitations for migration of data - as where conditions for tables. This option requires good analysis of dependencies in the source database. Missing data can break Foreign Key constraints in the target database. See further in the documentation.
  • Migrator provides reach logging and error handling, has 2 levels of logging - INFO and DEBUG, in case of error, detailed error message is printed.
  • By default logging messages are printed both to console and to log file, name of the log file is configurable in command line arguments.
  • Rich information is also logged to the migration database - see below.

Installation

Via PyPI:

credativ-pg-migrator is available from PyPI: https://pypi.org/project/credativ-pg-migrator/

python3 -m venv migrator_venv
. ./migrator_venv/bin/activate
pip install credativ-pg-migrator

Via Debian/Ubuntu packages:

credativ-pg-migrator is included in apt.postgresql.org PostgreSQL community repository, see https://wiki.postgresql.org/wiki/Apt for details.

Usage

credativ-pg-migrator --config=./test_database.yaml --log-file=./test_database_$(date +%Y%m%d).log --log-level=INFO

Configuration file

  • Configuration file is a YAML file
  • Settings available in the config file are described in config_sample.yaml file

Architecture

Architecture

Source databases

  • Source database connector must implement DatabaseConnector class from the credativ-pg-migrator.database_connector module
  • Methods of this class contain descriptions of actions and return values that are expected by the migrator tool
  • Supported databases should be accessed via ODBC, JDBC or native python libraries. Not all options are available for all databases.
  • See feature matrix in FEATURE MATRIX for supported features in different database connectors.

Target databases

  • Target database connector must implement DatabaseConnector class from the migrator.database_connector module
  • Solution currently supports only PostgreSQL as target database

Migration database

  • Solution uses a migration database to store metadata about the migration process
  • Migration database is a PostgreSQL database, credentials must be configured in the configuration file
  • In most cases we assume that the migration database will the same as the target database, but it is fully possible to use a different database from the same or different PostgreSQL server
  • Migration protocol tables contain detailed information about all migrated objects, like source code, target code, success or failure of migration, etc.

Changes

See CHANGELOG.

Known issues

See ISSUESLOG

Authors

credativ-pg-migrator has been primarily developped and is maintained by Josef Machytka, see AUTHORS.

License

credativ-pg-migrator is released under the GNU General Public License, version 3 (or any later version). See the file COPYING in the distribution for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

credativ_pg_migrator-0.9.0rc2.tar.gz (122.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

credativ_pg_migrator-0.9.0rc2-py3-none-any.whl (127.7 kB view details)

Uploaded Python 3

File details

Details for the file credativ_pg_migrator-0.9.0rc2.tar.gz.

File metadata

  • Download URL: credativ_pg_migrator-0.9.0rc2.tar.gz
  • Upload date:
  • Size: 122.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.2

File hashes

Hashes for credativ_pg_migrator-0.9.0rc2.tar.gz
Algorithm Hash digest
SHA256 c38b47cb1bbeb5d5b9a4691b443feb6d835e3e8b280b5ab90fe45dfb2e112491
MD5 002a0213531cedc19ea31e67324f2b6f
BLAKE2b-256 84f2379a8e64d9836afb4c58411cb7bae0ca232a036836e995d97a11b4aebb04

See more details on using hashes here.

File details

Details for the file credativ_pg_migrator-0.9.0rc2-py3-none-any.whl.

File metadata

File hashes

Hashes for credativ_pg_migrator-0.9.0rc2-py3-none-any.whl
Algorithm Hash digest
SHA256 26ef6dc2e0e7c055b71d62f427865e1fb6e85529ca664dc31c114a317fdac926
MD5 f2f28f669bfc65e40fa8afc902e33a3c
BLAKE2b-256 f25fcb08a0ca4543ec59b7e072c00e5a0a124c4cd74c0e8d5514214c542751fa

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page