Chrome開発チームがSQLiteチームとWebAssembly版SQLiteを開発中。Webブラウザ上からのファイル書き込みで永続化も可能。Web SQL APIの代替として

今回は「Chrome開発チームがSQLiteチームとWebAssembly版SQLiteを開発中。Webブラウザ上からのファイル書き込みで永続化も可能。Web SQL APIの代替として」についてご紹介します。

関連ワード (操作、記事、非推奨等) についても参考にしながら、ぜひ本記事について議論していってくださいね。

本記事は、Publickey様で掲載されている内容を参考にしておりますので、より詳しく内容を知りたい方は、ページ下の元記事リンクより参照ください。


Google Chromeの開発チームは、すでに非推奨となっているWeb標準のWeb SQL Database APIをChromeから削除、その代替機能としてSQLite開発チームと協力してWebAssembly版のSQLiteを開発し、提供する予定であることを明らかにしました。

Chrome is deprecating and eventually removing Web SQL! Read @tomayac’s post that details all the steps for getting there.

[We are here] Chrome 105 shows a deprecation warning in the DevTools Issues panel when you use Web SQL in non-secure contexts.https://t.co/Zu6MGofb76

— Chrome Developers (@ChromiumDev) August 31, 2022

Web SQL Database APIはその名称から分かるとおり、WebアプリケーションがSQLを通じてローカルなリレーショナルデータベースを操作できるAPIです。その実装はChromeがまだWebKitをベースに開発されていた2009年に行われ、その後2013年にWebKitからフォークして新たなChromeのベースとなったBlinkでも維持されてきました。

ただし現実にはさまざまな理由でWeb SQL Database APIが活用されることはほとんどなく、現在ではIndexedDBなどほかの機能を利用することが推奨されています。

そして今年1月にリリースされたChrome 97ではサードパーティからのWeb SQL Database API利用について非推奨となり、今後のリリースでは時期未定ながらこのAPIの削除が予定されています。

WebAssembly版SQLiteの提供で代替へ

と同時に、Chromeの開発チームは、ただ単にWeb SQL Database APIを削除するのではなく、代替機能としてSQLite開発チームと協力してWebAssembly版のSQLiteを開発し提供することを発表しました。

下記は「Deprecating and removing Web SQL」からの引用です。

We’re therefore working with the SQLite community on a replacement for Web SQL based on SQLite implemented in WebAssembly (Wasm), which will be released in the near future. For developers looking for a drop-in replacement, we’re investigating if a shim script can be provided.

というわけで、私たちはSQLiteコミュニティと協力してSQLiteのWebAssembly版をベースとしたWeb SQLの代替を開発しており、近い将来リリースする予定だ。ドロップインで置き換えられることを望む開発者のために、shimスクリプトを提供できるかどうかも調査しているところだ。

Web SQL Database APIは実質的にSQLiteをベースとしたAPIですので、WebAssembly版のSQLiteによる代替は適切な選択だといえるでしょう。

また、すでにSQLiteのWebAssembly実装はVMwareのWasm Labsによる実験的実装が存在するため、実現可能性も十分にあることが実証されています。

参照:PHPとSQLiteをWebAssembly化し、Webブラウザ上でWordPressを実行可能にしたデモをVMwareが公開

ただしこの実験的実装ではデータベースをメモリ上に構築した仮想的なファイルシステムで行っているため、Webブラウザを閉じてしまえばデータは消えます。これではデータベースを使う意味がほとんどありません。

WebAssembly版SQLiteからローカルファイルへ書き込んで永続化も

そこでChrome開発チームがWebAssembly版SQLiteで採用する予定なのがFile System Access API(旧Native File System API)です。

参考:Chrome 78ベータに「Native File System API」搭載。Webブラウザからローカルファイルを読み書き可能に

File System Access APIは、Webブラウザからローカルのファイルシステムを読み書き可能にするAPIです。これを使うことでWebAssembly版SQLiteからローカルファイルシステムにデータベースを書き込んで永続化することが可能になります。

このWebAssembly版SQLiteが実現すれば、Webアプリケーションでもリレーショナルデータベースを活用した高機能なアプリケーションの可能性が急速に広がっていくのではないでしょうか。

WebAssemblyを使うことで、Webブラウザに対してさまざまな機能拡張ができる例をこれまでも記事で紹介してきました(関連記事参照)。SQLiteのWebAssembly実装は、その先端的事例の1つとして注目されることになるはずです。登場を心待ちにしたいと思います。

関連記事

  • PHPとSQLiteをWebAssembly化し、Webブラウザ上でWordPressを実行可能にしたデモをVMwareが公開
  • WebAssembly化したPostgreSQLをWebブラウザ上で実際に動かして学ぶ「Postgres playground」をCrunchy Dataが公開
  • 「PyScript」はJavaScriptのようにPythonコードをHTML内に記述して実行可能、Anacondaがオープンソースで公開
  • WebAssembly/WASIに対応した「Ruby 3.2 Preview 1」公開。WebブラウザでRubyが動く世界がやってくる

COMMENTS


Recommended

TITLE
CATEGORY
DATE
ヴイエムウェア、「混迷するクラウドをスマートにする」新製品を多数発表
IT関連
2022-09-02 21:17
味の素がZ世代対象事業創出の専任組織を新設、スタートアップや大学と新たな価値共創
フードテック
2021-04-01 00:36
フェイスブックもグーグルと同様に職場復帰する従業員にワクチン接種を義務付け
パブリック / ダイバーシティ
2021-08-01 09:51
「呪術廻戦UT」6月発売 ユニクロと初コラボ
くらテク
2021-05-11 03:11
Appleフェローのフィル・シラー氏「最も誇りに思うのはiPod」
IT関連
2021-07-30 05:34
バイデン大統領の民主主義サミットのコミットメント拡大にはパートナーシップが鍵となる
IT関連
2022-02-15 02:08
顧客エンゲージメントのノウハウを可視化しアクションを提案する営業支援SaaSのMagic Momentが6.6億円調達
ネットサービス
2021-04-14 18:51
ノースロップ・グラマンが軌道上の古い衛星の再生に成功、衛星の寿命を5年延ばす
宇宙
2021-04-18 17:08
遠くにいる者同士で並んで散歩できるテレプレゼンス散歩 東大など開発 :Innovative Tech
トップニュース
2021-01-27 12:54
お金の未来を探る–ブロックチェーンと仮想通貨がもたらす変化
IT関連
2022-01-28 12:44
IBMが量子コンピュータの開発者認定を開始
ソフトウェア
2021-03-31 16:22
AIが最適ルート判断、乗り合いバス 大阪で社会実験スタート
IT関連
2021-04-02 03:23
携帯3社、料金の支払い期限を延長 コロナ禍で支払いが困難な人向けに
企業・業界動向
2021-01-22 12:27
「Chrome 90」の安定版公開 HTTPS接続強化や低帯域幅での動画改善など
アプリ・Web
2021-04-16 10:53