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関連
2024-02-17 11:14
テクノロジーで難民を支える–ロゼッタストーンと支援団体の取り組み
IT関連
2022-07-13 02:47
契約審査プラットフォームのLegalOn Technologies、生成AI・LLM分野に5億円の投資
IT関連
2023-04-25 14:47
「Linux」でのトラブルシューティングで知っておくべきコマンド5選
IT関連
2024-06-21 05:07
「チケットぴあ」店舗運営を終了 ネットに移行、「役目果たした」
くらテク
2021-04-11 10:01
ITサービスの大手ベンダートップ6にアクセンチュアが浮上–IDC調査
IT関連
2023-07-13 03:24
ワクチンパスポート普及に課題 国際規格の統一に壁
IT関連
2021-07-22 01:04
「Slack」で特定の日付の投稿を見つけるには
IT関連
2023-05-10 01:41
吉野家、公式通販ショップに機械学習を活用した不正取引防止サービスを導入
IT関連
2021-04-12 19:14
MS、中国ハッカー集団によるメール不正アクセスを公表–政府機関も標的
IT関連
2023-07-14 12:05
Microsoft、「Azure」の新アイコン発表 「Fluent Design System」準拠
アプリ・Web
2021-05-10 00:48
IIJ、時系列でIDや組織マスターを管理可能なクラウドサービスを開始
IT関連
2024-08-01 20:24
キヤノンITS、クラウド型ローコード開発基盤「WebPerformer-NX」を発表
IT関連
2022-11-27 19:14
満足度は高いプログラミング言語「Go」–一部機能の不足に不満も
IT関連
2021-05-08 12:15