0
0
mirror of https://github.com/tursodatabase/libsql.git synced 2025-01-22 05:38:57 +00:00
libsql/docs/BUILD-RUN.md
2024-04-23 15:21:36 +00:00

5.1 KiB

Build and run sqld

There are four ways to build and run sqld:

Running sqld

You can simply run launch the executable with no command line arguments to run an instance of sqld. By default, sqld listens on 127.0.0.1 port 8080 and persists database data in a directory ./data.sqld.

Use the --help flag to discover how to change its runtime behavior.

Query sqld

You can query sqld using one of the provided client libraries.

You can also use the turso cli to connect to the sqld instance:

turso db shell http://127.0.0.1:8000    

Download a prebuilt binary

The libsql-server release page for this repository lists released versions of sqld along with downloads for macOS and Linux.

Build and install with Homebrew

The sqld formulae for Homebrew works with macOS, Linux (including WSL).

1. Add the tap libsql/sqld to Homebrew

brew tap libsql/sqld

2. Install the formulae sqld

brew install sqld

This builds and installs the binary sqld into $HOMEBREW_PREFIX/bin/sqld, which should be in your PATH.

3. Verify that sqld works

sqld --help

Using a prebuilt Docker image

The sqld release process publishes a Docker image to the GitHub Container Registry. The URL is https://ghcr.io/tursodatabase/libsql-server. You can run the latest image locally on port 8080 with the following:

docker run -p 8080:8080 -d ghcr.io/tursodatabase/libsql-server:latest

Or you can run a specific version using one of the sqld container release tags in the following form for version X.Y.Z:

docker run -p 8080:8080 -d ghcr.io/tursodatabase/libsql-server:vX.Y.Z

Build from source using Docker / Podman

To build sqld with Docker, you must have a Docker installed and running on your machine with its CLI in your shell PATH.

1. Clone this repo

Clone this repo using your preferred mechanism. You may want to use one of the sqld release tags.

2. Build with Docker

Run the following to build a Docker image named "libsql/sqld" tagged with version "latest".

docker build -t libsql/sqld:latest .

3. Verify the build

Check that sqld built successfully using its --help flag:

docker container run \
  --rm \
  -i \
  libsql/sqld \
  /bin/sqld --help

4. Create a data volume

The following will create a volume named sqld-data that sqld uses to persist database files.

docker volume create sqld-data

5. Run sqld in a container

The following uses the built image to create and run a new container named sqld, attaching the sqld-data volume to it, and exposing its port 8080 locally:

docker container run \
  -d \
  --name sqld \
  -v sqld-data:/var/lib/sqld \
  -p 127.0.0.1:8080:8080 \
  libsql/sqld:latest

8080 is the default port for the sqld HTTP service that handles client queries. With this container running, you can use the URL http://127.0.0.1:8080 or ws://127.0.0.1:8080 to configure one of the libSQL client SDKs for local development.

6. Configure sqld with environment variables

In the sqld output using --help from step 3, you saw the names of command line flags along with the names of environment variables (look for "env:") used to configure the way sqld works.

Build from source using Rust

To build from source, you must have a Rust development environment installed and available in your PATH.

Currently we only support building sqld on macOS and Linux (including WSL). We are working native Windows build instructions.

1. Clone this repo

Clone this repo using your preferred mechanism. You may want to use one of the sqld release tags.

Change to the libsql-server directory.

2. Build with cargo

cargo build

The sqld binary will be in ./target/debug/sqld.

3. Verify the build

Check that sqld built successfully using its --help flag:

./target/debug/sqld --help

4. Run sqld with all defaults

The following starts sqld, taking the following defaults:

  • Local files stored in the directory ./data.sqld
  • Client HTTP requests on 127.0.0.1:8080
./target/debug/sqld

8080 is the default port for the sqld HTTP service that handles client queries. With this container running, you can use the URL http://127.0.0.1:8080 or ws://127.0.0.1:8080 to configure one of the libSQL client SDKs for local development.

5. Run tests (optional)

cargo xtask test