Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/skynyrd/cikilop
Easy data migration for MongoDB using Python.
https://github.com/skynyrd/cikilop
ci continuous-integration migration-tool mongodb pymongo
Last synced: about 1 month ago
JSON representation
Easy data migration for MongoDB using Python.
- Host: GitHub
- URL: https://github.com/skynyrd/cikilop
- Owner: skynyrd
- License: gpl-3.0
- Created: 2018-02-25T21:09:53.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2018-08-31T19:02:32.000Z (over 6 years ago)
- Last Synced: 2024-08-09T13:17:28.822Z (5 months ago)
- Topics: ci, continuous-integration, migration-tool, mongodb, pymongo
- Language: Python
- Homepage:
- Size: 36.1 KB
- Stars: 35
- Watchers: 6
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![Build Status](https://travis-ci.org/skynyrd/cikilop.svg?branch=master)](https://travis-ci.org/skynyrd/cikilop)
[![Docker Hub](https://img.shields.io/badge/docker-ready-blue.svg)](https://hub.docker.com/r/skynyrd/cikilop/)```
_ _ _ _
___(_) | _(_) | ___ _ __
/ __| | |/ / | |/ _ \| '_ \
| (__| | <| | | (_) | |_) |
\___|_|_|\_\_|_|\___/| .__/
|_|
```
Cikilop v.1.1 is a simple and easy to use data migration tool for MongoDB that encourages you to write your migration scripts in Python.
All you need is docker (or python 3.6).### Why it's the tool you are looking for?
1. You need to manage your migrations commit by commit in your CI pipeline. A commit can have more than one new migration, in that case you need to migrate them in order, and if commit fails, you need to revert them in reverse order.
2. You want simply revert your migration from the CLI
3. Your project is written in Python, you are more comfortable with pymongo then plain mongo script.
4. You don't want to depend anything except docker
5. You just liked it's name <3### Usage
What you need: Prepare your migration scripts, prepare your config, run cikilop. That's it.
[![asciicast](https://asciinema.org/a/wU68w7hAWfl44YbYcTj6rL8P7.png)](https://asciinema.org/a/wU68w7hAWfl44YbYcTj6rL8P7)
__1. Build your migration script with only two functions:__
```py
def success(client):
col = client["exampledb"]["examplecol"]
col.insert_one({"_id": 1})def fail(client):
col = client["exampledb"]["examplecol"]
col.remove({"_id": 1})
```
Both functions must have an input parameter `client`, which cikilop ships to you. Indeed, it is regular `pymongo` MongoClient object (`pymongo.MongoClient`).__2. You need to name your script as `01-xxxx.py`, it must start with a number with dash. Cikilop sorts your migration files using that number.__
_Caveat: When applying the migration, scripts run with ascending order (e.g. `01-mig.py`, `02-mig.py`, `03-mig.py`).
When reverting the migration, scripts run with descending order (e.g. `03-mig.py`, `02-mig.py`, `01-mig.py`).___3. Prepare your simple configuration file, Its name must be config.json. You must define configuration for each environment.
There is an example for *local* environment above:__```json
{
"local": {
"migrations_db_name" : "migrations_db",
"migrations_coll_name" : "migration_list",
"mongo_uri" : "mongodb://username:[email protected]:27017..."
}
}
```_Note: The name you set for __migrations_coll_name__ and __migrations_db_name__ are used by cikilop itself. It creates a collection in specified db and stores the migration records in it._
__4. Run it!__
Use the wrapper script (it also uses docker):
1. `curl https://raw.githubusercontent.com/skynyrd/cikilop/master/ciki.sh --output ciki.sh && chmod +x ciki.sh`
2. `sudo ./ciki.sh -e ENVIRONMENT -c ABSOLUTE_CONFIG_FILE_PATH -m ABSOLUTE_MIGRATIONS_FOLDER_PATH`
e.g.: `sudo ./ciki.sh -e local -c $(pwd)/config.local.json -m $(pwd)/migrations`
To revert, add `-r true`
or use docker directly:
```bash
docker run -e env=local -v ABSOLUTE_CONFIG_FILE_PATH:/app/src/config/config.json -v ABSOLUTE_MIGRATIONS_FOLDER_PATH:/app/src/migrations skynyrd/cikilope.g. docker run -e env=local -v $(pwd)/config.json:/app/src/config/config.json -v $(pwd)/migrations:/app/src/migrations skynyrd/cikilop
```To revert, add `--revert` to `docker run` command
### Behind the scenes:
* When migrating:
* Cikilop first checks your files in your migrations folder with its migration collection in your mongo.
* If your folder has any new files, or any files that is already reverted in mongo, cikilop runs success functions of that files. (ordering: first 01-example.py, then 02-example.py)
* When reverting:
* Cikilop gets last created migration from its migration collection. It may have more than one files.
* It checks the files in last created migration with the files in your migrations folder.
* Takes their union.
* Reverts them by calling fail functions of the files. (ordering: first 02-example.py then 01-example.py)Thanks!
### Version History
`1.0.1 => 1.1`
* Feature: Multiple mongo db support by allowing user to access mongo client object.
* Feature: Users can store migration records in distinct database. (It was restricted to the database script will run on)### License
* GNU GPL v3