This repo contains the source for the valkey.io website (build scripts, template, blog posts, stylesheets, etc.).
The build integrates content from valkey-io/valkey-doc
and the commands definitions from valkey-io/valkey
(see Build Locally below for more details).
Note: The site is currently in transition to a new static site generator. The current production website is built from branch jekyll-version
but will be built from main
in the near future.
We welcome contributions! Please see our CONTRIBUTING page to learn more about how to contribute to the website.
If you discover potential security issues, see the reporting instructions on our CONTRIBUTING page for more information.
This site is built with Zola.
Follow these steps to build the site locally:
- Install Zola.
- Switch to the directory with your fork of this repo.
- Run
zola serve
Open your browser to http://127.0.0.1:1111/
Zola will automatically rebuild on changes to the template or any content stored in this repo.
Changes to external content (command reference, documentation topics) require a restart of the Zola server process (ctrl-c
then zola serve
again, a browser refresh may also be needed).
By default, the site will build without documentation topics nor command reference.
This content is stored within the valkey-io/valkey-doc
and valkey-io/valkey
repos respectively.
If you want to build the site with this content, you'll need to have a local copy of valkey-io/valkey-doc
and valkey-io/valkey
outside of this repo.
Then follow the instructions to build the documentation topics and/or build the command reference.
The instructions show how to use scripts that create symbolic links to the valkey-io/valkey-doc
and valkey-io/valkey
repos as well as create a series of empty stub files that tell Zola to create pages.
Documentation 'topics' (i.e. /docs/topics/keyspace/
, /docs/topics/encryption/
, /docs/topics/transactions/
) sources content from valkey-io/valkey-doc
.
flowchart TD
A[Webpage: /docs/topics/keyspace/ ]
A --> B[Template: valkey-io/valkey-website]
B --> H[Repo: valkey-io/valkey-doc ] --> I[File: /topics/keyspace.md ] --> Y[Topic content]
Let's say that this repo and your local copy of valkey-io/valkey-doc
reside in the same directory.
First, stop the zola serve
process if you're running it.
From the root directory of this repo run:
# You should only need to run this once or when you add a new topic.
./build/init-topics.sh ../valkey-doc/topics
Then, restart Zola.
Point your browser at http://127.0.0.1:1111/docs/topics/
and you should see the fully populated list of topics.
All files created in this process are ignored by git.
Commit your changes to your local copy of valkey-io/valkey-doc
.
The command reference (i.e. /command/set/
, /command/get/
, /command/lolwut/
) sources information from valkey-io/valkey
, and valkey-io/valkey-doc
.
valkey-io/valkey
provides the command metadata (items like computational complexity, version history, arguments, etc) whilst valkey-io/valkey-doc
provides the actual command description.
flowchart TD
A[Webpage: valkey.io/set/command]
A --> B[Template: valkey-io/valkey-website]
B --> F[Repo: valkey-io/valkey ] --> G[File: /src/commands/set.json ] --> X[Command Metadata]
B --> H[Repo: valkey-io/valkey-doc ] --> I[File: /commands/set.md ] --> Y[Command Description]
Let's say that this repo and your local copy of valkey-io/valkey-doc
and valkey-io/valkey
reside in the same directories.
First, stop the zola serve
process if you're running it.
From the root directory of this repo run:
# You should only need to run this once or when you add a new command.
./build/init-commands.sh ../valkey-doc/commands ../valkey/src/commands
Then, restart Zola.
Point your browser at http://127.0.0.1:1111/commands/
and you should see the fully populated list of topics.
All files created in this process are ignored by git.
Commit your changes to your local copy of valkey-io/valkey-doc
for description changes and valkey-io/valkey
for command JSON changes (if you have any).
This project is licensed under the BSD-3-Clause License.