mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-10-25 18:09:10 +00:00 
			
		
		
		
	Most of the contents of docs/ has moved to kubernetes.github.io. Development of the docs and accompanying files has continued there, making the copies in this repo stale. I've removed everything but the .md files which remain to redirect old links. The .yaml config files in the docs were used by some tests, these have been moved to test/fixtures/doc-yaml, and can remain there to be used by tests or other purposes.
		
			
				
	
	
		
			264 lines
		
	
	
		
			8.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			264 lines
		
	
	
		
			8.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| <!-- BEGIN MUNGE: UNVERSIONED_WARNING -->
 | ||
| 
 | ||
| <!-- BEGIN STRIP_FOR_RELEASE -->
 | ||
| 
 | ||
| <img src="http://kubernetes.io/kubernetes/img/warning.png" alt="WARNING"
 | ||
|      width="25" height="25">
 | ||
| <img src="http://kubernetes.io/kubernetes/img/warning.png" alt="WARNING"
 | ||
|      width="25" height="25">
 | ||
| <img src="http://kubernetes.io/kubernetes/img/warning.png" alt="WARNING"
 | ||
|      width="25" height="25">
 | ||
| <img src="http://kubernetes.io/kubernetes/img/warning.png" alt="WARNING"
 | ||
|      width="25" height="25">
 | ||
| <img src="http://kubernetes.io/kubernetes/img/warning.png" alt="WARNING"
 | ||
|      width="25" height="25">
 | ||
| 
 | ||
| <h2>PLEASE NOTE: This document applies to the HEAD of the source tree</h2>
 | ||
| 
 | ||
| If you are using a released version of Kubernetes, you should
 | ||
| refer to the docs that go with that version.
 | ||
| 
 | ||
| Documentation for other releases can be found at
 | ||
