LogicFlow 概要

Preview:

Citation preview

LogicFlow Overview

2017/11/18

LogicFlow-ja 小尾智之

Self Introduction

Attribute1: VB / LogicApps-Flow-PowerApps

@twit_ahf

Attribute2: 提督 / 殿 / メガネ / クマ / プロレス /もっふり

tomoyuki.obi

http://el.jibun.atmarkit.co.jp/ahf

Community: LogicFlow-ja / CLR/H

Microsoft MVP for Microsoft Azure(2017.03 ~)

https://www.facebook.com/groups/logicflowja/

Agenda

・LogicApps/Flow 概要

Session Goal

• LogicFlow が適している場面を理解する

• LogicFlow でできることを理解する

LogicFlow is iPaas

iPaasis

Integration Platformas a Service

> ≧

IFTTT は非常に多くのサービスと連携可能間に制御を挟まないシンプル構成

IFTTT / Flow / LogicApps

Flow / LogicApps はユーザーが制御を挟む余地があるサービス数はまだ限られている

一般ユーザー ITPro

Trigger

Action

Action

LogicFlow の構造

発生したイベントをトリガで受け取り後続のアクションで処理を行う

Price Plan

LogicApps 従量課金プラン

LogicApps AppService プラン

https://azure.microsoft.com/ja-jp/pricing/details/logic-apps/

Flow とは課金単位が異なる

1 Action

1 Action

1 Action

1 Flow

LogicApps の課金単位

Flow の課金単位

LogicApps 仕様と制限

最大実行継続時間 90 日

ストレージリテンション期間 90 日

最小繰り返し時間 1 秒

最大繰り返し間隔 500 日

ForEach レコード数 100,000

Loop Until 回数 5,000

SplitOn 最大数 100,000

ForEach 並列処理数 50

アクション実行数(5分間) 100,000

同時呼出し数 2,500

エンドポイント同時受信数 1,000

エンドポイント読取可能呼出し数 60,000

エンドポイント起動可能呼出し数 45,000

ワークフローでのアクション数 250

ワークフロー内部でのネスト数 5

1リージョンのワークフロー数 1,000

ワークフローごとのトリガ数 10

一つの式での最大文字数 8,192

アクション/トリガ名の文字数 80

コメントの文字数 256

パラメーター数 50

Microsoft Flow 料金プラン

1 ユーザー 25 LogicFlow が定義可能(リクエスト送付で拡張可能)https://flow.microsoft.com/ja-jp/pricing/

Flow プランでの機能制限

Premium 系コネクタはPlan1 / 2 でのみ利用可能

PowerApps 料金プラン

https://powerapps.microsoft.com/ja-jp/communityplan/

PowerApps コミュニティプラン

既にアカウントを所有していても作成可能

Service Connectors

Enterprise

Integration

SNS

Office365 / Dynamics365

Data Connect

Web Service

Azure Service

Online Storage

Notification Standard

Connecter

Cognitive Service

Button

Approval

Batch

Enterprise

Integration

SNS

Office365 / Dynamics365

Data Connect

Web Service

Azure Service

Online Storage

Notification Standard

Connecter

Cognitive Service

Button

Approval

Batch

LogicApps Only

Enterprise

Integration

SNS

Office365 / Dynamics365

Data Connect

Web Service

Azure Service

Online Storage

Notification Standard

Connecter

Cognitive Service

Button

Approval

Batch

Flow Only

Connector Detail

LogicFlow 基本コネクタ

スケジュール

OpenAPI(Swagger) 定義されたAPI 呼出

HTTPS リクエスト

RSSFTP/SFTP

HTTP/HTTPS

WebHook

Mail(SendGrid)

SMTP

変数

制御HTTP レスポンス

データ操作

PowerApps

プッシュ通知

Flow Button

HTML-テキスト変換

PowerApps用プッシュ通知

条件判断 / Condition

IF ~ THEN ~ ELSE(条件分岐)

Switch Case(条件多分岐)

繰り返し / Loop

Do Until ループ

ループが一定時間内に終了しない場合にタイムアウトとする場合はISO 8601 形式でタイムアウト条件を設定

繰り返し / Loop

ForEach ループ

規定では 20 アクションの並列動作operationOptions:Sequential で変更可能

デザイナ上だけでネストしたループも作成可能

並列動作アクション数はデザイナー上からも調整可能

ブロック化 / Scope

処理のブロック化

実行条件の構成 / RunAfter

ブロック化した場合は「ブロック内部の処理が何か一つでも失敗したら」という条件で利用できる

並列分岐 / RunAfter(2)

デザイナー上から並列動作させるアクションを直接設定可能

