-
Notifications
You must be signed in to change notification settings - Fork 14.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Translate concepts/extend-kubernetes/operator/ into Japanese #16455
Merged
Merged
Changes from all commits
Commits
Show all changes
6 commits
Select commit
Hold shift + click to select a range
43522fd
Translate concepts/extend-kubernetes/operator/ into Japanese
hasebe b858a01
Update the word operator into Japanese
hasebe fdd9f7a
Apply suggestions by inductor and oke-py from code review
hasebe 81b7dcd
Apply suggestions by inductor from code review
hasebe 7ec626d
Refine sentences under bullet points
hasebe f18cee0
Refine sentences in response to the review by makocchi-git
hasebe File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
--- | ||
title: オペレーターパターン | ||
content_template: templates/concept | ||
weight: 30 | ||
--- | ||
|
||
{{% capture overview %}} | ||
|
||
オペレーターはサードパーティのアプリケーション、コンポーネントを管理するためのリソースを活用する、Kubernetesへのソフトウェア拡張です。 | ||
オペレーターは、特に[制御ループ](/docs/concepts/#kubernetes-control-plane)のようなKubernetesが持つ仕組みに準拠しています。 | ||
|
||
{{% /capture %}} | ||
|
||
{{% capture body %}} | ||
|
||
## モチベーション | ||
|
||
オペレーターパターンはサービス、またはサービス群を管理している運用担当者の主な目的をキャプチャすることが目標です。 | ||
特定のアプリケーション、サービスの面倒を見ている運用担当者は、システムがどのように振る舞うべきか、どのようにデプロイをするか、何らかの問題があったときにどのように対応するかについて深い知識を持っています。 | ||
|
||
Kubernetes上でワークロードを稼働させている人は、しばしば繰り返し可能なタスクを自動化することを好みます。 | ||
オペレーターパターンは、Kubernetes自身が提供している機能を超えて、あなたがタスクを自動化するために、どのようにコードを書くかをキャプチャします。 | ||
|
||
## Kubernetesにおけるオペレーター | ||
|
||
Kubernetesは自動化のために設計されています。追加の作業、設定無しに、Kubernetesのコア機能によって多数のビルトインされた自動化機能が提供されます。 | ||
ワークロードのデプロイ及び稼働を自動化するためにKubernetesを使うことができます。 *更に* Kubernetesがそれをどのように行うかの自動化も可能です。 | ||
|
||
Kubernetesの{{< glossary_tooltip text="コントローラー" term_id="controller" >}}コンセプトは、Kubernetesのソースコードを修正すること無く、クラスターの振る舞いを拡張することを可能にします。 | ||
オペレーターはKubernetes APIのクライアントで、[Custom Resource](/docs/concepts/api-extension/custom-resources/)にとっての、コントローラーのように振る舞います。 | ||
|
||
## オペレーターの例 {#example} | ||
|
||
オペレーターを使い自動化できるいくつかのことは、下記のようなものがあります: | ||
|
||
* 必要に応じてアプリケーションをデプロイする | ||
* アプリケーションの状態のバックアップを取得、リストアする | ||
* アプリケーションコードの更新と同時に、例えばデータベーススキーマ、追加の設定修正など必要な変更の対応を行う | ||
* Kubernetes APIをサポートしていないアプリケーションに、サービスを公開してそれらを発見する | ||
* クラスターの回復力をテストするために、全て、または一部分の障害をシミュレートする | ||
* 内部のリーダー選出プロセス無しに、分散アプリケーションのリーダーを選択する | ||
|
||
オペレーターをもっと詳しく見るとどのように見えるでしょうか?より詳細な例を示します: | ||
|
||
1. クラスターに設定可能なSampleDBという名前のカスタムリソース | ||
2. オペレーターの、コントローラー部分を含むPodが実行されていることを保証するDeployment | ||
3. オペレーターのコードを含んだコンテナイメージ | ||
4. 設定されているSampleDBのリソースを見つけるために、コントロールプレーンに問い合わせるコントローラーのコード | ||
5. オペレーターのコアは、現実を、設定されているリソースにどのように合わせるかをAPIサーバーに伝えるコードです。 | ||
* もし新しいSampleDBを追加した場合、オペレーターは永続化データベースストレージを提供するためにPersistentVolumeClaimsをセットアップし、StatefulSetがSampleDBの起動と、初期設定を担うJobを走らせます | ||
* もしそれを削除した場合、オペレーターはスナップショットを取り、StatefulSetとVolumeも合わせて削除されたことを確認します | ||
6. オペレーターは定期的なデータベースのバックアップも管理します。それぞれのSampleDBリソースについて、オペレーターはデータベースに接続可能な、バックアップを取得するPodをいつ作成するかを決定します。これらのPodはデータベース接続の詳細情報、クレデンシャルを保持するConfigMapとSecret、もしくはどちらかに依存するでしょう。 | ||
7. オペレーターは、管理下のリソースの堅牢な自動化を提供することを目的としているため、補助的な追加コードが必要になるかもしれません。この例では、データベースが古いバージョンで動いているかどうかを確認するコードで、その場合、アップグレードを行うJobをあなたに代わり作成します。 | ||
|
||
## オペレーターのデプロイ | ||
|
||
オペレーターをデプロイする最も一般的な方法は、Custom Resource Definitionとそれに関連するコントローラーをクラスターに追加することです。 | ||
このコントローラーは通常、あなたがコンテナアプリケーションを動かすのと同じように、{{< glossary_tooltip text="コントロールプレーン" term_id="control-plane" >}}外で動作します。 | ||
|
||
例えば、コントローラーをDeploymentとしてクラスター内で動かすことができます。 | ||
|
||
## オペレーターを利用する {#using-operators} | ||
|
||
一度オペレーターをデプロイすると、そのオペレーターを使って、それ自身が使うリソースの種類を追加、変更、または削除できます。 | ||
上記の利用例に従ってオペレーターそのもののためのDeploymentをセットアップし、以下のようなコマンドを実行します: | ||
|
||
```shell | ||
kubectl get SampleDB # 設定したデータベースを発見します | ||
|
||
kubectl edit SampleDB/example-database # 手動でいくつかの設定を変更します | ||
``` | ||
|
||
これだけです!オペレーターが変更の適用だけでなく既存のサービスがうまく稼働し続けるように面倒を見てくれます。 | ||
|
||
## 自分でオペレーターを書く {#writing-operator} | ||
|
||
必要な振る舞いを実装したオペレーターがエコシステム内に無い場合、自分で作成することができます。 | ||
[次の項目](#what-s-next)で、自分でクラウドネイティブオペレーターを作るときに利用できるライブラリやツールのリンクを見つけることができます。 | ||
|
||
オペレーター(すなわち、コントローラー)はどの言語/ランタイムでも実装でき、[Kubernetes APIのクライアント](/docs/reference/using-api/client-libraries/)として機能させることができます。 | ||
|
||
{{% /capture %}} | ||
|
||
{{% capture whatsnext %}} | ||
|
||
* [Custom Resources](/docs/concepts/extend-kubernetes/api-extension/custom-resources/)をより深く学びます | ||
* ユースケースに合わせた、既製のオペレーターを[OperatorHub.io](https://operatorhub.io/)から見つけます | ||
* 自前のオペレーターを書くために既存のツールを使います、例: | ||
* [KUDO](https://kudo.dev/)(Kubernetes Universal Declarative Operator)を使います | ||
* [kubebuilder](https://book.kubebuilder.io/)を使います | ||
* [Metacontroller](https://metacontroller.app/)を自分で実装したWebHooksと一緒に使います | ||
* [Operator Framework](https://github.com/operator-framework/getting-started)を使います | ||
* 自前のオペレーターを他のユーザーのために[公開](https://operatorhub.io/)します | ||
* オペレーターパターンを紹介している[CoreOSオリジナル記事](https://coreos.com/blog/introducing-operators.html)を読みます | ||
* Google Cloudが出したオペレーター作成のベストプラクティス[記事](https://cloud.google.com/blog/products/containers-kubernetes/best-practices-for-building-kubernetes-operators-and-stateful-apps)を読みます | ||
|
||
{{% /capture %}} |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
若干違和感あるなと思ったが細かいwordingレベル(人の好き好き)の指摘になってしまいそうなのと原文がそもそもアレなのでこのままで、、
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
そうなのです。何度か書き直したのですが、しっくり来る形が見つけられませんでした。。