Percona Monitoring and Management (PMM) is a database monitoring solution that is free and open-source.
This repo holds the source files for the official PMM technical documentation.
To contribute to that documentation, you can:
-
report a general problem -- open a Jira issue.
-
fix a problem yourself -- Use the Edit this page link to take you the Markdown source file for that page. Make your changes (you'll have to fork the repo unless you're Percona staff) and submit a PR which we'll review and adjust where necessary before merging and publishing. If the changes are more than a few lines, you might want to build the website locally to see how it looks in context. That's what the rest of this README covers.
We use MkDocs to convert Markdown files into a static HTML website (or PDF). This process is called building the documentation.
The documentation source files are in the docs
directory. (Other files in this repo are explained in Directories and files.)
The two major PMM versions are kept in separate branches:
-
main
is for PMM 2.x (latest) -
1.x
is for PMM 1.x
Before you start, it helps to know what Git, Python and Docker are, what Markdown is and how to write it, and how to install and use those things on the command line. (If you don't, consider opening a Jira issue instead.)
If you'd like to have a local copy of PMM documentation, or are thinking about contributing, it helps if you can build the documentation to see how it will look when published. The easiest way is to use Docker, as this avoids having to install MkDocs and its dependencies.
-
Install Docker.
-
Clone this repository.
-
Change directory to
pmm-doc
. -
Use our PMM documentation Docker image to build the documentation:
docker run --rm -v $(pwd):/docs perconalab/pmm-doc-md mkdocs build
-
Find the
site
directory, openindex.html
in a browser to view the first page of documentation.
If you want to see how things look as you edit, MkDocs has a built-in server for live previewing. After (or instead of) building, run:
docker run --rm -v $(pwd):/docs -p 8000:8000 perconalab/pmm-doc-md mkdocs serve --dev-addr=0.0.0.0:8000
Wait until you see INFO - Start detecting changes
then point your browser to http://0.0.0.0:8000.
If you don't use Docker, you must install MkDocs and all its dependencies.
-
Install Python.
-
Install MkDocs and required extensions:
pip install -r requirements.txt
-
Build the site:
mkdocs build
-
Open
site/index.html
Or, to run the built-in web server:
mkdocs serve
View the site at http://0.0.0.0:8000
How to create a PDF version of the documentation.
-
(For Percona staff) If bulding for a release of PMM, edit
mkdocs-base.yml
and change:- The release number in
plugins.with-pdf.output_path
- The release number and date in
plugins.with-pdf.cover_subtitle
- The release number in
-
Build
-
With Docker:
docker run --rm -v $(pwd):/docs -e ENABLE_PDF_EXPORT=1 perconalab/pmm-doc-md mkdocs build -f mkdocs-pdf.yml
-
Without:
ENABLE_PDF_EXPORT=1 mkdocs build -f mkdocs-pdf.yml
-
-
The PDF is in
site/_pdf
.
-
mkdocs-base.yml
: MkDocs base configuration file, inherited by all others. Contains common table-of-contentsnav
element. -
mkdocs-percona.yml
: MkDocs configuration file. Creates unthemed HTML for hosting on percona.com. -
mkdocs.yml
: Default MkDocs configuration file. Creates (Material) themed HTML for hosting anywhere. -
mkdocs-pdf.yml
: MkDocs configuration file. Creates themed PDF. -
docs
:-
*.md
: Markdown files. -
_images/*
: Images, image resources, videos. -
css
: Styling. -
js
: JavaScript files.
-
-
_resources
:-
bin
-
glossary.tsv
: Export from a spreadsheet of glossary entries. -
make_glossary.pl
: Script to write Markdown page fromglossary.tsv
. -
grafana-dashboards-descriptions.py
: Script to extract dashboard descriptions from https://github.com/percona/grafana-dashboards/. -
plantuml
: Wrapper script for running PlantUML. -
plantuml.jar
: Copy of the PlantUML Java file (needed for Netlify builds).
-
-
templates
: Stylesheet for PDF output (used by mkdocs-with-pdf extension). -
theme
:main.html
: MkDocs template for HTML published on percona.com.
-
-
requirements.txt
: Python package dependencies. -
runtime.txt
: Python version specifier (used by netlify). -
variables.yml
: Values used throughout the Markdown, including the current PMM version/release number. -
netlify.toml
: Netlify build definition. -
.spelling
: Words regarded as correct bymdspell
(See Spelling and grammar.) -
.github
:-
workflows
:build.yml
: Workflow specification for building the documentation via a GitHub action. (Usesmike
which puts HTML inpublish
branch.)
-
-
site
: When building locally, directory where HTML is put.
We are trialing the use of mike to build different versions.
With this, a GitHub actions workflow runs mike
(which runs mkdocs
). The HTML is committed and pushed to the publish
branch. The whole branch is then copied (by us, naturally) to our web server.
docs/using/interface.md
uses an image of the home dashboard overlaid with numbered boxes to identify menu bars and control. This approach means the home dashboard image and its numbered version always look the same. You need only recreate the home page image in 1280x1280 format, then merge with the numbered overlay.
Here's how it's done.
-
PMM_Home_Dashboard.jpg
is created by pmm-screenshots-pw. If snapped by hand, it should be 1280x1280 pixels, to match the overlay image. -
PMM_Home_Dashboard_Overlay.png
is exported fromdocs/_images/PMM_Home_Dashboard_Overlay.drawio
using https://app.diagrams.net/.-
If it's your first time, select Device at the Save diagrams to: dialog
-
Click Open existing diagram
-
Navigate to
pmm-doc/docs/_images
and selectPMM_Home_Dashboard_Overlay.drawio
-
If the dashboard layout has changed, replace the Guide Layer with a new screenshot and adjust the elements on the Overlay layer as needed (To show layers, click View --> Layers). Untick the Guide Layer so it is not exported.
-
Click File --> Export as --> PNG
-
In the Image settings dialog, use these settings:
-
Zoom: 100%, Border Width: 0
-
Size: Page (The page dimensions in inches should be as close to the base image as possible, i.e. 1280x1280)
-
Transparent Background: ON
-
Shadow: OFF
-
Grid: OFF
-
Include a copy of my diagram: OFF
-
-
Click Export
-
Click Device
-
Navigate to
pmm-doc/docs/_images
and clickPMM_Home_Dashboard_Overlay.png
-
Click Save and overwrite the current file
The overlay image is merged with a copy of the latest home dashboard using composite, one of the ImageMagick tools.
composite docs/_images/PMM_Home_Dashboard_Overlay.png docs/_images/PMM_Home_Dashboard.jpg docs/_images/PMM_Home_Dashboard_Numbered.png
The GitHub actions build job performs a basic spell and grammar check. You can do these yourself on the command line if you have Node.js installed.
npm i markdown-spellcheck -g
mdspell --report --en-us --ignore-acronyms --ignore-numbers docs/<path to file>.md
To check all files:
mdspell --report --en-us --ignore-acronyms --ignore-numbers "docs/**/*.md"
Add any custom dictionary words to .spelling
. If spell checking fails, the GitHub action will fail too, but after the MkDocs build and so can be safely ignored. The publish
branch will still have the latest build and can be used. Meanwhile, see what the spelling error is and either fix it or add the word to .spelling
.
Grammar is checked using write-good
. (The results of this check are ignored and don't affect the GitHub action.)
npm i write-good -g
write-good docs/<path to file>.md
To check all files:
write-good docs/**/*.md
We're using the mkdocs-htmlproofer-plugin
link checking plugin to detect broken URLs. It works great but increases the build time significantly (by between 10 and 50 times longer).
The plugin is installed in our PMM documentation Docker image and by the GitHub action but it is commented out in mkdocs.yml
.
To enable it for local builds, uncomment the line with htmlproofer
in the plugins
section of mkdocs.yml
and parse the build output for warnings.