RunAfter 設定を変更しどのコネクタの後に実行するかを設定している

IF コネクタでエラー判定しなくともこのような形でエラー処理が作成できる

ドラッグ&ドロップで移動可能

変数/ Variables

初期化を先に実施する必要がある

変数の初期化はループ内部では利用不可

データ操作 / Compose

関数で行っていたものがコネクタ化され簡易に利用可能

inputArguments.Select(Function(x)

Return New With {Key x.orgArg1,

Key x.orgArg2,

Key Sum(x.orgArg3)}

End Function).ToArray

選択/ Selecct

配列オブジェクトの再定義

バッチ / Batch

一定回数呼び出される定期的に実行する一定量のメッセージを受け取るなどをトリガにして起動できる

再試行ポリシー/ Retry Policy

動作エラーになったものを何回(Limit)どの程度の間隔で(Duration)再実行するかを設定

HTTP コネクタの仕様と制限

Request

Response

HTTP ステータス 200 が正常終了202 は処理継続中として Retry-After 値に基づいてポーリング

Location ヘッダの値がある場合再試行時にリクエストを投げる URL が変化

ワークフローが開始されるのはステータス 200 の時に限定される

http://blogahf.blogspot.jp/2017/07/logicflow-http.html

Trigger

CodeView 上で LogicFlow を直接記載

デザイナーでは未サポート

動作自体は問題なく可能

マルチトリガ / Multi Trigger

@triggerOutputs() 関数にて呼出時に付与されていたクエリパラメータを取得できる

Request トリガにおけるクエリパラメータ

@triggerOutputs()['queries']['test1']などでパラメータを利用可能

Workflow Function

演算子 / Operator

[]

?演算子は特に重要で値がない事が想定される場合は必ず使うのがよい

関数 / Workflow Functions

Referencing functions

Collection functions

String functions

Logical functions

Conversion functions

Math functions

Date functions

URI functions

https://docs.microsoft.com/ja-jp/azure/logic-apps/

logic-apps-workflow-definition-language

インテリセンスサポートあり

Manipulation functions

Workflow functions

Functions の書き方

最初の関数のみ@をつける必要がある(CodeView のみ)

文字列は ‘ でのみ囲める

デザイナー上で記載する場合は「詳細設定」LogicApps なら CodeView で記載するのを活用

Workflow Functions のコネクタ対応

一部関数はコネクタとして提供も行っている

Azure API App

同一サブスクリプション上にある API Apps を呼出可能

トリガ/アクション両方を利用可能

OpenAPI

API Apps での OpenAPI(Swagger)設定によりダイアログでの表示などカスタマイズ可能

メソッドなどへ属性を付与してデザイナ上の表示を指定T-Rex ライブラリも利用可能(https://github.com/nihaue/TRex)

[HttpPost, Route]

[Metadata("Create Message", "Creates a new message absolutely nowhere")]

[SwaggerResponse(HttpStatusCode.OK, Type = typeof(SampleOutputMessage))]

public async Task<IHttpActionResult> Post([FromBody]

[Metadata("Sample Input", "A sample input message")]

SampleInputMessage sampleInput)

{

return await SampleOutputMessage.FromInputAsync(sampleInput);

}

参考)https://flow.microsoft.com/ja-jp/documentation/customapi-how-to-swagger/

Azure Function App

LogicFlow デザイナー上で直接 FunctionApp を記述可能(ただし js のみ)

Custom Connector

外部 API を事前に登録することで他コネクタと同様に利用させることが可能

アイコンや説明文なども設定できるので詳しくない人でも利用できるようになる

カスタムコネクタ登録

カスタムコネクタ登録により他のコネクタと比較しても判別つかない形でコネクタを提供することが可能

利用する側にとっては詳細な設定を毎回行う必要がないので利便性が高い

OnPremiss Data Gateway

Hybrid Connection

(ServiceBus – Relay)

OnPremiss Data Gateway

(ServiceBus – Queue)

OnPremiss DataGateway

対象コネクタ

DataGateway はメッセージをポーリングする方式でやり取りを行う(リアルタイム性は若干落ちる)

•ルートフォルダ:接続先 PC でのローカルパス(共有はかけなくても大丈夫)•認証タイプ:Windows 認証•ユーザー名:(マシン名)¥(アカウント) を入力AD アカウントではないので注意!•パスワード:パスワードを入力•ゲートウェイ:インストールしたゲートウェイを選択

DataGateway 利用ポート

TCP 443 (既定値) / 5671 / 5672 / 9350 ~ 9354

データ送信のみで受信は必要ない

HTTPS を強要する場合は config ファイルの書き換えかインストーラから設定

Enterprise Integration

Enterprise Integration

統合アカウント

