Upgrade to Pro — share decks privately, control downloads, hide ads and more …

最近の Azure App Service について

最近の Azure App Service について

Avatar for Tatsuro Shibamura

Tatsuro Shibamura

September 29, 2018
Tweet

More Decks by Tatsuro Shibamura

Other Decks in Technology

Transcript

  1. はじめに • shibayan (Tatsuro Shibamura) • Azure MVP (2018/7-) •

    無職 (2018/8-) • 好きな Azure のサービス – App Service • https://blog.shibayan.jp/
  2. 今日話すこと • App Service をざっくり振り返りつつ整理 • Ignite 2018 で発表されたことを少し •

    2018 年らしい App Service の使い方 • デプロイ周りを抑えておけば大体良い(個人の感想)
  3. App Service について • 地味に複雑なんですよ • Web Apps • Windows

    / Linux • Web App for Containers (Docker) • Windows / Linux • Mobile Apps • API Apps この二つは開発止まってそうな気配ある
  4. App Service を使ったサービス • Azure Functions • もはや説明は要りませんね • QnA

    Maker • アプリ側の実装に Web App が使われている • Mobile Apps • API Apps この二つは開発(ry
  5. App Service Plan について • これも地味に複雑なんですよ • Free (F1) /

    Shared (D1) / Consumption (Y1) • Basic (B1-B3) • Standard (S1-S3) • Premium (P1-P3) • Premium v2 (P1v2-P3v2) / Isolated (I1-I3) • Premium Container (PC2-PC4) 高くて遅い、選ぶ理由も存在価値もなし Dv2 ベースなので速い Dv3 ベースなのでもっと速い
  6. 選べない Pricing Tier がある • Consumption • Azure Functions のみ

    • Premium • 古い Scale unit で動いている場合のみ • Premium v2 • 新しい Scale unit で動いている場合のみ • Premium Container • Web App for Containers (Windows) の場合のみ
  7. VM のスペックについて • Free / Basic / Standard / Premium

    • A シリーズ (昔は AMD Opteron HE、今は Intel Xeon) • Premium v2 / Isolated • Dv2 シリーズ • Premium Container • Dv3 シリーズ (Hyper Threading 有効)
  8. App Service の選び方 • シンプルな ASP.NET アプリを動かしたい • Web Apps

    (Windows) を使う • PHP や ASP.NET Core アプリをサクッと Linux で動かしたい • Web Apps (Linux) を使う • 既に Docker を使って開発してるので楽な実行環境が欲しい • Web App for Containers (Linux) を使う
  9. Web App for Containers (Windows) は? • 主に Lift and

    Shift 用だと思っている • 世の中にある ASP.NET アプリの 98% は Web Apps で動く • と思っている、感覚的に • 残りの 2% を PaaS に持っていくために使う • GAC にコンポーネントをインストールしないと動かないやつ • 実行環境をカスタマイズしないと動かないやつ
  10. Ignite 2018 での発表 • Linux Consumption Plan が Private Preview

    • 謎テクノロジー感 • Premium Functions が Private Preview • Consumption と App Service Plan の中間的な感じ • VNET Integration の改良 • ExpressRoute や Service Endpoints へのアクセスが可能に • Private IP でのアクセスも可能になるらしい
  11. 2018 年のトレンド • Run From Package を出来る限り使う • 難しい場合は Zip

    Deploy で我慢する • Linux の場合は Docker Image でデプロイする • ACR と組み合わせると便利 • Azure Functions を積極的に組み合わせる • WebJobs の時代はほぼ終わった
  12. デプロイが圧倒的進化 MS Deploy を使った場合 • 謎プロトコルで差分だけ • ロールバック不可能 • 失敗したら中途半端な状態に

    • 差分を見るので遅い • ファイルロックされてると死ぬ Run From Package を使った場合 • ファイル一式を zip で上げる • デプロイがアトミックに • 謎テクノロジーでマウント • 高速化、安定性向上 • 1 つの zip を上げるだけなので
  13. Run From Package • Zip Deploy と WEBSITE_RUN_FROM_PACKAGE のセット •

    WEBSITE_RUN_FROM_PACKAGE = 1 の時に挙動が変わる • 0 の時は Zip を wwwroot に展開する • 1 の時は Zip を wwwroot に直接マウントする • URL を指定すると再起動の時に自動で最新版を落としてくる
  14. Docker Image の作成 • Multi-stage build ちゃんと使ってますか? • ACR Tasks

    (元 ACR Build) も便利 • Automate OS / Framework patching は神機能だと思う • もし App Service でスケールが足りない場合も移行が容易 • AKS もあるし、ACI と Virtual Kubelet とかも使える • 他のクラウドベンダーにも移行できる
  15. WebJobs より Azure Functions • 理由は圧倒的に便利で安全だから • Azure Functions は

    WebJobs の上位互換と考えてよい • Long-running なタスクはそもそも適切かどうか検討する • もっと最適な処理単位があるのではないか • Durable Functions でいい感じに処理できないか、など • Application Insights でモニタリングが容易に • WebJobs はモニタリングが弱い
  16. Azure Functions v2 の GA • これも Ignite 2018 でリリース

    • v1 からの移行が推奨されている • HttpTrigger での比較で 70% スループットが改善 • .NET Standard 2.0 で書く必要があるので注意 • .NET Core 2.1 の Span<T> / Memory<T> は使えない • SocketsHttpHandler も怪しい • パフォーマンス上で不利になるかも
  17. まとめ • Windows は Web Apps を使う • Linux は

    Web App for Containers を使う • Zip Deploy / Run From Package を使う • Docker をちゃんと活用する • Azure Functions は最高、v2 に移行する