From 18968901dc42b735ebb8520ffe45fc7e33074ab1 Mon Sep 17 00:00:00 2001 From: Sayan Nandan Date: Fri, 29 Dec 2023 16:45:45 +0000 Subject: [PATCH] Simplify documentation on Docker installations --- docs/2.installation.md | 37 ++++++++++++++++++++++++++++--------- 1 file changed, 28 insertions(+), 9 deletions(-) diff --git a/docs/2.installation.md b/docs/2.installation.md index 341581640..2e14965af 100644 --- a/docs/2.installation.md +++ b/docs/2.installation.md @@ -6,7 +6,7 @@ title: Installation Getting started with Skytable involves choosing a mode of installation, downloading any required files and then starting up the database. You can choose to either use: - [**Native binaries (recommended)**](#native-binaries): This is what is generally recommended for the best performance. You will need to download a bundle and then start the server binary; no expert knowledge required -- [**Using a Debian package (recommended)**](#debian-package): If you're deploying on Ubuntu or any other Debian based Linux distribution, then consider using this method. Configuration files, users and passwords are autogenerated. +- [**Using a Debian package (recommended)**](#debian-package): If you're deploying on Ubuntu or any other Debian based Linux distribution, then consider using this method. Configuration files, users and passwords are autogenerated. - [**A Docker image**](#docker-image): We generally recommend using a Docker image for experimenting with Skytable on your local system during development and you want to keep your local system *clean*. If you want to use a Docker image for deployment, you're always free to do so! > **Note:** You might experience slightly degraded performance from the storage engine due to Docker engine's abstractions. @@ -26,9 +26,11 @@ To use native binaries you need to download a bundle which is simply a ZIP file - `skysh`: This is the Skytable shell and it provides a very helpful interactive REPL database client - `sky-bench`: This is the benchmarking tool that you can use to load test Skytable 3. **Start up the server**. You need to choose a `root` password for the `root` account which will have complete control over the database. + ```bash ./skyd --auth-root-password= --auth-plugin=pwd ``` + **Replace with your own secure password!** Explanation: @@ -40,10 +42,13 @@ The server starts up at `localhost:2003` and is ready to run queries. ## Debian package Find the correct `*.deb` file [from the releases page](https://github.com/skytable/skytable/releases). Now simply run: + ```sh sudo dpkg -i .deb ``` + The package will: + - **Generate a root password:** Watch the terminal output! - **Create a `systemd` unit**: So you can start and stop the process using `systemd` like `systemd start skyd` - **Generate a configuration**: Your configuration is stored in `/var/lib/skytable/config.yaml`. Go ahead and modify it if you need to! @@ -51,27 +56,41 @@ The package will: ## Docker image :::info You must have docker set up! + - Use [this great guide from Docker](https://docs.docker.com/engine/install/) to install and get started - To be able to run `docker run` and related commands, you may need administrative privileges ::: +### Simple setup + +1. **Download the bundle**: To be able to run queries you need to download the bundle as described above +2. **Start the container**: + + ```shell + docker run -d --name skydb -p 2003:2003 skytable/skytable:latest + ``` + +:::tip +The password for the Skytable instance on the Docker container is auto-generated Run `docker logs -f skydb` and you'll see a log +message with the generated password. +::: + +### With persistence + 1. **Download the bundle**: To be able to run queries you need to download the bundle as described above 2. **Create the data directory**: To ensure that our database is persistent and all our data doesn't vanish as soon as the container is terminated, we'll map the data directory to an actual directory on our local system. > **Note:** Create a folder called `skytable` in a convenient location. We recommend having a directory in `$HOME/docker-containers` where you can store the Skytable container's data and any other containers that you might use. It's a great way to keep things organized. -3. **Start the container**: +3. **Create your configuration**: [Download this template file](https://raw.githubusercontent.com/skytable/skytable/next/examples/config-files/template.yaml) and place it into the directory you created. Update the password with your `root` password of choice. +4. **Start the container**: + ```shell docker run -d --name skydb \ - -v /home/docker-containers/skytable:/var/lib/skytable \ + -v $HOME/docker-containers/skytable:/var/lib/skytable \ -p 2003:2003 \ skytable/skytable:latest ``` - **Replace with your own secure password!** Explanation: - This starts a container with name `skydb` - - It maps the folder (as discussed earlier) `/home/docker-containers/skytable` from your local file system to `/var/skytable` (in the container's file system) + - It maps the folder (as discussed earlier) `$HOME/docker-containers/skytable` from your local file system to `/var/skytable` (in the container's file system) - Maps port `2003` on the host to the containers port `2003` so that you can use the command-line client `skysh` without having to inspect the container's IP address -:::tip -The password for the Skytable instance on the Docker container is auto-generated Run `docker logs -f skydb` and you'll see a log -message with the generated password. -:::