The code in the repository was designed to create a large number of test databases spanning a wide range of use cases, databases and version numbers to test various ingestion capabilities including full, incremental and log based replication. Below are a list of all of the different databases currently supported and which databases are on them. Note due to minor differences in DB engines, the same database is NOT guarenteed to be the same across different databases or database versions. The number in parentheses is the port number that instance will be listening on.
database_engine | version | adventureworks | sakila | world_x | siemens-test-db | jaffle | hopper |
---|---|---|---|---|---|---|---|
mysql | 5.5 | Y (4000) | N | N | N | N (just needs config tweak) | Y (4500) |
mysql | 5.6 | Y (4001) | Y (4101) | N | Y (4301) | Y (4401) | Y (4501) |
mysql | 5.7 | Y (4002) | Y (4102) | Y (4202) | Y (4302) | Y (4402) | Y (4502) |
mysql | 8.0 | Y (4003) | Y (4103) | Y (4203) | Y (4203) | N (just needs config tweak) | Y (4503) |
mariadb | 10.1 | Y (5000) | N | N | N | N | |
mariadb | 10.2 | Y (5001) | N | N | N | N | |
mariadb | 10.3 | Y (5002) | N | N | N | N | |
mariadb | 10.4 | Y (5003) | N | N | N | N | |
postgres | 9.6 | Y (6000) | Y (6100) | N | N | N | |
MS SQL Server (Linux) | 2017 | Y (7000) | N | N | N | N | |
MS SQL Server (Linux) | 2019 | Y (7001) | N | N | N | N |
When adding, do NOT use - or . in datasource names in sources.csv
This has ONLY been tested running on an Ubuntu 18.04 and a recent version of docker. Further setup is required for incremental loads (see below).
To create, test and delete all the databases, a number of helper functions are required.
render.py
is a python script that takes csv source and an action template and produces bash commands to execute.
To create all data sources
python3 render.py --source source.csv --action create | bash
NOTE: the create execution is VERY sensitive to being in the right folder. If you are not, everything will probably run fine but you'll end up with an empty database. If you find data not loading it's very likely this is the cause.
- Clone this project to the box you're running on. You can't run it locally to 'generate' the docker command then copy/paste it to the target box as it needs the local resources on startup.
- Run the script above (or a filtered version, below) to start the docker containers
If for example you want to just spin up a single sample database it might be simpler to ignore the piped bash command:
- Clone the project
- Say you want an adventureworks sample, so run
python3 render.py --source source.csv --action create | grep adventureworks
- Copy the line you want e.g.
docker run -d --name mysql5.7-adventureworks [etc.] $(pwd)/mysql-flex/adventureworks:/varlib/mysql-files/ mysql:5.7
- Run that command manually
To create all listed sources
python3 render.py --source source.csv --action list | bash
To delete all sources:
python3 render.py --source source.csv --action remove | bash
To show the number of rows (approximate in the case of many databases) in the first 10 tables:
python3 render.py --source source.csv --action show_tables | bash
For all the mysql based databases this row count is a query against the information schema. Note that row counts in here are estimates only - it will look like some data has not completely loaded but usually this is just bad estimation. If you are in any doubt check with a proper select count(*)
.
Subsets of these commands can be made with simple use of grep. For example just to create all sources using adventureworks
:
python3 render.py --source source.csv --action create | grep adventureworks | bash
To remove all sources using MySQL 5.7:
python3 render.py --source source.csv --action remove | grep mysql5.7 | bash
To test various key and log based incremental replications, it is necessary to continuously add in new rows of data. A data generator has been created that can create up to 100 new rows per second (perhaps more on a higher spec machine). Currently it only adds new rows to the salesorderheader
table in the adventureworks
database. It currently only works with the following databases:
- mysql5.5
- mysql5.6
- mysql5.7
- mysql8.0
- mariadb10.1
- mariadb10.2
- mariadb10.3
- mariadb10.4
The load scripts current run from the host, not inside a container. To prepare your system for them ensure you are running python3 and then:
sudo apt install -y python3-pip
pip3 install Faker mysql-connector-python pymssql
Run once for each database you want to insert to:
python3 -u adventureworks_incremental_data_generator.py --host 127.0.0.1 --port 4000 --database adventureworks --username datalytyx --password horsewelltree --sleep 0 > /tmp/mysql_incremental_4000.log 2>&1 &
python3 -u adventureworks_incremental_data_generator.py --host 127.0.0.1 --port 4001 --database adventureworks --username datalytyx --password horsewelltree --sleep 0 > /tmp/mysql_incremental_4001.log 2>&1 &
python3 -u adventureworks_incremental_data_generator.py --host 127.0.0.1 --port 4002 --database adventureworks --username datalytyx --password horsewelltree --sleep 0 > /tmp/mysql_incremental_4002.log 2>&1 &
python3 -u adventureworks_incremental_data_generator.py --host 127.0.0.1 --port 4003 --database adventureworks --username datalytyx --password horsewelltree --sleep 0 > /tmp/mysql_incremental_4003.log 2>&1 &
python3 -u adventureworks_incremental_data_generator.py --host 127.0.0.1 --port 5000 --database adventureworks --username datalytyx --password horsewelltree --sleep 0 > /tmp/mysql_incremental_5000.log 2>&1 &
python3 -u adventureworks_incremental_data_generator.py --host 127.0.0.1 --port 5001 --database adventureworks --username datalytyx --password horsewelltree --sleep 0 > /tmp/mysql_incremental_5001.log 2>&1 &
python3 -u adventureworks_incremental_data_generator.py --host 127.0.0.1 --port 5002 --database adventureworks --username datalytyx --password horsewelltree --sleep 0 > /tmp/mysql_incremental_5002.log 2>&1 &
python3 -u adventureworks_incremental_data_generator.py --host 127.0.0.1 --port 5003 --database adventureworks --username datalytyx --password horsewelltree --sleep 0 > /tmp/mysql_incremental_5003.log 2>&1 &
Note the port number changing to point to different database_engine/dataset combinations. These scripts are not robust - loosing connection to their DB will cause them to exit. If you need them to be reliable, wrap them in a restart loop.