Check out the kubernetes/kubernetes.github.io repo and the docsv2 branch.
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
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
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.
A concept overview covers the most essential, important information about core
Kubernetes concepts and features. Examples of Concepts include Pod
,
Deployment
, Service
, etc.
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
.
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.
glossary:
a brief (~140 character) definition of what this concept is.object_rankings:
associates the page with API objects/functions.concept_rankings:
associates the page with Kubernetes concepts.command_rankings:
associates the page with CLI commandsIn 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 %}
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.
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
.
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.
object_rankings:
associates the page with API objects/functions.concept_rankings:
associates the page with Kubernetes concepts.command_rankings:
associates the page with CLI commandsIn 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 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.
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 %}
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.
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.
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.