Gnotus is an open-source, permissively licensed, and self-hosted knowledge-base software for both public and internal documentation.
- Light-weight single-page application built with React and FastAPI.
- Browser caching for fast page loads
- In-app document creation and editing
- Markdown document format
- Upload management for images and other files
- Optimized for search engine indexing
- Supports both light and dark mode
- Responsive design for mobile, desktop, and print
- Customizable site branding with colors and logo
- Automatic table of contents generation
- Document history with the ability to revert to previous versions
- Public and private documents
- Full-text search, including in private documents
- In-app user management with various user roles
The recommended way to install Gnotus is with Docker Compose.
- 
Download the Docker Compose file curl -L https://raw.githubusercontent.com/merlinz01/gnotus/main/compose.yml -o compose.yml If you are serving Gnotus on a public domain, you may want edit the compose.ymlfile to open ports 80 and 443 on the frontend service instead of 5173.
- 
Create the configuration file Create a configuration file at config.ymlin the same directory ascompose.yml. This file will define the site branding. Use this as a template:# config.yml site_name: "My Documentation Site" site_description: > This is my documentation site where I can create and manage documentation. primary_color: "#654321" secondary_color: "#123456" # Optionally, you can set the dark mode colors primary_color_dark: "#987654" secondary_color_dark: "#456789" If you want to use a custom logo, you can simply place an SVG file named icon.svgin the same directory ascompose.ymlandconfig.yml, and uncomment the line in thecompose.ymlfile that mounts the icon file to the backend service:backend: volumes: - ./icon.svg:/app/icon.svg 
- 
Configure the environment variables Create a .envfile in the same directory ascompose.ymlwith the following content:# .env # The domain name of your Gnotus instance. # If you are serving Gnotus on a public domain, set this to your domain name # and make sure to open ports 80 and 443 in the frontend service. CADDY_DOMAIN=my.domain.com # The email address to use for Let's Encrypt registration. # This is required for the Caddy service to obtain SSL certificates. CADDY_EMAIL[email protected] # GNOTUS_BASE_URL is the base URL of your Gnotus instance. # If you are serving Gnotus on a public domain, set this to your domain name. GNOTUS_BASE_URL=https://my.domain.com # The secret key for the backend service. # This must be changed a long, securely generated random string. GNOTUS_SECRET_KEY=your-secret-key 
- 
Start the services docker compose up -d This will download the necessary Docker images, and start everything for you. 
- 
Create the initial admin user After the services are up and running, you can create the initial admin user by running the following command: docker compose exec backend ./manage.sh create-userFollow the prompts to set up your admin user. 
- 
Access the application You can now access the Gnotus application at http://localhost:5173(or your configured domain if you set it up for public access).You can log in with the admin user you just created. 
- 
(Optional) Configure IPv6 If your server is reachable via IPv6, it is recommended to configure IPv6 in Docker so that logging and rate limiting work correctly. (If you don't do this, the Caddy service will see all IPv6 requests as coming from the internal Docker gateway, which will mean that all IPv6 requests will be rate-limited as if they were all from the same IP address.) To do this, add the following line to your Docker daemon configuration file (usually located at /etc/docker/daemon.json):{ "ip6tables": true }Then restart the Docker service (you may want to stop the Docker Compose services first): sudo systemctl restart docker Create a new file compose.override.ymlin the same directory ascompose.ymlwith the following content:networks: default: enable_ipv6: true ipam: config: - subnet: <your_ipv6_subnet> # e.g. "2001:db8:1::/64" Replace <your_ipv6_subnet>with your actual IPv6 subnet.Finally, restart the Docker Compose services: docker compose down docker compose up -d Now the Caddy service should be able to correctly log and rate limit IPv6 requests. 
If you want to develop Gnotus, the recommended way is to use Docker Compose to set up the development environment for both the backend and frontend. Simply run the following command in the root directory of the project:
docker compose -f compose-dev.yml up --build
# Add the `-d` flag to run in the backgroundThis will start the backend and frontend services in development mode, with hot-reloading enabled for both.
If you want to override settings, you can set them as environment variables in a .env file in the backend directory.
If you need to run commands in the backend service, you can use the following command:
docker compose -f compose.dev.yml exec backend <command>You can also set up the development environment without Docker Compose, but this requires more manual setup.
- 
Install Python dependencies This project uses the uvpackage manager.cd backend uv sync
- 
Configure environment You can use the provided config-dev.ymlor create your ownconfig-custom.ymlto customize the site title and appearance.
- 
Activate the virtual environment source .venv/bin/activate
- 
(Optional) Start Meilisearch If you want to test the full-text search functionality, you can run Meilisearch in a Docker container. This is optional, as Gnotus can run without it with the disable_searchoption set totruein the configuration file or theGNOTUS_DISABLE_SEARCHenvironment variable set totrue. Note that disabling search will prevent you from using the search functionality in the app and will cause the search index to become out of sync with the documents if previously indexed.docker run -d --name meilisearch -p 7700:7700 getmeili/meilisearch:v1.15 Make sure to set the GNOTUS_MEILISEARCH_URLandGNOTUS_MEILISEARCH_API_KEYenvironment variables (or the corresponding options in your configuration file) to connect to Meilisearch.To index all documents in Meilisearch, you can use the following command: GNOTUS_CONFIG_FILE=config-dev.yml python -m app.manage index To stop and remove the Meilisearch container, you can run: docker stop meilisearch docker rm meilisearch 
- 
Run the backend server GNOTUS_CONFIG_FILE=config-dev.yml fastapi dev The API will be available at http://localhost:8000and will auto-reload when you modify backend code.
- 
Install Node.js dependencies cd frontend npm install
- 
Run the frontend development server npm run dev The app will be available at http://localhost:5173and will hot-reload when you modify frontend code.
Gnotus is licensed under the MIT License. See LICENSE.txt for details.