Go to file
Kubernetes Prow Robot 3ca7abce96
Merge pull request #27058 from jihoon-seo/patch-5
Fix broken link
2021-03-15 11:35:32 -07:00
.github Add automatic build triggering 2020-12-23 16:33:36 +00:00
api-ref-generator@ce97454e55 New API Reference presentation on /content/en/docs/reference/kubernetes-api 2021-01-19 21:05:09 +01:00
archetypes cleanup example-tutorial template 2020-07-10 15:46:43 -04:00
assets Fix search input overlapping site nav 2021-01-26 08:38:41 -08:00
content Merge pull request #27058 from jihoon-seo/patch-5 2021-03-15 11:35:32 -07:00
data Add historical announcement text 2021-01-19 11:03:59 -05:00
deprecated
i18n Merge pull request #25324 from rayw000/translate-zh-menu 2021-01-16 21:11:43 -08:00
layouts Fix deprecated landscape URLs (#26251) 2021-02-28 11:26:39 -08:00
scripts Enhance diff_l10n_branches script output 2020-12-30 10:14:48 +09:00
static Update install-kubectl.md to use tabs for the different Operating Systems (#26682) 2021-03-04 19:04:21 -08:00
themes updating docsy theme submodule 2021-03-03 18:07:08 +08:00
update-imported-docs update reference.yml for 1.20 reference docs 2020-12-03 09:07:43 -05:00
.dockerignore
.editorconfig .editorconfig: turning off trim_trailing_whitespace for markdown files 2020-10-27 10:26:47 -07:00
.gitignore
.gitmodules New API Reference presentation on /content/en/docs/reference/kubernetes-api 2021-01-19 21:05:09 +01:00
.htmltest.yml
CONTRIBUTING.md Merge pull request #21680 from CriaHu/hyq-612 2020-10-15 12:01:25 -07:00
Dockerfile New API Reference presentation on /content/en/docs/reference/kubernetes-api 2021-01-19 21:05:09 +01:00
LICENSE
Makefile Merge pull request #23294 from feloy/feloy-gsod-api-reference-ex1 2021-01-19 16:25:59 -08:00
OWNERS cleanup docs owners 2020-09-28 01:21:35 +00:00
OWNERS_ALIASES Merge pull request #26623 from rikatz/patch-3 2021-03-12 02:10:18 -08:00
README-de.md update http to https (readme.md) 2020-12-20 00:52:04 +02:00
README-es.md update http to https 2020-12-23 01:43:32 +02:00
README-fr.md Merge pull request #23444 from didier-durand/master 2020-09-10 13:20:14 -07:00
README-hi.md Merge pull request #23535 from lovebaby979/br1 2020-10-18 01:24:13 -07:00
README-id.md Merge pull request #23536 from lovebaby979/br2 2020-09-30 18:12:54 -07:00
README-it.md Merge pull request #23537 from lovebaby979/br3 2020-10-01 13:49:19 -07:00
README-ja.md update readme-ja 2020-11-04 20:33:21 +09:00
README-ko.md Update README-ko.md file 2020-11-30 17:19:42 +09:00
README-pl.md update broken link 2020-10-30 15:41:48 +08:00
README-pt.md Update README-pt.md 2021-02-04 17:57:28 -03:00
README-ru.md Translating code comments in Russian README 2020-12-28 10:41:28 +07:00
README-uk.md Update uk translation in README-uk.md 2020-11-01 17:10:55 +00:00
README-vi.md update broken link 2020-10-30 15:51:04 +08:00
README-zh.md [zh] update http to https (readme.md) 2020-12-19 02:18:48 +02:00
README.md Update README.md 2021-02-01 18:59:03 -03:00
SECURITY.md Add SECURITY.md 2020-07-27 16:07:58 -06:00
SECURITY_CONTACTS Update for chair emeritus 2020-09-27 14:30:12 -07:00
code-of-conduct.md
config.toml feat: add print directive allows print sections. 2021-03-07 09:11:49 +08:00
go.mod Fix examples tests 2021-01-16 14:09:28 +08:00
go.sum Fix examples tests 2021-01-16 14:09:28 +08:00
labels.yaml
linkcheck-config.toml
netlify.toml Switch to Hugo v0.79.1 2020-12-22 23:57:16 +00:00
package-lock.json add package-lock file 2020-07-03 19:08:25 -04:00
package.json updating packaging 2020-07-03 18:04:53 -04:00
postcss.config.js updating packaging 2020-07-03 18:04:53 -04:00

README.md

The Kubernetes documentation

Netlify Status GitHub release

This repository contains the assets required to build the Kubernetes website and documentation. We're glad that you want to contribute!

Using this repository

You can run the website locally using Hugo (Extended version), or you can run it in a container runtime. We strongly recommend using the container runtime, as it gives deployment consistency with the live website.

Prerequisites

To use this repository, you need the following installed locally:

Before you start, install the dependencies. Clone the repository and navigate to the directory:

git clone https://github.com/kubernetes/website.git
cd website

The Kubernetes website uses the Docsy Hugo theme. Even if you plan to run the website in a container, we strongly recommend pulling in the submodule and other development dependencies by running the following:

# pull in the Docsy submodule
git submodule update --init --recursive --depth 1

Running the website using a container

To build the site in a container, run the following to build the container image and run it:

make container-image
make container-serve

Open up your browser to http://localhost:1313 to view the website. As you make changes to the source files, Hugo updates the website and forces a browser refresh.

Running the website locally using Hugo

Make sure to install the Hugo extended version specified by the HUGO_VERSION environment variable in the netlify.toml file.

To build and test the site locally, run:

# install dependencies
npm ci
make serve

This will start the local Hugo server on port 1313. Open up your browser to http://localhost:1313 to view the website. As you make changes to the source files, Hugo updates the website and forces a browser refresh.

Building the API reference pages

The API reference pages located in content/en/docs/reference/kubernetes-api are built from the Swagger specification, using https://github.com/kubernetes-sigs/reference-docs/tree/master/gen-resourcesdocs.

To update the reference pages for a new Kubernetes release (replace v1.20 in the following examples with the release to update to):

  1. Pull the kubernetes-resources-reference submodule:
git submodule update --init --recursive --depth 1
  1. Create a new API revision into the submodule, and add the Swagger specification:
mkdir api-ref-generator/gen-resourcesdocs/api/v1.20
curl 'https://raw.githubusercontent.com/kubernetes/kubernetes/master/api/openapi-spec/swagger.json' > api-ref-generator/gen-resourcesdocs/api/v1.20/swagger.json
  1. Copy the table of contents and fields configuration for the new release from a previous one:
mkdir api-ref-generator/gen-resourcesdocs/api/v1.20
cp api-ref-generator/gen-resourcesdocs/api/v1.19/* api-ref-generator/gen-resourcesdocs/api/v1.20/
  1. Adapt the files toc.yaml and fields.yaml to reflect the changes between the two releases

  2. Next, build the pages:

make api-reference

You can test the results locally by making and serving the site from a container image:

make container-image
make container-serve

In a web browser, go to http://localhost:1313/docs/reference/kubernetes-api/ to view the API reference.

  1. When all changes of the new contract are reflected into the configuration files toc.yaml and fields.yaml, create a Pull Request with the newly generated API reference pages.

Troubleshooting

error: failed to transform resource: TOCSS: failed to transform "scss/main.scss" (text/x-scss): this feature is not available in your current Hugo version

Hugo is shipped in two set of binaries for technical reasons. The current website runs based on the Hugo Extended version only. In the release page look for archives with extended in the name. To confirm, run hugo version and look for the word extended.

Troubleshooting macOS for too many open files

If you run make serve on macOS and receive the following error:

ERROR 2020/08/01 19:09:18 Error: listen tcp 127.0.0.1:1313: socket: too many open files
make: *** [serve] Error 1

Try checking the current limit for open files:

launchctl limit maxfiles

Then run the following commands (adapted from https://gist.github.com/tombigel/d503800a282fcadbee14b537735d202c):

#!/bin/sh

# These are the original gist links, linking to my gists now.
# curl -O https://gist.githubusercontent.com/a2ikm/761c2ab02b7b3935679e55af5d81786a/raw/ab644cb92f216c019a2f032bbf25e258b01d87f9/limit.maxfiles.plist
# curl -O https://gist.githubusercontent.com/a2ikm/761c2ab02b7b3935679e55af5d81786a/raw/ab644cb92f216c019a2f032bbf25e258b01d87f9/limit.maxproc.plist

curl -O https://gist.githubusercontent.com/tombigel/d503800a282fcadbee14b537735d202c/raw/ed73cacf82906fdde59976a0c8248cce8b44f906/limit.maxfiles.plist
curl -O https://gist.githubusercontent.com/tombigel/d503800a282fcadbee14b537735d202c/raw/ed73cacf82906fdde59976a0c8248cce8b44f906/limit.maxproc.plist

sudo mv limit.maxfiles.plist /Library/LaunchDaemons
sudo mv limit.maxproc.plist /Library/LaunchDaemons

sudo chown root:wheel /Library/LaunchDaemons/limit.maxfiles.plist
sudo chown root:wheel /Library/LaunchDaemons/limit.maxproc.plist

sudo launchctl load -w /Library/LaunchDaemons/limit.maxfiles.plist

This works for Catalina as well as Mojave macOS.

Get involved with SIG Docs

Learn more about SIG Docs Kubernetes community and meetings on the community page.

You can also reach the maintainers of this project at:

Contributing to the docs

You can click the Fork button in the upper-right area of the screen to create a copy of this repository in your GitHub account. This copy is called a fork. Make any changes you want in your fork, and when you are ready to send those changes to us, go to your fork and create a new pull request to let us know about it.

Once your pull request is created, a Kubernetes reviewer will take responsibility for providing clear, actionable feedback. As the owner of the pull request, it is your responsibility to modify your pull request to address the feedback that has been provided to you by the Kubernetes reviewer.

Also, note that you may end up having more than one Kubernetes reviewer provide you feedback or you may end up getting feedback from a Kubernetes reviewer that is different than the one initially assigned to provide you feedback.

Furthermore, in some cases, one of your reviewers might ask for a technical review from a Kubernetes tech reviewer when needed. Reviewers will do their best to provide feedback in a timely fashion but response time can vary based on circumstances.

For more information about contributing to the Kubernetes documentation, see:

Localization README.md's

Language Language
Chinese Korean
French Polish
German Portuguese
Hindi Russian
Indonesian Spanish
Italian Ukrainian
Japanese Vietnamese

Code of conduct

Participation in the Kubernetes community is governed by the CNCF Code of Conduct.

Thank you!

Kubernetes thrives on community participation, and we appreciate your contributions to our website and our documentation!