Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Blazor WebAssembly HostedのアプリにMessagePackを使ってみる
Search
tomokusaba
January 27, 2023
Programming
510
0
Share
Blazor WebAssembly HostedのアプリにMessagePackを使ってみる
Blazor WebAssembly HostedのアプリにMessagePackを使ってみる
.NETラボ 勉強会 2023年1月
tomokusaba
January 27, 2023
More Decks by tomokusaba
See All by tomokusaba
薬屋のひとりごとからみるプロジェクトにおけるコミットの方法
tomokusaba
1
32
Webアクセシビリティは“もしも”に備える設計
tomokusaba
0
180
WebアクセシビリティをCI/CDで担保する ― axe DevTools × Playwright C#実践ガイド
tomokusaba
2
290
Azure Portalのアクセシビリティを探ってみた
tomokusaba
1
74
聲の形にみるアクセシビリティ
tomokusaba
1
220
Webアクセシビリティ技術と実装の実際
tomokusaba
0
300
プロダクトでもバイブコーディングしようぜ!
tomokusaba
0
37
M5Stackで猫耳光らせよう!
tomokusaba
0
130
コンピューティングリソース何を使えばいいの?
tomokusaba
1
53
Other Decks in Programming
See All in Programming
今年もTECHSCOREブログを書き続けます!
hiraoku101
0
230
YJITとZJITにはイカなる違いがあるのか?
nakiym
0
130
Symfony + NelmioApiDocBundle を使った スキーマ駆動開発 / Schema Driven Development with NelmioApiDocBundle
okashoi
0
270
[PHPerKaigi 2026]PHPerKaigi2025の企画CodeGolfが最高すぎて社内で内製して半年運営して得た内製と運営の知見
ikezoemakoto
0
340
メッセージングを利用して時間的結合を分離しよう #phperkaigi
kajitack
3
570
Smarter Angular mit Transformers.js & Prompt API
christianliebel
PRO
1
120
瑠璃の宝石に学ぶ技術の声の聴き方 / 【劇場版】アニメから得た学びを発表会2026 #エンジニアニメ
mazrean
0
190
iOS機能開発のAI環境と起きた変化
ryunakayama
0
170
Reactive ❤️ Loom: A Forbidden Love Story
franz1981
2
230
PHP で mp3 プレイヤーを実装しよう
m3m0r7
PRO
0
180
GNU Makeの使い方 / How to use GNU Make
kaityo256
PRO
16
5.6k
「話せることがない」を乗り越える 〜日常業務から登壇テーマをつくる思考法〜
shoheimitani
2
210
Featured
See All Featured
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.1k
AI Search: Where Are We & What Can We Do About It?
aleyda
0
7.3k
A Soul's Torment
seathinner
6
2.6k
Bioeconomy Workshop: Dr. Julius Ecuru, Opportunities for a Bioeconomy in West Africa
akademiya2063
PRO
1
89
Facilitating Awesome Meetings
lara
57
6.8k
Avoiding the “Bad Training, Faster” Trap in the Age of AI
tmiket
0
120
Redefining SEO in the New Era of Traffic Generation
szymonslowik
1
270
Between Models and Reality
mayunak
3
260
Building Better People: How to give real-time feedback that sticks.
wjessup
370
20k
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
118
110k
A Guide to Academic Writing Using Generative AI - A Workshop
ks91
PRO
1
260
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
0
190
Transcript
Blazor WebAssembly Hostedのアプリに MessagePackを使ってみる 株式会社SAKURUG エンジニアリングユニット 草場 友光 .NETラボ 2023年1月
自己紹介 • 普段は主にWebFormsアプリの保守の お仕事をしてます。 • 古めのシステムが多いので時代に取り 残されぬよう新しい技術を一つでも入 れるよう日々努力しています。 • 2022/08-2023
Microsoft MVP (Developer Technologies) • tomo_kusaba
宣伝 【VISION】ひとの可能性を開花させる企業であり続ける VISIONに共感できる仲間募集中。
注意 • 個人の見解・解釈が多分に入っています。 • 見解の相違・事実誤認などありましたらご指摘ください。 • #dotnetlabでtweetすると右側に表示されます
今日の目的 • 通常、WebAPIのシリアライザとしてはJSONシリアライザが 使用されている。Webアプリケーションにおいてはパフォーマ ンスにおけるウェイトはデータベースやネットワークに比べシ リアライザーは少ないと考えられる。 • しかしながら、パフォーマンスチューニングは一般的に難しい • そこで、手軽なパフォーマンスアップの方法としてJSONシリ
アライザーをバイナリシリアライザであるMessagePack for C#に置き換えることでどれだけパフォーマンスアップできる か検証してみた
MessagePack for C#とは • C#用の超高速バイナリシリアライザ • .NET Standard2.0以上がターゲットで.NET Core 2.1以上向
けの最適化がされている • 河合さん(@neuecc)/Microsoft MVP for Developer Techologiesにより開発 • Visual Studio 2022の内部通信 • SignalRのMessagePack Hub • Blazor Serverプロトコル
MessagePack for C#とは
MemoryPackとは • 河合さんによる最新の超高速バイナリシリアライザ • .NET 7及びC#11に最適化
何で速いのか?? • この辺を読んでください • →https://neue.cc/2022/12/08_MemoryPackSessionInDo tNetConfRecapTokyo.html
通常のBlazor WebAssembly+WebAPI サーバー クライアント(ブラウザ) GET JSON (テキスト)
メリット・デメリット • メリット • OpenAPIのエコシステムを享受できる(Swaggerなど) • データのやりとりがテキストなので人間にも読める • デメリット •
テキストへのシリアライズのコストが高い
検証 • まずは、「WeatherForcast」のデモをMessagePackでシリ アライズ/デシリアライズして正常に画面表示できるかどうか を検証する • MessagePackでのパフォーマンスを最大限に引き出すことが 目的ではなく、いかに簡単にJSONシリアライザから MessagePackに置き換えるかを主眼に置いていることに留意 していただきたい。
検証ーController • Controllerは以下のように変更 • 戻り値の型を「IActionResult」 • JSONシリアラズされないようFileとして返す
検証ーShared • MessagePackObject属性をつける
検証ーClient • MessagePackでデシリアライズ
結果 • Weather forcastの表示ができました
サンプルの動作検証 • Edgeの開発者ツールで内容確認したところバイナリデータで 通信していると確認できます。
通常のWebアプリでは・・・ • データベースとネットワークの時間が無視できない。 • データベースとネットワークの時間の揺らぎが大きくそのまま ではシリアライズ・デシリアライズの差が出てくることが難し いのではと予想 • .NETはJITであるため初回と2回目以降の速度に大きく差が出 ると想定
今回の計測環境 • データベースの読み取りの揺らぎ対策 • サーバ内に結果をキャッシュし2回目以降は実データベースへ読みに 行かないようにする。 • 計測専用アプリであるので常に同じ結果を返す • ネットワークの揺らぎ対策
• Webアプリケーションサーバで実行する • JITによる揺らぎ対策 • 2回連続実行し2回目の値を採用する
サーバー側 _dataはSingletonでDI 2回目以降はデータありなのでDBアクセスなしに実行される
クライアント側 計測の2回目を有効な値とする (アドバイス thanks:とっちゃん) 以降、MessagePack、MemoryPackの計測に続く
クライアント側つづき
計測結果 • 各、20ループ JSON MessagePack MemoryPack 計測1 637ms 293ms 218ms
計測2 535ms 484ms 252ms 計測3 853ms 345ms 231ms 計測4 522ms 332ms 288ms 計測5 625ms 537ms 305ms 計測6 653ms 426ms 249ms 計測7 713ms 341ms 222ms 計測8 582ms 292ms 257ms 計測9 484ms 289ms 211ms 計測10 868ms 530ms 283ms 平均 647ms 387ms 252ms
今回の場合の結果 JSON MessagePack MemoryPack 平均 647ms 387ms 252ms 差 -260ms
-135ms サーバー側をWebAPIとしてシリアライザーをJSONからMessagePackまたはMemoryPack に置き換えただけの雑な実装でもそれなりにシリアライズ・デシリアライズ部分のパフォーマンス向上 は見られることは分かった。 しかし、実アプリケーションベースではどうだろうか??
実画面ベースでの実装 • 先ほどのWebAPIを流用し画面のみを制作 • 体感上、有意な変化があるのかそれぞれが判断して欲しい https://kind-moss-0af0a4d00.2.azurestaticapps.net/
実画面ベースでの比較(REST API) 783ms
実画面ベースでの比較(Memory Pack) 539ms
参考文献 • MessagePack for C#(Github) • MemoryPack(Github) • System.Text.Json名前空間
おしまい おしまい