Support

Troubleshooting resources, frequently asked questions, and community support channels.

Edit This Page

New Template Instructions

Before you Begin: Get the docs code checked out locally

Check out the kubernetes/kubernetes.github.io repo and the docsv2 branch.

Step 1: Fork and Clone the repo

cd ~/go/src/k8s.io
git clone git@github.com:<your-github-username>/kubernetes.github.io
cd kubernetes.github.io
git remote add upstream https://github.com/kubernetes/kubernetes.github.io.git

Step 2: Switch to the docsv2 branch

Docs v2 development is being performed in the docsv2 branch. This is the branch you want to be working from.

From ~/go/src/k8s.io/kubernetes.github.io:

git checkout -b docsv2
git fetch upstream
git reset --hard upstream/docsv2

Step 3: Make sure you can serve rendered docs

One option is to simply rename your fork’s repo on GitHub.com to yourusername.github.io, which will auto-stage your commits at that URL.

Or, just use Docker! Run this from within your local kubernetes.github.io directory and you should be good:

docker run -ti --rm -v "$PWD":/k8sdocs -p 4000:4000 gcr.io/google-samples/k8sdocs:1.0

The site will then be viewable at http://localhost:4000/.

Or, you can follow the instructions for running a from-scratch staging server, which is both the most performant option and the biggest pain to get set up.

Writing Docs Using Templates

Types of Templates

Concept Overview Template Details

A concept overview covers the most essential, important information about core Kubernetes concepts and features. Examples of Concepts include Pod, Deployment, Service, etc.

Reference Examples

Usage

Creating the file

To create a new concept overview page, create a new directory with the concept name under the docs directory and an index.md file. e.g. docs/your-concept-name/index.md.

Adding the page to navigation

Once your page is saved, somewhere in the /docs/ directory, add a reference to the concepts.yml file under /_data/ so that it will appear in the left-hand navigation of the site. This is also where you add a title to the page.

Adding the Template sections

Tags structure

In each case, the association is ranked. If ranked “1,” the topic will surface as a “Core Topic” (of high importance) on various associated pages. If ranked “2,” the topic will be grouped under “Advanced Topics,” which are deemed less essential.

Only ranks 1 and 2 are supported.

Tags are mandatory and should be thorough; they are the connective tissue of the site. To see them in action, visit our sitemap.

---
glossary: A pod is the vehicle for running containers in Kubernetes.
object_rankings:
- object: pod
  rank: 1
concept_rankings:
- concept: pod
  rank: 1
command_rankings:
- command: kubect describe
  rank: 1
- command: kubectl get
  rank: 1
---
{% capture concept %} concept-name-here {% endcapture %}
{% capture what_is %} description-of-concept-here {% endcapture %}
{% capture when_to_use %} when-to-use-here {% endcapture %}
{% capture when_not_to_use %} anti-patterns-here {% endcapture %}
{% capture status %} how-to-get-with-kubectl-here {% endcapture %}
{% capture usage %} yaml-config-usage-here {% endcapture %}
{% include templates/concept-overview.md %}

Task Template Details

A task page offers step-by-step instructions for completing a task with Kubernetes. A task page should be narrowly focused on task completion and not delve into concepts or reference information.

Example

Usage

Creating the file

To create a new task page, create a file under docs/tasks/task-name. e.g. docs/tasks/your-task-name.

Task filenames should match the title, chaining words with dashes in all lowercase, omitting articles and prepositions. For example, the topic “Explictly Scheduling a Pod on a Node” is stored in file /docs/tasks/explicitly-scheduling-pod-node.md.

Adding the page to navigation

Add a reference to the tasks.yml file under /_data/ so that it will appear in the left-hand navigation of the site. This is also where you add a title to the page.

Adding the Template sections

Tags structure

In each case, the association is ranked. If ranked “1,” the topic will surface as a “Core Topic” (of high importance) on various associated pages. If ranked “2,” the topic will be grouped under “Advanced Topics,” which are deemed less essential.

Only ranks 1 and 2 are supported.

Tags are mandatory and should be thorough; they are the connective tissue of the site. To see them in action, visit our sitemap.

---
object_rankings:
- object: nodeAffinity
  rank: 1
- object: nodeSelector
  rank: 2
concept_rankings:
- concept: node
  rank: 1
- concept: pod
  rank: 1
command_rankings:
- command: kubectl label
  rank: 1
- command: kubectl get
  rank: 2
---
{% capture purpose %} task-description-here {% endcapture %}
{% capture recommended_background %} prereq-reading-here {% endcapture %}
{% capture step_by_step %} single-step-here {% endcapture %}
{% include templates/task.md %}

Landing Pages

Landing pages are a set of clickable “cards” arranged in a grid. Each card has a heading and description, and optioninall, a thumbnail image. They are meant to be index pages that quickly forward users on to deeper content.

Demos

Usage

To use this template, create a new file with these contents. Essentially, you declare the cards you want by inserting the following YAML structure in the front-matter YAML section at the top of the page, and the body of the page just has the include statement.

---
cards:
- progression: no #"yes" = display cards as linearly progressing
- card:
  title: Mean Stack
  image: /images/docs/meanstack/image_0.png
  description: Lorem ipsum dolor it verberum.
# repeat -card: items as necessary
---
{% include templates/landing-page.md %}

Adding page to navigation

Once your page is saved, somewhere in the /docs/ directory, add a reference to the appropriate .yml file under /_data/ so that it will appear in the left-hand navigation of the site. This is also where you add a title to the page.

kubectl yaml

You probably shouldn’t be using this, but we also have templates which consume YAML files that are generated by the Kubernetes authors. These are turned into pages which display the reference information for the various CLI tools.

Demos

Adding page to navigation

Once your page is saved, somewhere in the /docs/ directory, add a reference to the reference.yml file under /_data/ so that it will appear in the left-hand navigation of the site. This is also where you add a title to the page.

Analytics Create an Issue Edit this Page