myt/README.md

224 lines
5.2 KiB
Markdown
Raw Normal View History

2020-11-14 01:38:56 +00:00
# MyVC (MySQL Version Control)
2020-11-15 18:24:25 +00:00
Utilities to ease the maintenance of MySQL or MariaDB database versioning using
a Git repository.
This project is just to bring an idea to life and is still in an early stage of
2021-10-23 17:14:09 +00:00
development, so any help is welcomed! Feel free to contribute.
2020-11-14 01:38:56 +00:00
2020-12-02 07:35:26 +00:00
## Requirements
2020-11-14 01:38:56 +00:00
2021-10-16 06:44:19 +00:00
* Node.js >= 14.0
2020-11-15 18:24:25 +00:00
* Git
2020-12-04 16:30:26 +00:00
* Docker (Local server)
2020-11-14 01:38:56 +00:00
2020-11-14 15:08:27 +00:00
## Installation
It's recommended to install the package globally.
2020-11-17 11:47:20 +00:00
2020-11-15 18:24:25 +00:00
```text
2020-11-14 15:08:27 +00:00
# npm install -g myvc
$ myvc [command]
2020-11-14 15:08:27 +00:00
```
2020-11-15 18:24:25 +00:00
You can also install locally and use the *npx* command to execute it.
2020-11-17 11:47:20 +00:00
2020-11-15 18:24:25 +00:00
```text
$ npm install myvc
$ npx myvc [command]
2020-11-14 01:38:56 +00:00
```
2020-11-15 18:24:25 +00:00
## How to use
2020-11-14 01:38:56 +00:00
Execute *myvc* with the desired command.
2020-11-17 11:47:20 +00:00
2020-11-15 18:24:25 +00:00
```text
$ [npx] myvc [-w|--workspace <string>] [-r|--remote <string>] [-d|--debug] [-h|--help] <command> [<args>]
2020-11-14 01:38:56 +00:00
```
2020-11-17 11:47:20 +00:00
2020-11-17 13:11:15 +00:00
The default workspace directory is the current working directory and unless
2020-12-04 16:30:26 +00:00
otherwise indicated, the default remote is *local*.
2020-11-14 01:38:56 +00:00
2020-12-04 16:30:26 +00:00
Database versioning commands:
* **init**: Initialize an empty workspace.
2021-10-23 17:14:09 +00:00
* **pull**: Incorporate database routine changes into workspace.
2020-12-02 07:35:26 +00:00
* **push**: Apply changes into database.
* **version**: Creates a new version.
2020-11-17 12:04:57 +00:00
2020-12-04 16:30:26 +00:00
Local server management commands:
2020-11-17 12:04:57 +00:00
* **dump**: Export database structure and fixtures.
* **run**: Build and start local database server container.
2020-12-02 07:35:26 +00:00
* **start**: Start local database server container.
2020-11-15 18:24:25 +00:00
Each command can have its own specific commandline options.
2020-11-14 01:38:56 +00:00
2021-10-23 17:14:09 +00:00
## Versioning commands
### init
Initializes an empty workspace.
```text
$ myvc init
```
### pull
Incorporates database routine changes into workspace.
```text
2022-02-07 11:46:14 +00:00
$ myvc pull [remote] [-f|--force] [-c|--checkout] [-u|--update]
2021-10-23 17:14:09 +00:00
```
When *checkout* option is provided, it does the following before export:
2021-10-23 17:14:09 +00:00
1. Get the last database push commit (saved in versioning tables).
2. Creates and checkout to a new branch based in database commit.
2021-10-23 17:14:09 +00:00
### push
Applies versions and routine changes into database.
```text
$ myvc push [<remote>] [-f|--force]
2021-10-23 17:14:09 +00:00
```
### version
Creates a new version folder, when name is not specified it generates a random
name mixing a color with a plant name.
2021-10-23 17:14:09 +00:00
```text
$ myvc version [<name>]
2021-10-23 17:14:09 +00:00
```
## Local server commands
### dump
Exports database structure and fixtures from remote into hidden files located
in *dump* folder. If no remote is specified *production* is used.
2021-10-23 17:14:09 +00:00
```text
$ myvc dump [<remote>]
2021-10-23 17:14:09 +00:00
```
### run
Builds and starts local database server container. It only rebuilds the image
when fixtures have been modified or when the day on which the image was built
is different to today.
```text
$ myvc run [-c|--ci] [-r|--random]
```
### start
Starts local database server container. It does the minium effort, if it
doesn't exists calls the run command, if it is started does nothing. Keep in
mind that when you do not rebuild the docker you may be using an outdated
version of it.
```text
$ myvc start
```
2020-11-14 01:38:56 +00:00
## Basic information
First of all you have to initalize the workspace.
2020-11-15 18:38:23 +00:00
```text
$ myvc init
```
2020-12-02 07:35:26 +00:00
Now you can configure MyVC using *myvc.config.yml* file, located at the root of
your workspace. This file should include the project codename and schemas/tables
wich are exported when you use *pull* or *dump* commands.
2020-11-15 18:38:23 +00:00
2020-12-04 16:30:26 +00:00
### Remotes
2020-11-16 00:58:27 +00:00
Create database connection configuration for each environment at *remotes*
2020-12-04 16:30:26 +00:00
folder using standard MySQL *ini* configuration files. The convention remote
names are *production* and *test*.
2020-11-17 11:47:20 +00:00
2020-11-15 18:24:25 +00:00
```text
2020-12-04 16:30:26 +00:00
remotes/[remote].ini
2020-11-14 01:38:56 +00:00
```
2020-11-15 18:24:25 +00:00
### Routines
Routines are placed inside *routines* folder. All objects that have PL/SQL code
are considered routines. It includes events, functions, procedures, triggers
and views with the following structure.
2020-11-17 11:47:20 +00:00
2020-11-15 18:24:25 +00:00
```text
2020-11-14 01:38:56 +00:00
routines
`- schema
|- events
| `- eventName.sql
|- functions
| `- functionName.sql
|- procedures
| `- procedureName.sql
|- triggers
| `- triggerName.sql
`- views
`- viewName.sql
```
2020-11-15 18:24:25 +00:00
### Versions
2020-11-14 01:38:56 +00:00
2021-10-23 17:14:09 +00:00
Versions are placed inside *versions* folder with the following structure.
Don't place your PL/SQL objects here, use the routines folder!
2020-11-17 11:47:20 +00:00
2020-11-15 18:24:25 +00:00
```text
versions
2020-11-14 01:38:56 +00:00
|- 00001-firstVersionCodeName
| |- 00-firstExecutedScript.sql
| |- 01-secondScript.sql
| `- 99-lastScript.sql
`- 00002-secondVersion
|- 00-firstExecutedScript.sql
`- 00-sameNumbers.sql
```
2020-11-17 11:47:20 +00:00
2020-11-17 12:04:57 +00:00
### Local server
The local server is created as a MariaDB Docker container using the base dump
created with the *dump* command plus pushing local versions and changed
2020-11-17 12:04:57 +00:00
routines.
### Dumps
2021-10-23 17:14:09 +00:00
You can create your local fixture and structure files.
* *dump/structure.sql*
* *dump/fixtures.sql*
2020-11-17 11:47:20 +00:00
## Why
The main reason for starting this project it's because there are no fully free
and open source migration tools available that allow versioning database
routines with an standard CVS system as if they were normal application code.
2020-11-17 11:47:20 +00:00
Also, the existing tools are too complex and require too much knowledge to
start a small project.
2020-11-17 11:47:20 +00:00
## Todo
* Preserve all characteristics on pull: comments, SQL mode, READS SQL DATA...
* Undo changes when there is an error applying a version using "undo" files.
2021-10-23 17:14:09 +00:00
* Use a custom *Dockerfile* for local database container.
* Console logging via events.
* Lock version table row when pushing.
2020-11-17 11:47:20 +00:00
2020-11-14 01:38:56 +00:00
## Built With
* [Git](https://git-scm.com/)
* [nodejs](https://nodejs.org/)
* [NodeGit](https://www.nodegit.org/)
2020-11-14 01:38:56 +00:00
* [docker](https://www.docker.com/)