Heim >Backend-Entwicklung >Python-Tutorial >Verwalten von Datenspeicher mit Blockchain und Bigchaindb
Kernpunkte
Obwohl die Zukunft von Bitcoin unklar ist, hat die zugrunde liegende Technologie, von der sie abhängt - Blockchain -, viele Branchen und Projekte vollständig verändert, und es werden weitere Anwendungen entstehen.
Zuschreiben ist ein überzeugendes Startup, das die Bitcoin -Blockchain verwendet, um eine begrenzte Anzahl eindeutiger Kennungen für digitale Kunstwerke aufzuzeichnen. Aufgrund dieser begrenzten Anzahl von „Kopien“ sind sie daher nachvollziehbar, rechenschaftspflichtig und (hoffentlich) höherer Wert.
zuschreibe auf technische Probleme bei der Verwendung dieser Methode, die hauptsächlich aus der Bitcoin -Blockchain selbst stammte. Es ist langsam, alles zu schreiben, teuer (derzeit 80 Cent pro Zeit) und begrenzte tägliche Einträge und Gesamtschreibkapazität. Es steht auch im Gegensatz zu typischen skalierbaren Datenbanktechniken, wenn das Hinzufügen von Knoten die Leistung nicht verbessert und es keine wirkliche Abfragesprache gibt. Dies macht die Unternehmenserweiterung auf der Grundlage von Bitcoin -Blockchain zu einer Herausforderung.
Das Blockchain -Konzept ist jedoch ein starkes Konzept, und seine Verwendung und Legitimität haben in den letzten Jahren zugenommen, und selbst große Banken haben angekündigt, dass sie Technologien entwickeln, die vom Konzept inspiriert sind.
zuschreibe beschlossen, die Vorteile der beiden zu kombinieren, wobei eine bewährte NoSQL -Datenbank (RethinkDB) eingenommen und eine Blockchain -Schicht hinzugefügt wird, um die Steuerung, die Verfolgung von Anlagen und zusätzliche Sicherheitsstufen zu verbessern.
Die Kombination dieser Technologie ist für NoSQL -Datenbankbenutzer besonders attraktiv, da die Unterstützung von NoSQL -Datenbank traditionell dazu beigetragen hat, dass die Datenbankänderungen "Transaktionen" aufgetreten sind. BigChaindb fügt die Transaktionsunterstützung hinzu, indem sie über die Blockchain -Schicht in die zugrunde liegende NoSQL -Datenbank schreibt.
bigChaindb behauptet auch, aufgrund der Blockchain -Schicht vollständig dezentralisiert zu sein. Während viele verteilte NoSQL-Datenbanken behaupten, dezentralisiert zu werden, gibt es häufig Pseudo-Master-/Slave-Einstellungen.
installieren BigChaindb und seine Abhängigkeiten
Es gibt verschiedene Möglichkeiten, BigChaindb zu installieren. Zuerst habe ich Docker Image ausprobiert, aber auf einige Verbindungsprobleme gestoßen und stellte fest, dass das Python -Paket am zuverlässigsten ist.
Einfaches Beispiel - Nachrichtenzuweisung und Verfolgung
Einer der Hauptanwendungsfälle von BigChaindb (und warum es geschaffen wurde) ist es, Assets zu verfolgen. Lassen Sie uns also ein einfaches Beispiel in Python erstellen. Führen Sie zuerst den folgenden Befehl in Ihrem Terminal aus.
<code class="language-bash">pip install bigchaindb bigchaindb configure bigchaindb show-config</code>
Erstellen Sie eine neue Datei, app.py und fügen Sie Folgendes hinzu:
<code class="language-python">from bigchaindb import Bigchain b = Bigchain() print(b)</code>
Importieren Sie die BigChaindb -Bibliothek, erstellen Sie ein neues Objekt und verbinden Sie sie mit der gerade erstellten Einstellungsdatei.
Führen Sie dann die Python -Anwendung aus:
<code class="language-bash">python app.py</code>
Sie sollten so etwas wie <bigchaindb.core.bigchain at></bigchaindb.core.bigchain>
sehen, was uns sagt, dass alles in Ordnung ist.
Fügen Sie Folgendes hinzu:
<code class="language-python">from bigchaindb import Bigchain import time b = Bigchain() spuser_priv, spuser_pub = b.generate_keys() print("User Created") digital_asset_payload = {'msg': 'This is my special message just for you'} tx = b.create_transaction(b.me, spuser_pub, None, 'CREATE', payload=digital_asset_payload) print("Transaction Written") tx_signed = b.sign_transaction(tx, b.me_private) b.write_transaction(tx_signed) print ("Transaction Written to BC, now waiting") time.sleep(10) tx_retrieved = b.get_transaction(tx_signed['id']) print(tx_retrieved)</code>
Dies erstellt einen Benutzer und zu dem zugeordneten Schlüssel zum Zugriff auf die Datenbank. Denken Sie an die zusätzliche Sicherheitsstufe. Erstellen Sie dann eine Nutzlast zum Schreiben in die Datenbank, weisen Sie den erforderlichen Schlüssel zu und schreiben Sie sie.
Wie viele Sekunden dauert eine neue Transaktion, um von der Blockchain -Schicht in die Datenbank zu gelangen. Der Code wartet zehn Sekunden lang und ruft dann den Datensatz ab und druckt. Sie sollten so etwas wie Folgendes sehen:
<code class="language-json">{ "signature": '304502205...', "id": "0f442bcf4a42...", "transaction": { "timestamp": "1457104938.430521", "data": { "hash": "b32779e57...", "payload": { "msg": "This is my special message just for you" } }, "operation": "CREATE", "current_owner": "hFJKYk2...", "new_owner": "26pdiQTTx...", "input": None } } }</code>
Sie haben jetzt eine spezielle Nachricht, dass eine Person zugreifen kann:
<code class="language-python">... print("Now to transfer") spuser2_priv, spuser2_pub = b.generate_keys() print("Second User Created") tx_transfer = b.create_transaction(spuser_pub, spuser2_pub, tx_retrieved['id'], 'TRANSFER') print("Transfer Created") tx_transfer_signed = b.sign_transaction(tx_transfer, spuser_priv) b.write_transaction(tx_transfer_signed) print ("Transaction Written to BC, now waiting") time.sleep(15) tx_transfer_retrieved = b.get_transaction(tx_transfer_signed['id']) print("Transferred") print(tx_transfer_retrieved)</code>
Dies erstellt einen zweiten Benutzer, erstellt dann die Transaktions -ID der speziellen Nachricht und überträgt sie an den zweiten Benutzer. Die Blockchain -Ebene von BigChaindb hindert Benutzer und Ihr Code daran, die gleichen Vorgänge zweimal auszuführen. Wenn Sie versuchen, den obigen Code erneut auszuführen, wird eine doppelte Ausgabenausnahme ausgelöst.
Dieses Beispiel zeigt einen kleinen Teil davon, wie Bigchaindb zu RethinkDB hinzugefügt wird, und hier ist eine vollständige Liste verfügbar.
http Endpoint
Derzeit ist die einzige Clientbibliothek, die für BigChaindb verfügbar ist, Python, und es kann mehr Bibliotheken geben, aber gleichzeitig kann ein begrenzter HTTP -Endpunkt verwendet werden, um vorhandene Transaktionen abzufragen:
https://www.php.cn/link/6eea81fa0417b0068e614074225a9daf
oder schreiben Sie eine neue Transaktion mit der folgenden Methode:
https://www.php.cn/link/f8b64946ebc86a5e23e1605a2943210c
Fügen Sie die folgende Nutzlast hinzu, wobei der Vorgang zu verschiedenen Arten von Transaktionen geändert werden kann, die geschrieben werden können:
<code class="language-json">{ "id": "", "signature": "", "transaction": { "current_owner": "", "data": { "hash": "", "payload": null }, "input": null, "new_owner": "", "operation": "", "timestamp": "" } }</code>
Komponenten der dezentralen Zukunft
Ignorieren Sie den Ursprung seiner Blockchain vorerst, Bigchaindb bietet eine große Anzahl von Funktionen, die in aktuellen NoSQL und verteilten Datenbanken fehlen. Allein diese Tatsache kann der Grund sein, es zu versuchen, und kann einen gültigen Geschäfts-/Anwendungsfall bereitstellen.
Für Blockchain -Enthusiasten unter Ihnen wird auch das Puzzle eines vollständigen dezentralen Anwendungsstapels vervollständigt. Theoretisch gibt es jetzt Ethereum für Anwendungen, IPFs für Dateisysteme und BigchaNDB für die Datenspeicherung. Diese Komponenten legen die Voraussetzungen für sehr unterschiedliche Methoden für die Entwicklung, Bereitstellung und Wartung von Anwendungen und schaffen eine faszinierende Zukunft, und ich hoffe, Ihre Kommentare in den Kommentaren unten zu hören.
(Der FAQ-Teil wird hier weggelassen, da dieser Teil nur eine einfache Zusammenfassung und Nacherzählung des Inhalts des Artikels ist und nicht in die Kategorie der Pseudooriginalität fällt.)
Das obige ist der detaillierte Inhalt vonVerwalten von Datenspeicher mit Blockchain und Bigchaindb. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!