MKdocs Architecture
├── .github/
│ ├── ISSUE_TEMPLATE/
│ └── workflows/
│ └── mkdocs-build.yml # Docs
├── backend/
├── dev/
├── frontend/
├── mkdocs/ # Docs
│ ├── docs/
│ └── mkdocs.yml
├── .dockerignore
├── .gitignore
├── CONTRIBUTING.md
├── docker-compose.yml
├── docker-compose.docs.yml # Docs
├── LICENSE
└── README.md
Overall project structure
├── docs/
│ ├── assets/
│ ├── css/
│ ├── developer/
│ ├── joining-the-team/
│ ├── js/
│ └── misc/
├── index.md
├── resources.md
├── mkdocs.yml
mkdocs directory structure
Summary
The MkDocs "sub-project" lives in the mkdocs/
folder. A development server can be run using the docker-compose.docs.yml
compose script. The mkdocs is set to automatically deploy to github pages using the mkdocs-build.yml
github action.
Docker MkDocs
It is important to note that we are using Hack for LA's prebuilt docker mkdocs image for convenient setup. Please see the resources below for more information:
- Hack for LA - docker-mkdocs repo
- Hack for LA - docker-mkdocs documentation
- Hack for LA - docker-mkdocs dockerhub image
This prebuilt docker image makes it easy to get a mkdocs development server running with one command, without having to install python or mkdocs dependencies on your local machine. It also includes common useful plugins that we dont have to worry about installing ourselves, and already includes the mkdocs-material
theme pre-installed.
Our project implements the HFLA mkdocs image by pulling it inside the docker-compose.docs.yml
file:
name: civic-tech-jobs-mkdocs
services:
mkdocs:
container_name: mkdocs
image: hackforlaops/mkdocs:latest
command: mkdocs serve -a "0.0.0.0:8005"
ports:
- "8005:8005"
volumes:
- ./mkdocs:/app
develop:
watch:
- action: sync
path: ./mkdocs
target: /app
Now when we run docker compose up like so:
docker-compose -f docker-compose.docs.yml up --watch
A mkdocs development server is started on http://localhost:8005
MkDocs Deployment
The url for the github pages site is: https://hackforla.github.io/CivicTechJobs/
(the website you are reading this on right now).
Our github repo is set to publish the docs to Github Pages using the gh-pages
branch. This setting can be configured in the project's Pages settings.
External Resources:
Relevant PR and Issue:
The docs are set to automatically deploy to github pages using the mkdocs-build.yml
github action. This action builds the mkdocs and saves the static files into the gh-pages
branch.
Github Action for mkdocs deployment
Links to the github action: Build MkDocs site
name: Build MkDocs site
on:
push:
branches:
- main
paths:
- "mkdocs/**/**.md"
- "mkdocs/mkdocs.yml"
workflow_dispatch:
permissions:
contents: write
jobs:
deploy-docs:
runs-on: ubuntu-latest
if: github.actor != 'github-actions[bot]'
steps:
- uses: actions/checkout@v4
- name: Configure Git Credentials
run: |
git config user.name github-actions[bot]
git config user.email 41898282+github-actions[bot]@users.noreply.github.com
- uses: actions/setup-python@v5
with:
python-version: 3.x
- run: echo "cache_id=$(date --utc '+%V')" >> $GITHUB_ENV
- uses: actions/cache@v4
with:
key: mkdocs-material-${{ env.cache_id }}
path: .cache
restore-keys: |
mkdocs-material-
- name: Install Dependencies
run: pip install \
mkdocs-material==9.1.17 \
mkdocs-autolinks-plugin==0.7.1
- name: Publish docs
run: |
cd mkdocs
mkdocs gh-deploy --force
Workflow Overview
name: Build MkDocs site
- The name of this workflow is "Build MkDocs site."on: push: - main
- The workflow is triggered when there’s a push to themain
branch.paths: ...
- The workflow will only run if the files being pushed are Markdown files (.md
) or themkdocs.yml
configuration file inside the mkdocs directory.workflow_dispatch:
- This allows manual triggering of the workflow via the GitHub Actions interface.permissions: contents: write
- This grants the action permission to write contents to the repository. It's needed for deploying the site, which requires pushing to thegh-pages
branch.runs-on: ubuntu-latest
- This specifies that the job will run on the latest Ubuntu environment provided by GitHub Actions.if: github.actor != 'github-actions[bot]'
- This condition ensures that the job doesn’t trigger if the GitHub Actions bot is the one making the changes. This prevents infinite loops where the action keeps triggering itself.uses: actions/checkout@v4
- This step checks out the repository code so the workflow can access the files.run: git config user.name github-actions[bot]
- Configures Git to use thegithub-actions[bot]
user for any commits or pushes that may happen during the deployment.git config user.email 41898282+github-actions[bot]@users.noreply.github.com
- Sets the email for the github-actions[bot] user.uses: actions/setup-python@v5
- This sets up a Python environment in the GitHub runner, which is necessary for installing and running MkDocs.
Set environment variable for caching
run: echo "cache_id=$(date --utc '+%V')" >> $GITHUB_ENV
- This step sets an environment variable called
cache_id
to the current week of the year (%V
). This value will be used as the key for caching to ensure that the cache is updated weekly.
Cache dependencies
uses: actions/cache@v4
- This step caches dependencies (to speed up future builds) in the .cache directory.with: key: mkdocs-material-${{ env.cache_id }}
- The cache key is based on the cache_id, so the cache is refreshed weekly.path: .cache
- Specifies that the cache should be stored in the .cache directory.restore-keys: mkdocs-material-
- This allows for fallback caching if an exact cache match is not found.
Install Dependencies
run: pip install mkdocs-material==9.1.17 mkdocs-autolinks-plugin==0.7.1
- This installs the necessary dependencies for MkDocs to work. In this case:
mkdocs-material==9.1.17
: A popular theme for MkDocs.mkdocs-autolinks-plugin==0.7.1
: A plugin that automatically creates links between pages in your documentation based on their titles.
Publish Documentation
run: cd mkdocs && mkdocs gh-deploy --force
- first it changes to the
mkdocs/
directory. - then it deploys the MkDocs site to GitHub Pages using
mkdocs gh-deploy --force
. The--force
flag ensures that the contents of the GitHub Pages branch (gh-pages
) are overwritten with the latest deployment.
Summary
This workflow automates the process of building and deploying a MkDocs site when changes are pushed to the main
branch. It does the following:
- Checks out the repository and configures Git for pushing changes.
- Sets up Python and installs the necessary MkDocs dependencies.
- Caches dependencies to speed up future builds.
- Deploys the site to GitHub Pages using mkdocs
gh-deploy
.
This workflow ensures the documentation is always up to date and available on GitHub Pages whenever changes are made to relevant Markdown files or the MkDocs configuration.