Швидкий старт з довідковою документацією
Ця сторінка показує, як використовувати скрипт update-imported-docs.py
для генерації довідкової документації Kubernetes. Скрипт автоматизує налаштування збірки та генерує довідкову документацію для релізу.
Перш ніж ви розпочнете
Вимоги:
Вам потрібна машина, що працює під управлінням Linux або macOS.
Вам потрібно встановити ці інструменти:
Ваша змінна середовища
PATH
повинна включати необхідні інструменти для збірки, такі як бінарникиGo
таpython
.Вам потрібно знати, як створити pull request до репозиторію на GitHub. Це включає створення власного форку репозиторію. Для отримання додаткової інформації дивіться Робота з локальним клоном.
Отримання репозиторію документації
Переконайтеся, що ваш форк репозиторію website
синхронізований з віддаленим репозиторієм kubernetes/website
на GitHub (гілка main
), і клонуйте ваш форк website
собі локально.
mkdir github.com
cd github.com
git clone git@github.com:<your_github_username>/website.git
Визначте базову теку вашого клону. Наприклад, якщо ви слідували попередньому кроку для отримання репозиторію, ваша базова тека — github.com/website
. Наступні кроки посилаються на вашу базову теку як <web-base>
.
Примітка:
Якщо ви хочете змінити вміст компонентів інструментів і довідкову документацію API, дивіться інструкцію для внесення змін в upstream.Огляд update-imported-docs
Скрипт update-imported-docs.py
розташований у теці <web-base>/update-imported-docs/
.
Скрипт будує наступні довідки:
- Довідкові сторінки компонентів та інструментів
- Довідка по команді
kubectl
- Довідка по API Kubernetes
Скрипт update-imported-docs.py
генерує довідкову документацію Kubernetes з вихідного коду Kubernetes. Скрипт створює тимчасову теку в /tmp
на вашій машині та клонує потрібні репозиторії: kubernetes/kubernetes
та kubernetes-sigs/reference-docs
у цю теку. Скрипт встановлює вашу змінну середовища GOPATH
на цю тимчасову теку. Встановлюються три додаткові змінні середовища:
K8S_RELEASE
K8S_ROOT
K8S_WEBROOT
Скрипт потребує два аргументи для успішного виконання:
- YAML конфігураційний файл (
reference.yml
) - Версія релізу, наприклад:
1.17
Конфігураційний файл містить поле generate-command
. Поле generate-command
визначає серію інструкцій для збірки з kubernetes-sigs/reference-docs/Makefile
. Змінна K8S_RELEASE
визначає версію релізу.
Скрипт update-imported-docs.py
виконує наступні кроки:
- Клонування повʼязаних репозиторіїв, зазначених у конфігураційному файлі. Для генерації довідкових документів типово клонуються
kubernetes-sigs/reference-docs
. - Запуск команд під час клонування репозиторіїв для підготовки генератора документації та генерація HTML і Markdown файлів.
- Копіювання згенерованих HTML і Markdown файлів до локального клону репозиторію
<web-base>
за вказаними в конфігураційному файлі шляхами. - Оновлення посилань команд
kubectl
зkubectl.md
у секції в довідці по командіkubectl
.
Коли згенеровані файли знаходяться у вашому локальному клоні репозиторію <web-base>
, ви можете подати їх у pull request до <web-base>
.
Формат конфігураційного файлу
Кожен конфігураційний файл може містити кілька репозиторіїв, які будуть імпортовані разом. За необхідності, ви можете налаштувати конфігураційний файл, редагуючи його вручну. Можна створювати нові конфігураційні файли для імпорту інших груп документів. Ось приклад YAML конфігураційного файлу:
repos:
- name: community
remote: https://github.com/kubernetes/community.git
branch: master
files:
- src: contributors/devel/README.md
dst: docs/imported/community/devel.md
- src: contributors/guide/README.md
dst: docs/imported/community/guide.md
Окремі Markdown документи, імпортовані за допомогою інструмента, повинні відповідати Посібнику зі стилю документації.
Налаштування reference.yml
Відкрийте <web-base>/update-imported-docs/reference.yml
для редагування. Не змінюйте вміст поля generate-command
, якщо не розумієте, як команда використовується для побудови довідок. Оновлення reference.yml
зазвичай не потрібне. Іноді зміни в upstream вихідному коді можуть вимагати змін у конфігураційному файлі (наприклад: залежності версій golang та зміни сторонніх бібліотек). Якщо ви стикаєтеся з проблемами збірки, зверніться до команди SIG-Docs у #sig-docs Kubernetes Slack.
Примітка:
generate-command
є необовʼязковим полем, яке можна використовувати для запуску заданої команди або короткого скрипту для генерації документації з репозиторію.У reference.yml
, files
містить список полів src
та dst
. Поле src
містить розташування згенерованого Markdown файлу у теці збірки kubernetes-sigs/reference-docs
, а поле dst
визначає, куди скопіювати цей файл у клонованому репозиторії kubernetes/website
. Наприклад:
repos:
- name: reference-docs
remote: https://github.com/kubernetes-sigs/reference-docs.git
files:
- src: gen-compdocs/build/kube-apiserver.md
dst: content/en/docs/reference/command-line-tools-reference/kube-apiserver.md
...
Зверніть увагу, що коли є багато файлів для копіювання з одного джерела в одну й ту ж теку призначення, ви можете використовувати шаблони в значенні src
. Ви повинні надати назву теки як значення для dst
. Наприклад:
files:
- src: gen-compdocs/build/kubeadm*.md
dst: content/en/docs/reference/setup-tools/kubeadm/generated/
Запуск інструмента update-imported-docs
Ви можете запустити інструмент update-imported-docs.py
наступним чином:
cd <web-base>/update-imported-docs
./update-imported-docs.py <configuration-file.yml> <release-version>
Наприклад:
./update-imported-docs.py reference.yml 1.17
Виправлення посилань
Конфігураційний файл release.yml
містить інструкції для виправлення відносних посилань. Щоб виправити відносні посилання у ваших імпортованих файлах, встановіть властивість gen-absolute-links
на true
. Ви можете знайти приклад цього в release.yml
.
Додавання та коміт змін у репо kubernetes/website
Перегляньте файли, що були згенеровані та скопійовані до <web-base>
:
cd <web-base>
git status
Вивід показує нові та змінені файли. Згенеровані результати варіюються залежно від змін, внесених у upstream вихідний код.
Згенеровані файли компонентів інструментів
content/en/docs/reference/command-line-tools-reference/cloud-controller-manager.md
content/en/docs/reference/command-line-tools-reference/kube-apiserver.md
content/en/docs/reference/command-line-tools-reference/kube-controller-manager.md
content/en/docs/reference/command-line-tools-reference/kube-proxy.md
content/en/docs/reference/command-line-tools-reference/kube-scheduler.md
content/en/docs/reference/setup-tools/kubeadm/generated/kubeadm.md
content/en/docs/reference/kubectl/kubectl.md
Згенеровані файли довідки команди kubectl
static/docs/reference/generated/kubectl/kubectl-commands.html
static/docs/reference/generated/kubectl/navData.js
static/docs/reference/generated/kubectl/scroll.js
static/docs/reference/generated/kubectl/stylesheet.css
static/docs/reference/generated/kubectl/tabvisibility.js
static/docs/reference/generated/kubectl/node_modules/bootstrap/dist/css/bootstrap.min.css
static/docs/reference/generated/kubectl/node_modules/highlight.js/styles/default.css
static/docs/reference/generated/kubectl/node_modules/jquery.scrollto/jquery.scrollTo.min.js
static/docs/reference/generated/kubectl/node_modules/jquery/dist/jquery.min.js
static/docs/reference/generated/kubectl/css/font-awesome.min.css
Згенеровані теки та файли довідки по Kubernetes API
static/docs/reference/generated/kubernetes-api/v1.31/index.html
static/docs/reference/generated/kubernetes-api/v1.31/js/navData.js
static/docs/reference/generated/kubernetes-api/v1.31/js/scroll.js
static/docs/reference/generated/kubernetes-api/v1.31/js/query.scrollTo.min.js
static/docs/reference/generated/kubernetes-api/v1.31/css/font-awesome.min.css
static/docs/reference/generated/kubernetes-api/v1.31/css/bootstrap.min.css
static/docs/reference/generated/kubernetes-api/v1.31/css/stylesheet.css
static/docs/reference/generated/kubernetes-api/v1.31/fonts/FontAwesome.otf
static/docs/reference/generated/kubernetes-api/v1.31/fonts/fontawesome-webfont.eot
static/docs/reference/generated/kubernetes-api/v1.31/fonts/fontawesome-webfont.svg
static/docs/reference/generated/kubernetes-api/v1.31/fonts/fontawesome-webfont.ttf
static/docs/reference/generated/kubernetes-api/v1.31/fonts/fontawesome-webfont.woff
static/docs/reference/generated/kubernetes-api/v1.31/fonts/fontawesome-webfont.woff2
Виконайте git add
та git commit
, щоб зафіксувати файли.
Створення pull request
Створіть pull request до репозиторію kubernetes/website
. Слідкуйте за вашим pull request і відповідайте на коментарі рецензентів за потреби. Продовжуйте слідкувати за вашим pull request до його злиття.
Через кілька хвилин після злиття вашого pull request, ваша оновлена довідкова документація буде видна в опублікованій документації.
Що далі
Щоб згенерувати окрему довідкову документацію, вручну налаштувавши необхідні репозиторії та запустивши цільові завдання збірки, дивіться наступні посібники: