- Move to the docker directory
$ cd docker- Run docker-compose
$ docker-compose up -d- Enter the control node
$ docker exec -it jepsen-control bash- Run a test
# cd /scalar-jepsen/cassandra
# lein run test --workload lwt --ssh-private-key ~/.ssh/id_rsa
- Check README in each test for more detail
- --ssh-private-keyshould be always set to specify the SSH key
- --workloadspecifies a test workload. previously we used- --test.
- --nemesissets- none,- partition,- clock, or- crash(default:- none)
- --adminsets- none,- joinor- flush(default:- none)
- Launch debian machines as a control machine and Cassandra nodes
- We recommend 1 control machine and 5 node machines
- You can decrease the number of nodes. If you do so then you will need to specify the nodes when starting a test.
 
- Install Java8 on each machine
sudo apt install openjdk-8-jre- Install Leiningen (https://leiningen.org/) on the control machine
- Make an SSH key pair for Jepsen to login nodes from the control machine
- Register the public key as root on each node
$ sudo echo ssh-rsa ... >> /root/.ssh/authorized_keys- Configure /etc/hostson each machine
$ sudo sh -c "cat << EOF >> /etc/hosts
<NODE1_IP> n1
<NODE2_IP> n2
<NODE3_IP> n3
<NODE4_IP> n4
<NODE5_IP> n5
EOF"- Run a test on the control machine
$ cd ${SCALAR_JEPSEN}/cassandra
$ lein run test --workload lwt --ssh-private-key ~/.ssh/id_rsaThis test runs against a Kubernetes cluster and requires kind (or a similar tool), helm, and kubectl to be installed beforehand.
The test will attempt to SSH into a machine where the Kubernetes cluster is deployed, so SSH access must be properly configured in advance.
Below is an example command to run the ScalarDB Cluster test:
lein with-profile cluster run test --workload transfer --db cluster \
    --nodes ${KUBERNETES_CLUSTER_HOST} \
    --username ${USER} \
    --docker-username ${GITHUB_USER} \
    --docker-access-token ${GITHUB_ACCESS_TOKEN}- KUBERNETES_CLUSTER_HOST: The IP address or hostname of the machine running the Kubernetes cluster.
- USER: The SSH username used to connect to the Kubernetes cluster host. If needed,- --passwordor- --ssh-private-keycan be added.
- GITHUB_USER: Your GitHub username, used to authenticate with ghcr.io for pulling the ScalarDB Cluster Docker image.
- GITHUB_ACCESS_TOKEN: A GitHub access token with permissions to pull images from ghcr.io.
- All other parameters match those used in standard ScalarDB tests