Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
FastAPIでKubernetesを扱うときに役立つTips
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Hiroki Okui
December 07, 2022
Technology
1.9k
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
FastAPIでKubernetesを扱うときに役立つTips
Hiroki Okui
December 07, 2022
More Decks by Hiroki Okui
See All by Hiroki Okui
CUEとKubernetesカスタムオペレータを用いた新しいネットワークコントローラをつくってみた
hrk091
1
750
New Network Provisioning System Leveraging Kubernetes and Cloud Native Open Source
hrk091
2
220
マニフェストレスで使える IaC・CI/CD のSaaSプロダクト化への挑戦
hrk091
2
940
クラウドネイティブな新しいネットワークコントローラをつくる
hrk091
6
2.2k
内製DevOps基盤を大きく作り直してみた
hrk091
7
3.2k
React HooksとGraphQLで社内レガシーサービスを巻き取ってみたらものすごくはかどった話
hrk091
12
4.9k
ODTN and TIP collaboration with Whitebox Transponder 'Cassini'
hrk091
0
500
Expectation and Activities for Open and Disaggregated Transport Network Project
hrk091
0
110
Model-Driven SDN Experiences and Learnings with NSO
hrk091
0
220
Other Decks in Technology
See All in Technology
AWS Security Hub CSPMの成功・失敗体験
cmusudakeisuke
0
180
AWS Security Agent といっしょに脅威モデリングをやってみよう
amarelo_n24
0
160
2026TECHFRESH畢業分享會 - Lightning Talk - 打造精準高效的 MCP 設計模式與測試實務
line_developers_tw
PRO
0
1.2k
手塩にかけりゃいいってもんじゃない
ming_ayami
0
600
小さく始める AI 活用推進 ― 日経電子版 Web チームの事例/nikkei-tech-talk47
nikkei_engineer_recruiting
0
300
入門!AWS Blocks
ysuzuki
1
150
失敗を資産に変えるClaude Code
shinyasaita
0
710
【セミナー資料】Claude Code をセキュアに使うための考え方と設定の勘どころ / Claude Code Webinar 20260616
masahirokawahara
2
410
マルチアカウント環境での コーディングエージェントを使った障害調査が大変なので AIエージェントにReadOnly権限を付与してみた / ReadOnly AI Agents for Multi-Account AWS Incident Response
yamaguchitk333
2
110
脆弱性対応、どこで線を引くか
rymiyamoto
1
410
Chainlitで作るお手軽チャットUI
ynt0485
0
270
AIAU_UMEMOGU_ninomiya_slide
ninomiya_ii
0
220
Featured
See All Featured
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.3k
Visualization
eitanlees
152
17k
Statistics for Hackers
jakevdp
799
230k
How STYLIGHT went responsive
nonsquared
100
6.2k
The Pragmatic Product Professional
lauravandoore
37
7.3k
Leo the Paperboy
mayatellez
7
1.8k
A Soul's Torment
seathinner
6
2.9k
Site-Speed That Sticks
csswizardry
13
1.2k
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
200
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.5k
Why Our Code Smells
bkeepers
PRO
340
58k
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1.1k
Transcript
#ochacafe FastAPIでKubernetesを 扱うときに役立つTips 2022/12/7 NTTコミュニケーションズ 奥井 OCHaCafe
Season6 #4
#ochacafe 自己紹介 NTTコミュニケーションズ Software Engineer 奥井 寛樹 略歴 • 伝送システムのSDNコントローラ開発
• DevOpsプラットフォーム開発 • IoTデータ収集基盤のモダナイゼーション @HirokiOkui 2
#ochacafe はじめに • FastAPIは、型安全性やOASの自動生成機能を備えた ASGIフレームワークで、さっとAPIを作るときに便利です • Kubernetes API Serverをwrapしてドメインロジックを 追加することで、簡易なXaaSがつくれます
• FastAPIからKubernetes API Serverを叩くときのTipsを4つご紹介します 3 Frontend API Kubernetes API Server TektonベースのCI/CDaaSを FastAPIを用いて作りました 構成イメージ
#ochacafe 1. k8s CRD => API => UI まで一気通貫で型を自動生成 •
FastAPIは、Pydantic型を用いることで「型指向開発」「 OASの自動生成」 「型のランタイム検査」などが可能になる • datamodel-codegenを用いると、OASやJSON SchemaからPydantic型を 自動生成できる => KubernetesのCRDから、Pydantic型を生成できる • Pydantic型を用いてAPIを定義するとFastAPIのOASを生成できるため、 openapi-generator-cli などを用いて、UIまで型を生成・流通できる Frontend API Kubernetes API Server k8s Custom Operator openapi-generator api client Pydantic CRD JSONSchema Go Struct datamodel-codegen generate OAS 4 CIで全自動化 できます
#ochacafe 2. kubernetes-clientを型対応する • Kubernetes API Machinery SIGから提供される公式のPython Client*1は、 typingをサポートしているが、型周りの体験が非常に悪い
• API callのresponseに型がない ◦ 汎用のUnion型になる ➞ 都度 型ヒントが必要 • dot notationで深い要素まで アクセス可能だが、 型がAnyになってしまう 5 *1: https://github.com/kubernetes-client/python from kubernetes import client from kubernetes.client import V1Namespace v1 = client.CoreV1Api() res = v1.read_namespace('test') # 汎用のUnion型 res: V1Namespace # 型ヒントを書いても ... res.spec # 子要素はAnyになる OpenAPIGeneratorで生成されており、 かつ古いversionのため(v4.3.0) (最新化を検討中:#1943) 実質、構造体の全てのレイヤで 型ヒントが必要に
#ochacafe 2. kubernetes-clientを型対応する 6 • そもそもFastAPIを使っているので、Pydantic型で扱いたい ◦ Pydantic型にすると、ランタイムチェックが効くし、 OASにも反映される •
kubernetes-clientをwrapして、Pydanticに対応する ◦ この機能を提供している OSSは(多分)ないので、自作が必要 ◦ Sample: https://github.com/hrk091/kubernetes-pydantic • Tips1の型自動生成を 実現するには、 上記の対応が必要 手間ですが、 FastAPIでk8sを制御 するならやるべき 要望いただければ メンテします 型ヒントなしで型が 決定しており、ネスト先の 型も推論できている
#ochacafe 3. kubernetes-clientをasync対応する • 公式のKubernetes Python Clientは、asyncに対応しているが、デフォルトは同期実行 • FastAPIのASGIを活かしてPerformance改善するために、asyncモードで動かすと良い ◦
k8s API Serverはリクエスト次第でレスポンスが良くないので、 blockingは回避すべし 7 都度async処理を書くと ドメイン層が汚れるので client内に隠蔽するとよい
#ochacafe 4: FastAPIのPerformanceに注意 • FastAPIは型のランタイム検査もしてくれるため便利だが、 大きなk8s Resourceを扱うと、CPU・メモリの消費がすごい ◦ さらに、uvicornのメモリリークもあり、メモリが開放されない •
型のランタイム検査をトグルする良い方法は現状ない (#5498) ◦ 検査対象外にしたい場所で、 Pydantic型の使用をやめるしかない • 性能が問題になる場合は、レスポンスのフィールドを 減らす工夫が必要 ◦ last-applied-configuration、managedFields等は削る ◦ 本当に必要なフィールドに限定する 8 uvicorn v0.18.3で メモリリークが 直ったそうです #1624 *1: https://github.com/tiangolo/fastapi/issues/1624 OOM kill
#ochacafe まとめ Tips1: k8s CRD => API => UIまで一気通貫で型を自動生成 Tips2:
kubernetes-clientを型対応する Tips3: kubernetes-clientをasync対応する Tips4: FastAPIのPerformanceに注意 9