Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Speaker Deck
PRO
Sign in
Sign up
for free
Containers at Edge and the future
Kohei Ota
August 20, 2020
Technology
2
160
Containers at Edge and the future
Kohei Ota
August 20, 2020
Tweet
Share
More Decks by Kohei Ota
See All by Kohei Ota
inductor
0
62
inductor
1
610
inductor
0
190
inductor
1
88
inductor
0
160
inductor
5
1.5k
inductor
5
680
inductor
8
860
inductor
3
1.2k
Other Decks in Technology
See All in Technology
smzksts
0
220
cmwatanabeseigo
0
330
caori_t
0
160
hirosys
0
120
shotakashihara
1
1.3k
shimacos
2
320
oracle4engineer
1
210
ocise
0
130
nihonbuson
2
1.6k
yuyaabo
0
250
comucal
PRO
0
410
ymas0315
0
150
Featured
See All Featured
tanoku
86
8.5k
holman
448
130k
chriscoyier
780
240k
dotmariusz
94
5.1k
thoeni
4
550
3n
163
22k
addyosmani
494
110k
marcelosomers
220
15k
jakevdp
774
200k
ufuk
56
5.4k
rasmusluckow
318
18k
smashingmag
229
18k
Transcript
Containers at Edge and the future TechFeed Summit #3 Presented
by @inductor
自己紹介 名前: Kohei Ota (@inductor) 所属: HPE 職種: Solutions Architect
その他: CNCF Ambassador Docker Meetup Tokyo, CloudNative Days Tokyo 運営
今日お話すること • エッジコンピューティングとIoT(前回のテーマ) • エッジにおけるデリバリーの課題とその解決策 • Kubernetesにおけるエッジコンピューティングの取り組み • KubernetesとWASM
エッジコンピューティングとIoT 01 エッジコンピューティングは、エンドユーザーの近くに計算リソースを分散させることで 中央サーバーとの遅延を解消する技術 02 IoTの文脈ではセンサーを搭載したラズパイなどが代表例として挙げられ、計測デー タをその場で処理して返却するためレスポンスが速くなり中央サーバーの負荷が下 がるなどのメリットがある 03 一方で、計算リソースを分散させるためネットワーク制約の大きい場所にアップデート
を配信する際の考慮が必要
エッジコンピューティングとIoT 01 エッジコンピューティングは、エンドユーザーの近くに計算リソースを分散させることで 中央サーバーとの遅延を解消する技術 02 IoTの文脈ではセンサーを搭載したラズパイなどが代表例として挙げられ、計測デー タをその場で処理して返却するためレスポンスが速くなり中央サーバーの負荷が下 がるなどのメリットがある 03 一方で、計算リソースを分散させるためネットワーク制約の大きい場所にアップデート
を配信する際の考慮などが必要 電車みたいな常に動いているデバイスにどうやって 最新のアプリケーションを配信するか?という課題
エッジにおけるデリバリーの課題とその解決策 軽量で、別環境でも動作保証できるパッケージング技術があ れば自動化がかんたんになるのでは? → コンテナやWASM等の技術が利用できるという期待
Case Study: Walmart • 世界最大のスーパーマーケット • レジの決済システムを各店舗でどうやってモダナイズ、展開していく かという課題にぶちあたった • 結論としては、Kubernetesでシステムを管理しつつ、エッジにクラス
ターを展開する方法を採用
Case Study: Walmart
Case Study: Walmart 店舗ごとに小さなサーバーを配置しそこに Kubernetesクラスターを展開 GitOpsによるクラスター構成の配信 店舗のレジはストア内クラスターと通信することで決済システムが動作
Case Study: Walmart
Case Study: Walmart サービスメッシュによるResiliency(対障害性)の確保 → 店舗と通信して失敗したらクラウドに通信 IstioとEnvoyを用いたトラフィックのルーティング
Case Studyからの学び • コンテナによるパッケージング + Kubernetes with GitOpsで 多数のクラスター構成管理が可能に →
Kubernetesのエコシステムで完結できる強みを活かす 他のIoTにおける利用でも参考にできそう
その他のKubernetesにおけるEdgeの取り組み • Rancher社のk3s ◦ 軽量(しょぼいスペックでも動く) ◦ オールインワンパッケージ • KubeEdge ◦
Kubernetesベース ◦ k3sのような魔改造はしてない • デンソーさんのMisaki(ロゴが見つからず) ◦ 車に組み込むやつ
KubernetesとWASM 1. WASMのおさらい 01 WASM(Web Assembly)はモダンブラウザでNative Codeを動かそうとするための試み CやRustなどで記述したコードをWASM用にコンパイルするとブラウザで爆速に動く ! みたいなやつ(例:
vimをブラウザ上で動かした人もいる ) 02 WASMを動かすにはランタイムが必要だが、ランタイムの仕様はオープンに公開されてい て誰でも作ることができる。 V8のようにブラウザ向けのものもあるが、 Non-webというブラウ ザ以外で動かせるランタイムも複数存在する (例: WASI) 03 コンセプトが「Run anywhere」な上、実体がコンパイル済みのアプリケーションバイナリな ので、コンテナのように軽量でどこでも動作できる特徴を持つ
KubernetesとWASM 2. Krustletについて 01 Deis Labsというプロジェクトにて開発中の OSS KubeletをRustで再実装したもの 一番の特徴はWASMをサポートしていること(Dockerの代わりにWASIなどが使える) 02
WASMモジュールをOCI形式に変換してコンテナレジストリに置くための仕様も作っていて、 Kubernetesの既存のエコシステムがあれば WASMのアプリケーションが動かせる変態的 な仕組み 03 HelmやCNABなどを牽引するチームで、マイクロソフトが主体となって開発を進めて いる
KubernetesとWASM 3. Krustletのアーキテクチャ ホストマシン Docker Containerd CRI-O Kubelet Pod (OCIコンテナ)
CRI OCI ホストマシン Krustlet (WASI or waSCC provider) Pod (WASM) コンテナレジストリ Pull OCI Image apiVersion : v1 kind: Pod metadata: name: krustlet-tutorial spec: containers : - name: krustlet-tutorial image: mycontainerregistry007.azurecr.io/krustlet-tutorial:v1.0.0 tolerations : - key: "krustlet/arch" operator: "Equal" value: "wasm32-wasi" effect: "NoExecute"
まとめ • Kubernetesでアプリケーションを動かすための選択肢は 必ずしもコンテナ、だけではなくなってきている • エッジにおける計算リソースの確保にはさまざまな方法がある • WASMはコンテナと対応する形のパッケージング技術として 見ても、とても面白い
謝辞 今回WASMに関して調査するにあたり、同じTech Feed Proのエ キスパートである@chikoskiさんに、WASMの技術的背景や基本 的な仕組みについて教えていただきました。 この場を借りて感謝申し上げます!
ありがとうございました