[ja] Translate content/en/docs/tasks/network/extend-service-ip-ranges.md into Japanese (#49549)
* [ja] add extend-service-ip-ranges.md * Update content/ja/docs/tasks/network/extend-service-ip-ranges.md Co-authored-by: Junya Okabe <86868255+Okabe-Junya@users.noreply.github.com> * Update content/ja/docs/tasks/network/extend-service-ip-ranges.md Co-authored-by: Junya Okabe <86868255+Okabe-Junya@users.noreply.github.com> * Update content/ja/docs/tasks/network/extend-service-ip-ranges.md Co-authored-by: Junya Okabe <86868255+Okabe-Junya@users.noreply.github.com> * Update content/ja/docs/tasks/network/extend-service-ip-ranges.md Co-authored-by: Junya Okabe <86868255+Okabe-Junya@users.noreply.github.com> * Update extend-service-ip-ranges.md --------- Co-authored-by: Junya Okabe <86868255+Okabe-Junya@users.noreply.github.com>
This commit is contained in:
		
							parent
							
								
									c257bf6054
								
							
						
					
					
						commit
						553a3cb2b7
					
				|  | @ -0,0 +1,180 @@ | |||
| --- | ||||
| min-kubernetes-server-version: v1.29 | ||||
| title: Service IPの範囲を拡張する | ||||
| content_type: task | ||||
| --- | ||||
| 
 | ||||
| <!-- overview --> | ||||
| {{< feature-state feature_gate_name="MultiCIDRServiceAllocator" >}} | ||||
| 
 | ||||
| このドキュメントはクラスターに割り当てられている既存のService IPの範囲を拡張する方法を説明します。 | ||||
| 
 | ||||
| ## {{% heading "prerequisites" %}} | ||||
| 
 | ||||
| {{< include "task-tutorial-prereqs.md" >}} | ||||
| 
 | ||||
| {{< version-check >}} | ||||
| 
 | ||||
| <!-- steps --> | ||||
| 
 | ||||
| ## API | ||||
| 
 | ||||
| APIサーバーで`MultiCIDRServiceAllocator`[フィーチャーゲート](/docs/reference/command-line-tools-reference/feature-gates/)を有効にし、`networking.k8s.io/v1beta1`APIグループをアクティブにしているKubernetesクラスターは、`kubernetes`という名前の特別なServiceCIDRオブジェクトを作成します。このオブジェクトには、APIサーバーのコマンドライン引数`--service-cluster-ip-range`の値に基づいたIPアドレス範囲が指定されます。 | ||||
| 
 | ||||
| ```sh | ||||
| kubectl get servicecidr | ||||
| ``` | ||||
| 
 | ||||
| ``` | ||||
| NAME         CIDRS          AGE | ||||
| kubernetes   10.96.0.0/28   17d | ||||
| ``` | ||||
| 
 | ||||
| APIサーバーのエンドポイントをPodに公開する`kubernetes`という特別なServiceは、デフォルトのServiceCIDRの範囲の最初のIPアドレスを算出し、そのIPアドレスをCluster IPとして使用します。 | ||||
| 
 | ||||
| ```sh | ||||
| kubectl get service kubernetes | ||||
| ``` | ||||
| 
 | ||||
| ``` | ||||
| NAME         TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE | ||||
| kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   17d | ||||
| ``` | ||||
| 
 | ||||
| この例では、デフォルトのServiceはClusterIPとして10.96.0.1を使用しており、対応するIPAddressオブジェクトがあります。 | ||||
| 
 | ||||
| ```sh | ||||
| kubectl get ipaddress 10.96.0.1 | ||||
| ``` | ||||
| 
 | ||||
| ``` | ||||
| NAME        PARENTREF | ||||
| 10.96.0.1   services/default/kubernetes | ||||
| ``` | ||||
| 
 | ||||
| ServiceCIDRは{{<glossary_tooltip text="ファイナライザー" term_id="finalizer">}}によって保護されており、ServiceのClusterIPが孤立することを防ぎます。ファイナライザーが削除されるのは、既存の全IPAddressを含む別のサブネットがある場合またはサブネットに属するIPAddressがない場合のみです。 | ||||
| 
 | ||||
| ## Serviceに使用できるIPアドレスの個数を拡張する | ||||
| 
 | ||||
| ユーザーはServiceに使用できるアドレスの個数を増やしたい場合がありますが、従来はServiceの範囲を拡張することは破壊的な操作であり、データ損失につながる可能性もありました。この新しい機能を使用することで、ユーザーは新しいServiceCIDRを追加するだけで使用可能なアドレスを増やすことができます。 | ||||
| 
 | ||||
| ### 新しいServiceCIDRを追加する | ||||
| 
 | ||||
| Service用として10.96.0.0/28の範囲が設定されたクラスターでは、2^(32-28) - 2 = 14個のIPアドレスしか使用できません。`kubernetes.default`Serviceは常に作成されるため、この例では最大13個しかServiceを作れません。 | ||||
| 
 | ||||
| ```sh | ||||
| for i in $(seq 1 13); do kubectl create service clusterip "test-$i" --tcp 80 -o json | jq -r .spec.clusterIP; done | ||||
| ``` | ||||
| 
 | ||||
| ``` | ||||
| 10.96.0.11 | ||||
| 10.96.0.5 | ||||
| 10.96.0.12 | ||||
| 10.96.0.13 | ||||
| 10.96.0.14 | ||||
| 10.96.0.2 | ||||
| 10.96.0.3 | ||||
| 10.96.0.4 | ||||
| 10.96.0.6 | ||||
| 10.96.0.7 | ||||
| 10.96.0.8 | ||||
| 10.96.0.9 | ||||
| error: failed to create ClusterIP service: Internal error occurred: failed to allocate a serviceIP: range is full | ||||
| ``` | ||||
| 
 | ||||
| IPアドレス範囲を拡張または追加する新しいServiceCIDRを作成することで、Serviceに使用できるIPアドレスの個数を増やせます。 | ||||
| 
 | ||||
| ```sh | ||||
| cat <EOF | kubectl apply -f - | ||||
| apiVersion: networking.k8s.io/v1beta1 | ||||
| kind: ServiceCIDR | ||||
| metadata: | ||||
|   name: newcidr1 | ||||
| spec: | ||||
|   cidrs: | ||||
|   - 10.96.0.0/24 | ||||
| EOF | ||||
| ``` | ||||
| 
 | ||||
| ``` | ||||
| servicecidr.networking.k8s.io/newcidr1 created | ||||
| ``` | ||||
| 
 | ||||
| これにより、新しいServiceを作成できるようになり、新しい範囲からClusterIPが割り当てられます。 | ||||
| 
 | ||||
| ```sh | ||||
| for i in $(seq 13 16); do kubectl create service clusterip "test-$i" --tcp 80 -o json | jq -r .spec.clusterIP; done | ||||
| ``` | ||||
| 
 | ||||
| ``` | ||||
| 10.96.0.48 | ||||
| 10.96.0.200 | ||||
| 10.96.0.121 | ||||
| 10.96.0.144 | ||||
| ``` | ||||
| 
 | ||||
| ### ServiceCIDRの削除 | ||||
| 
 | ||||
| あるServiceCIDRに依存しているIPAddressが存在する場合、そのServiceCIDRは削除できません。 | ||||
| 
 | ||||
| ```sh | ||||
| kubectl delete servicecidr newcidr1 | ||||
| ``` | ||||
| 
 | ||||
| ``` | ||||
| servicecidr.networking.k8s.io "newcidr1" deleted | ||||
| ``` | ||||
| 
 | ||||
| KubernetesはServiceCIDRのファイナライザーを使ってこの依存関係を追跡します。 | ||||
| 
 | ||||
| ```sh | ||||
| kubectl get servicecidr newcidr1 -o yaml | ||||
| ``` | ||||
| 
 | ||||
| ```yaml | ||||
| apiVersion: networking.k8s.io/v1beta1 | ||||
| kind: ServiceCIDR | ||||
| metadata: | ||||
|   creationTimestamp: "2023-10-12T15:11:07Z" | ||||
|   deletionGracePeriodSeconds: 0 | ||||
|   deletionTimestamp: "2023-10-12T15:12:45Z" | ||||
|   finalizers: | ||||
|   - networking.k8s.io/service-cidr-finalizer | ||||
|   name: newcidr1 | ||||
|   resourceVersion: "1133" | ||||
|   uid: 5ffd8afe-c78f-4e60-ae76-cec448a8af40 | ||||
| spec: | ||||
|   cidrs: | ||||
|   - 10.96.0.0/24 | ||||
| status: | ||||
|   conditions: | ||||
|   - lastTransitionTime: "2023-10-12T15:12:45Z" | ||||
|     message: There are still IPAddresses referencing the ServiceCIDR, please remove | ||||
|       them or create a new ServiceCIDR | ||||
|     reason: OrphanIPAddress | ||||
|     status: "False" | ||||
|     type: Ready | ||||
| ``` | ||||
| 
 | ||||
| ServiceCIDRの削除を止めているIPAddressを含むServiceを削除すると | ||||
| 
 | ||||
| ```sh | ||||
| for i in $(seq 13 16); do kubectl delete service "test-$i" ; done | ||||
| ``` | ||||
| 
 | ||||
| ``` | ||||
| service "test-13" deleted | ||||
| service "test-14" deleted | ||||
| service "test-15" deleted | ||||
| service "test-16" deleted | ||||
| ``` | ||||
| 
 | ||||
| コントロールプレーンがそれを検知します。そしてコントロールプレーンはファイナライザを削除し、削除が保留されているServiceCIDRが実際に削除されるようにします。 | ||||
| 
 | ||||
| ```sh | ||||
| kubectl get servicecidr newcidr1 | ||||
| ``` | ||||
| 
 | ||||
| ``` | ||||
| Error from server (NotFound): servicecidrs.networking.k8s.io "newcidr1" not found | ||||
| ``` | ||||
		Loading…
	
		Reference in New Issue