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
wstdなんだか良さそう
Search
asuka
June 17, 2025
Technology
130
0
Share
wstdなんだか良さそう
UV Study : Rust LT会 ~お好きなCrate紹介してください~
https://uniquevision.connpass.com/event/355069/
asuka
June 17, 2025
More Decks by asuka
See All by asuka
2025年ふりかえり
askua
1
200
ライブラリを公開してメンテナンスした一年
askua
0
82
Wasmの気になる最新情報
askua
1
350
Wasmのエコシステムを使った ツール作成方法
askua
0
370
Pure Goで体験するWasmの未来
askua
1
980
Wasmで社内ツールを作って配布しよう
askua
0
290
Wasm元年
askua
0
340
Dartでウェブ開発 (やりたい)
askua
0
87
Denoでパッケージを作りJSRに公開する
askua
0
84
Other Decks in Technology
See All in Technology
AgentCore Managed Harness を使ってみよう
yakumo
2
250
AWS Agent Registry の基礎・概要を理解する/aws-agent-registry-intro
ren8k
3
410
Angular Architecture Revisited Modernizing Angular Architectural Patterns
rainerhahnekamp
0
100
Shipping AI Agents — Lessons from Production
vvatanabe
0
290
生成AIが変える SaaS の競争原理と弁護士ドットコムのプロダクト戦略
bengo4com
1
2.6k
バイブコーディングで3倍早く⚪⚪を作ってみた
samakada
0
190
AIが自律的に働く時代へ Amazon Quick で実現するAIエージェント紹介
koheiyoshikawa
0
150
目的ファーストのハーネス設計 ~ハーネスの変更容易性を高めるための優先順位~
gotalab555
9
3.1k
Anthropic「Long-running a gents」をGeminiで再現してみた
tkikuchi
0
670
Class.new is all you need
riseshia
1
200
PyCon JPに学ぶ『決め方の決め方』: TechLead Conference 2026
terapyon
1
200
"おまじない"を卒業する ボイラープレート再入門
shunsuke_1b
1
120
Featured
See All Featured
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
430
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4k
How to build a perfect <img>
jonoalderson
1
5.4k
Building Experiences: Design Systems, User Experience, and Full Site Editing
marktimemedia
0
490
Bootstrapping a Software Product
garrettdimon
PRO
307
120k
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
170
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
Measuring & Analyzing Core Web Vitals
bluesmoon
9
810
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
120
A Soul's Torment
seathinner
6
2.7k
Visual Storytelling: How to be a Superhuman Communicator
reverentgeek
2
520
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
Transcript
wstdなんか良さそう UV Study : Rust LT会 June 17, 2025
WHOAMI asuka • 株式会社モニクル/SWE ◦ Monicle Techbook vol.1 技術書典17 •
Wasm関連の同人誌・商業誌の執筆 ◦ 実践入門WebAssembly ◦ WebAssembly System Interface入門 ◦ ご注文はWASIですか?? 技術書典16 ◦ Wasm Cookbook vol.2 技術書典17 ◦ Wasm Cookbook vol.3 技術書典18 ◦ Wasm Cookbook vol.4 技術書典NT • 新宿御苑.dev ◦ 新宿御苑.wasm #2025.6.25 LT会 2 商業誌 Cookbookシリーズ ごちWASI
前提知識 3
前提知識 4 • WASI 0.2というWasmのシステムインターフェースの仕様が存在する • WASI 0.2はWIT(Wasm Interface Type)でインターフェースが定義されている
• RustはWASI 0.2をサポートしている Wasmの詳しい話は こういう本を読むと良い
前提知識 5 • WASI 0.2というWasmのシステムインターフェースの仕様が存在する • WASI 0.2はWIT(Wasm Interface Type)でインターフェースが定義されている
• RustはWASI 0.2をサポートしている Wasmの詳しい話は こういう本を読むと良い
RustはWASI 0.2をサポートしている cargo build -r –-target wasm32-wasip2 6 $ wasmtime
run <TARGET_PATH>/hello-world.wasm Hello, WASI 0.2! ターゲットにWASIp2 (WASI 0.2)を指定すると 「wasi:cli/command」ワールドが実装される
wasi:cli/commandワールド CLI実行に必要なFSなどの一般的なインターフェース実装 7 $ wasm-tools component wit <TARGET_PATH>/hello-world.wasm | head
package root:component; world root { import wasi:cli/
[email protected]
; import wasi:cli/
[email protected]
; import wasi:io/
[email protected]
; import wasi:io/
[email protected]
; import wasi:cli/
[email protected]
; import wasi:cli/
[email protected]
; import wasi:cli/
[email protected]
; import wasi:clocks/
[email protected]
; import wasi:filesystem/
[email protected]
; import wasi:filesystem/
[email protected]
; export wasi:cli/
[email protected]
; } https://wa.dev/wasi:cli
wasi:cli/commandワールド CLI実行に必要なFSなどの一般的なインターフェース実装 → ネットワーク関連のインターフェース定義は含まれていない 8 wasi:httpやwasi:socketといったパッケージ定義はあるが, ビルドターゲットとなる wasi:cli/commandには含まれていない WASIのインターフェース 使いたいなー
wasi:cli/commandに含まれていない WASIインターフェースを使うには 9
WASIインターフェースを使うには 10 1. WITを使ってインターフェースを定義 & 実装する a. wit-bindgen 2. WASIのインターフェースをラップしたクレートを使う
a. wasmcloud → 今回説明しない b. wstd
WITを使ってインターフェースを定義 & 実装する wit-bindgenを使う 11 インターフェースの定義 インターフェースの実装
WITを使ってインターフェースを定義 & 実装する wit-bindgenを使う 12 wasi:http/proxyを実装してみると... WITのインターフェース定義を そのまま使うのは少々面倒
WASIのインターフェースを もう少し簡単に扱いたい 13
WASIのインターフェースをラップした クレートを使おう 14
wstd 15
wstd 16 https://github.com/yoshuawuyts/wstd An async standard library for Wasm Components
and WASI 0.2 $ wasmtime run -S http <TARGET_PATH>/example.wasm <!doctype html> <html> <head> <title>Example Domain</title> ... 実行できる
wstd 1. 非同期をサポートしている 2. WASIの薄いラッパーである 17 #[wstd::main] WASI 0.2には非同期インターフェースがない (WASI
0.3で導入予定) pollingインターフェースをラップして Futureとして扱えるように
wstd 1. 非同期をサポートしている 2. WASIの薄いラッパーである 18 WASIとの対応がわかりやすい
wstd 1. 非同期をサポートしている 2. WASIの薄いラッパーである 19 Request::get(“https::example.com”).body(io::empty())?; WITの定義をそのまま使うともっと冗長になる
wstd 20 WASIのインターフェースを 使いたい時に良さそう