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

Azure Functionsで始めるサーバーレス アーキテクチャ

Avatar for TonyTonyKun TonyTonyKun
December 10, 2017

Azure Functionsで始めるサーバーレス アーキテクチャ

JAZUG 6周年総会のセッション資料です。

Avatar for TonyTonyKun

TonyTonyKun

December 10, 2017
Tweet

More Decks by TonyTonyKun

Other Decks in Technology

Transcript

  1. ⾃⼰紹介 名前 Twitter : @TonyTonyKun(トニー) 仕事 C# で業務アプリケーションを開発しています。 Azure を活⽤して

    ASP.NET で作っています。 Blog ROMANCE DAWN for the new world http://gooner.hateblo.jp/ Copyright© 2016, JAZUG All Rights Reserved. 2
  2. Serverless Architectures (Martin FowlerのBlog) Backend as a Service Single Page

    Application なアプリやモバイルアプリから利⽤するクラウド上の バックエンドサービス(ストレージや認証とか) Function as a Service ⾃分で書いたコードがイベント駆動で実⾏されるステートレスなサービス 発端は、AWS の Lambda がリリースされたこと その後、他のクラウドベンダーも相次いでリリースしたサーバーレス 環境は、後者の FaaS のこと Google の Cloud Functions IBM の OpenWhisk Microsoft の Azure Functions Copyright© 2016, JAZUG All Rights Reserved. 6 http://martinfowler.com/articles/serverless.html
  3. What is Serverless Computing? Exploring Azure Functions. ( Scott Hanselman

    のBlog ) サーバーレスとは、サーバーがないという意味ではない ⾃分でサーバーを管理する必要がないということ PaaS のように聞こえるかもしれないけど、それよりも⾼いレベル PaaS は Web アプリをデプロイして、常にサーバーを意識するけど、サー バーレスは、コードをアップロードし、イベント駆動で実⾏される Copyright© 2016, JAZUG All Rights Reserved. 7 http://www.hanselman.com/blog/WhatIsServerlessComputingExploringAzureFunctions.aspx https://blogs.msdn.microsoft.com/visualstudio_jpn/2016/09/01/whatisserverlesscomputingexploringazurefunctions/
  4. さまざまな Trigger と Binding をサポート① Copyright© 2016, JAZUG All Rights

    Reserved. 11 Type Service Trigger Input Output Schedule Azure Functions ✔ HTTP (REST or WebHook) Azure Functions ✔ ✔ Blob Storage Azure Storage ✔ ✔ ✔ Queues Azure Storage ✔ ✔ Queues Azure Service Bus Queue ✔ ✔ Topics Azure Service Bus Topic ✔ ✔ Tables Azure Storage ✔ ✔ Tables Azure Mobile Apps Easy Tables ✔ ✔ No-SQL DB Azure DocumentDB ✔ ✔ Streams Azure Event Hubs ✔ ✔ Push Notifications Azure Notification Hubs ✔
  5. さまざまな Trigger と Binding をサポート② Copyright© 2016, JAZUG All Rights

    Reserved. 12 Type Service Trigger Input Output SaaS File BOX ✔ ✔ Dropbox ✔ ✔ FTP ✔ ✔ Google Drive ✔ ✔ One Drive (for Business) ✔ ✔ SFTP ✔ ✔ SaaS Table DB2 ✔ ✔ Dynamics CRM Online ✔ ✔ Excel ✔ ✔ Google Sheets ✔ ✔ Informix ✔ ✔
  6. さまざまな Trigger と Binding をサポート③ Copyright© 2016, JAZUG All Rights

    Reserved. 13 Type Service Trigger Input Output SaaS Table Salesforce ✔ ✔ SharePoint ✔ ✔ SQL Server ✔ ✔ Mail SendGrid ✔ SMS Twilio ✔
  7. 複数の開発⾔語をサポート メイン C# Node / JavaScript その他(⼀部の Trigger や Binding

    のみ対応) F# Python PHP Batch Bash PowerShell Copyright© 2016, JAZUG All Rights Reserved. 14
  8. 2つの課⾦モデル Dynamic App Service Plan メモリサイズ(GB単位) × 実⾏時間(秒単位) 実⾏回数 毎⽉無料枠があって、それを超えると課⾦される

    サーバーレスアーキテクチャらしいモデル 最近、⽇本のデータセンターでも使えるようになった Classic App Service Plan 従来の課⾦モデル(Free, Basic, Standard, Premium) Web Apps にデプロイしたアプリと共存させるときに使う Functions ⾃体には課⾦されない、Web Jobs に近いイメージ Copyright© 2016, JAZUG All Rights Reserved. 15
  9. Azure App Service に追加されたサービス Web Jobs を拡張したサービス 実⾏環境は Web Apps

    なので、同じ機 能が使える App Settings Connection Strings Advanced Tools / App Service Editor Remote Debug 便利かつ⾃由度の⾼いサービス Copyright© 2016, JAZUG All Rights Reserved. 18
  10. Azure Portal の Advanced Editor Copyright© 2016, JAZUG All Rights

    Reserved. 22 function.json を編集できるので、詳細な構成ができる
  11. HTTP Trigger https://{site name}.azurewebsites.net/api/{function name} name .csx のコードで使う変数名 authLevel Function:Function

    Key admin:Master Key anonymous:認証なし Copyright© 2016, JAZUG All Rights Reserved. 23
  12. API Key HTTP Trigger と WebHook Trigger で API Key

    を要求できる クエリ⽂字列:code HTTP ヘッダー:x-functions-key API Key ⾃体は、D:¥home¥data¥Functions¥secrets に定義されている Function Key 無効なファンクションはトリガーできない ファンクションごと or 共通の API Key Master Key 無効なファンクションもトリガーできる すべてのファンクションで共通の API Key Copyright© 2016, JAZUG All Rights Reserved. 25
  13. Azure Storage Queue Trigger Copyright© 2016, JAZUG All Rights Reserved.

    26 引数へのバインド string byte[] JObject CloudQueueMessage など myqueue-items
  14. Azure Storage Queue Output Binding Copyright© 2016, JAZUG All Rights

    Reserved. 27 引数へのバインド string byte[] JObject CloudQueueMessage ICollector<T> など outqueue
  15. Azure Storage Blob Input Binding Copyright© 2016, JAZUG All Rights

    Reserved. 28 引数へのバインド string Stream JObject CloudBlockBlob など incontainer
  16. Blob Trigger を利⽤する際の注意事項 トリガーが監視する Blob コンテナに10,000を超える Blob が含 まれる場合は、リアルタイムに発⽕しないことがある 数分またはそれ以上経過しないとトリガーされない可能性あり

    すべてのイベントがキャプチャされる保証はない トリガーのリアルタイム性と信頼性の制限が許容できない場合 は、Queue トリガーと組み合わせることを推奨している Copyright© 2016, JAZUG All Rights Reserved. 29 https://azure.microsoft.com/ja-jp/documentation/articles/functions-bindings-storage/ https://feedback.azure.com/forums/355860-azure-functions/suggestions/13282098-should-be- support-real-time-storage-blob-triggers
  17. Timer Trigger {second} {minute} {hour} {day} {month} {day of the

    week} 6つのフィールドを含む CRON 式 {second} フィールドを省略してはダメ hh:mm:ss 形式も可能 タイムゾーンは UTC で指定する runOnStartup すぐに実⾏するかどうか Copyright© 2016, JAZUG All Rights Reserved. 30
  18. Timer Trigger 10分ごとに実⾏する場合 すぐに実⾏し、毎⽇0時(JST)に実⾏する場合 ⽉曜から⾦曜の17時(JST)に実⾏する場合 Copyright© 2016, JAZUG All Rights

    Reserved. 31 "schedule": "0 */10 * * * *“ "schedule": "0 0 15 * * * “ "runOnStartup": true "schedule": "0 0 8 * * 1-5“ "schedule": "00:10:00“
  19. 外部アセンブリの参照 よく使う .NET のアセンブリは、⾃動的に参照されている System.Net.Http.dll Microsoft.Azure.WebJobs.dll など 必要に応じて、#r “AssemblyName” で参照できる

    Newtonsoft.Json.dll のように、.NET に含まれていなくても、使えるア センブリもある プライベート アセンブリは、bin フォルダにアップロードする “D:¥home¥site¥wwwroot¥{function name}¥bin” に配置する #r “MyAssembly.dll“ で参照できる Copyright© 2016, JAZUG All Rights Reserved. 35
  20. NuGet ライブラリの参照 project.json ファイルをアップロードする ランタイムがパッケージを取得し、アセンブ リに参照が⾃動的に追加される #r “AssemblyName” を追加する必要はない using

    を追加するだけでOK アップロードする⽅法 App Service Editor ( Visual Studio Online ) Advanced Tools ( Kudu ) FTP Copyright© 2016, JAZUG All Rights Reserved. 36
  21. 参考資料 Azure Functions の概要 https://azure.microsoft.com/ja-jp/documentation/articles/functions-overview/ Introducing Azure Functions https://channel9.msdn.com/Events/Build/2016/B858 Azure

    Functions Under the Hood https://channel9.msdn.com/Events/Build/2016/T692 Azure Functions overview and under the hood https://channel9.msdn.com/Events/de-code/2016/DEV-017 https://buchizo.wordpress.com/2016/06/04/azure-functions-overview-and-under- the-hood/ オープンソース https://github.com/azure/azure-webjobs-sdk-script Copyright© 2016, JAZUG All Rights Reserved. 40