Localizing Kubernetes documentation

    You can help add or improve the content of an existing localization. In , you can find a channel for each localization. There is also a general SIG Docs Localizations Slack channel where you can say hello.

    Note: For extra details on how to contribute to a specific localization, look for a localized version of this page.

    First, consult the ISO 639-1 standard to find your localization’s two-letter language code. For example, the two-letter code for Korean is .

    Fork and clone the repo

    First, create your own fork of the repository.

    Then, clone your fork and cd into it:

    The website content directory includes subdirectories for each language. The localization you want to help out with is inside content/<two-letter-code>.

    Suggest changes

    Create or update your chosen localized page based on the English original. See for more details.

    If you notice a technical inaccuracy or other problem with the upstream (English) documentation, you should fix the upstream documentation first and then repeat the equivalent fix by updating the localization you’re working on.

    Limit changes in a pull requests to a single localization. Reviewing pull requests that change content in multiple localizations is problematic.

    Follow Suggesting Content Improvements to propose changes to that localization. The process is similar to proposing changes to the upstream (English) content.

    If you want the Kubernetes documentation localized into a new language, here’s what you need to do.

    Because contributors can’t approve their own pull requests, you need at least two contributors to begin a localization.

    All localization teams must be self-sufficient. The Kubernetes website is happy to host your work, but it’s up to you to translate it and keep existing localized content current.

    You’ll need to know the two-letter language code for your language. Consult the ISO 639-1 standard to find your localization’s two-letter language code. For example, the two-letter code for Korean is ko.

    When you start a new localization, you must localize all the before the Kubernetes project can publish your changes to the live website.

    SIG Docs can help you work on a separate branch so that you can incrementally work towards that goal.

    Find community

    Let Kubernetes SIG Docs know you’re interested in creating a localization! Join the and the SIG Docs Localizations Slack channel. Other localization teams are happy to help you get started and answer your questions.

    Please also consider participating in the . The mission of the SIG Docs localization subgroup is to work across the SIG Docs localization teams to collaborate on defining and documenting the processes for creating localized contribution guides. In addition, the SIG Docs localization subgroup looks for opportunities to create and share common tools across localization teams and identify new requirements for the SIG Docs Leadership team. If you have questions about this meeting, please inquire on the SIG Docs Localizations Slack channel.

    You can also create a Slack channel for your localization in the kubernetes/community repository. For an example of adding a Slack channel, see the PR for .

    Join the Kubernetes GitHub organization

    When you’ve opened a localization PR, you can become members of the Kubernetes GitHub organization. Each person on the team needs to create their own in the kubernetes/org repository.

    Add your localization team in GitHub

    Next, add your Kubernetes localization team to . For an example of adding a localization team, see the PR to add the Spanish localization team.

    Members of @kubernetes/sig-docs-**-owners can approve PRs that change content within (and only within) your localization directory: /content/**/. For each localization, The @kubernetes/sig-docs-**-reviews team automates review assignments for new PRs. Members of @kubernetes/website-maintainers can create new localization branches to coordinate translation efforts. Members of @kubernetes/website-milestone-maintainers can use the /milestone to assign a milestone to issues or PRs.

    Next, add a GitHub label for your localization in the kubernetes/test-infra repository. A label lets you filter issues and pull requests for your specific language.

    For an example of adding a label, see the PR for adding the .

    Modify the site configuration

    The Kubernetes website uses Hugo as its web framework. The website’s Hugo configuration resides in the file. You’ll need to modify config.toml to support a new localization.

    Add a configuration block for the new language to config.toml under the existing [languages] block. The German block, for example, looks like:

    1. title = "Kubernetes"
    2. description = "Produktionsreife Container-Verwaltung"
    3. languageName = "Deutsch (German)"
    4. languageNameLatinScript = "Deutsch"
    5. contentDir = "content/de"
    6. weight = 8

    languageNameLatinScript can be used to access the language name in Latin script and use it in the theme. Assign “language name in latin script” to languageNameLatinScript. For example, languageNameLatinScript ="Korean" or languageNameLatinScript = "Deutsch".

    When assigning a weight parameter for your block, find the language block with the highest weight and add 1 to that value.

    For more information about Hugo’s multilingual support, see “Multilingual Mode“.

    Add a new localization directory

    Add a language-specific subdirectory to the content folder in the repository. For example, the two-letter code for German is :

    You also need to create a directory inside data/i18n for ; look at existing localizations for an example. To use these new strings, you must also create a symbolic link from i18n/<localization>.toml to the actual string configuration in data/i18n/<localization>/<localization>.toml (remember to commit the symbolic link).

    For example, for German the strings live in data/i18n/de/de.toml, and i18n/de.toml is a symbolic link to data/i18n/de/de.toml.

    Localize the community code of conduct

    Open a PR against the repository to add the code of conduct in your language.

    Setting up the OWNERS files

    To set the roles of each user contributing to the localization, create an OWNERS file inside the language-specific subdirectory with:

    • reviewers: A list of kubernetes teams with reviewer roles, in this case,
    • the sig-docs-**-reviews team created in .
    • approvers: A list of kubernetes teams with approvers roles, in this case,
    • the sig-docs-**-owners team created in Add your localization team in GitHub.
    • labels: A list of GitHub labels to automatically apply to a PR, in this case, the language label created in .

    More information about the OWNERS file can be found at go.k8s.io/owners.

    The , with language code es, looks like this:

    1. # See the OWNERS docs at https://go.k8s.io/owners
    2. # This is the localization project for Spanish.
    3. # Teams and members are visible at https://github.com/orgs/kubernetes/teams.
    4. reviewers:
    5. - sig-docs-es-reviews
    6. approvers:
    7. - sig-docs-es-owners
    8. labels:
    9. - language/es

    After adding the language-specific OWNERS file, update the root OWNERS_ALIASES file with the new Kubernetes teams for the localization, sig-docs-**-owners and sig-docs-**-reviews.

    For each team, add the list of GitHub users requested in , in alphabetical order.

    Open a pull request

    Next, (PR) to add a localization to the kubernetes/website repository. The PR must include all the minimum required content before it can be approved.

    For an example of adding a new localization, see the PR to enable .

    To guide other localization contributors, add a new to the top level of kubernetes/website, where ** is the two-letter language code. For example, a German README file would be README-de.md.

    Guide localization contributors in the localized README-**.md file. Include the same information contained in as well as:

    • Any information specific to the localization

    After you create the localized README, add a link to the file from the main English README.md, and include contact information in English. You can provide a GitHub ID, email address, , or another method of contact. You must also provide a link to your localized Community Code of Conduct.

    Launching your new localization

    When a localization meets the requirements for workflow and minimum output, SIG Docs does the following:

    • Enables language selection on the website.
    • Publicizes the localization’s availability through (CNCF) channels, including the Kubernetes blog.

    Localizing all the Kubernetes documentation is an enormous task. It’s okay to start small and expand over time.

    Minimum required content

    At a minimum, all localizations must include:

    Translated documents must reside in their own content/**/ subdirectory, but otherwise, follow the same URL path as the English source. For example, to prepare the tutorial for translation into German, create a subfolder under the content/de/ folder and copy the English source:

    1. mkdir -p content/de/docs/tutorials
    2. cp content/en/docs/tutorials/kubernetes-basics.md content/de/docs/tutorials/kubernetes-basics.md

    Translation tools can speed up the translation process. For example, some editors offer plugins to quickly translate text.

    Caution: Machine-generated translation is insufficient on its own. Localization requires extensive human review to meet minimum standards of quality.

    To ensure accuracy in grammar and meaning, members of your localization team should carefully review all machine-generated translations before publishing.

    Source files

    Localizations must be based on the English files from a specific release targeted by the localization team. Each localization team can decide which release to target, referred to as the target version below.

    To find source files for your target version:

    1. Select a branch for your target version from the following table:

    Target versionBranch
    Latest version
    Previous versionrelease-1.25
    Next version

    The main branch holds content for the current release v1.26. The release team creates a release-1.26 branch before the next release: v1.27.

    Site strings in i18n

    Localizations must include the contents of in a new language-specific file. Using German as an example: data/i18n/de/de.toml.

    Add a new localization directory and file to data/i18n/. For example, with German (de):

    Revise the comments at the top of the file to suit your localization, then translate the value of each string. For example, this is the German-language placeholder text for the search form:

    1. [ui_search_placeholder]
    2. other = "Suchen"

    Localizing site strings lets you customize site-wide text and features: for example, the legal copyright text in the footer on each page.

    Language-specific localization guide

    As a localization team, you can formalize the best practices your team follows by creating a language-specific localization guide.

    For example, see the , which includes content on the following subjects:

    • Sprint cadence and releases
    • Branch strategy
    • Pull request workflow
    • Style guide
    • Glossary of localized and non-localized terms
    • Markdown conventions
    • Kubernetes API object terminology

    If the localization project needs a separate meeting time, contact a SIG Docs Co-Chair or Tech Lead to create a new reoccurring Zoom meeting and calendar invite. This is only needed when the team is large enough to sustain and require a separate meeting.

    Per CNCF policy, the localization teams must upload their meetings to the SIG Docs YouTube playlist. A SIG Docs Co-Chair or Tech Lead can help with the process until SIG Docs automates it.

    Because localization projects are highly collaborative efforts, we encourage teams to work in shared localization branches - especially when starting out and the localization is not yet live.

    To collaborate on a localization branch:

    1. A team member of @kubernetes/website-maintainers opens a localization branch from a source branch on .

      Your team approvers joined the @kubernetes/website-maintainers team when you added your localization team to the repository.

      We recommend the following branch naming scheme:

      dev-<source version>-<language code>.<team milestone>

      For example, an approver on a German localization team opens the localization branch dev-1.12-de.1 directly against the kubernetes/website repository, based on the source branch for Kubernetes v1.12.

    2. Individual contributors open feature branches based on the localization branch.

      For example, a German contributor opens a pull request with changes to kubernetes:dev-1.12-de.1 from username:local-branch-name.

    3. Approvers review and merge feature branches into the localization branch.

    4. Periodically, an approver merges the localization branch with its source branch by opening and approving a new pull request. Be sure to squash the commits before approving the pull request.

    Repeat steps 1-4 as needed until the localization is complete. For example, subsequent German localization branches would be: dev-1.12-de.2, dev-1.12-de.3, etc.

    Teams must merge localized content into the same branch from which the content was sourced. For example:

    • A localization branch sourced from main must be merged into main.
    • A localization branch sourced from release-1.25 must be merged into release-1.25.

    Note: If your localization branch was created from main branch, but it is not merged into main before the new release branch release-1.26 created, merge it into both main and new release branch release-1.26. To merge your localization branch into the new release branch release-1.26, you need to switch the upstream branch of your localization branch to .

    At the beginning of every team milestone, it’s helpful to open an issue comparing upstream changes between the previous localization branch and the current localization branch. There are two scripts for comparing upstream changes.

    • upstream_changes.py is useful for checking the changes made to a specific file. And
    • is useful for creating a list of outdated files for a specific localization branch.

    While only approvers can open a new localization branch and merge pull requests, anyone can open a pull request for a new localization branch. No special permissions are required.

    SIG Docs welcomes upstream contributions and corrections to the English source.