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-03-02 19:42
ニコ動に“プレミア公開”風機能 新作動画を公開と同時に「ニコ生」で配信
企業・業界動向
2021-08-03 16:54
折り畳みディスプレイは弱点克服 次は「三つ折り」「ローラブル」?──モバイル端末の2021年を占う (1/3)
くわしく
2021-01-13 23:17
AWS、DWHサービスのサーバーレス版「Redshift Serverless」を提供開始
IT関連
2022-07-15 23:57
メルカリUS、即日配送を全米展開 Uberと連携
ネットトピック
2021-07-22 20:01
製造業での「2025年の崖」認知度が低い状況に–八千代ソリューションズ調査
IT関連
2025-01-23 05:21
「ソーシャルイノベーション企業」を目指すNTT東日本社長の熱い思いとは
IT関連
2023-02-11 07:21
パナソニック、ローカル5Gの実証実験を開始
IT関連
2021-01-19 13:08
あの恐竜骨格を360度見回せる 科博のティラノサウルスなど9体のVRモデル公開
IT関連
2021-01-20 09:14
Rust Foundationの初代会長にAWSのRustプラットフォームチーム率いるミラー氏
IT関連
2021-04-12 18:57
ワークスモバイルジャパン、「LINE WORKS」のメジャーアップデートを発表
IT関連
2022-10-18 21:03
[速報]オラクル、OpenJDKコミュニティにGraalVM CEのJava関連コードを寄贈すると発表。JavaOne 2022
GraalVM
2022-10-19 05:19
富士通と武田薬品ら、卵巣がん患者の「ペイシェントジャーニー」可視化に向けた研究開始
IT関連
2021-05-18 10:54
北朝鮮ハッカー、偽企業を立ち上げセキュリティ研究者を攻撃–グーグルが指摘
IT関連
2021-04-02 05:42