Skip to content

Projet INSA Lyon 4e année : écrire sa propre Blockchain en partant de zéro

Notifications You must be signed in to change notification settings

gforien/DistributedBuildYourBlock

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Distributed Build Your Block

Le but de ce tutoriel est de coder une blockchain depuis zéro pour en comprendre les mécanismes. Cette blockchain sera très loin d'une blockchain de production mais permettra d'illustrer les différentes mécaniques la constituant. Les notions et les problématiques seront introduites au fur et à mesure de la progression. Certaines seront un peu simplifiées.

Le code se fait en Javascript pour permettre au plus grand nombre de réaliser ce tutoriel et parce que c'est le langage de programmation que j'utilise quotidiennement :D. L'environnement utilisé pour l'écriture de ce sujet est Node.js (https://nodejs.org/fr/) en version 12 avec npm pour gérer les dépendances mais il doit fonctionner à partir de la version 10.

Ce tutoriel est la seconde itération, vous pouvez trouver la première là : https://github.com/dreimert/BuildYourBlock.

Prérequis

Je pars du principe que vous savez coder en Javascript et utiliser git et github. Si ce n'est pas le cas, je vous invite pour le prochain TD à lire :

Installation de node

Télécharger les binaires et les décompresser :

wget https://nodejs.org/dist/v12.8.1/node-v12.8.1-linux-x64.tar.xz
tar -xJvf node-v12.8.1-linux-x64.tar.xz

Mettre à jour votre PATH :

echo "export PATH=$PATH:$(pwd)/node-v12.8.1-linux-x64/bin/" >> ~/.bashrc

Recharger vos variables d'environnement :

. ~/.bashrc

Vérifier que node s'exécute bien :

node --version

Cloner ce dépôt

git clone https://github.com/dreimert/DistributedBuildYourBlock.git
cd DistributedBuildYourBlock
npm install

Objectif

Les buts de cette étape sont :

  • Mettre en place l'environnement du tutoriel.
  • Comprendre les bases de socket.io.
  • Comprendre le fonctionnement d'une base de données minimaliste.

Une base de données minimaliste

J'ai réalisé pour vous un serveur de base de données minimaliste. Pour l'exécuter, taper la commande : node db.js.

La base de données n'accepte que deux commandes : get et set :

  • get : permet de récupérer la valeur d'une clé. Si la clé n'existe pas, retourne null.
  • set : permet d'associer une valeur à une clé. Si la clé existe déjà, elle n'est pas modifiée et la commande retourne false. Sinon, la valeur est affecté à la clé et la commande retourne true.

Pour illustrer le fonctionnement, vous pouvez lancer plusieurs fois le client : node db-client.js.

Est-ce que le serveur se comporte comme la spécification ?

Vous pouvez voir le code du serveur et du client dans les fichiers db.js et db-client.js. Corrigez le code pour que le serveur soit conforme à la spécification.

Socket.io

Pour gagner du temps, j'utilise socket.io qui me permet d'établir une connexion entre le serveur et le client. Vous pouvez trouver la documentation là : https://socket.io/.

Nous n'utiliseront pas beaucoup plus de fonctionnalités que celles utilisés dans l'exemple de la base de données. Il faut savoir envoyer et recevoir un message.

Keys

Vous allez implémentez une nouvelle commande keys dans le serveur de la BDD. Cette commande retourne un tableau de toutes les clés de la base de données. Si la base de données est vide, la commande retourne un tableau vide. Pour obtenir la liste des clés d'un object : Object.keys(monObject).

Implémentez la nouvelle commande keys.

Conclusion

Vous avez survécu ? Cool !

Quel est le rapport entre cette base de données et la blockchain ? La blockchain est une base de données avec les propriétés décrites. On ne peut pas mettre à jours les données ni en supprimer, on ne peut qu'en ajouter et lire le contenu.

Mais la blockchain est une base de données distribuées, ce qui n'est pas le cas de la notre qui raisonne en terme de client / serveur. On va essayer de corriger ça !

Suite

Aller à l'étape 2 : git checkout etape-2.

Pour continuer à lire le sujet :

  • soit vous lisez le fichier README.md sur votre machine.
  • soit sur GitHub, au-dessus de la liste des fichiers, vous pouvez cliquer sur Branch: master et sélectionner etape-2.

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%