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
wasmって何? WebAssemblyはじめての方へ
Search
nako@9時間睡眠
October 19, 2022
Programming
0
190
wasmって何? WebAssemblyはじめての方へ
こちらの会の発表資料です
ElixirImp#25:はじめてのWebAssembly+Elixir
https://fukuokaex.connpass.com/event/262073/
nako@9時間睡眠
October 19, 2022
Tweet
Share
More Decks by nako@9時間睡眠
See All by nako@9時間睡眠
Elixir国内コミュニティと アンチパターン回避
nako_sleep_9h
3
110
「推し」について話すLT〜NOKIA、Elixir〜
nako_sleep_9h
0
89
YouTubeライブ対談からのエッジコンピューティング入門
nako_sleep_9h
1
130
piyopiyo.ex#15 春のElixir入学式
nako_sleep_9h
0
100
おすすめエンジニアコミュニティ
nako_sleep_9h
0
170
ElixirDesktopを楽しむための前説
nako_sleep_9h
0
360
Livebookを楽しむための前説
nako_sleep_9h
0
210
Nx、Axonを楽しむための前説
nako_sleep_9h
0
180
会社員プログラマから見たzackyさんの研究活動がすごいという話
nako_sleep_9h
0
270
Other Decks in Programming
See All in Programming
RailsでCQRS/ESをやってみたきづき
suzukimar
2
1.3k
気がついたら子供が社会人になって 自分と同じモバイルアプリエンジニアになった件 / Parent-Child Engineers
koishi
0
220
AI Agentを利用したAndroid開発について
yuchan2215
0
180
ローコードサービスの進化のためのモノレポ移行
taro28
1
230
ABEMA iOS 大規模プロジェクトにおける段階的な技術刷新 / ABEMA iOS Technology Upgrade
akkyie
1
290
CloudRun, Spanner に対する負荷試験の反省と オブザーバビリティによるアプローチ
oyasumipants
1
250
SREチームのタスク優先度と向き合う Road to SRE NEXT@札幌
nealle
0
130
Modern Angular with Signals and Signal StoreNew Rules for Your Architecture @bastacon 2025 in Frankfurt
manfredsteyer
PRO
0
190
私の愛したLaravel 〜レールを超えたその先へ〜
kentaroutakeda
1
160
もっと大きなデータを送りませんか? エラーがゴロゴロ出るようなデータです
sublimer
0
170
TCAを用いたAmebaのリアーキテクチャ
dazy
0
270
‘무차별 LGTM~👍’만 외치던 우리가 ‘고봉밥 코드 리뷰’를?
hannah0731
0
460
Featured
See All Featured
RailsConf 2023
tenderlove
29
1k
Navigating Team Friction
lara
183
15k
Building an army of robots
kneath
303
45k
Producing Creativity
orderedlist
PRO
344
40k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.2k
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
KATA
mclloyd
29
14k
What’s in a name? Adding method to the madness
productmarketing
PRO
22
3.3k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
50
2.3k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
366
25k
Building Your Own Lightsaber
phodgson
104
6.3k
Mobile First: as difficult as doing things right
swwweet
223
9.5k
Transcript
wasmって何? WebAssemblyはじめての方へ 2022/10/19 nako
自己紹介 • nako@9時間睡眠 • Elixir/Phoenix初心者コミュニティ 『piyopiyo.ex』オーガナイザー • 会社員。Webサービスのサーバサイ ドエンジニア •
Elixir10周年のお祝いにSnapCamera エフェクトを作りました:D
WebAssemblyとは?
WebAssemblyとは? • WebAssembly(略称:Wasm)は、 ブラウザでプログラムを高速実行するための 「ブラウザ上で動くバイナリコードの新しいフォーマット(仕様)」です。 • WebAssemblyの開発はMozilla、マイクロソフト、Google、Appleといった主要ブラ ウザの開発者により行われています。
WebAssemblyを利用したサービスが出来るまで C/C++/Rustなどで記述されたソースコードをコンパイルし、 wasmコードを生成する。 生成したwasmコードをWebアプリとして アップロードする。 JavaScriptコードから呼び出したり、 wasmコードからJavaScriptコードを呼び出す ことができる。 C/C++/Rust などの
ソースコード コンパイラ wasm コード Webアプリケーション wasm コード Java Script HTML CSS
Google Earthを開発ツールで 見てみると、wasmファイルが あることがわかります。
WebAssemblyの歴史 2015年6月17日 開発開始を公式にアナウンス 2016年3月15日 主要ブラウザ (Firefox, Chromium, Google Chrome, Microsoft
Edge) 上で UnityによるAngry Botsというデモが行われた 最初の目標としてCとC++からのコンパイルをサポートすることを目指し、 Rust がバージョン1.14以降で、Goがバージョン1.11以降で、Kotlin/Nativeがバー ジョン0.4以降で対応するなど、他のプログラミング言語のサポートも進められ た 2017年3月7日 WebAssemblyに標準対応した初のブラウザとなる Firefox 52.0がリリースされ た 2017年11月 MozillaはSafariとEdgeがWebAssemblyに対応したと発表し、すでに対応して いるChromeとFirefoxを含め、主要なブラウザすべてでサポートされることに なった 2019年12月5日 W3C勧告「WebAssembly Core Specification」が策定され、WebAssemblyは 正式なウェブ標準に認定された
WebAssemblyが使えるプログラミング言語 https://github.com/appcypher/awesome-wasm-langs より 🥚進行中、🐣不安定だが使える、🐥本番環境で使える 🐥 .Net、🐥 AssemblyScript、🥚 Ballerina、🐥 Brainfuck、🐥 C、🐥
C#、🐥 C++、🐣 C4wa、🐥 Clean、🥚 Co、🐥 COBOL、🥚 Crystal、🐣 D、🐣 Eel、🐣 Elixir、 🐥 F#、🥚 Faust、🥚 Forest、🐥 Forth、🐥 Go、🥚 Grain、🥚 Haskell、🐣 Java、 🐣 JavaScript、🥚 Julia、🐣 Kotlin/Native、🥚 Kou、🐣 Lisp、🐥 Lobster、🐥 Lua、 🐣 Lys、🐥 Never、🥚 Nim、🥚 Ocaml、🐣 Pascal、🐣 Perl、🐣 PHP、🥚 Plorth、🐣 Poetry、🐣 Python、🐣 Prolog、🐣 Ruby、🐥 Rust、🐣 Scheme、🐣 Scopes、🐣 Swift、🐥 TypeScript、🥚 Wase、🐥 WebAssembly、🥚 xcc、🐥 Zig
WebAssemblyでよく使われる言語 よく使われる言語は • Rust • C++ • AssemblyScript が多いようです。 ※調査は2021年6月、196カ国
(米国21.8%、ドイツ9.1%、 中国9.1%など)に分散した 250人のITエンジニアが回答
WebAssemblyとElixir • Wasmex ◦ https://github.com/tessi/wasmex ◦ Wasmexは、Elixirのための高速で安全なWebAssemblyとWASIランタイム ◦ 2020年に開発開始 ◦
定期的にバージョンアップがあり、開発が進んでいる • Firefly ◦ https://github.com/GetFirefly/firefly ◦ BEAM言語用の新しいコンパイラとランタイム ◦ 2018年に開発開始
WebAssemblyが 使われているプロダクト
WebAssemblyが使われているプロダクト 『Made with WebAssembly』というサイトで確認できます。 https://madewithwebassembly.com/ Google Earth、 Unity、Figmaといった WebAssemblyを使った サービスが確認できます。
国内事例:VKET CLOUD • 自社の所有する仮想空間でサービス展開を可能にするVRエンジン • Webリンクからの簡単なアクセス、3Dアバターを使った音声とチャットによるコミュ ニケーション、美しい仮想空間での様々なサービス展開が可能です
国内事例:メルカリレンズβ • メルカリレンズβでは、カメラの入力をサーバーに送信せず、デバイス内で高速に機 械学習に関連する処理を実行 • 物体検出の数値計算のバックエンドにWebAssemblyを用いている。 • https://engineering.mercari.com/blog/entry/20211222-mercari-lens/ より •
2021/12/16公開
ご清聴ありがとう ございました!