|
| 1 | +--- |
| 2 | +layout: blog |
| 3 | +title: "Gateway API v1.1: サービスメッシュ、GRPCRoute、そして更なる進化" |
| 4 | +date: 2024-05-09T09:00:00-08:00 |
| 5 | +slug: gateway-api-v1-1 |
| 6 | +author: > |
| 7 | + [Richard Belleville](https://github.com/gnossen) (Google), |
| 8 | + [Frank Budinsky](https://github.com/frankbu) (IBM), |
| 9 | + [Arko Dasgupta](https://github.com/arkodg) (Tetrate), |
| 10 | + [Flynn](https://github.com/kflynn) (Buoyant), |
| 11 | + [Candace Holman](https://github.com/candita) (Red Hat), |
| 12 | + [John Howard](https://github.com/howardjohn) (Solo.io), |
| 13 | + [Christine Kim](https://github.com/xtineskim) (Isovalent), |
| 14 | + [Mattia Lavacca](https://github.com/mlavacca) (Kong), |
| 15 | + [Keith Mattix](https://github.com/keithmattix) (Microsoft), |
| 16 | + [Mike Morris](https://github.com/mikemorris) (Microsoft), |
| 17 | + [Rob Scott](https://github.com/robscott) (Google), |
| 18 | + [Grant Spence](https://github.com/gcs278) (Red Hat), |
| 19 | + [Shane Utt](https://github.com/shaneutt) (Kong), |
| 20 | + [Gina Yeh](https://github.com/ginayeh) (Google), |
| 21 | + and other review and release note contributors |
| 22 | +translator: > |
| 23 | + [Taisuke Okamoto](https://github.com/b1gb4by) ([IDC Frontier Inc.](https://www.idcf.jp/)), |
| 24 | + [Daiki Hayakawa(bells17)](https://github.com/bells17) ([3-shake Inc.](https://3-shake.com/en/)), |
| 25 | + [Junya Okabe](https://github.com/Okabe-Junya) (University of Tsukuba) |
| 26 | +--- |
| 27 | + |
| 28 | + |
| 29 | + |
| 30 | +昨年10月のGateway APIの正式リリース後、Kubernetes SIG Networkは[Gateway API](https://gateway-api.sigs.k8s.io/)のv1.1リリースを発表しました。 |
| 31 | +このリリースでは、いくつかの機能が _標準機能_ (GA)に昇格しています。 |
| 32 | +特にサービスメッシュとGRPCRouteのサポートが含まれます。 |
| 33 | +また、セッション維持とクライアント証明書の検証を含む新しい実験的機能も導入しています。 |
| 34 | + |
| 35 | +## 新機能 |
| 36 | + |
| 37 | +### GAへの昇格 |
| 38 | + |
| 39 | +このリリースでは、4つの待望の機能が標準機能に昇格しました。 |
| 40 | +これにより、これらの機能は実験的な段階を卒業したことになります。 |
| 41 | +GAへの昇格が行われたということは、APIの設計に対する高い信頼性を示すとともに、後方互換性を保証するものです。 |
| 42 | +他のKubernetes APIと同様に、GAへ昇格した機能も時間とともに後方互換性を保ちながら進化していきます。 |
| 43 | +今後もこれらの新機能のさらなる改良と改善が行われることを期待しています。 |
| 44 | +これらの仕組みについて詳しくは、Gateway APIの[バージョニングポリシー](https://gateway-api.sigs.k8s.io/concepts/versioning/)をご覧ください。 |
| 45 | + |
| 46 | +#### [サービスメッシュのサポート](https://gateway-api.sigs.k8s.io/mesh/) |
| 47 | + |
| 48 | +Gateway APIのサービスメッシュサポートにより、サービスメッシュユーザーは同じAPIを使用してIngressトラフィックとメッシュトラフィックを管理することが可能になります。 |
| 49 | +これにより同じポリシーとルーティングインターフェースを再利用することができます。 |
| 50 | +また、Gateway API v1.1では、HTTPRouteなどのルートがServiceを`parentRef`として持つことができるようになり、特定のサービスへのトラフィックの動作を制御できます。 |
| 51 | +詳細については、[Gateway APIのサービスメッシュドキュメント](https://gateway-api.sigs.k8s.io/mesh/)をお読みいただくか、[Gateway APIの実装リスト](https://gateway-api.sigs.k8s.io/implementations/#service-mesh-implementation-status)をご覧ください。 |
| 52 | + |
| 53 | +例えば、アプリケーションのコールグラフの深部にあるワークロードに対して、HTTPRouteを使用してカナリアデプロイメントを行うことができます。 |
| 54 | +以下はその例です: |
| 55 | + |
| 56 | +```yaml |
| 57 | +apiVersion: gateway.networking.k8s.io/v1 |
| 58 | +kind: HTTPRoute |
| 59 | +metadata: |
| 60 | + name: color-canary |
| 61 | + namespace: faces |
| 62 | +spec: |
| 63 | + parentRefs: |
| 64 | + - name: color |
| 65 | + kind: Service |
| 66 | + group: "" |
| 67 | + port: 80 |
| 68 | + rules: |
| 69 | + - backendRefs: |
| 70 | + - name: color |
| 71 | + port: 80 |
| 72 | + weight: 50 |
| 73 | + - name: color2 |
| 74 | + port: 80 |
| 75 | + weight: 50 |
| 76 | +``` |
| 77 | +
|
| 78 | +これにより、名前空間`faces`内の`color`サービスに送信されるトラフィックが、元の`color`サービスと`color2`サービスの間で50対50に分割されます。 |
| 79 | +この設定は移植性が高く、あるメッシュから別のメッシュへ簡単に移行できます。 |
| 80 | + |
| 81 | +#### [GRPCRoute](https://gateway-api.sigs.k8s.io/guides/grpc-routing/) |
| 82 | + |
| 83 | +すでにGRPCRouteの実験的機能バージョンを使用している場合、使用しているコントローラーがGRPCRoute v1をサポートするようアップデートされるまで、標準バージョンのGRPCRouteへのアップグレードは控えることをお勧めします。 |
| 84 | +それまでは、`v1alpha2`と`v1`の両方のAPIバージョンを含むv1.1の実験的チャンネルバージョンのGRPCRouteにアップグレードしても問題ありません。 |
| 85 | + |
| 86 | +#### [ParentReference Port](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io%2fv1.ParentReference) |
| 87 | + |
| 88 | +ParentReferenceにportフィールドが追加されました。 |
| 89 | +これにより、リソースをGatewayのリスナー、Service、あるいは他の親リソース(実装によって異なります)に関連付けることができるようになりました。 |
| 90 | +ポートにバインドすることで、複数のリスナーに一度に関連付けることも可能です。 |
| 91 | + |
| 92 | +例えば、HTTPRouteをGatewayの特定のリスナーに関連付ける際、リスナー名ではなくリスナーのポートを指定できるようになりました。 |
| 93 | +これにより、一つまたは複数の特定のリスナーに関連付けることができます。 |
| 94 | + |
| 95 | +詳細については、[Gatewayへの関連付け](https://gateway-api.sigs.k8s.io/api-types/httproute/#attaching-to-gateways)を参照してください。 |
| 96 | + |
| 97 | +#### [適合性プロファイルとレポート](https://gateway-api.sigs.k8s.io/concepts/conformance/#conformance-profiles) |
| 98 | + |
| 99 | +適合性レポートのAPIが拡張され、実装の動作モードを指定する`mode`フィールドと、Gateway APIのチャネル(標準版または実験的機能版)をしめす`gatewayAPIChannel`が追加されました。 |
| 100 | +`gatewayAPIVersion`と`gatewayAPIChannel`は、テスト結果の簡単な説明とともに、テストスイートの仕組みによって自動的に入力されるようになりました。 |
| 101 | +レポートの構成がより体系的に整理され、実装者はテストの実行方法に関する情報を追加し、再現手順を提供できるようになりました。 |
| 102 | + |
| 103 | +### 実験的機能版チャンネルへの新機能追加 |
| 104 | + |
| 105 | +#### [Gatewayのクライアント証明書の検証](https://gateway-api.sigs.k8s.io/geps/gep-91/) |
| 106 | + |
| 107 | +Gatewayの各リスナーでクライアント証明書の検証が設定できるようになりました。 |
| 108 | +これは、`tls`内に新しく追加された`frontendValidation`フィールドによって実現されています。 |
| 109 | +このフィールドでは、クライアントが提示する証明書を検証するための信頼アンカーとして使用できるCA証明書のリストを設定できます。 |
| 110 | + |
| 111 | +以下の例は、ConfigMapの`foo-example-com-ca-cert`に保存されているCA証明書を使用して、Gatewayリスナーの`foo-https`に接続するクライアントの証明書を検証する方法を示しています。 |
| 112 | + |
| 113 | +```yaml |
| 114 | +apiVersion: gateway.networking.k8s.io/v1 |
| 115 | +kind: Gateway |
| 116 | +metadata: |
| 117 | + name: client-validation-basic |
| 118 | +spec: |
| 119 | + gatewayClassName: acme-lb |
| 120 | + listeners: |
| 121 | + name: foo-https |
| 122 | + protocol: HTTPS |
| 123 | + port: 443 |
| 124 | + hostname: foo.example.com |
| 125 | + tls: |
| 126 | + certificateRefs: |
| 127 | + kind: Secret |
| 128 | + group: "" |
| 129 | + name: foo-example-com-cert |
| 130 | + frontendValidation: |
| 131 | + caCertificateRefs: |
| 132 | + kind: ConfigMap |
| 133 | + group: "" |
| 134 | + name: foo-example-com-ca-cert |
| 135 | +``` |
| 136 | + |
| 137 | +#### [セッション維持とBackendLBPolicy](https://gateway-api.sigs.k8s.io/geps/gep-1619/) |
| 138 | + |
| 139 | +Gateway APIに[セッション維持機能](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io%2fv1.SessionPersistence)が導入されました。 |
| 140 | +これは新しいポリシー([BackendLBPolicy](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io/v1alpha2.BackendLBPolicy))によってサービスレベルで設定でき、さらにHTTPRouteとGRPCRoute内のフィールドを使用してルートレベルでも設定可能です。 |
| 141 | +BackendLBPolicyとルートレベルのAPIは、セッションのタイムアウト、セッション名、セッションタイプ、クッキーの有効期間タイプなど、同じセッション維持の設定を提供します。 |
| 142 | + |
| 143 | +以下は、`foo`サービスにクッキーベースのセッション維持を有効にする`BackendLBPolicy`の設定例です。 |
| 144 | +セッション名を`foo-session`に設定し、絶対タイムアウトとアイドルタイムアウトを定義し、クッキーをセッションクッキーとして設定しています: |
| 145 | + |
| 146 | +```yaml |
| 147 | +apiVersion: gateway.networking.k8s.io/v1alpha2 |
| 148 | +kind: BackendLBPolicy |
| 149 | +metadata: |
| 150 | + name: lb-policy |
| 151 | + namespace: foo-ns |
| 152 | +spec: |
| 153 | + targetRefs: |
| 154 | + - group: core |
| 155 | + kind: service |
| 156 | + name: foo |
| 157 | + sessionPersistence: |
| 158 | + sessionName: foo-session |
| 159 | + absoluteTimeout: 1h |
| 160 | + idleTimeout: 30m |
| 161 | + type: Cookie |
| 162 | + cookieConfig: |
| 163 | + lifetimeType: Session |
| 164 | +``` |
| 165 | + |
| 166 | +### その他の変更点 |
| 167 | + |
| 168 | +#### [TLS関連用語の明確化](https://gateway-api.sigs.k8s.io/geps/gep-2907/) |
| 169 | + |
| 170 | +API全体でTLS関連の用語を統一する取り組みの一環として、BackendTLSPolicyに互換性のない変更を加えました。 |
| 171 | +これにより、新しいAPIバージョン(v1alpha3)が導入されました。 |
| 172 | +既存のv1alpha2を使用している場合は、データのバックアップや古いバージョンのアンインストールなど、適切な対応が必要です。 |
| 173 | + |
| 174 | +v1alpha2のBackendTLSPolicyフィールドへの参照は、v1alpha3に更新する必要があります。 |
| 175 | +主な変更点は以下の通りです: |
| 176 | + |
| 177 | +- `targetRef`が`targetRefs`に変更(複数のターゲットへの適用が可能に) |
| 178 | +- `tls`が`validation`に変更 |
| 179 | +- `tls.caCertRefs`が`validation.caCertificateRefs`に変更 |
| 180 | +- `tls.wellKnownCACerts`が`validation.wellKnownCACertificates`に変更 |
| 181 | + |
| 182 | +このリリースに含まれるすべての変更点については、[v1.1.0リリースノート](https://github.com/kubernetes-sigs/gateway-api/releases/tag/v1.1.0)をご覧ください。 |
| 183 | + |
| 184 | +## Gateway APIの背景 |
| 185 | + |
| 186 | +Gateway APIのアイデアは、2019年のKubeCon San Diegoで次世代のIngress APIとして[最初に提案](https://youtu.be/Ne9UJL6irXY?si=wgtC9w8PMB5ZHil2)されました。 |
| 187 | +それ以来、すばらしいコミュニティが形成され、おそらく[Kubernetes史上最も協力的なAPI](https://www.youtube.com/watch?v=V3Vu_FWb4l4)を開発してきました。 |
| 188 | +これまでに200人以上がこのAPIに貢献しており、その数は今も増え続けています。 |
| 189 | + |
| 190 | +メンテナーは、リポジトリへのコミット、議論、アイデア、あるいは一般的なサポートなど、あらゆる形でGateway APIに貢献してくださった _全ての方々_ に感謝の意を表します。 |
| 191 | +このように献身的で活発なコミュニティのサポートなしでは、ここまで到達することはできませんでした。 |
| 192 | + |
| 193 | +## 実際に使ってみましょう |
| 194 | + |
| 195 | +Gateway APIの特徴として、最新版を使用するためにKubernetesそのものを最新にする必要がありません。 |
| 196 | +Kubernetes 1.26以降であれば、このバージョンのGateway APIをすぐに利用開始できます。 |
| 197 | + |
| 198 | +APIを試すには、[スタートガイド](https://gateway-api.sigs.k8s.io/guides/)をご覧ください。 |
| 199 | + |
| 200 | +## 開発に参加しませんか |
| 201 | + |
| 202 | +Ingressやサービスメッシュ向けのKubernetesルーティングAPIの未来を形作るチャンスがたくさんあります。 |
| 203 | + |
| 204 | +- [ユーザーガイド](https://gateway-api.sigs.k8s.io/guides)で、対応可能なユースケースをチェックしてみてください。 |
| 205 | +- [既存のGatewayコントローラー](https://gateway-api.sigs.k8s.io/implementations/)を実際に試してみるのもおすすめです。 |
| 206 | +- さらに、[コミュニティへの参加](https://gateway-api.sigs.k8s.io/contributing/)もお待ちしています。一緒にGateway APIの未来を築いていきましょう! |
| 207 | + |
| 208 | +## 関連するKubernetesブログ記事 |
| 209 | + |
| 210 | +- [New Experimental Features in Gateway API v1.0](/blog/2023/11/28/gateway-api-ga/) |
| 211 | + 11/2023 |
| 212 | +- [Gateway API v1.0: GA Release](/blog/2023/10/31/gateway-api-ga/) |
| 213 | + 10/2023 |
| 214 | +- [Introducing ingress2gateway; Simplifying Upgrades to Gateway API](/blog/2023/10/25/introducing-ingress2gateway/) |
| 215 | + 10/2023 |
| 216 | +- [Gateway API v0.8.0: Introducing Service Mesh Support](/blog/2023/08/29/gateway-api-v0-8/) |
| 217 | + 08/2023 |
0 commit comments