2022-04-15 13:44:08 +00:00
---
title: "Traefik Contribution Documentation"
description: "Found something unclear in the Traefik Proxy documentation and want to give a try at explaining it better? Read the guide to building documentation."
---
2019-02-26 13:50:07 +00:00
# Documentation
Features Are Better When You Know How to Use Them
{: .subtitle }
You've found something unclear in the documentation and want to give a try at explaining it better?
Let's see how.
## Building Documentation
### General
2024-11-20 13:08:24 +00:00
This [documentation ](../../ "Link to the official Traefik documentation" ) is built with [MkDocs ](https://mkdocs.org/ "Link to the website of MkDocs" ).
2019-02-26 13:50:07 +00:00
### Method 1: `Docker` and `make`
2022-11-15 09:28:07 +00:00
Please make sure you have the following requirements installed:
2024-11-18 10:42:04 +00:00
- [Docker ](https://www.docker.com/ "Link to the website of Docker" )
2022-11-15 09:28:07 +00:00
2021-06-08 17:02:05 +00:00
You can build the documentation and test it locally (with live reloading), using the `docs-serve` target:
2019-02-26 13:50:07 +00:00
```bash
2021-06-08 17:02:05 +00:00
$ make docs-serve
2019-02-26 13:50:07 +00:00
docker build -t traefik-docs -f docs.Dockerfile .
# […]
2020-09-16 13:46:04 +00:00
docker run --rm -v /home/user/go/github/traefik/traefik:/mkdocs -p 8000:8000 traefik-docs mkdocs serve
2019-02-26 13:50:07 +00:00
# […]
[I 170828 20:47:48 server:283] Serving on http://0.0.0.0:8000
[I 170828 20:47:48 handlers:60] Start watching changes
[I 170828 20:47:48 handlers:62] Start detecting changes
```
!!! tip "Default URL"
2021-08-31 16:54:06 +00:00
Your local documentation server will run by default on < http: / / 127 . 0 . 0 . 1:8000 > .
2019-02-26 13:50:07 +00:00
If you only want to build the documentation without serving it locally, you can use the following command:
```bash
$ make docs-build
...
```
2022-11-15 09:28:07 +00:00
### Method 2: `MkDocs`
Please make sure you have the following requirements installed:
2019-02-26 13:50:07 +00:00
2024-11-18 10:42:04 +00:00
- [Python ](https://www.python.org/ "Link to the website of Python" )
2022-11-15 09:28:07 +00:00
- [pip ](https://pypi.org/project/pip/ "Link to the website of pip on PyPI" )
2019-02-26 13:50:07 +00:00
```bash
$ python --version
Python 2.7.2
$ pip --version
pip 1.5.2
```
2022-11-15 09:28:07 +00:00
Then, install MkDocs with `pip` .
2019-02-26 13:50:07 +00:00
```bash
pip install --user -r requirements.txt
```
To build the documentation locally and serve it locally, run `mkdocs serve` from the root directory.
This will start a local server.
```bash
$ mkdocs serve
INFO - Building documentation...
INFO - Cleaning site directory
[I 160505 22:31:24 server:281] Serving on http://127.0.0.1:8000
[I 160505 22:31:24 handlers:59] Start watching changes
[I 160505 22:31:24 handlers:61] Start detecting changes
```
### Check the Documentation
To check that the documentation meets standard expectations (no dead links, html markup validity, ...), use the `docs-verify` target.
```bash
$ make docs-verify
docker build -t traefik-docs-verify ./script/docs-verify-docker-image ## Build Validator image
...
2020-09-16 13:46:04 +00:00
docker run --rm -v /home/travis/build/traefik/traefik:/app traefik-docs-verify ## Check for dead links and w3c compliance
2019-02-26 13:50:07 +00:00
=== Checking HTML content...
Running ["HtmlCheck", "ImageCheck", "ScriptCheck", "LinkCheck"] on /app/site/basics/index.html on *.html...
```
!!! note "Clean & Verify"
2022-11-15 09:28:07 +00:00
If you've made changes to the documentation, it's safer to clean it before verifying it.
2019-02-26 13:50:07 +00:00
```bash
2021-06-08 17:02:05 +00:00
$ make docs
2019-02-26 13:50:07 +00:00
...
```
2021-06-08 17:02:05 +00:00
Will perform all necessary steps for you.
2019-02-26 13:50:07 +00:00
!!! note "Disabling Documentation Verification"
Verification can be disabled by setting the environment variable `DOCS_VERIFY_SKIP` to `true` :
2021-06-08 17:02:05 +00:00
2019-02-26 13:50:07 +00:00
```shell
DOCS_VERIFY_SKIP=true make docs-verify
...
DOCS_LINT_SKIP is true: no linting done.
```