What is App Engine FE?
- App Engineのコンテナを、Dockerベースのものに差し替え、Compute Engineの上で動かす機能
- 旧 Managed VMs (Managed VMs誕生までの歴史を振り返る)
App Engine Architecture
data:image/s3,"s3://crabby-images/a0cf7/a0cf76035de466fdc5e247fa2177f0b88edd7562" alt="appengine.png"
App Engine Standard Environment
- 限定されたコンテナ
- runtime 縛り (Java, Python, Go, PHP)
- CPUはシングルコアのみ
- メモリの最大は1GB
App Engine Standard Environment
- ミドルウェア利用不可
- local file systemに書き込み不可
- 好きなportをlistenできない
App Engine Flexible Environment
- Compute Engine上にコンテナを立てる
- Dockerコンテナ
- 自由な世界
- App EngineのAPIをそのまま使える
- ミドルウェアインストール可能
App Engine FE Architecture
data:image/s3,"s3://crabby-images/1aea6/1aea6ca0553b0baa2aa469004afd2643f31822f0" alt="appengine_fe.png"
FEで用意済みのRuntime
- Go
- Java 8 / Servlet 3.1 / Jetty 9
- Python 2.7 and Python 3.4
- Node.js
- Ruby
Demo
Custom Runtime
- 好きなDockerfileを書いて動かす
App Engine FEの使いどころ
- WebSocket (ただし、めんどう。。。)
- マルチコアCPU, 豊富なメモリ
- ImageMagickなどミドルウェアが必要な時
- standard runtime以外が使いたい時
FEでClientからのリクエストを受け取る
WebSocketはなぜめんどうか?
- App Engine FrontendはWetSocketが使えない
- FEが動いているGCEのグローバルIPAddrに接続する必要がある
data:image/s3,"s3://crabby-images/5d7f0/5d7f075257122dccdd84141244a5943ae0c49fb5" alt="client_gce.png"
FEは好きなportをlistenできる?
- Yes
- しかし、やっぱり、App Engine Frontendは通れない
data:image/s3,"s3://crabby-images/5d7f0/5d7f075257122dccdd84141244a5943ae0c49fb5" alt="client_gce.png"
SEでできないことをFEに頼る
SEでできないことをFEに頼る
- ユーザからのリクエストはSEで受け、後ろのバッチはFEで回す
- Example : サムネイル作成 ...
data:image/s3,"s3://crabby-images/3b8c6/3b8c68939270be5374e7e655432e1f68a13aeb50" alt="Screen Shot 2016-07-28 at 21.44.56.png"
FEで失われた物
- spinup speed - SE:10ms ~ 7000ms, FE:1min
- price - SE:豊富な無料枠, FE:Compute Engineの料金に準拠
FEの不便なところ
- Preemptible VMが使えない
- 1VM 1コンテナ
- 最低インスタンス台数 = 1
Preemptible VMを使ったバッチ処理
- TaskはQueueで管理し、Preemptible Instanceがshutdonwされても、別のWokerでTaskをリトライする
- Taskの数に応じてWorkerの数を調整
data:image/s3,"s3://crabby-images/d672c/d672cb1fab3a17bf08fb65c41c6182122b532db5" alt="Screen Shot 2016-08-25 at 00.27.00.png"
Preemptible VMを使う利点
安い
僕が欲しかったFE
- 1 VM マルチコンテナ
- 負荷に応じて、コンテナをスケールさせる
data:image/s3,"s3://crabby-images/70b4f/70b4fc7e1b568b9fa8e41af0d15cdebb04f509c9" alt="Screen Shot 2016-07-28 at 21.48.40.png"