はじめに
ここでは、自分なりの視点で、2022年末時点でのブロックチェーンとデータベースについての覚書を整理してみたいと思います。
Blockchain-based Database
まず、初めに、Wikipediaを見てみます。
まずは冒頭、
The blockchain-based database is a combination of traditional database and distributed database where data is transacted and recorded via Database Interface(also known as Compute Interface) supported by multiple-layers of blockchains. The database itself is shared in the form of an encrypted/immutable ledger which makes the information open for everyone.
ブロックチェーンベースのデータベースとは、従来のデータベースと分散型データベースとの組み合わせであり、そこでは、データは、ブロックチェーンの複数の層でサポートされているデータベース インターフェース(コンピュート インターフェースとも呼ばれる)を介して処理および記録されます。データベース自体は、暗号化されたイミュータブルな台帳の形で共有され、情報は全ての人に対して公開されます。
「従来のデータベースと分散型データベースとの組み合わせ」について、Wikipediaの続きの部分から見てみると...
The idea behind the blockchain based database concept is to complement the functionality and features of SQL and NoSQL databases with blockchain properties: data immutability, integrity assurance, decentralized control, Byzantine fault tolerance and transaction traceability.
ブロックチェーンベースのデータベースというコンセプトの背後にあるアイディアは、データの不変性、完全性保証、分散制御、ビザンチンフォールトトレランス、トランザクショントレーサビリティなどのブロックチェーンのプロパティを用いて、SQLおよびNoSQLデータベースの機能と機能を補完することです。
このようにあります。「従来のデータベースと分散型データベースとの組み合わせ」という表現は、元々「分散型データベース」という表現が、ブロックチェーン以外で成立していたことを度外視した表現なのかなと感じました。「分散型データベース」といえば、NoSQLを、それに対する「従来のデータベース」といえばRDB/SQLを想像してしまう筆者のような者には、なにやら訳の分からないキメラのようなものを連想させられましたが、これは、「従来の(SQL/RDBあるいはNoSQL)データベースと(ブロックチェーンという)分散型テクノロジーとの組み合わせ」という意味で理解することができるかと思われます。
そこで、マーケットを見てみると、既存のデータベース(SQL/RDBあるいはNoSQL)をローカルデータベースとして利用し、ブロックチェーンを実現しているテクノロジーがいくつか存在しています。
トップ7(のうち6つ)
そこで、ここでは以下のブログ記事に注目してみます。
ここで紹介されているのは、以下の7つのデータベースです。
- BigchainDB
- Apache Cassandra
- ChainifyDB
- CovenantSQL
- Modex BCDB
- Postchain
- ProvenDB
BigchainDBは、MongoDB を利用したブロックチェーンベースのデータベースであり、アプリケーションに分散化されたブロックチェーンテクノロジーをアプリケーションから利用するために使うことができます。記事中にも、「世界で最も人気のあるブロックチェーン データベース」と書かれており、Googleの検索でも、上位に表示されています。
ChainifyDBは、BigchainDBは、MongoDBを利用しているのとは異なり、独自のデータベースを持たず、外部から提供されたデータベースを用いて、プロックチェーンレイヤーとの接続を行うところにあります。
CovenantSQLは、分散型アプリを構築するためのインフラストラクチャを提供します。これは、いわばEthereumの位置付けと同等と捉えられます。CovenantSQLは、その名の通り、ブロックチェーンアプリケーション開発に、SQLサポートを提供します。
Modex BCDB は、複数のブロックチェーンフレームワークを使用できるという点に特徴があります。
現在、Hyperledger Sawtooth フレームワークが主に使用されており、他のフレームワークである Ethereum やHyperledger Fabric も使用できます。
Postchain は、Ethereum や Hyperledger と同様のブロックチェーン フレームワークです。Postchain は、データを SQL データベースに保存します。また、Postchain のトランザクション ロジックは SQL コードで定義できます。
ProvenDB はブロックチェーン対応のデータベース サービスです。内部的には、MongoDBが利用されています。
ここで、「ブロックチェーン対応のデータベース」とは何かといえば、いったんデータが入力されるとデータは不変であり、改ざんが防止されたデータベース、ということになるようです。財務記録、知的財産、法的文書、公的記録などの機密データを保存する目的で利用することができます。
残りの一つ(Cassandra)
トップ7中、BigchainDBに続く2番目に登場していながら、Cassandraは、その他のデータベースとは全く異なる視点から選ばれています。いわく「Cassandra には、独自のブロックチェーンベースの DB となる多くの注目すべき機能があります。」実際、Cassandra自体は、ブロックチェーンの機能を提供するわけでもなければ、逆に内部的にブロックチェーンのテクノロジーを活用しているわけでもありません。
そこで、「Cassandra」と「Blockchain」をキーワードに情報収集をしてみると、以下のようなE-BookがDataStax社から発行されていることに気がつきました(DataStax社はApache Cassandraのエンタープライズ向けディストリビューションとサポートを提供しています)。
この資料から一部引用します。なるほど、Blockchainへ直接、書き込みながら、「Exportor」を使って、検証済みのトランザクションをCassandraへ入力することで、読み込みのリクエストを肩代わりさせる、という構成が提案されているのが分かります。
なお、上記の図で、Astra DBとあるのは、DataStaxが提供するCassandraのマネージドサービスです。
そこで、Astra DBでの、ブロックチェーン利用について、さらに情報を求めてみたところ、以下のブログが見つかりました。
ブログの内容自体には踏み込みませんが、そこからAstra DBの公式ドキュメントとして、クィックスタートとして、サンプルアプリが紹介されていました。
ここでは、それらの画面イメージを紹介したいと思います。
こちらは、NFTの情報を表示するWEBアプリです。
また、こちらはイーサリアムのトランザクション情報を表示するWEBアプリです。
最後に
本稿については、ここで筆を置きたいと思います。
ブロックチェーンというテーマに対して、データベース技術者として、今何に注目しておくべきか、という観点から、概観を整理しました。後は、より具体的な目的に対して、どこに注目すべきか、という方向性のようなものが、朧げにでも伝わったようでしたら、幸いです。自分としては、ブロックチェーンとデータベースとの関係についてウォッチしながら、また機会を見て、情報発信できればと思っています。
ここまで、お付き合いいただき、ありがとうございました。
補足:Astra Block (2023/2/9追記)
2022年末にBlockchain Adventカレンダーに参加した際には、Cassandraとブロックチェーンとの関わりについては、特に実装の面で実現しているものとしては、サンプルプログラムのレベルで触れることができたのみでした。
米国時間の昨日2023年2月8日に下記の発表が行われたことをきっかけとして、追記したいと思います。
以下は、冒頭部分からの意訳です。
DataStax Astra Blockを使用して、リアルタイムの Ethereum ブロックチェーン データを Web3 アプリにストリーミングできるようになりました。Astra DB は、ブロックチェーン アプリケーションに最適な DBaaS です。Astraは、全世界規模の大量データを、低レイテンシ、高スループットで利用できるだけでなく、任意のクラウドを選択できる従量課金性のサーバーレスアーキテクチャを要しています。
以下は、Astra BlockのDataStax製品ページです。
参考情報
その他、DataStaxから、以下のような各種情報が発信されています。
Web3: What is It?
Web2 vs. Web3: Explained
What is Web3, Blockchain, NFTs.
What is Ethereum?
What is Blockchain technology?
What is Web3.js?
Why Web3 Needs Real Time Data
サンプルアプリコード
紹介したサンプルアプリのコードは、以下から参照できます。
Block Explorer