Upgrade to PRO for Only $50/Year—Limited-Time Offer! 🔥
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Application Insights Preview
Search
Tatsuro Shibamura
June 09, 2017
Programming
0
210
Application Insights Preview
Tatsuro Shibamura
June 09, 2017
Tweet
Share
More Decks by Tatsuro Shibamura
See All by Tatsuro Shibamura
# Azure Cosmos DB パフォーマンス最適化入門 - 設計・開発・運用の実践テクニック
shibayan
0
400
Hack Azure! #5 - Geek of Azure Serverless
shibayan
0
98
.NET Conf 2020 Online - .NET 5 リリース記念パーティートーク
shibayan
0
9.2k
Terraform Provider for Azure に貢献してみた話
shibayan
0
610
Azure Functions と SendGrid の良い関係
shibayan
0
1.2k
Azure Serverless を活用したリアルタイム Web のすべて
shibayan
1
2.9k
祝 東日本リージョン一般提供! Azure Application Insights 基礎と実践
shibayan
1
42k
なかなか楽にならないSSL/TLS証明書の話
shibayan
2
1.8k
.NET Conf 2018 Tokyo
shibayan
1
4k
Other Decks in Programming
See All in Programming
Full-Cycle Reactivity in Angular: SignalStore mit Signal Forms und Resources
manfredsteyer
PRO
0
180
これだけで丸わかり!LangChain v1.0 アップデートまとめ
os1ma
6
1.3k
CSC305 Lecture 17
javiergs
PRO
0
270
開発に寄りそう自動テストの実現
goyoki
1
480
TypeScriptで設計する 堅牢さとUXを両立した非同期ワークフローの実現
moeka__c
6
2.9k
AIと協働し、イベントソーシングとアクターモデルで作る後悔しないアーキテクチャ Regret-Free Architecture with AI, Event Sourcing, and Actors
tomohisa
5
18k
Level up your Gemini CLI - D&D Style!
palladius
1
180
無秩序からの脱却 / Emergence from chaos
nrslib
2
12k
Google Antigravity and Vibe Coding: Agentic Development Guide
mickey_kubo
2
130
Rediscover the Console - SymfonyCon Amsterdam 2025
chalasr
2
140
tsgolintはいかにしてtypescript-goの非公開APIを呼び出しているのか
syumai
5
1.4k
Microservices rules: What good looks like
cer
PRO
0
600
Featured
See All Featured
Being A Developer After 40
akosma
91
590k
KATA
mclloyd
PRO
32
15k
Into the Great Unknown - MozCon
thekraken
40
2.2k
Intergalactic Javascript Robots from Outer Space
tanoku
273
27k
Building Adaptive Systems
keathley
44
2.9k
Producing Creativity
orderedlist
PRO
348
40k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.5k
Imperfection Machines: The Place of Print at Facebook
scottboms
269
13k
Reflections from 52 weeks, 52 projects
jeffersonlam
355
21k
For a Future-Friendly Web
brad_frost
180
10k
Principles of Awesome APIs and How to Build Them.
keavy
127
17k
The Art of Programming - Codeland 2020
erikaheidi
56
14k
Transcript
Application Insights Preview @shibayan Microsoft MVP for ASP.NET/IIS http://shibayan.jp/
はじめに • 今日は Azure と Visual Studio の間をフラフラしている Application Insights
について話します • Visual Studio 2015 リリース記念なので、Visual Studio から扱 える範囲に絞ることにします
注意点 • Application Insights はまだ Preview です • 必要なものはデータが遅延しても泣かない気持ち
Application Insights とは • アプリケーションのパフォーマンスの解析、クラッシュの診断、 使用状況の追跡が行えるサービス • 先行する New Relic
に近いサービス • データ量に基づく課金体系、無料で使用可能 • 月間 500 万データポイント、生データ保存 7 日の制限のみ • 有料版だと Blob へのデータエクスポート機能も
Application Insights で出来ること • Web アプリケーション • パフォーマンス、クラッシュ監視、使用状況の追跡、パフォーマンス カウンタの確認 •
Web アプリケーション実行環境 • 外部サービスの呼び出し追跡、パフォーマンスカウンタの確認 • クライアントアプリケーション • クラッシュ監視、使用状況の追跡
対応するプラットフォーム • Web アプリケーション • ASP.NET / ASP.NET 5 /
Java / JavaScript / Python / Ruby / PHP • Web アプリケーション実行環境 • Windows Server (IIS) / Azure Web Apps • クライアントアプリケーション • Android / iOS / OS X / Windows Store App / デスクトップアプリ
Web アプリケーション
Application Insights SDK • 基本的なイベントのハンドリング • アプリケーションの起動、終了など • キャッチされていない例外のハンドリング •
スタックトレースなどをテレメトリとして送信 • カスタムメトリック、トレースログの送信 • TraceListener / NLog を使っている場合には、対応するパッケージを インストールするだけで対応可能
ASP.NET アプリケーションに組み込む • Visual Studio から簡単に SDK をインストール可能 • ASP.NET
アプリケーションの作成時 • 作成済みアプリケーションへ追加 • Application Insights 自体は Web App の追加時に作られる • ポータルから単体で作成することも可能
ASP.NET アプリケーションの作成時 チェックを入れるだけ
作成済みアプリケーションへ追加 テレメトリの追加を選ぶ 右クリックして
対象の App Insights を選択して完了 送信先を選択して クリックすれば完了
Web Apps で使う場合の注意 • パフォーマンスカウンタは Web Apps では参照できないので、 Application Insights
の設定から外しておく • 放置しておくとテレメトリがおかしくなる • ApplicationInsights.config の TelemetryModules に存在する PerformanceCollectorModule を削除
パフォーマンスカウンタを使わない コメントアウトする
クライアント用 JavaScript を追加 • Azure ポータルからスクリプトをコピー&ペースト </head> の直前に貼り付ける
ローカル環境で動作確認 • Visual Studio でデバッグ実行を行う • 最初にテレメトリが送信されたタイミングでメッセージ表示 • 診断ツールでもテレメトリの確認が可能
デプロイしてポータルから確認 クライアント側の情報 アプリケーション側の情報
エラー画面を表示している場合 • ASP.NET MVC の場合は HandleError を変更 • http://blogs.msdn.com/b/visualstudioalm/archive/2014/12/12/appl ication-insights-exception-telemetry.aspx
• 任意のタイミングで例外を通知することもできる try { // 例外を投げるかもしれない new WebClient().DownloadString("..."); } catch (WebException ex) { // App Insights に例外が投げられたことだけは伝える var ai = new TelemetryClient(); ai.TrackException(ex); }
アプリケーションのエラーを確認 500 エラーの原因に なった例外 例外が発生した環境 の詳細情報 スタックトレースと メッセージを確認
Web アプリケーション 実行環境
Application Insights Status Monitor • 仮想マシンへのインストール向けモニタリングサービス • Windows の管理者権限があれば利用可能 •
既存のアプリに変更を加えることなく Application Insights を 使ったパフォーマンスの監視が行える • 既に運用中のアプリケーションの監視に最適 • .NET Framework 4.5 と ASP.NET 4.5 が必須
Status Monitor のインストール Web PI でインストール Application Insights を追加 対象のアプリケーションを選ぶ
Application Insights Site Extension • Status Monitor のインストールが出来ない Azure Web
Apps 用 に追加されたモニタリングサービス • Azure ポータルから 30 秒でインストール可能 • App Insights SDK を組み込んだアプリとセットで動作 • 単体での動作は想定していない
Site Extension のインストール Application Insights を選ぶ インストールが完了すると 表示される
外部サービスの呼び出し確認 SQL DB へのアクセス が表示される 実行されたクエリが 確認可能
Application Insights の活用
Web test で可用性の確認 • Azure ポータルから ping テストを作成 テストを行う リージョンを選択
テスト結果が表示される
テストシナリオを作成 • Visual Studio で Web パフォーマンスプロジェクトを作成 プロジェクトを作成して シナリオをレコーディング
作成したシナリオを使ってテスト • 作成した webtest ファイルをアップロード Multi-step を選んで 作成した webtest ファイル
を選択 テスト結果が表示される
Stream Analytics との連携 (1) • Application Insights から継続的に Blob へイベントを書き出す
必要なイベントのみを 選択可能
Stream Analytics との連携 (2) • Stream Analytics でイベントをストリームデータとして処理 • 結果を
SQL Database / Storage / Power BI へ出力 Azure Stream Analytics イベント単位で書き出される
まとめ • Application Insights はプレビューだけど使えるレベルに • データの遅延は頻繁に起こっているので注意 • 当然ながら Azure
との親和性は抜群に良い • Azure ポータルを使えば GUI だけで、ほとんど設定できる • Visual Studio との連携でさらに便利に