Skip to content
/ cquill Public

Versioned CQL migrations for Cassandra and ScyllaDB

License

Notifications You must be signed in to change notification settings

eighty4/cquill

Repository files navigation

CI

Versioned CQL migrations for Cassandra and ScyllaDB

Create a directory with CQL files. Develop with Cquill locally. Then version, package and release with Cquill to your database deployment.

VC interest is welcome.

Migrate command

cquill migrate performs a migration using cql sources from the ./cql directory.

CQL files are versioned with a 3 digit version prefix specified v001 or V001 and must be sequentially versioned. v001-create-api-keyspace.cql is valid while v8.cql is not valid.

On the event of a CQL statement error, Cquill will stop executing statements from the file and report which statement failed. Remediation at this point is a manual process and guidance is included with the error message from Cassandra.

Migration history is stored in a table named cquill.migrated_cql with a md5 hash record for every completed CQL file. Future migrations will validate previously migrated CQL files against the md5 hashes. This step ensures correctness and prevents a migration that could cause data integrity problems.

Use cquill help migrate for parameters. The migration history table's keyspace, name and replication can be configured with the migrate command's parameters.

Getting started

Cquill can be used as a local binary built with Cargo/Rust, a Docker image, or as a Rust library.

Install locally with Cargo

Cargo will build the latest published version of Cquill with install:

cargo install cquill

Versions published with Cargo are detailed on crates.io/crates/cquill.

Run a migration with local CQL sources in a Docker container

Image 84tech/cquill will migrate CQL sources in its /cquill/cql directory (documented in Cquill's Dockerfile).

This approach requires specifying the CASSANDRA_NODE env variable to match Cassandra's hostname and the Docker network:

docker run -it --rm -v $(pwd)/cql:/cquill/cql:ro -e CASSANDRA_NODE=cassandra --network my_network 84tech/cquill migrate

Create a Docker image of versioned CQL sources

In a containerized environment using CI/CD automation, versioning CQL to distribute with release is ideal for workflow automation. Copy the release's CQL sources ./cql relative to the WORKDIR:

FROM 84tech/cquill
WORKDIR /
COPY cql cql

Given a ./cql directory and a cql.Dockerfile build manifest, Docker build a versioned image to be deployed in coordination with the API:

docker build -t my-api-cql:0.0.1 -f cql.Dockerfile .

Using Cquill as a library

Rust projects can embed the Cquill crate into their project to keep an environment's CQL up-to-date as new versions of a project is deployed or run Cquill from unit tests.

The examples show the cquill::migrate_cql API that can be used directly from your Rust project. Check it out at ./examples/migrate.rs and run with cargo run --example migrate

Contributing

Rust and Docker are Cquill's only development dependencies.

Use docker compose to launch a Cassandra or ScyllaDB instance for running cargo test. Each supported database version is configured in docker-compose.yml and the compose service name must be included in the docker compose up command:

docker compose up cassandra_4_1 -d --wait

CI checks on pull requests are detailed in the verify.yml workflow. This workflow runs:

cargo fmt
cargo clippy -- -D warnings
cargo test
cargo build --release

The script ci_verify.sh will run all of these CI checks.

Roadmap

This is a list of nice-to-have features that I will hope to add in the future:

  • cquill verify command validates CQL file names, CQL connection, and the md5 hashes of previously migrated CQL files
  • cquill doctor command corrects migration history and md5 hashes
  • cquill dev command using file watches to drop and recreate keyspaces and tables during active development
  • Support v001.dev.cql or similar dev-annotated filenames to populate development environments with data
  • Create an AST for CQL statements, enabling support for several additional features:
    • rewrite keyspace names for a migration to create parallel deploys of a system's keyspaces (useful for isolated testing)
    • validate CQL statement syntax before executing against a live database
    • resolve specific line and column data for CQL statements for command output
    • invert CQL statements, such as creating an ALTER TABLE to drop a column from a statement that creates the column, to revert statements executed before an error prevents a CQL file from completing