Skip to content

Latest commit

 

History

History
76 lines (58 loc) · 4.19 KB

Installation.md

File metadata and controls

76 lines (58 loc) · 4.19 KB

Installation

Choose and initialize the storage system:

Install Medusa on each Cassandra node using one of the following methods.

Using pip

Online installation

  • if the storage backend is a locally accessible shared storage, run sudo pip3 install cassandra-medusa
  • if your backups are to be stored in AWS S3 or S3 compatible backends (IBM, OVHCloud, MinIO, ...), run sudo pip3 install cassandra-medusa[S3]
  • if your backups are to be stored in Google Cloud Storage, run sudo pip3 install cassandra-medusa
  • if your backups are to be stored in Azure Blob Storage, run sudo pip3 install cassandra-medusa[AZURE]

Running the installation using sudo is necessary to have the /usr/local/bin/medusa script created properly.

Offline installation

If your Cassandra servers do not have internet access:

  • on a machine with the same target OS and Python version, clone the cassandra-medusa repo and cd into the root directory
  • run POETRY_VIRTUALENVS_IN_PROJECT=true poetry install to install Medusa's dependencies
  • run poetry run pip freeze | grep -v cassandra-medusa > requirements.txt to identify the dependencies
  • run mkdir -p medusa_dependencies && pip download -r requirements.txt -d medusa_dependencies to download the dependencies into a sub directory
  • run tar --exclude=".venv" -zcf medusa.tar.gz . to compress Medusa together with its dependencies but without Poetry's venv
  • upload the archive to all Cassandra nodes and decompress it (mkdir -p cassandra-medusa && tar xf medusa.tar.gz -C cassandra-medusa)
  • install Medusa's dependencies using pip install --no-index --find-links medusa_dependencies -r requirements.txt
  • install medusa itself using a command similar to poetry build && pip install dist/cassandra_medusa-<version>-py3-none-any.whl
  • test if the installation was successful by running medusa

Example of Offline installation using pipenv on RHEL, centos 7

  • install RPM pre-requisites sudo yum install -y python3-pip python3-devel
  • install pipenv sudo pip3 install pipenv
  • unpack your archive built using the procedure from previous section
  • create your python env in the directory previously created cd cassandra-medusa && pipenv --python 3
  • install python dependencies of medusa pipenv run pip3 install -r requirements.txt --no-index --find-links medusa_dependencies/
  • prepare an installation directory with appropriate privileges sudo mkdir /opt/cassandra-medusa ; sudo chmod go+rwX /opt/cassandra-medusa
  • build Medusa using pipenv run pip3 install poetry && poetry build
  • install medusa as non-root user pipenv run pip3 install dist/cassandra_medusa-0.20.0.dev0-py3-none-any.whl --no-index --find-links medusa_dependencies
  • test if the installation was successful by running pipenv run medusa

Debian packages

Using apt-get

1/ Using the command line, run the following:

curl -1sLf \
  'https://dl.cloudsmith.io/public/thelastpickle/medusa/setup.deb.sh' \
  | sudo -E bash

In case of problem, read the full instructions on the cloudsmith.io documentation

Note: since Medusa 0.9 we publish releases for Ubuntu bionic and focal only. Note: since Medusa 0.23 we switched focal for jammy.

2/ Install Medusa :

sudo apt-get update
sudo apt-get install cassandra-medusa

4/ (optional) Install the storage dependencies