ファイルからのエンコード

ファイルへのデコード

XML の検証 XML 変換

EDIFACT

AS2

X12特定プロトコルのコネクタは用意済

VS 上でスキーマやマップの定義を行いAzure へアップロードが必要(現時点では VS2015 限定)

BizTalk Server Architecture

BizTalk Service Architecture

オーケストレーション部分が

Enterprise Integration Pack

統合アカウントB2B などで EDI/EOS をする際の情報を登録

マップは xslt とLiquid Template に対応

LogicFlow Configration

実行履歴 / History

コネクタによっては BASE64 し結果をやり取りするものもある

バージョン履歴 / Version

編集履歴より過去のバージョンへ戻すことが可能

履歴表示時に「昇格」で復元される

テンプレート生成 / Template

Template 化することでGithub などからのデプロイも可能

新規作成時のデフォルト値を定義したテンプレートも作成可能

Azure Alert の LogicApps 呼出し

Azure の各種サービスでAlert が発生した際に実行する LogicApps を指定できる

Alert ルールはメトリックとして定義可能

Flow で定義した LogicFlow を呼出したい際はWebhook として Request コネクタで生成された URL を指定することで可能(ブレード上 LogicApps 呼出がない際も同様)

発生した Alert の集約も非常に簡単に行える

LogicApps の呼び出し元 IP アドレス

LogicAppsからアクセスした場合の IP アドレス

LogicApps のセキュリティ

LogicFlow にアクセスできるIP アドレスの制限を指定可能

Flow のセキュリティ

複数の環境を作成してユーザーを切り分ける

接続可能なコネクタルールを定義し不用意にデータ流出を行えなくする

Log Analytics

細かい設定なしでLogicApps のログ情報をOMS へと連携が可能

Flow/PowerAppsLimited

ボタン / Button

Flow モバイルアプリ導入で利用可能端末 / Web サイトより実行可能

作成したボタントリガはメニュー上にウィジェットとして配置することが可能

通知 / Notification

Flow モバイルアプリ導入で利用可能自分の端末へのプッシュ通知 / メールによる通知

PowerApps で利用可能(ブラウザ上では未対応)アプリケーション単位での通知(特定ユーザーも可)

PowerApps Notification

Notification

承認 / Approval

Flow Premium(または Office365 FreePlan)で可能活用するには Office365 ユーザーが必要

Flow モバイルアプリまたは Flow ウェブサイト上で承認行為が可能

Functions App Proxy

Function Apps Proxy と API Management Services

どちらも LogicFlow を呼び出すプロキシとして利用可能

特定のメソッドで呼び出された際にAPI を呼び出すことが可能

Function Apps Proxy

Other Contents

LogicApps の高可用性対応

API Management リダイレクト先の調整

ServiceBus メッセージング

Hot-Cold 的に構築動作中のリージョンで障害発生時にCOLD 側へ切り替えさせる

常に全てのリージョンで動作するよう構築LogicApps の課金としては変化なし(トリガで対象データなしは無課金)

LogicApps Orchestration

Functions App でチェーン的につなぎ処理を構築するよりもLogicApps から Functions App を呼び出させる方が、処理が正常に動作しているかも把握しやすく修正しやすい

高レスポンスを求めないならば

Functions をチェーンしない方が良い

LogicApps Ludicrous Mode

LogicApps 上に仕込みは済んでいるのでそう遠くない時期に公開予定

高パフォーマンス用 LogicApps

16ユニット以上の構成

高スケール対応が可能

PowerApps/Flow が向いている領域

• アプリを作るまでもないちょっとした事のシステム化• 日頃の作業を少しだけ便利に• 一部メンバー間に限定して実施したい• 社内用、部門用システムを短期間で用意したい• スマートフォンを安価に活用したい

LogicApps が向いている領域

• 複数サービス間での連携が必要• EOS/EDI などデータ連携や変換が多くなる時に• コードを書いて負債を増やしたくない• コードを書かなくてもできる事でコードを書きたくない

Let’s develop without coding,

and Welcome to Serverless !

Appendix

• LogicFlow-ja( https://www.facebook.com/groups/logicflowja/ )

• LogicFlow を扱っている Blog– nrjlog ( http://zuvuyalink.net/nrjlog/ )– てすとぶろぐ ( http://blogahf.blogspot.jp/ )

• Azure LogicApps( https://blogs.msdn.microsoft.com/logicapps/ )

• Flow – Blog(https://flow.microsoft.com/en-us/blog/)

• PowerApps – Blog(https://powerapps.microsoft.com/en-us/blog/)

• Twitter Hashtag– LogicApps → #LogicApps

– Flow → #MicrosoftFlow