| [releases.k8s.io](http://releases.k8s.io).
 | ||
| </strong>
 | ||
| --
 | ||
| 
 | ||
| <!-- END STRIP_FOR_RELEASE -->
 | ||
| 
 | ||
| <!-- END MUNGE: UNVERSIONED_WARNING -->
 | ||
| 
 | ||
| # Document Conventions
 | ||
| 
 | ||
| Updated: 11/3/2015
 | ||
| 
 | ||
| *This document is oriented at users and developers who want to write documents
 | ||
| for Kubernetes.*
 | ||
| 
 | ||
| **Table of Contents**
 | ||
| <!-- BEGIN MUNGE: GENERATED_TOC -->
 | ||
| 
 | ||
| - [Document Conventions](#document-conventions)
 | ||
|   - [General Concepts](#general-concepts)
 | ||
|   - [How to Get a Table of Contents](#how-to-get-a-table-of-contents)
 | ||
|   - [How to Write Links](#how-to-write-links)
 | ||
|   - [How to Include an Example](#how-to-include-an-example)
 | ||
|   - [Misc.](#misc)
 | ||
|     - [Code formatting](#code-formatting)
 | ||
|     - [Syntax Highlighting](#syntax-highlighting)
 | ||
|     - [Headings](#headings)
 | ||
|   - [What Are Mungers?](#what-are-mungers)
 | ||
|   - [Auto-added Mungers](#auto-added-mungers)
 | ||
|     - [Unversioned Warning](#unversioned-warning)
 | ||
|     - [Is Versioned](#is-versioned)
 | ||
|     - [Generate Analytics](#generate-analytics)
 | ||
| - [Generated documentation](#generated-documentation)
 | ||
| 
 | ||
| <!-- END MUNGE: GENERATED_TOC -->
 | ||
| 
 | ||
| ## General Concepts
 | ||
| 
 | ||
| Each document needs to be munged to ensure its format is correct, links are
 | ||
| valid, etc. To munge a document, simply run `hack/update-munge-docs.sh`. We
 | ||
| verify that all documents have been munged using `hack/verify-munge-docs.sh`.
 | ||
| The scripts for munging documents are called mungers, see the
 | ||
| [mungers section](#what-are-mungers) below if you're curious about how mungers
 | ||
| are implemented or if you want to write one.
 | ||
| 
 | ||
| ## How to Get a Table of Contents
 | ||
| 
 | ||
| Instead of writing table of contents by hand, insert the following code in your
 | ||
| md file:
 | ||
| 
 | ||
| ```
 | ||
| <!-- BEGIN MUNGE: GENERATED_TOC -->
 | ||
| <!-- END MUNGE: GENERATED_TOC -->
 | ||
| ```
 | ||
| 
 | ||
| After running `hack/update-munge-docs.sh`, you'll see a table of contents
 | ||
| generated for you, layered based on the headings.
 | ||
| 
 | ||
| ## How to Write Links
 | ||
| 
 | ||
| It's important to follow the rules when writing links. It helps us correctly
 | ||
| versionize documents for each release.
 | ||
| 
 | ||
| Use inline links instead of urls at all times. When you add internal links to
 | ||
| `docs/` or `examples/`, use relative links; otherwise, use
 | ||
| `http://releases.k8s.io/HEAD/<path/to/link>`. For example, avoid using:
 | ||
| 
 | ||
| ```
 | ||
| [GCE](https://github.com/kubernetes/kubernetes/blob/master/docs/getting-started-guides/gce.md)  # note that it's under docs/
 | ||
| [Kubernetes package](../../pkg/)                                                                # note that it's under pkg/
 | ||
| http://kubernetes.io/                                                                           # external link
 | ||
| ```
 | ||
| 
 | ||
| Instead, use:
 | ||
| 
 | ||
| ```
 | ||
| [GCE](../getting-started-guides/gce.md)                 # note that it's under docs/
 | ||
| [Kubernetes package](http://releases.k8s.io/HEAD/pkg/)  # note that it's under pkg/
 | ||
| [Kubernetes](http://kubernetes.io/)                     # external link
 | ||
| ```
 | ||
| 
 | ||
| The above example generates the following links:
 | ||
| [GCE](../getting-started-guides/gce.md),
 | ||
| [Kubernetes package](http://releases.k8s.io/HEAD/pkg/), and
 | ||
| [Kubernetes](http://kubernetes.io/).
 | ||
| 
 | ||
| ## How to Include an Example
 | ||
| 
 | ||
| While writing examples, you may want to show the content of certain example
 | ||
| files (e.g. [pod.yaml](../../test/fixtures/doc-yaml/user-guide/pod.yaml)). In this case, insert the
 | ||
| following code in the md file:
 | ||
| 
 | ||
| ```
 | ||
| <!-- BEGIN MUNGE: EXAMPLE path/to/file -->
 | ||
| <!-- END MUNGE: EXAMPLE path/to/file -->
 | ||
| ```
 | ||
| 
 | ||
| Note that you should replace `path/to/file` with the relative path to the
 | ||
| example file. Then `hack/update-munge-docs.sh` will generate a code block with
 | ||
| the content of the specified file, and a link to download it. This way, you save
 | ||
| the time to do the copy-and-paste; what's better, the content won't become
 | ||
| out-of-date every time you update the example file.
 | ||
| 
 | ||
| For example, the following:
 | ||
| 
 | ||
| ```
 | ||
| <!-- BEGIN MUNGE: EXAMPLE ../../test/fixtures/doc-yaml/user-guide/pod.yaml -->
 | ||
| <!-- END MUNGE: EXAMPLE ../../test/fixtures/doc-yaml/user-guide/pod.yaml -->
 | ||
| ```
 | ||
| 
 | ||
| generates the following after `hack/update-munge-docs.sh`:
 | ||
| 
 | ||
| <!-- BEGIN MUNGE: EXAMPLE ../../test/fixtures/doc-yaml/user-guide/pod.yaml -->
 | ||
| 
 | ||
| ```yaml
 | ||
| apiVersion: v1
 | ||
| kind: Pod
 | ||
| metadata:
 | ||
|   name: nginx
 | ||
|   labels:
 | ||
|     app: nginx
 | ||
| spec:
 | ||
|   containers:
 | ||
|   - name: nginx
 | ||
|     image: nginx
 | ||
|     ports:
 | ||
|     - containerPort: 80
 | ||
| ```
 | ||
| 
 | ||
| [Download example](../../test/fixtures/doc-yaml/user-guide/pod.yaml?raw=true)
 | ||
| <!-- END MUNGE: EXAMPLE ../../test/fixtures/doc-yaml/user-guide/pod.yaml -->
 | ||
| 
 | ||
| ## Misc.
 | ||
| 
 | ||
| ### Code formatting
 | ||
| 
 | ||
| Wrap a span of code with single backticks (`` ` ``). To format multiple lines of
 | ||
| code as its own code block, use triple backticks (```` ``` ````).
 | ||
| 
 | ||
| ### Syntax Highlighting
 | ||
| 
 | ||
| Adding syntax highlighting to code blocks improves readability. To do so, in
 | ||
| your fenced block, add an optional language identifier. Some useful identifier
 | ||
| includes `yaml`, `console` (for console output), and `sh` (for shell quote
 | ||
| format). Note that in a console output, put `$ ` at the beginning of each
 | ||
| command and put nothing at the beginning of the output. Here's an example of
 | ||
| console code block:
 | ||
| 
 | ||
| ```
 | ||
| ```console
 | ||
| 
 | ||
| $ kubectl create -f test/fixtures/doc-yaml/user-guide/pod.yaml
 | ||
| pod "foo" created
 | ||
| 
 | ||
| ``` 
 | ||
| ```
 | ||
| 
 | ||
| which renders as:
 | ||
| 
 | ||
| ```console
 | ||
| $ kubectl create -f test/fixtures/doc-yaml/user-guide/pod.yaml
 | ||
| pod "foo" created
 | ||
| ```
 | ||
| 
 | ||
| ### Headings
 | ||
| 
 | ||
| Add a single `#` before the document title to create a title heading, and add
 | ||
| `##` to the next level of section title, and so on. Note that the number of `#`
 | ||
| will determine the size of the heading.
 | ||
| 
 | ||
| ## What Are Mungers?
 | ||
| 
 | ||
| Mungers are like gofmt for md docs which we use to format documents. To use it,
 | ||
| simply place
 | ||
| 
 | ||
| ```
 | ||
| <!-- BEGIN MUNGE: xxxx -->
 | ||
| <!-- END MUNGE: xxxx -->
 | ||
| ```
 | ||
| 
 | ||
| in your md files. Note that xxxx is the placeholder for a specific munger.
 | ||
| Appropriate content will be generated and inserted between two brackets after
 | ||
| you run `hack/update-munge-docs.sh`. See
 | ||
| [munger document](http://releases.k8s.io/HEAD/cmd/mungedocs/) for more details.
 | ||
| 
 | ||
| ## Auto-added Mungers
 | ||
| 
 | ||
| After running `hack/update-munge-docs.sh`, you may see some code / mungers in
 | ||
| your md file that are auto-added. You don't have to add them manually. It's
 | ||
| recommended to just read this section as a reference instead of messing up with
 | ||
| the following mungers.
 | ||
| 
 | ||
| 
 | ||
| ### Unversioned Warning
 | ||
| 
 | ||
| UNVERSIONED_WARNING munger inserts unversioned warning which warns the users
 | ||
| when they're reading the document from HEAD and informs them where to find the
 | ||
| corresponding document for a specific release.
 | ||
| 
 | ||
| ```
 | ||
| <!-- BEGIN MUNGE: UNVERSIONED_WARNING -->
 | ||
| 
 | ||
| <!-- BEGIN STRIP_FOR_RELEASE -->
 | ||
| <!-- END STRIP_FOR_RELEASE -->
 | ||
| 
 | ||
| <!-- END MUNGE: UNVERSIONED_WARNING -->
 | ||
| ```
 | ||
| 
 | ||
| ### Is Versioned
 | ||
| 
 | ||
| IS_VERSIONED munger inserts `IS_VERSIONED` tag in documents in each release,
 | ||
| which stops UNVERSIONED_WARNING munger from inserting warning messages.
 | ||
| 
 | ||
| ```
 | ||
| <!-- BEGIN MUNGE: IS_VERSIONED -->
 | ||
| <!-- TAG IS_VERSIONED -->
 | ||
| <!-- END MUNGE: IS_VERSIONED -->
 | ||
| ```
 | ||
| 
 | ||
| ### Generate Analytics
 | ||
| 
 | ||
| ANALYTICS munger inserts a Google Anaylytics link for this page.
 | ||
| 
 | ||
| ```
 | ||
| <!-- BEGIN MUNGE: GENERATED_ANALYTICS -->
 | ||
| <!-- END MUNGE: GENERATED_ANALYTICS -->
 | ||
| ```
 | ||
| 
 | ||
| # Generated documentation
 | ||
| 
 | ||
| Some documents can be generated automatically. Run `hack/generate-docs.sh` to
 | ||
| populate your repository with these generated documents, and a list of the files
 | ||
| it generates is placed in `.generated_docs`. To reduce merge conflicts, we do
 | ||
| not want to check these documents in; however, to make the link checker in the
 | ||
| munger happy, we check in a placeholder. `hack/update-generated-docs.sh` puts a
 | ||
| placeholder in the location where each generated document would go, and
 | ||
| `hack/verify-generated-docs.sh` verifies that the placeholder is in place.
 | ||
| 
 | ||
| 
 | ||
| <!-- BEGIN MUNGE: GENERATED_ANALYTICS -->
 | ||
| []()
 | ||
| <!-- END MUNGE: GENERATED_ANALYTICS -->
 |