Scalingo Documentation Center relies on Jekyll and GitHub Pages to host, build and serve. You are welcome to contribute to this documentation by forking and sending pull requests.
To add a new article simply create a new markdown file in the _posts
folder with the following file format: yyyy-mm-dd-title.md
(e.g. 1970-01-01-what-is-epoch.md).
Please use the current date when creating the file.
The minimal front matter that you need to add is:
---
title: What is Epoch
modified_at: 1970-01-01 00:00:00
categories: unix
tags: time
---
Be aware that the categories
will be used in the final URL. In the case of the previous front matter, the generated URL will be: /unix/what-is-epoch.html
.
If you add a permalink
that doesn't ends with .html
in the front matter you have to append a trailing slash. Otherwise, the generated URL will not match the real accessible URL, which is troublesome for crawlers.
You are welcome to modify any article, but please remember to update modified_at
before sending your pull request.
Please do not use the date
metadata as it will conflict with the date extracted from the file name. Instead, use modified_at
to record when a modification is made to an article.
Please do not use first-level HTML/Markdown headers (i.e. <h1></h1>
) as it will be pulled from the title
metadata.
Blockquotes should be only used for quotes. If you'd like to incorporate a useful note please use
Do not put categories
, category
or permalink
in the Front Matter, everything is handled by the jekyll-dirname-generator plugin.
If you want to write a useful note:
{% note %}
My useful note here
{% endnote %}
If you want to write a warning note:
{% warning %}
My warning note here
{% endwarning %}
If you want to insert a link to another blog post:
<a href="{% post_url platform/internals/2000-01-01-routing %}">text of the link</a>
To insert an image, first upload it to our CDN, inside the documentation
folder. Give it a public permission Grant public read access to this object(s)
. Then, insert it with:
{% assign img_url = "https://cdn.scalingo.com/documentation/screenshot_*" %}
{% include mdl_img.html %}
Update the list of packages of the Docker image scalingo-18
:
docker pull scalingo/scalingo-18:latest
docker run --rm scalingo/scalingo-18:latest bash -c 'dpkg -l | grep "^ii" | awk '\'' { printf "|%30s | %30s |\n", $2, $3} '\'' ' > _includes/scalingo_18_stack_packages.md
To install dependencies locally:
docker-compose run web bundle install
docker-compose run web yarn install
To build the static site and spin-up a file server:
docker-compose up
And visit http://localhost:4300
If you want to serve the doc like in production (through the rack stack), generate the site first (see above) and then:
docker-compose -f docker-compose-prod.yml up
This will run puma in parallel and serve the site at http://localhost:4302
For a reason I ignore and I don't want to spend time understanding, we need to manually re-build the pages when adding a new changelog entry. This is done with:
docker-compose exec web bundle exec jekyll build