Install on Docker
Installing Drasi into a Docker container is the fastest way to get started.  It will also allow you to connect to databases running on your local machine, by using the host.docker.internal host name.
Prerequisites
On the computer where you will install Drasi, you need to install Docker
Get the Drasi CLI
You can get the Drasi CLI for your platform using one of the following options:
curl -fsSL https://raw.githubusercontent.com/drasi-project/drasi-platform/main/cli/installers/install-drasi-cli.sh | /bin/bashiwr -useb "https://raw.githubusercontent.com/drasi-project/drasi-platform/main/cli/installers/install-drasi-cli.ps1" | iexwget -q "https://raw.githubusercontent.com/drasi-project/drasi-platform/main/cli/installers/install-drasi-cli.sh" -O - | /bin/bashDownload a specific version of the CLI from the drasi-platform releases page on GitHub. The file to download for your platform is:
- macOS arm64 - drasi-darwin-arm64
- macOS x64 - drasi-darwin-x64
- Windows x64 - drasi-windows-x64.exe
- Linux x64 - drasi-linux-x64
- Linux arm64 - drasi-linux-arm64
Once downloaded, rename the file to drasi (macOS and Linux) or drasi.exe (Windows) and add it to your path.
The Drasi CLI source code is in the drasi-platform repo in the cli folder.
The readme.md file in the cli folder describes how to build and install the Drasi CLI on your computer.
If you encounter sudo-related errors during installation (such as “no new privileges” flag restrictions in certain containerized or restricted environments), you can install the Drasi CLI to a user directory instead of the default system-wide location. Set the DRASI_INSTALL_DIR environment variable to a directory in your home folder before running the installation script. Below is the sample script for Linux:
export DRASI_INSTALL_DIR="$HOME/.local/bin" mkdir -p "$HOME/.local/bin" # Execute the installation command
Install Drasi as a Docker container
To install Drasi as a Docker container using all default settings, simply run the command:
drasi init --docker
This will install the version of Drasi that matches the version of the Drasi CLI that you are using. The Drasi container images will be pulled from the main Drasi container registry located on ghcr.io.
The drasi init command gives you control over certain aspects of the install process and the configuration of the Drasi environment through these flags and argument:
- --dapr-runtime-version <version>: Specifies the Dapr runtime version to install.
- --dapr-sidecar-version <version>: Specifies the Dapr sidecar (daprd) version to install.
- --docker <name (optional)>(optional): If set, a Docker container will be created and a self-contained instance of drasi will be installed into it. You do not need a Kubernetes cluster or the kubectl tooling if using this option. You can optionally provide a name for the instance, the default will be- docker.
- --local: If set, the Drasi CLI will use locally available images to install Drasi instead of pulling them from a remote container registry. If used in conjunction with the- --dockerflag, it will also scan your local Docker cache for all images with the- drasi-project/prefix and automatically load them into the self contained Drasi instance.
- --registry <registry>: Address of the container registry to pull Drasi images from. The default value is “ghcr.io”.
- --version <tag>: Container image version tag to use when pulling Drasi images. The default value is the version tag of the Drasi CLI, which is available through the drasi version command.
For example, to install Drasi 0.2.0, you would run the following command:
drasi init --version 0.2.0 --docker
The following shows the output you would expect from a successful installation of Drasi 0.1.3:
Installing Drasi with version 0.2.0 from registry ghcr.io
✓ Container 37951820a0d4a810cc3abd6ad9ef4ede4e075ad18f5708814da9cfe0cc23fb36 created
✓ Container 37951820a0d4a810cc3abd6ad9ef4ede4e075ad18f5708814da9cfe0cc23fb36 started
ℹ Dapr not installed
✓ Dapr installed successfully
✓ Infrastructure deployed
  ✓ app=rg-redis is online
  ✓ app=rg-mongo is online
✓ Control plane is online
  ✓ drasi/infra=api is online
  ✓ drasi/infra=resource-provider is online
✓ Query container created
  ✓ Apply: QueryContainer/default: complete
  ✓ Wait QueryContainer/default online
✓ Default source providers created
  ✓ Apply: SourceProvider/PostgreSQL: complete
  ✓ Apply: SourceProvider/SQLServer: complete
  ✓ Apply: SourceProvider/CosmosGremlin: complete
✓ Default reaction providers created
  ✓ Apply: ReactionProvider/Debug: complete
  ✓ Apply: ReactionProvider/Debezium: complete
  ✓ Apply: ReactionProvider/EventGrid: complete
  ✓ Apply: ReactionProvider/Gremlin: complete
  ✓ Apply: ReactionProvider/Result: complete
  ✓ Apply: ReactionProvider/SignalR: complete
  ✓ Apply: ReactionProvider/StorageQueue: complete
  ✓ Apply: ReactionProvider/StoredProc: complete
If drasi init completes without error, the Drasi environment is ready for use and you can start to create Sources, Continuous Queries, and Reactions.
Deleting the Drasi container
To delete a Drasi environment that is installed in a Docker container, run the command:
drasi env delete docker
This command will remove the docker Drasi environment from the collection in your local user profile and prompt you to delete the container as well.
This will delete the Docker container, are you sure you want to continue? (y/N): y
Deleting Docker container docker...
Environment docker deleted