Как сделать свой блокчейн. Часть 1 — Создание, Хранение, Синхронизация, Отображение, Майнинг и Доказательная работа
Доброго всем! Мы тут потихоньку начали исследовать новое совсем для нас направление для обучения — блокчейны и нашли то, что оказалось интересным в рамках нашего курса по
Python, в том числе. Чем, собственно, и хотим поделиться с вами.
Я могу узнать, когда у меня появился первый Bitcoin, из истории кошелька в моем аккаунте на Coinbase — входящая транзакция в 2012 году в подарок за регистрацию. Bitcoin в то время стоил около 6.50$. Если бы я сохранил те 0.1 BTC, на момент написания статьи это бы уже стоило более 500$. Если кому-то интересно, я продал их, когда Bitcoin стоил 2000$. Так что я получил только 200$ вместо ныне возможных 550$. Не стоило торопиться.
О существовании Bitcoin я знал, но особо не интересовался. Я видел взлеты и падения курса $/BTC. Я видел, как люди говорят, что за ним будущее, а видел статьи о его полной бессмысленности. Но личного мнения у меня не было — просто наблюдал со стороны.
И тогда я внезапно понял, что нужно чуть глубже разобраться в этой теме. И начал с “исследования” — прочитал огромное количество статей в интернете, объясняющую их суть. Некоторые были хорошие, некоторые плохие, некоторые глубокие, а некоторые очень поверхностные.
Чтения оказалось недостаточно, а если существует одна вещь, которую я знаю наверняка, так это то, что чтение не объяснит и сотой доли того, что объяснит программирование. И так я понял, что стоит написать свой собственный локальный блокчейн.
Нужно учитывать, что есть большая разница между базовым блокчейном, который я описываю и “профессиональным” блокчейном. Эта цепь не создаст криптовалюту. Блокчейны не требуют производства монет, которые можно продавать и менять на физические деньги.
Блокчейны используются для хранения и подтверждения информации. Монеты побуждают узлы участвовать в валидации, но их наличие не обязательно.
Я пишу пост по нескольким причинам: 1) Чтобы люди, прочитавшие его, смогли узнать больше о блокчейнах; 2) Чтобы я смог понять больше, объяснив код, а не просто написав его.
В этом посте я покажу способ хранения данных блокчейна и генерации начального блока, синхронизацию узла с локальными данными блокчейна, отображение блокчейна (что впоследствии будет использоваться для синхронизации с другими узлами), а затем, майнинг и создание валидных новых блоков. В первом посте не будет никаких других узлов. Никаких кошельков, пиров, важных данных. О них поговорим позднее.
В двух словах
Если вы не хотите углубляться в детали и читать код, или если вы наткнулись на этот пост, рассчитывая на статью, которая бы понятным языком объясняла блокчейны, я постараюсь кратко резюмировать, как они работают.
На самом высоком уровне, блокчейн — база данных, где каждый, участвующий в блокчейне, может хранить, просматривать, подтверждать и никогда не удалять данные.
На более низком уровне, данные в этих блоках могут быть чем угодно, пока это позволяет конкретный блокчейн. Например, данные в Bitcoin блокчейне — исключительно транзакции Bitcoin между аккаунтами. Ethereum блокчейн позволяет как аналогичные транзакции Ether, так и транзакции, использующиеся для запуска кода.
Прежде чем блок будет создан и объединен в блокчейн, он подтверждается большинством людей, работающих над блокчейном — их называют узлами. Настоящий блокчейн — цепь, состоящая из огромного множества блоков, подтвержденных большинством узлов. Таким образом, если узел попытается изменить данные предыдущего блока, новые блоки не будут валидны, и узлы не будут доверять данным из некорректного блока.
Не волнуйтесь, если это сбивает с толку. Мне понадобилось время, чтобы самому вникнуть в это, и еще больше времени на написание такого поста, чтобы даже моя сестра (которая ничего не знает о блокчейнах) смогла понять.
Если хотите изучить код, посмотрите ветку part 1 на Github. Смело присылайте мне любые вопросы, комментарии, правки и похвалы (если вы в настроении сделать что-то особо хорошее), или просто пишите в твиттер.
Шаг 1 — Классы и Файлы
Первый шаг — написание класса, обрабатывающего блоки при запуске узлов. Я назову этот класс Block. Честно говоря, много делать не придется. В функции __init__ мы будем верить, что вся необходимая информация уже представлена в словаре. Для производственного блокчейна — это не самое мудрое решение, но подходит в качестве примера, потому что код пишу только я. Также я напишу метод, запаковывающий важную информацию блока в словарь, а после заведу более удобный способ для отображения информации блока при его печати в терминал.
class Block(object):
def __init__(self, dictionary):
'''
We're looking for index, timestamp, data, prev_hash, nonce
'''
for k, v in dictionary.items():
setattr(self, k, v)
if not hasattr(self, 'hash'): #in creating the first block, needs to be removed in future
self. hash = self.create_self_hash()
def __dict__(self):
info = {}
info['index'] = str(self.index)
info['timestamp'] = str(self.timestamp)
info['prev_hash'] = str(self.prev_hash)
info['hash'] = str(self.hash)
info['data'] = str(self.data)
return info
def __str__(self):
return "Block<prev_hash: %s,hash: %s>" % (self.prev_hash, self.hash)
Чтобы создать первый блок, запустим этот простой код:
def create_first_block(): # index zero and arbitrary previous hash block_data = {} block_data['index'] = 0 block_data['timestamp'] = date.datetime.now() block_data['data'] = 'First block data' block_data['prev_hash'] = None block = Block(block_data) return block
Отлично. Последний вопрос в этой части — где хранить данные в файловой системе. Это необходимо, если мы не хотим потерять локальные данные блока при отключении узла.
Я назову папку с данными ‘chaindata’, в какой-то степени подражая схеме папок Etherium Mist. Каждому блоку теперь присвоен отдельный файл, названный по его индексу. Нужно убедиться, что имена файлов содержат в начале достаточное количество нулей, чтобы блоки перечислялись по порядку.
С учетом кода выше, нужно написать следующее для создание первого блока:
#check if chaindata folder exists.
chaindata_dir = 'chaindata'
if not os.path.exists(chaindata_dir):
#make chaindata dir
os.mkdir(chaindata_dir)
#check if dir is empty from just creation, or empty before
if os.listdir(chaindata_dir) == []:
#create first block
first_block = create_first_block()
first_block.self_save()
Шаг 2 — Синхронизация блокчейна, локально
Прежде чем начать майнинг, интерпретацию данных или отправку/создание новых данных для цепи, необходимо синхронизировать узел. В нашем случае других узлов нет, поэтому я говорю только о чтении блоков из локальных файлов. В будущем частью синхронизации будет не только чтение из файлов, но и коммуникация с пирами для сбора блоков, которые были сгенерированы, пока ваш узел не был запущен.
def sync(): node_blocks = [] #We're assuming that the folder and at least initial block exists chaindata_dir = 'chaindata' if os.path.exists(chaindata_dir): for filename in os.listdir(chaindata_dir): if filename.endswith('.json'): #.DS_Store sometimes screws things up filepath = '%s/%s' % (chaindata_dir, filename) with open(filepath, 'r') as block_file: block_info = json.load(block_file) block_object = Block(block_info) #since we can init a Block object with just a dict node_blocks.append(block_object) return node_blocks
Пока просто и красиво. Чтение строк из файлов их загрузка в структуры данных не требуют чрезмерно сложного кода. Пока это работает. Но в будущих постах, где я буду писать о возможностях коммуникации разных узлов, эта функция sync станет значительно сложнее.
Шаг 3 — Отображение блокчейна
Теперь наш блокчейн находится в памяти, и поэтому я хочу отобразить цепь в браузере. Для того, чтобы сделать это прямо сейчас, есть две причины. Во-первых, необходимо подтвердить в браузере, что изменения произошли. Во-вторых, я буду использовать браузер в будущем для просмотра и совершения каких-либо операций, связанных с блокчейном. Например, отправка транзакций или управление кошельком.
Для этого я использую Flask — у него низкий порог вхождения, и я решил, что он подходит для наших целей.
Ниже представлен код для отображения json блокчейна. Я проигнорирую импорты для экономии места.
node = Flask(__name__)
node_blocks = sync.sync() #inital blocks that are synced
@node.route('/blockchain.json', methods=['GET'])
def blockchain():
'''
Shoots back the blockchain, which in our case, is a json list of hashes
with the block information which is:
index
timestamp
data
hash
prev_hash
'''
node_blocks = sync.sync() #regrab the nodes if they've changed
# Convert our blocks into dictionaries
# so we can send them as json objects later
python_blocks = []
for block in node_blocks:
python_blocks. append(block.__dict__())
json_blocks = json.dumps(python_blocks)
return json_blocks
if __name__ == '__main__':
node.run()
Запустите этот код, зайдите на localhost:3000/blockchain.json и увидите текущий блок.
Шаг 4 — “Майнинг”, также известный как создание блока
Сейчас есть только генезис блок, но если у нас появится больше данных, которые необходимо хранить и распределять, нужен способ включить это в новый блок. Вопрос — как создать новый блок и соединить его с предыдущим.
Сатоши описывает это следующим образом в Bitcoin whitepaper. Учтите, что “timestamp сервер” назван “узлом”.
“Начнем описание нашего решения с timestamp сервера. Его работа заключается в хэшировании блока данных, на который нужно поставить timestamp, и открытой публикации этого хэша… Timestamp показывает, что в данный момент конкретные данные существовали и потому попали в хэш блока. Каждый хэш включает в себя предыдущий timestamp: так выстраивается цепь, где очередное звено укрепляет все предыдущие. ”
Скриншот изображения, прикрепленного под описанием:
Основная идея раздела — при необходимости соединить блоки, мы создаем хэш информации о новом блоке, включая время создания блока, хэш предыдущего блока и информацию в самом блоке. Я буду называть всю эту информацию “хедером” блока. Таким образом, мы можем проверить корректность блока, посчитав все хэши перед ним, подтвердив последовательность.
В данном случае хедер, который я создаю, объединяет значения строки в одну огромную строку. Я включил следующие данные:
- Индекс, показывающий каким по счету является блок;
- Хэш предыдущего блока;
- Данные — просто случайные строки. Для bitcoin они называются Merkle root и содержат информацию о транзакциях;
- Timestamp майнинга этого блока.
def generate_header(index, prev_hash, data, timestamp):
return str(index) + prev_hash + data + str(timestamp)
Поясню один момент — объединение строк информации не является обязательным для создания хедера.
Требование состоит в том, чтобы каждый знал, как генерировать хедер блока и хэш предыдущего блока внутри него. Делается это для того, чтобы каждый мог убедиться в корректности хэша в новом блоке и подтвердить связь между двумя блоками.Хедер Bitcoin значительно сложнее объединения строк. Он использует хэши данных и времени и завязан на то, как данные расположены в памяти. Но в нашем случае объединения строк достаточно.
Теперь у нас есть хедер и можно вычислить валидность хэша. Я буду использовать метод, отличающийся от метода Bitcoin, но все равно запущу хедер блока через функцию sha256.
def calculate_hash(index, prev_hash, data, timestamp, nonce):
header_string = generate_header(index, prev_hash, data, timestamp, nonce)
sha = hashlib.sha256()
sha.update(header_string)
return sha.hexdigest()
Для майнинга блока мы используем функцию выше, чтобы получить хэш, положить его в новый блок и сохранить этот блок в директории chaindata.
node_blocks = sync. sync()
def mine(last_block):
index = int(last_block.index) + 1
timestamp = date.datetime.now()
data = "I block #%s" % (int(last_block.index) + 1) #random string for now, not transactions
prev_hash = last_block.hash
block_hash = calculate_hash(index, prev_hash, data, timestamp)
block_data = {}
block_data['index'] = int(last_block.index) + 1
block_data['timestamp'] = date.datetime.now()
block_data['data'] = "I block #%s" % last_block.index
block_data['prev_hash'] = last_block.hash
block_data['hash'] = block_hash
return Block(block_data)
def save_block(block):
chaindata_dir = 'chaindata'
filename = '%s/%s.json' % (chaindata_dir, block.index)
with open(filename, 'w') as block_file:
print new_block.__dict__()
json.dump(block.__dict__(), block_file)
if __name__ == '__main__':
last_block = node_blocks[-1]
new_block = mine(last_block)
save_block(new_block)
Готово! Но при таком типе создания блока кто угодно с самым быстрым CPU сможет создавать самые длинные цепи, которые другие узлы посчитают корректными. Нужен способ снизить скорость создания блока и подтверждение до перехода к следующему блоку.
Шаг 5 — Доказательство выполнения работы
Для снижения скорость я использую Доказательство выполнения работы, как и Bitcoin. Доказательство доли владения — другой способ, используемый в блокчейнах для достижения консенсуса, но в этом случае я воспользуюсь работой.
Способ сделать это — установить требования к структуре хэша блока. Как и в случае с bitcoin, необходимо убедиться, что хэш начинается с определенного количества нулей, перед тем, как перейти к следующему. А для этого нужно добавить в хедер дополнительную информацию — случайно перебираемое число (nonce).
def generate_header(index, prev_hash, data, timestamp, nonce):
return str(index) + prev_hash + data + str(timestamp) + str(nonce)
Теперь функция майнинга настроена для создания хэша, но если хэш блока не содержит достаточного количества нулей, мы увеличиваем значение nonce, создаем новый хедер, вычисляем новый хэш и проверяем хватает ли нулей.
NUM_ZEROS = 4
def mine(last_block):
index = int(last_block.index) + 1
timestamp = date.datetime.now()
data = "I block #%s" % (int(last_block.index) + 1) #random string for now, not transactions
prev_hash = last_block.hash
nonce = 0
block_hash = calculate_hash(index, prev_hash, data, timestamp, nonce)
while str(block_hash[0:NUM_ZEROS]) != '0' * NUM_ZEROS:
nonce += 1
block_hash = calculate_hash(index, prev_hash, data, timestamp, nonce)
block_data = {}
block_data['index'] = int(last_block.index) + 1
block_data['timestamp'] = date.datetime.now()
block_data['data'] = "I block #%s" % last_block.index
block_data['prev_hash'] = last_block.hash
block_data['hash'] = block_hash
block_data['nonce'] = nonce
return Block(block_data)
Отлично. Новый блок содержит валидное значение nonce, поэтому другие узлы могут подтвердить хэш. Мы можем сгенерировать, сохранить и распределить новый блок остальным.
Заключение
На этом все! Пока что. Осталось еще много вопросов и фичей в блокчейнах, которые я не объяснил.
Например, как задействовать другие узлы? Как узлы передают данные, когда включаются в блок? Существуют ли иные способы хранения данных кроме огромных строк данных?
Ответы на эти вопросы можно будет найти в следующих частях этой серии постов, как только я сам найду на них ответы. Пожелания по содержанию можно писать мне в твиттер, в комментарии к посту или через форму обратной связи!
Спасибо моей сестре Саре за уточняющие вопросы о блокчейнах и помощь в редактировании поста!
THE END
Комментарии, вопросы, как всегда, приветствуются и тут, и на дне открытых дверей.
Пишем свой блокчейн
Самый быстрый способ изучить работу Блокчейнов – это создать свой блокчейн. Стоит лишь только попробовать!
Скорее всего вы здесь, также, как и я, потому что были недовольны резким подъемом Криптовалюты. И вы хотите узнать, как же работают Блокчейны – фундаментальная технология, которая стоит за всеми криптовалютами.
Но понять, как работают Блокчейны не так просто – ну или, как минимум для меня, это сложно. Я с трудом пробирался сквозь множество непонятных видеороликов, сомнительных туториалов и боролся с сильным разочарованием от очень малого количества примеров. Поэтому мы с вами напишем свой блокчейн.
Вообще, я люблю изучать что-либо практическим путём. Это заставляет меня разобраться с сутью вопроса на уровне кода, который позволяет уловить суть происходящего. Если вы делаете точно также, то к концу этого туториала, у вас будет полностью функционирующий свой Блокчейн, и твёрдое понимание того, как они работают.
Обратите внимание, что блокчейн – это неизменяемая последовательная цепочка записей, называемых Блоками. Они могут состоять из транзакций, файлов, или любой другой информации, которая вам необходима. Но самым важным здесь является то, что все они связаны вместе с помощью хэшей.
Если вы не уверены в том, что такое хэш, то вот объяснение.
У вас не должно возникать трудностей с чтением синтаксиса и написанием базовых вещей на Python. Кроме того, у вас должно быть понимание того, как работают HTTP-запросы, поскольку обращаться к нашему Блокчейну мы будем именно через них.
Убедитесь в том, что у вас установлен Python 3.6+ (также как и pip). Вам также необходимо установить библиотеку Flask и прекрасную библиотеку Request:
pip install Flask==0.12.2 requests==2.18.4
О, вам также понадобится HTTP-клиент, наподобие Postman или cURL. Но все будет дальше.
Исходный код будет доступен здесь.
…
Запустите ваш любимый редактор кода или IDE, лично мне нравится PyCharm. Создайте новый файл с названием blockchain.py. Мы будем использовать только один файл, но если вы вдруг запутаетесь, то всегда можете обратиться к исходному коду.
Создадим класс Blockchain, конструктор которого будет создавать изначально пустой список (для хранения нашего блокчейна), и еще один для хранения транзакций. Ниже приведен макет нашего класса:
class Blockchain(object): def __init__(self): self. chain = [] self.current_transactions = [] def new_block(self): # Создает новый Блок и добавляет его к цепочке pass def new_transaction(self): # Добавляет новую транзакцию к списку транзакций pass @staticmethod def hash(block): # Хэшируем блоки pass @property def last_block(self): # Возвращает последний блок в цепочке pass
Наш класс blockchain отвечает за управление цепочкой. В нем будут хранится транзакции и некоторые вспомогательные методы для добавления блоков в цепочку. Давайте же начнем использовать некоторые из методов.
Каждый блок содержит в себе индекс, временную метку (timestamp, по Unix времени), список транзакций, доказательность (proof, подробнее об этом позже) и хэш предыдущего Блока.
Далее приведен пример того, как выглядит отдельный Блок:
block = { 'index': 1, 'timestamp': 1506057125. 900785, 'transactions': [ { 'sender': "8527147fe1f5426f9dd545de4b27ee00", 'recipient': "a77f5cdfa2934df3954a5c7c7da5df1f", 'amount': 5, } ], 'proof': 324984774000, 'previous_hash': "2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824" }
На данном этапе идея цепочки должна быть очевидна – каждый новый блок внутри себя содержит хэш предыдущего Блока. Именно наличие предыдущего хэша является решающим фактором, который делает блокчейны неизменяемыми. Если хакер повредит один из начальных блоков (любой предыдущий блок), то вся последовательность блоков будет содержать в себе некорректный хэш.
Какой в этом смысл? Если это не так, то потребуется некоторое количество времени для того, чтобы понять, что вообще происходит – это и есть ключевая идея блокчейнов.
Итак, нам понадобится способ добавления транзакций в блок. Наш метод new_transaction() отвечает за это, и он довольно простой:
class Blockchain(object): ... def new_transaction(self, sender, recipient, amount): """ Создает новую транзакцию для того чтобы перейти к следующему искомому Блоку :параметр sender: <str> Адрес отправителя :параметр recipient: <str> Адрес получателя :параметр amount: <int> Количество :return: <int> Индекс Блока, в котором будет хранится данная транзакция """ self.current_transactions.append({ 'sender': sender, 'recipient': recipient, 'amount': amount, }) return self.last_block['index'] + 1
После того, как наш метод добавил транзакцию в список, то он возвращает индекс блока, в который будет добавлена транзакция – следующий искомый блок. Позже, для пользователя, отправляющего транзакцию, это будет полезно.
После того, как мы создали экземпляр нашего Блокчейна, нам необходимо заполнить его исходным блоком – блок у которого нет предшественников. Также нам необходимо добавить «proof» в наш исходный блок, который является результатом анализа (или алгоритма «доказательство выполнения работы»). По поводу анализа мы поговорим позднее.
Кроме этого, для создания исходного блока в нашем конструкторе, нам также необходимо добавить следующие методы: new_block(), new_transaction() и hash():
import hashlib import json from time import time class Blockchain(object): def __init__(self): """ Инициализируем свой блокчейн """ self.current_transactions = [] self.chain = [] # Create the genesis block self.new_block(previous_hash=1, proof=100) def new_block(self, proof, previous_hash=None): """ Создаем новый блок в нашем Блокчейне :параметр proof: <int> proof полученный после использования алгоритма «Доказательство выполнения работы» :параметр previous_hash: (Опциональный) <str> Хэш предыдущего Блока :return: <dict> New Block """ block = { 'index': len(self. chain) + 1, 'timestamp': time(), 'transactions': self.current_transactions, 'proof': proof, 'previous_hash': previous_hash or self.hash(self.chain[-1]), } # Сбрасываем текущий список транзакций self.current_transactions = [] self.chain.append(block) return block def new_transaction(self, sender, recipient, amount): """ Создает новую транзакцию для перехода к следующему замайненному Блоку :param sender: <str> Address of the Sender :param recipient: <str> Address of the Recipient :param amount: <int> Amount :return: <int> Индекс блока который будет хранить в себе эту транзакцию """ self.current_transactions.append({ 'sender': sender, 'recipient': recipient, 'amount': amount, }) return self. last_block['index'] + 1 @property def last_block(self): return self.chain[-1] @staticmethod def hash(block): """ Создает a SHA-256 хэш блока :параметр block: <dict> Блок :return: <str> """ # Мы должны быть уверены что наш Словарь упорядочен, или мы можем непоследовательные хэши block_string = json.dumps(block, sort_keys=True).encode() return hashlib.sha256(block_string).hexdigest()
Код выше должен быть всем ясен и понятен – я добавил некоторое количество комментариев и немного строк документации, чтобы все было максимально прозрачно. Мы практически закончили с представлением нашего блокчейна. Однако на данном этапе, вы должны быть удивлены тому как новые блоки создаются, формируются и майнятся.
Алгоритм «Доказательство выполнения работы» (PoW) – это то, как новые блоки создаются или майнятся в блокчейне. Целью алгоритма PoW является нахождение такого числа (метки), которое будет решать проблему. Число должно быть таким, чтобы его было сложно найти и легко проверить. Говоря в вычислительном отношении не важно кем в сети это может быть сделано. В этом и заключается основная идея данного алгоритма.
Итак, давайте взглянем на простой пример, которой поможет нам во всем разобраться.
Предположим, что хэш некоторого целочисленного числа x, умноженного на другое целочисленное число y, должен заканчиваться на 0. Следовательно, hash(x * y) = ac23dc…0. И для нашего упрощенного примера исправим x на 5. Реализуем это в Python:
from hashlib import sha256 x = 5 y = 0 # Пока мы не знаем каким должен быть y while sha256(f'{x*y}'.encode()).hexdigest()[-1] != "0": y += 1 print(f'The solution is y = {y}')
Решением здесь будет y=21. Поскольку полученный хэш заканчивается на 0:
hash(5 * 21) = 1253e9373e. ..5e3600155e860
В сфере Биткоинов, алгоритм «Доказательство выполнения работы» называется Hashcash. И он не сильно отличается от нашего базового примера выше. Это алгоритм, который майнеры используют в гонке по решению задачи создания новых блоков. Как правило, сложность определяется количеством символов, которые необходимо обнаружить в строке. После чего майнеры получают награду за свое решение в качестве биткойна при транзакции.
Сеть может легко проверить их решение.
Давайте реализуем простой алгоритм для того, чтобы реализовать свой блокчейн. Наше правило будет аналогично приведенному выше примеру:
Ищем число p, которое при хэшировании с решением предыдущего блока будет создавать хэш с четырьмя лидирующими нулями.
import hashlib import json from time import time from uuid import uuid4 class Blockchain(object): ... def proof_of_work(self, last_proof): """ Простой алгоритм Proof of Work: - Ищем число p' такое, чтобы hash(pp') содержал в себе 4 лидирующих нуля, где p это предыдущий p' - p это предыдущий proof, а p' это новый proof :параметр last_proof: <int> :return: <int> """ proof = 0 while self. valid_proof(last_proof, proof) is False: proof += 1 return proof @staticmethod def valid_proof(last_proof, proof): """ Проверяем Proof: Содержит ли hash(last_proof, proof) 4 лидирующих нуля? :параметр last_proof: <int> предыдущий Proof :параметр proof: <int> Тукущий Proof :return: <bool> True если все верно, иначе False. """ guess = f'{last_proof}{proof}'.encode() guess_hash = hashlib.sha256(guess).hexdigest() return guess_hash[:4] == "0000"
Для регулирования сложности алгоритма, мы можем модифицировать количество лидирующих нулей. Одна четырех будет достаточно. Вы можете попробовать сами и понять, что добавление одного единственного лидирующего нуля приведет к гигантской разнице во времени поиска решения.
Наш класс практически готов, и мы готовы начать взаимодействовать с ним посредствам HTTP-запросов.
…
Мы будем использовать фреймворк Flask. Данный микро-фреймворк упрощает размещение конечных точек (endpoints) в Python-функциях. Это позволит нам обращаться к нашему блокчейну за счет веб-соединения с помощью HTTP-запросов.
Создадим три метода:
- /transactions/new для создания новой транзакции в блоке;
- /mine для передачи нашему серверу информации о том, что пора майнить новый блок;
- /chain для возврата всего Блокчейна.
Настраиваем Flask для того, чтобы реализовать свой блокчейн
Наш «сервер» будет формировать одиночный узел в нашей блокчейн-сети. Давайте напишем некоторый шаблонный код:
import hashlib import json from textwrap import dedent from time import time from uuid import uuid4 from flask import Flask class Blockchain(object): ... # Создаем экземпляр нашего узла app = Flask(__name__) # Генерируем уникальный глобальный адрес для этого узла node_identifier = str(uuid4()). replace('-', '') # Создаем экземпляр Blockchain blockchain = Blockchain() @app.route('/mine', methods=['GET']) def mine(): return "We'll mine a new Block" @app.route('/transactions/new', methods=['POST']) def new_transaction(): return "We'll add a new transaction" @app.route('/chain', methods=['GET']) def full_chain(): response = { 'chain': blockchain.chain, 'length': len(blockchain.chain), } return jsonify(response), 200 if __name__ == '__main__': app.run(host='0.0.0.0', port=5000)
Небольшое пояснение того, что мы добавили в примере выше:
- Строка 15: Создаем экземпляр узла. Более подробно узнать о Flask можно здесь.
- Строка 18: Генерируем случайное имя для нашего узла;
- Строка 21: Создаем экземпляр класса Blockchain;
- Строки 24-26: Создаем endpoint для метода /mine, который является GET-запросом;
- Строки 28-30: Создаем endpoint для метода /transactions/new, который является POST-запросом, поскольку мы будем отправлять сюда данные;
- Строки 32-38: Создаем endpoint для метода /chain, который будет возвращать весь Блокчейн;
- Строки 40-41: Запускаем наш сервер на порт 5000.
Endpoint для транзакций
Вот так будет выглядеть запрос транзакции. То есть, именно эту информацию пользователь отправляет на сервер:
{ "sender": "my address", "recipient": "someone else's address", "amount": 5 }
В силу того, что мы уже создали методы для нашего класса, отвечающие за добавление транзакции в блок, то осталась самая простая часть. Давайте напишем функцию, которая будет добавлять наши транзакции:
import hashlib import json from textwrap import dedent from time import time from uuid import uuid4 from flask import Flask, jsonify, request ... @app.route('/transactions/new', methods=['POST']) def new_transaction(): values = request.get_json() # Проверяем, что обязательные поля переданы в POST-запрос required = ['sender', 'recipient', 'amount'] if not all(k in values for k in required): return 'Missing values', 400 # Создаем новую транзакцию index = blockchain. new_transaction(values['sender'], values['recipient'], values['amount']) response = {'message': f'Transaction will be added to Block {index}'} return jsonify(response), 201
Endpoint для майнинга
Наш endpoint майнинга – это то, где происходит магия, и в ней нет ничего сложного. Здесь совершаются три следующих вещи:
- Расчет алгоритма PoW;
- Майнер(ы) получают награду в виде транзакции, которая гарантируем им 1 биткойн;
- Формирование нового блока, путем его добавления в цепочку.
import hashlib import json from time import time from uuid import uuid4 from flask import Flask, jsonify, request ... @app.route('/mine', methods=['GET']) def mine(): # Мы запускаем алгоритм PoW для того чтобы найти следующий proof... last_block = blockchain.last_block last_proof = last_block['proof'] proof = blockchain. proof_of_work(last_proof) # Мы должны получить награду за найденный proof. # Если sender = "0", то это означает что данный узел заработал биткойн. blockchain.new_transaction( sender="0", recipient=node_identifier, amount=1, ) # Формируем новый блок, путем добавления его в цепочку block = blockchain.new_block(proof) response = { 'message': "New Block Forged", 'index': block['index'], 'transactions': block['transactions'], 'proof': block['proof'], 'previous_hash': block['previous_hash'], } return jsonify(response), 200
Обратите внимание, что получателем замайненного блока является адрес нашего узла. И большинство из того, что мы здесь сделали, просто взаимодействует с методами нашего класса Blockchain. На данном этапе мы закончили с подготовкой нашего блокчейна и теперь готовы взаимодействовать с ним.
Вы можете использовать простой, но уже устаревший cURL или Postman, для взаимодействия с нашим API через сеть.
Запускаем наш сервер:
$ python blockchain.py* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
Давайте попробуем смайнить блок. Для этого воспользуемся GET-запросом на http://localhost:5000/mine:
Создадим новую транзакцию с помощью POST-запроса на http://localhost:5000/transactions/new с телом, содержащим структуру нашей транзакции:
Если не хотите использовать Postman, то вы можете сделать аналогичные запрос с помощью cURL:
$ curl -X POST -H "Content-Type: application/json" -d '{ "sender": "d4ee26eee15148ee92c6cd394edd974e", "recipient": "someone-other-address", "amount": 5 }' "http://localhost:5000/transactions/new"
Я перезагрузил свой сервер, и смайнил два блока, чтобы в итоге получилось три. Давайте проверим всю цепочку, с помощью запроса на http://localhost:5000/chain:
{ "chain": [ { "index": 1, "previous_hash": 1, "proof": 100, "timestamp": 1506280650. 770839, "transactions": [] }, { "index": 2, "previous_hash": "c099bc...bfb7", "proof": 35293, "timestamp": 1506280664.717925, "transactions": [ { "amount": 1, "recipient": "8bbcb347e0634905b0cac7955bae152b", "sender": "0" } ] }, { "index": 3, "previous_hash": "eff91a...10f2", "proof": 35089, "timestamp": 1506280666.1086972, "transactions": [ { "amount": 1, "recipient": "8bbcb347e0634905b0cac7955bae152b", "sender": "0" } ] } ], "length": 3 }
Пока, все что мы делали, это круто. Мы получили базовый Блокчейн, который может принимать транзакции, тем самым позволяя нам майнить новые Блоки. Однако вся суть Блокчейнов заключается в том, что они должны быть децентрализованы. Но если блокчейны децентрализованы, то как мы можем гарантировать, что все они отражают одну и ту же цепочку? Данная проблема называется проблемой Консенсуса (конфликтов). Мы реализуем алгоритм Консенсуса, если мы конечно хотим, чтобы в нашей сети было больше одного узла.
Перед тем как мы сможем реализовать алгоритм Консенсуса, нам необходимо придумать способ, как наши узлы будут знать о своих «соседях» в сети. Каждый узел в нашей сети будет хранить в себе запись о других узлах в сети. Итак, нам необходимо еще некоторое количество endpoint-ов:
- /nodes/register чтобы можно было принимать список новых узлов в форме URL;
- /nodes/resolve для реализации нашего алгоритма Консенсуса, который разрешит любые конфликтные ситуации, чтобы каждый узел содержал корректную цепочку.
Для всего этого нам необходимо модифицировать конструктор нашего Блокчейна, и предоставить метод по регистрации узлов:
... from urllib.parse import urlparse . .. class Blockchain(object): def __init__(self): ... self.nodes = set() ... def register_node(self, address): """ Добавляем новый узел в список узлов :параметр address: <str> Адрес узла, например: 'http://192.168.0.5:5000' :return: None """ parsed_url = urlparse(address) self.nodes.add(parsed_url.netloc)
Обратите внимание, что мы использовали set() для хранения списка узлов. Это самый дешёвый способ гарантировать, что новый узлы будут добавляться, не изменяя при этом объект, то есть не важно сколько раз мы добавляли определенный узел, он появится ровно один раз.
Как уже было сказано, конфликтная ситуация – это когда один узел содержит цепочку отличную от той, что есть в другом узле. Для решения этого, мы создадим правило, что наиболее длинная, прошедшая проверку, цепочка будет являться достоверной. Другими словами, самая длинная цепочка в сети будет фактической. При использовании данного алгоритма, мы достигаем консенсуса среди всех узлов в нашей сети.
... import requests class Blockchain(object) ... def valid_chain(self, chain): """ Определяем, что данный блокчейн прошел проверку :параметр chain: <list> Блокчейн :return: <bool> True если прошел проверку, иначе False """ last_block = chain[0] current_index = 1 while current_index < len(chain): block = chain[current_index] print(f'{last_block}') print(f'{block}') print("\n-----------\n") # Проверяем, что хэш этого блока корректен if block['previous_hash'] != self.hash(last_block): return False # Проверяем, что алгоритм PoW корректен if not self.valid_proof(last_block['proof'], block['proof']): return False last_block = block current_index += 1 return True def resolve_conflicts(self): """ Это наш алгоритм Консенсуса, он разрешает конфликт путём замены нашей цепочки на самую длинную в нашей сети. :return: <bool> True если наша цепочка была заменена, False если это не так """ neighbours = self.nodes new_chain = None # Мы ищем цепочки длиннее наших max_length = len(self.chain) # Берем все цепочки со всех узлов нашей сети и проверяем их for node in neighbours: response = requests.get(f'http://{node}/chain') if response.status_code == 200: length = response.json()['length'] chain = response.json()['chain'] # Проверяем, что цепочка имеет # максимальную длину и она корректна if length > max_length and self.valid_chain(chain): max_length = length new_chain = chain # Заменяем нашу цепочку, если нашли другую, # которая имеет большую длину и является корректной if new_chain: self.chain = new_chain return True return False
Первый метод valid_chain () отвечает за проверку цепочки на корректность, путем прогонки её по циклу через каждый блок, в котором сравнивается хэш и proof.
resolve_conflicts() – это метод который в цикле проходит по всем соседним узлам, скачивает их цепочки и проверяет их, используя метод выше. Если найдена необходимая цепочка, то мы заменяем текущую на эту.
Давайте зарегистрируем два endpoint-а в нашем API, один будет предназначен для добавления соседних узлов, а второй для разрешения конфликтных ситуаций.
@app.route('/nodes/register', methods=['POST']) def register_nodes(): values = request.get_json() nodes = values.get('nodes') if nodes is None: return "Error: Please supply a valid list of nodes", 400 for node in nodes: blockchain.register_node(node) response = { 'message': 'New nodes have been added', 'total_nodes': list(blockchain.nodes), } return jsonify(response), 201 @app.route('/nodes/resolve', methods=['GET']) def consensus(): replaced = blockchain.resolve_conflicts() if replaced: response = { 'message': 'Our chain was replaced', 'new_chain': blockchain.chain } else: response = { 'message': 'Our chain is authoritative', 'chain': blockchain.chain } return jsonify(response), 200
На этом этапе вы можете задействовать любое количество машин, по вашему усмотрению, и реализовать различные узлы в вашей сети. Или же реализовать все то же самое на одной машине, используя разные порты. Я это реализовал вторым способом, используя разные порты. То есть, я зарегистрировал другой узел, уже с имеющимся узлом. Итак, у меня есть два узла: http://localhost:5000 и http://localhost:5001.
После чего я замайнил новые блоки на узел 2, для того чтобы цепочка стала длиннее. Потом, я вызвал GET /nodes/resolve на узел 1, где цепочка была заменена по алгоритму Консенсуса:
И это просто обёртка… Объединитесь с друзьями для того, чтобы затестить свой Блокчейн.
…
Итак, мы с вами написали свой блокчейн. Я надеюсь, что данная статья способствует тому, что вы создадите что-то новое для себя.
Дополнение: Также планирую продолжить со второй частью статьи, где мы будем расширять свой блокчейн, для того чтобы у нас был свой механизм проверки транзакций. Кроме того, обсудим некоторые способы, с помощью которых вы сможете запустить свой Блокчейн в работу.
Простейший блокчейн своими руками
10 полезных ресурсов по технологии blockchain
Ссылка на оригинальную статью
Перевод: Александр Давыдов
Создаем Blockchain с нуля на Python
Самый быстрый способ узнать, как работает блокчейн — это создать его.
Вы здесь, потому что, как и я, немного помешаны на криптовалюте. Кроме этого, вы явно хотите узнать, как работает блокчейн — фундаментальная технология, связанная с криптовалютой.
Однако, понимание блокчейн — не самое простое дело, по крайней мере, так было в моем случае. Я прошел через тонны видеороликов, изучал руководства и постоянно разочаровывался из-за слишком маленького количества примеров.
Есть вопросы по Python?
На нашем форуме вы можете задать любой вопрос и получить ответ от всего нашего сообщества!
Telegram Чат & Канал
Вступите в наш дружный чат по Python и начните общение с единомышленниками! Станьте частью большого сообщества!
Паблик VK
Одно из самых больших сообществ по Python в социальной сети ВК. Видео уроки и книги для вас!
Я люблю учиться на практике. Это лучше всего показывает суть дела на уровне кода, что запоминается лучше всего. Если у вас похожее мнение, то в конце статьи вы получите рабочий блокчейн с твердым пониманием того, как они работают.
Перед тем, как начать…
Помните, что блокчейн — это неизменная, последовательная цепочка записей, каждая часть этой цепочки называется блоками. Они могут содержать транзакции, файлы или любой вид данных, который вам угоден. Однако важный момент заключается в том, что они связаны вместе хешами.
Если вы не знаете, что такое хеш, то вот вам статьи:
На кого нацелена данная статья?
В целом, вы уже должны более-менее свободно читать и писать основы Python, наряду с пониманием работы запросов HTTP, так как мы будем говорить о блокчейне на HTTP.
Что нам нужно? Убедитесь, что у вас установлен Python 3.6+ (а также pip). Вам также нужно будет установить Flask и замечательную библиотеку Requests:
pip install Flask==0.12.2 requests==2.18.4
pip install Flask==0.12.2 requests==2.18.4 |
И да, вам также нужен будет HTTP клиент, такой как Postman или cURL. В целом, что-нибудь подойдет.
Исходный код статьи
Вот здесь вы можете ознакомиться с исходным: https://github.com/dvf/blockchain
Шаг 1: Создание блокчейна
Открывайте свой любимый редактор текста, или IDE, лично я предпочитаю PyCharm. Создайте новый файл под названием blockchain.py. Мы используем только один файл, но если вы запутаетесь, вы всегда можете пройтись по исходному коду.
Скелет блокчейна
Мы создадим класс блокчейна, чей конструктор создает начальный пустой лист (для хранения нашего блокчейна), и еще один — для хранения транзакций. Вот чертёж нашего класса:
class Blockchain(object): def __init__(self): self.chain = [] self.current_transactions = [] def new_block(self): # Создает новый блок и вносит его в цепь pass def new_transaction(self): # Вносит новую транзакцию в список транзакций pass @staticmethod def hash(block): # Хеширует блок pass @property def last_block(self): # Возвращает последний блок в цепочке pass
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | class Blockchain(object): def __init__(self): self.chain = [] self.current_transactions = []
def new_block(self): # Создает новый блок и вносит его в цепь pass
def new_transaction(self): # Вносит новую транзакцию в список транзакций pass
@staticmethod def hash(block): # Хеширует блок pass
@property def last_block(self): # Возвращает последний блок в цепочке pass |
Наш класс Blockchain отвечает за управление цепью. Он будет хранить транзакции, а также иметь несколько вспомогательных методов для внесения новых блоков в цепь. Начнем с работы с несколькими методами.
Как выглядит блок?
Каждый блок содержит индекс, временной штамп (время unix), список транзакций, доказательство (об этом позже) и хеш предыдущего блока.
Вот пример того, как выглядит один блок:
block = { ‘index’: 1, ‘timestamp’: 1506057125.900785, ‘transactions’: [ { ‘sender’: «8527147fe1f5426f9dd545de4b27ee00», ‘recipient’: «a77f5cdfa2934df3954a5c7c7da5df1f», ‘amount’: 5, } ], ‘proof’: 324984774000, ‘previous_hash’: «2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824» }
block = { ‘index’: 1, ‘timestamp’: 1506057125.900785, ‘transactions’: [ { ‘sender’: «8527147fe1f5426f9dd545de4b27ee00», ‘recipient’: «a77f5cdfa2934df3954a5c7c7da5df1f», ‘amount’: 5, } ], ‘proof’: 324984774000, ‘previous_hash’: «2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824» } |
С этого момента, понимание цепи должно быть раздельным — каждый новый блок содержит внутри себя хеш предыдущего блока. Это принципиально важно, так как этим обеспечивается неизменность блокчейна: если злоумышленник взломает предыдущий блок, то все остальные блоки будут содержать неправильные хеши.
Имеет ли это смысл? Если нет — то вам нужно уделить время, чтобы понять и осознать это, так как мы говорим о фундаментальном принципе работы блокчейна.
Внесение транзакций в блок
Нам нужен будет способом внесения транзакций в блок. Наш метод new_transaction() отвечает за это, и он достаточно прямолинейный:
class Blockchain(object): … def new_transaction(self, sender, recipient, amount): «»» Направляет новую транзакцию в следующий блок :param sender: <str> Адрес отправителя :param recipient: <str> Адрес получателя :param amount: <int> Сумма :return: <int> Индекс блока, который будет хранить эту транзакцию «»» self.current_transactions.append({ ‘sender’: sender, ‘recipient’: recipient, ‘amount’: amount, }) return self.last_block[‘index’] + 1
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | class Blockchain(object): …
def new_transaction(self, sender, recipient, amount): «»» Направляет новую транзакцию в следующий блок
:param sender: <str> Адрес отправителя :param recipient: <str> Адрес получателя :param amount: <int> Сумма :return: <int> Индекс блока, который будет хранить эту транзакцию «»»
self.current_transactions.append({ ‘sender’: sender, ‘recipient’: recipient, ‘amount’: amount, })
return self.last_block[‘index’] + 1 |
После того, как new_transaction() внесет транзакцию в список, он вернет индекс блока, в которой должна будет быть внесена транзакция — а именно следующая. В будущем, это будет полезно для пользователя, отправляющего транзакцию.
Создание новых блоков
После того, как мы получили экземпляр блокчейна, нам нужно посадить в него блок генезиса — первый блок без предшественников. Нам также нужно внести “пруф” в наш блок генезиса, который представляет собой результат майнинга (доказательства проведенной работы). Мы рассмотрим майнинг позже.
В дополнению к созданию блока генезиса в конструкторе, мы также выкатим методы для new_block(), new_transaction() и hash():
import hashlib import json from time import time class Blockchain(object): def __init__(self): self.current_transactions = [] self.chain = [] # Создание блока генезиса self.new_block(previous_hash=1, proof=100) def new_block(self, proof, previous_hash=None): «»» Создание нового блока в блокчейне :param proof: <int> Доказательства проведенной работы :param previous_hash: (Опционально) хеш предыдущего блока :return: <dict> Новый блок «»» block = { ‘index’: len(self.chain) + 1, ‘timestamp’: time(), ‘transactions’: self.current_transactions, ‘proof’: proof, ‘previous_hash’: previous_hash or self.hash(self.chain[-1]), } # Перезагрузка текущего списка транзакций self.current_transactions = [] self.chain.append(block) return block def new_transaction(self, sender, recipient, amount): «»» Направляет новую транзакцию в следующий блок :param sender: <str> Адрес отправителя :param recipient: <str> Адрес получателя :param amount: <int> Сумма :return: <int> Индекс блока, который будет хранить эту транзакцию «»» self.current_transactions.append({ ‘sender’: sender, ‘recipient’: recipient, ‘amount’: amount, }) return self.last_block[‘index’] + 1 @property def last_block(self): return self.chain[-1] @staticmethod def hash(block): «»» Создает хэш SHA-256 блока :param block: <dict> Блок :return: <str> «»» # Мы должны убедиться в том, что словарь упорядочен, иначе у нас будут непоследовательные хеши block_string = json.dumps(block, sort_keys=True).encode() return hashlib.sha256(block_string).hexdigest()
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 | import hashlib import json from time import time
class Blockchain(object): def __init__(self): self.current_transactions = [] self.chain = []
# Создание блока генезиса self.new_block(previous_hash=1, proof=100)
def new_block(self, proof, previous_hash=None): «»» Создание нового блока в блокчейне
:param proof: <int> Доказательства проведенной работы :param previous_hash: (Опционально) хеш предыдущего блока :return: <dict> Новый блок «»»
block = { ‘index’: len(self.chain) + 1, ‘timestamp’: time(), ‘transactions’: self.current_transactions, ‘proof’: proof, ‘previous_hash’: previous_hash or self.hash(self.chain[-1]), }
# Перезагрузка текущего списка транзакций self.current_transactions = []
self.chain.append(block) return block
def new_transaction(self, sender, recipient, amount): «»» Направляет новую транзакцию в следующий блок
:param sender: <str> Адрес отправителя :param recipient: <str> Адрес получателя :param amount: <int> Сумма :return: <int> Индекс блока, который будет хранить эту транзакцию «»» self.current_transactions.append({ ‘sender’: sender, ‘recipient’: recipient, ‘amount’: amount, })
return self.last_block[‘index’] + 1
@property def last_block(self): return self.chain[-1]
@staticmethod def hash(block): «»» Создает хэш SHA-256 блока
:param block: <dict> Блок :return: <str> «»»
# Мы должны убедиться в том, что словарь упорядочен, иначе у нас будут непоследовательные хеши block_string = json.dumps(block, sort_keys=True).encode() return hashlib.sha256(block_string).hexdigest() |
Код выше должен быть достаточно ясным — я внес несколько комментариев и документацию, чтобы все было понятно. Структура данных будет в json. Мы почти закончили с скелетом нашего блокчейна. Однако на данный момент, вам наверное интересно, как создаются новые блоки?
Понимание подтверждения работы
Алгоритм пруфа работы (Proof of Work, PoW) — это то, как новые блоки созданы или майнятся в блокчейне. Цель PoW — это найти число, которое решает проблему. Число должно быть таким, чтобы его тяжело было найти, но легко подтвердить (говоря о вычислениях) кем угодно в интернете. Это главная задача алгоритма.
Рассмотрим простой пример, чтобы получить лучшее представление.
Скажем, что хеш того или иного числа х, умноженного на другое число должен заканчиваться нулем. Таким образом, hash(x * y) = ac23dc…0. Для этого упрощенного примера, представим что x = 5. Как это работает в Python:
from hashlib import sha256 x = 5 y = 0 # Мы еще не знаем, чему равен y… while sha256(f'{x*y}’.encode()).hexdigest()[-1] != «0»: y += 1 print(f’The solution is y = {y}’)
from hashlib import sha256
x = 5 y = 0 # Мы еще не знаем, чему равен y… while sha256(f'{x*y}’.encode()).hexdigest()[-1] != «0»: y += 1
print(f’The solution is y = {y}’) |
Решение здесь следующее: y = 21, так как созданный хеш заканчивается нулем:
hash(5 * 21) = 1253e9373e…5e3600155e860
hash(5 * 21) = 1253e9373e…5e3600155e860 |
В биткоине, такой алгоритм называется Hashcash. И он особо не отличается от приведенного выше примера. Это алгоритм, который поколение майнеров (читай, отдельная раса) пытается решить, чтобы создать новый блок. В целом, сложность определяется количеством символом, которые рассматриваются в строке. Майнеры неплохо вознаграждаются за решение задачи получением коина в транзакции.
Реализация базового PoW
Давайте реализуем аналогичный алгоритм для нашего блокчейна. Наше правило будет аналогично указанному ранее:
Найдите число «p«, которое хешировано с предыдущим созданным решением блока с хешем содержащим 4 заглавных нуля.
import hashlib import json from time import time from uuid import uuid4 class Blockchain(object): … def proof_of_work(self, last_proof): «»» Простая проверка алгоритма: — Поиска числа p`, так как hash(pp`) содержит 4 заглавных нуля, где p — предыдущий — p является предыдущим доказательством, а p` — новым :param last_proof: <int> :return: <int> «»» proof = 0 while self.valid_proof(last_proof, proof) is False: proof += 1 return proof @staticmethod def valid_proof(last_proof, proof): «»» Подтверждение доказательства: Содержит ли hash(last_proof, proof) 4 заглавных нуля? :param last_proof: <int> Предыдущее доказательство :param proof: <int> Текущее доказательство :return: <bool> True, если правильно, False, если нет. «»» guess = f'{last_proof}{proof}’.encode() guess_hash = hashlib.sha256(guess).hexdigest() return guess_hash[:4] == «0000»
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | import hashlib import json
from time import time from uuid import uuid4
class Blockchain(object): …
def proof_of_work(self, last_proof): «»» Простая проверка алгоритма: — Поиска числа p`, так как hash(pp`) содержит 4 заглавных нуля, где p — предыдущий — p является предыдущим доказательством, а p` — новым
:param last_proof: <int> :return: <int> «»»
proof = 0 while self.valid_proof(last_proof, proof) is False: proof += 1
return proof
@staticmethod def valid_proof(last_proof, proof): «»» Подтверждение доказательства: Содержит ли hash(last_proof, proof) 4 заглавных нуля?
:param last_proof: <int> Предыдущее доказательство :param proof: <int> Текущее доказательство :return: <bool> True, если правильно, False, если нет. «»»
guess = f'{last_proof}{proof}’.encode() guess_hash = hashlib.sha256(guess).hexdigest() return guess_hash[:4] == «0000» |
Чтобы скорректировать сложность алгоритма, мы можем изменить количество заглавных нулей. В нашем случае, 4 — достаточно. Вы узнаете, что внесение одного ведущего нуля создает колоссальную разницу во времени, необходимом для поиска решения (майнинга).
Наш класс практически готов, так что мы можем начать взаимодействовать с ним через HTTP запросы.
Шаг 2: Блокчейн как API
Здесь мы задействуем фреймворк под названием Flask. Это макро-фреймворк, который заметно упрощает сопоставление конечных точек с функциями Python. Это позволяет нам взаимодействовать с нашим блокчейном в интернете при помощиHTTP-запросов.
Мы создадим три метода:
- /transactions/new для создания новой транзакции в блоке;
- /mine, чтобы указать серверу, что нужно майнить новый блок;
- /chain для возвращения всего блокчейна
Настройка Flask
Наш “сервер” сформирует единый узел в нашей сети блокчейна. Давайте создадим шаблонный код:
import hashlib import json from textwrap import dedent from time import time from uuid import uuid4 from flask import Flask class Blockchain(object): … # Создаем экземпляр узла app = Flask(__name__) # Генерируем уникальный на глобальном уровне адрес для этого узла node_identifier = str(uuid4()).replace(‘-‘, ») # Создаем экземпляр блокчейна blockchain = Blockchain() @app.route(‘/mine’, methods=[‘GET’]) def mine(): return «We’ll mine a new Block» @app.route(‘/transactions/new’, methods=[‘POST’]) def new_transaction(): return «We’ll add a new transaction» @app.route(‘/chain’, methods=[‘GET’]) def full_chain(): response = { ‘chain’: blockchain.chain, ‘length’: len(blockchain.chain), } return jsonify(response), 200 if __name__ == ‘__main__’: app.run(host=’0.0.0.0′, port=5000)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 | import hashlib import json from textwrap import dedent from time import time from uuid import uuid4
from flask import Flask
class Blockchain(object): …
# Создаем экземпляр узла app = Flask(__name__)
# Генерируем уникальный на глобальном уровне адрес для этого узла node_identifier = str(uuid4()).replace(‘-‘, »)
# Создаем экземпляр блокчейна blockchain = Blockchain()
@app.route(‘/mine’, methods=[‘GET’]) def mine(): return «We’ll mine a new Block»
@app.route(‘/transactions/new’, methods=[‘POST’]) def new_transaction(): return «We’ll add a new transaction»
@app.route(‘/chain’, methods=[‘GET’]) def full_chain(): response = { ‘chain’: blockchain.chain, ‘length’: len(blockchain.chain), } return jsonify(response), 200
if __name__ == ‘__main__’: app.run(host=’0.0.0.0′, port=5000) |
Краткое объяснение того, что мы только что добавили:
- Строка 15: Создание экземпляра узла. Можете больше узнать о Flask здесь;
- Строка 18: Создание случайного имени нашего узла;
- Строка 21: Создание экземпляра класса Blockchain;
- Строки 24-26: Создание конечной точки /mine, которая является GET-запросом;
- Строки 28-30: Создание конечной точки /transactions/new, которая являетсяPOST-запросом, так как мы будем отправлять туда данные;
- Строки 32-38: Создание конечной точки /chain, которая возвращает весь блокчейн;
- Строки 40-41: Запускает сервер на порт: 5000.
Конечная точка транзакций
Вот так запрос транзакции должен будет выглядеть. Это то, что пользователь отправляет в сервер:
{ «sender»: «my address», «recipient»: «someone else’s address», «amount»: 5 }
{ «sender»: «my address», «recipient»: «someone else’s address», «amount»: 5 } |
Так как мы уже обладаем методом класса для добавления транзакций в блок, дело осталось за малым. Давайте напишем функцию для внесения транзакций:
import hashlib import json from textwrap import dedent from time import time from uuid import uuid4 from flask import Flask, jsonify, request … @app.route(‘/transactions/new’, methods=[‘POST’]) def new_transaction(): values = request.get_json() # Убедитесь в том, что необходимые поля находятся среди POST-данных required = [‘sender’, ‘recipient’, ‘amount’] if not all(k in values for k in required): return ‘Missing values’, 400 # Создание новой транзакции index = blockchain.new_transaction(values[‘sender’], values[‘recipient’], values[‘amount’]) response = {‘message’: f’Transaction will be added to Block {index}’} return jsonify(response), 201
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | import hashlib import json from textwrap import dedent from time import time from uuid import uuid4
from flask import Flask, jsonify, request
…
@app.route(‘/transactions/new’, methods=[‘POST’]) def new_transaction(): values = request.get_json()
# Убедитесь в том, что необходимые поля находятся среди POST-данных required = [‘sender’, ‘recipient’, ‘amount’] if not all(k in values for k in required): return ‘Missing values’, 400
# Создание новой транзакции index = blockchain.new_transaction(values[‘sender’], values[‘recipient’], values[‘amount’])
response = {‘message’: f’Transaction will be added to Block {index}’} return jsonify(response), 201 |
Конечная точка майнинга
Конечная точка майнинга — это часть, где происходит магия, и это просто! Для этого нужно сделать три вещи:
- Подсчитать PoW;
- Наградить майнера (нас), добавив транзакцию, дающую нам 1 коин;
- Слепить следующий блок, внеся его в цепь.
import hashlib import json from time import time from uuid import uuid4 from flask import Flask, jsonify, request … @app.route(‘/mine’, methods=[‘GET’]) def mine(): # Мы запускаем алгоритм подтверждения работы, чтобы получить следующее подтверждение… last_block = blockchain.last_block last_proof = last_block[‘proof’] proof = blockchain.proof_of_work(last_proof) # Мы должны получить вознаграждение за найденное подтверждение # Отправитель “0” означает, что узел заработал крипто-монету blockchain.new_transaction( sender=»0″, recipient=node_identifier, amount=1, ) # Создаем новый блок, путем внесения его в цепь previous_hash = blockchain.hash(last_block) block = blockchain.new_block(proof, previous_hash) response = { ‘message’: «New Block Forged», ‘index’: block[‘index’], ‘transactions’: block[‘transactions’], ‘proof’: block[‘proof’], ‘previous_hash’: block[‘previous_hash’], } return jsonify(response), 200
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | import hashlib import json
from time import time from uuid import uuid4
from flask import Flask, jsonify, request
…
@app.route(‘/mine’, methods=[‘GET’]) def mine(): # Мы запускаем алгоритм подтверждения работы, чтобы получить следующее подтверждение… last_block = blockchain.last_block last_proof = last_block[‘proof’] proof = blockchain.proof_of_work(last_proof)
# Мы должны получить вознаграждение за найденное подтверждение # Отправитель “0” означает, что узел заработал крипто-монету blockchain.new_transaction( sender=»0″, recipient=node_identifier, amount=1, )
# Создаем новый блок, путем внесения его в цепь previous_hash = blockchain.hash(last_block) block = blockchain.new_block(proof, previous_hash)
response = { ‘message’: «New Block Forged», ‘index’: block[‘index’], ‘transactions’: block[‘transactions’], ‘proof’: block[‘proof’], ‘previous_hash’: block[‘previous_hash’], } return jsonify(response), 200 |
Обратите внимание на то, что получатель замайненого блока — это адрес нашего узла. Большая часть того, что мы здесь сделали, это просто взаимодействие с методами в нашем классе Blockchain. С этого момента, мы закончили, и можем начать взаимодействовать с нашим blockchain на Python.
Шаг 3: Взаимодействие с нашим блокчейном
Вы можете использовать старый добрый cURL или Postman для взаимодействия с нашим API в сети.
Запускаем сервер:
$ python blockchain.py * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
$ python blockchain.py * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit) |
Давайте попробуем майнить блок, создав GET-запрос к узлу http://localhost:5000/mine:
curl http://localhost:5000/mine
curl http://localhost:5000/mine |
Теперь, давайте создадим новую транзакцию, отправив POST-запрос к узлу http://localhost:5000/transactions/new с телом, содержащим структуру нашей транзакции:
Если вы не пользуетесь Postman, тогда вы можете создать аналогичный запрос при помощи cURL:
$ curl -X POST -H «Content-Type: application/json» -d ‘{ «sender»: «d4ee26eee15148ee92c6cd394edd974e», «recipient»: «someone-other-address», «amount»: 5 }’ «http://localhost:5000/transactions/new»
$ curl -X POST -H «Content-Type: application/json» -d ‘{ «sender»: «d4ee26eee15148ee92c6cd394edd974e», «recipient»: «someone-other-address», «amount»: 5 }’ «http://localhost:5000/transactions/new» |
Я перезапустил свой сервер и замайнил два блока, итого их количество 3. Давайте проверим всю цепочку, выполнив запрос к узлу http://localhost:5000/chain:
{ «chain»: [ { «index»: 1, «previous_hash»: 1, «proof»: 100, «timestamp»: 1506280650.770839, «transactions»: [] }, { «index»: 2, «previous_hash»: «c099bc…bfb7», «proof»: 35293, «timestamp»: 1506280664.717925, «transactions»: [ { «amount»: 1, «recipient»: «8bbcb347e0634905b0cac7955bae152b», «sender»: «0» } ] }, { «index»: 3, «previous_hash»: «eff91a…10f2», «proof»: 35089, «timestamp»: 1506280666.1086972, «transactions»: [ { «amount»: 1, «recipient»: «8bbcb347e0634905b0cac7955bae152b», «sender»: «0» } ] } ], «length»: 3 }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | { «chain»: [ { «index»: 1, «previous_hash»: 1, «proof»: 100, «timestamp»: 1506280650.770839, «transactions»: [] }, { «index»: 2, «previous_hash»: «c099bc…bfb7», «proof»: 35293, «timestamp»: 1506280664.717925, «transactions»: [ { «amount»: 1, «recipient»: «8bbcb347e0634905b0cac7955bae152b», «sender»: «0» } ] }, { «index»: 3, «previous_hash»: «eff91a…10f2», «proof»: 35089, «timestamp»: 1506280666.1086972, «transactions»: [ { «amount»: 1, «recipient»: «8bbcb347e0634905b0cac7955bae152b», «sender»: «0» } ] } ], «length»: 3 } |
Шаг 4: Консенсус
Пока всё идет очень здорово. У нас есть базовый blockchain, который принимает транзакции и дает возможность майнить новые блоки. Но вся суть блокчейна в том, что они должны быть децентрализованными. А если они децентрализованы, каким образом мы можем гарантировать, все они отображают одну цепочку?
Это называется проблемой Консенсуса, так что нам нужно реализовать алгоритм Консенсуса, если нам нужно больше одного узла в нашей цепи.
Регистрация новых узлов
Чтобы мы смогли реализовать алгоритм Консенсуса, нам нужно найти способом дать узлу знать о существовании соседних узлов в цепи. Каждый узел в нашей цепи должен содержать регистр других узлов в цепи. Следовательно, нам понадобиться больше конечных точек:
- /nodes/register для принятия список новых узлов в форме URL-ов;
- /nodes/resolve для реализации нашего алгоритма Консенсуса, который решает любые конфликты, связанные с подтверждением того, что узел находиться в своей цепи.
Нам нужно будет изменить конструктор нашего Blockchain и привнести метод для регистрации узлов:
… from urllib.parse import urlparse … class Blockchain(object): def __init__(self): … self.nodes = set() … def register_node(self, address): «»» Вносим новый узел в список узлов :param address: <str> адрес узла , другими словами: ‘http://192.168.0.5:5000’ :return: None «»» parsed_url = urlparse(address) self.nodes.add(parsed_url.netloc)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | … from urllib.parse import urlparse …
class Blockchain(object): def __init__(self): … self.nodes = set() …
def register_node(self, address): «»» Вносим новый узел в список узлов
:param address: <str> адрес узла , другими словами: ‘http://192.168.0.5:5000’ :return: None «»»
parsed_url = urlparse(address) self.nodes.add(parsed_url.netloc) |
Обратите внимание на то, что мы использовали set() для хранения списка узлов. Это легкий способ убедиться в том, что внесение новых узлов является идемпотентным — это означает, что вне зависимости от того, сколько раз мы внесем определенный узел, он возникнет только один раз.
Реализация алгоритма Консенсуса
Как мы уже знаем, конфликт заключается в том, что один узел имеет другую цепь, связанную с другим узлом. Чтобы решить это, мы введем правило, где самая длинная и валидная цена является авторитетной. Другими словами, длиннейшая цепь сети де-факто является единственной. Используясь этот алгоритм, мы достигнем Консенсуса среди узлов в нашей сети.
… import requests class Blockchain(object) … def valid_chain(self, chain): «»» Проверяем, является ли внесенный в блок хеш корректным :param chain: <list> blockchain :return: <bool> True если она действительна, False, если нет «»» last_block = chain[0] current_index = 1 while current_index < len(chain): block = chain[current_index] print(f'{last_block}’) print(f'{block}’) print(«\n————\n») # Проверьте правильность хеша блока if block[‘previous_hash’] != self.hash(last_block): return False # Проверяем, является ли подтверждение работы корректным if not self.valid_proof(last_block[‘proof’], block[‘proof’]): return False last_block = block current_index += 1 return True def resolve_conflicts(self): «»» Это наш алгоритм Консенсуса, он разрешает конфликты, заменяя нашу цепь на самую длинную в цепи :return: <bool> True, если бы наша цепь была заменена, False, если нет. «»» neighbours = self.nodes new_chain = None # Ищем только цепи, длиннее нашей max_length = len(self.chain) # Захватываем и проверяем все цепи из всех узлов сети for node in neighbours: response = requests.get(f’http://{node}/chain’) if response.status_code == 200: length = response.json()[‘length’] chain = response.json()[‘chain’] # Проверяем, является ли длина самой длинной, а цепь — валидной if length > max_length and self.valid_chain(chain): max_length = length new_chain = chain # Заменяем нашу цепь, если найдем другую валидную и более длинную if new_chain: self.chain = new_chain return True return False
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 | … import requests
class Blockchain(object) …
def valid_chain(self, chain): «»» Проверяем, является ли внесенный в блок хеш корректным
:param chain: <list> blockchain :return: <bool> True если она действительна, False, если нет «»»
last_block = chain[0] current_index = 1
while current_index < len(chain): block = chain[current_index] print(f'{last_block}’) print(f'{block}’) print(«\n————\n») # Проверьте правильность хеша блока if block[‘previous_hash’] != self.hash(last_block): return False
# Проверяем, является ли подтверждение работы корректным if not self.valid_proof(last_block[‘proof’], block[‘proof’]): return False
last_block = block current_index += 1
return True
def resolve_conflicts(self): «»» Это наш алгоритм Консенсуса, он разрешает конфликты, заменяя нашу цепь на самую длинную в цепи
:return: <bool> True, если бы наша цепь была заменена, False, если нет. «»»
neighbours = self.nodes new_chain = None
# Ищем только цепи, длиннее нашей max_length = len(self.chain)
# Захватываем и проверяем все цепи из всех узлов сети for node in neighbours: response = requests.get(f’http://{node}/chain’)
if response.status_code == 200: length = response.json()[‘length’] chain = response.json()[‘chain’]
# Проверяем, является ли длина самой длинной, а цепь — валидной if length > max_length and self.valid_chain(chain): max_length = length new_chain = chain
# Заменяем нашу цепь, если найдем другую валидную и более длинную if new_chain: self.chain = new_chain return True
return False |
Первый метод valid_chain() отвечает за проверку того, является ли цепь валидной, запустив цикл через каждый блок и проводя верификацию как хеша, так и пруфа.
Метод resolve_conflicts(), который запускает цикл через все наши соседние узлы, загружает их цепи и проводит проверку, как и в предыдущем методе. Если валидная цепь, длина которой больше, чем наша, мы заменяем нашу.
Давайте зарегистрируем две конечные точки нашего API, одну для внесения соседних узлов, а вторую — для решения конфликтов:
@app.route(‘/nodes/register’, methods=[‘POST’]) def register_nodes(): values = request.get_json() nodes = values.get(‘nodes’) if nodes is None: return «Error: Please supply a valid list of nodes», 400 for node in nodes: blockchain.register_node(node) response = { ‘message’: ‘New nodes have been added’, ‘total_nodes’: list(blockchain.nodes), } return jsonify(response), 201 @app.route(‘/nodes/resolve’, methods=[‘GET’]) def consensus(): replaced = blockchain.resolve_conflicts() if replaced: response = { ‘message’: ‘Our chain was replaced’, ‘new_chain’: blockchain.chain } else: response = { ‘message’: ‘Our chain is authoritative’, ‘chain’: blockchain.chain } return jsonify(response), 200
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | @app.route(‘/nodes/register’, methods=[‘POST’]) def register_nodes(): values = request.get_json()
nodes = values.get(‘nodes’) if nodes is None: return «Error: Please supply a valid list of nodes», 400
for node in nodes: blockchain.register_node(node)
response = { ‘message’: ‘New nodes have been added’, ‘total_nodes’: list(blockchain.nodes), } return jsonify(response), 201
@app.route(‘/nodes/resolve’, methods=[‘GET’]) def consensus(): replaced = blockchain.resolve_conflicts()
if replaced: response = { ‘message’: ‘Our chain was replaced’, ‘new_chain’: blockchain.chain } else: response = { ‘message’: ‘Our chain is authoritative’, ‘chain’: blockchain.chain }
return jsonify(response), 200 |
Теперь вы можете сесть за другой компьютер (если хотите), и развернуть разные узлы в своей сети. Также вы можете развернуть процессы при помощи различных портов на одном и том же компьютере. Я развернул еще один узел на своем компьютере, но на другом порте и зарегистрировал его при помощи моего текущего узла. Таким образом, я получил два узла: http://localhost:5000 и http://localhost:5001.
После этого я получил два новых блока в узле 2, чтобы убедиться в том, что цепь была длиннее. После этого, я вызвал GET /nodes/resolve в узле 1, где цепь была заменена нашим алгоритмом консенсуса:
И это была обертка… Найдите друзей и вместе попробуйте протестировать ваш блокчейн!
Подведем итоги
Надеюсь, эта статья вдохновила вас на что-нибудь новое. Я в восторге от криптовалют, так как я верю, что блокчейн радикально изменят наше представление об экономике, правительстве и учетных записях!
Являюсь администратором нескольких порталов по обучению языков программирования Python, Golang и Kotlin. В составе небольшой команды единомышленников, мы занимаемся популяризацией языков программирования на русскоязычную аудиторию. Большая часть статей была адаптирована нами на русский язык и распространяется бесплатно.
E-mail: [email protected]
Образование
Universitatea Tehnică a Moldovei (utm.md)
- 2014 — 2018 Технический Университет Молдовы, ИТ-Инженер. Тема дипломной работы «Автоматизация покупки и продажи криптовалюты используя технический анализ»
- 2018 — 2020 Технический Университет Молдовы, Магистр, Магистерская диссертация «Идентификация человека в киберпространстве по фотографии лица»
Как запустить свой блокчейн: выбираем движок
Перед разработкой собственного блокчейна ваша команда должна четко понимать, для чего необходим блокчейн и какой бюджет вы сможете выделить на его содержание.
Проектирование и запуск блокчейна имеют свои нюансы. Их можно легко упустить при планировании, если вы неверно оценили объем и сложность задачи.
Чтобы помочь проектам избежать таких ошибок, руководитель отдела исследований MixBytes Сергей Прилуцкий подготовил пошаговое руководство по запуску блокчейна.
Данная статья поможет вам определиться с выбором движка для построения собственного блокчейна. Технические свойства и ограничения блокчейна описаны здесь, выбор алгоритма консенсуса — здесь.
Блокчейн с нуля
Попытки создать блокчейн с нуля без сомнения похвальны, ведь благодаря им появились многие существующие решения. Тем не менее нужно трезво оценивать возможности своей команды.
Написание с нуля кода блокчейн-ноды напоминает создание собственной базы данных с механизмом надежной сетевой репликации. Если вы поищете, сколько таких БД было создано за последние десятилетия, то найдете максимум сотню проектов. Огромной долей рынка владеют всего несколько компаний (Oracle, MS SQL Server, MySQL, PostgreSQL), а разработчики ядра таких систем ценятся крайне высоко.
Для разработки блокчейн-ноды вам придется собрать команду очень крутых и редких специалистов, имеющих опыт работы с многопоточным программированием, криптографией, сетевыми протоколами, сложными внутренними алгоритмами и понимающих работу современных операционных систем.
Особенное место для блокчейнов занимает тестирование, так как алгоритмы консенсуса могут прекрасно себя вести на нескольких валидаторах и совершенно по другому при наличии десятков и сотен узлов под нагрузкой. Увеличение числа разработчиков в данном случае приведет разве что к усложнению коммуникаций внутри команды.
По опыту нашей компании, бизнес-заказчики редко выбирают этот путь. Создание своего блокчейна — это задача для группы исследователей, энтузиастов, которые могут себе позволить работать свободно, не имея жестких сроков и бизнес-плана. Такая команда должна иметь возможность свободно исследовать любой встретившийся вопрос, не сильно заботясь о сроках сдачи проектов. На текущий момент работа над такими проектами, как биткоин и Ethereum, производится независимыми разработчиками по всему миру, без жестких дедлайнов. Внешнее давление бизнес-факторов может сыграть с вашим проектом злую шутку, заставив быстрее решать проблемы, не продумав последствия.
Готовые блокчейн-движки
Я намеренно назвал раздел «движки», так как этот термин в области ПО часто используется для обозначения комплексов разнопланового ПО, предназначенного для решения конкретной задачи. Например, «поисковый движок» или «графический движок» — это не только код, но и вспомогательное ПО, дополнительные утилиты, описания алгоритмов и многое другое. Учитывая существование нескольких основных ядер блокчейнов, на базе которых построены уже существующие сети, будет удобно называть их движками (например, «построен на движке Ethereum»).
Если ваш блокчейн не обладает уникальной архитектурой и ваша задача — доставка решения за определенный промежуток времени, лучшим вариантом будет работа с уже существующими движками. Они позволяют реализовать ваш вид консенсуса и транзакций, по-своему организовать управление валидаторами сети. Вы сможете использовать готовый открытый код, проверенный в реальных сетях. Вам не придется изменять код блокчейн-ноды, а для реализации своей логики нужно будет менять только часть, предусмотренную разработчиками движков. Не внося новых уязвимостей и не решая проблемы сетевого слоя, вы сможете сосредоточиться только на бизнес-логике вашего блокчейна.
Разберем готовые для работы блокчейн-движки, используя которые вы сможете запустить собственный блокчейн, спроектировать и реализовать его внутреннюю экономику и организовать запуск для проведения сложных сделок.
Ethereum
Этот комплекс ПО построен на базе ядра публичного блокчейна Ethereum. Публичный Ethereum использует консенсус типа Proof-of-Work, а его многочисленные тестовые сети — различные виды Proof-of-Authority и Proof-of-Stake консенсусов. ПО отвечает самым строгим критериям безопасности, проверено в десятках реально работающих сетей и, на мой взгляд, является наиболее развитым для создания блокчейнов с любыми видами консенсусов и полноценными, многофункциональными смарт-контрактами.
Нужно отметить роль проекта POA Network, чьи разработчики проделали огромную работу и запустили уже несколько быстрых и надежных сетей. POA Network существенно быстрее оригинального Ethereum, но при этом обладает той же стойкостью и универсальностью для заключения любых сделок, а роль валидаторов (майнеров) исполняют компьютеры, честная работа которых заверяется юридически. Эту сеть можно считать эталоном для запуска корпоративных блокчейнов на базе Ethereum.
Код блокчейн-ноды и консенсус
Существуют две основных имплементации кода ноды Ethereum: на языке Rust (код, названия: poa-parity (старое) или openethereum(новое)) и на Go (код, название: geth).
На момент написания при построении PoA-сети на geth (Go) вам будет доступен только консенсус Clique — это простейший и небезопасный протокол без финализации, который можно использовать только в тестовых целях.
Консенсус, реализованный в poa-parity (Rust), состоит из двух алгоритмов: schedule валидаторов Aura и finality gadget GRANDPA. Именно этот вариант, проверенный и безопасный, работает в POA-сетях на базе Ethereum. POA Network работают также над имплементацией перспективного BFT-консенсуса HoneyBadger.
Отдельного упоминания заслуживает новая блокчейн-нода Nethermind, написанная на C# для платформы .NET Core. Она полностью поддерживает Ethereum, большое число операционных систем и является отличным выбором для компаний, которые используют .NET Core.
Смарт-контракты и управление сетью
POA Ethereum использует виртуальную машину EVM и смарт-контракты, которые лучше всего писать на языке Solidity. EVM давно стала стандартом для виртуальных машин с большим количеством готового кода и паттернов разработки. Код контрактов под EVM отвечает за большие суммы криптовалюты, и любая найденная уязвимость вызывает мощную реакцию сообщества и СМИ, поэтому безопасность контрактов EVM на текущий момент крайне высока.
Управление списком валидаторов осуществляется посредством смарт-контрактов — это потрясающе удобно. Можно оперировать одним или несколькими токенами или вообще избавиться от них. Можно сделать процедуру добавления валидаторов гибкой или максимально упростить, добавив «всемогущий» аккаунт. Мощь этой схемы в том, что буквально один разработчик контрактов может создать полную экономику сети на одной платформе с высочайшим уровнем безопасности и переносимости, реализовав сразу и управление сетью, и логику сделок, и другие свойства.
Дополнительное ПО
С Ethereum можно использовать JavaScript-библиотеку web3.js, вне зависимости от консенсуса, валидаторов и ее расположения.
Для POA Ethereum существует репозитарий для автоматизации операций по развертыванию готовой сети — deployment-playbooks.
Если вы планируете запускать POA Ethereum, используйте эту инструкцию. Она проведет вас от создания ключей валидаторов к запуску первых нод, развертыванию системных контрактов и запуску интерфейса валидаторов и обозревателя блоков.
Готовая POA-сеть Ethereum присутствует в AWS, но я все же рекомендую контролировать запуск своими руками. Вы должны понимать, какие сервисы вы запускаете и как они работают.
EOS и его форки
Вторым по гарантиям работоспособности и безопасности будет EOS. “OS” в его названии появилась не случайно.
EOS можно запустить в качестве отдельной сети, в PoS- или PoA-варианте. Как и Ethereum, это ПО уже проверено в бою, обладает высокой безопасностью и функционалом, который позволяет запустить собственный блокчейн со смарт-контрактами для автоматизации любых сделок
Если Ethereum имеет простую систему адресов, то в EOS сразу же используется иерархическая система аккаунтов и права на различные действия. Все это делает EOS похожей по дизайну на операционную систему — «программу для запуска других программ».
В качестве межкорпоративной платформы EOS позволяет из коробки получить удобную систему управления аккаунтами и быстрый консенсус, а также легко интегрировать практически любой функционал при помощи плагинов на C++ и смарт-контрактов на C++/WebAssembly (например, можно добавить другую криптографию).
Дизайн консенсуса в EOS и быстрые блоки позволяют достичь очень быстрого времени ответа пользователю, что крайне важно для построения децентрализованных приложений со сложным функционалом (например, проекты Cyberway, Golos.io или соцсеть Commun). Cyberway недавно произвел сложнейшую миграцию всей бизнес-логики из предыдущего блокчейна прозрачно для пользователей, что лишний раз доказывает гибкость и универсальность EOS.
Код блокчейн-ноды и консенсус
Код EOS написан на C++ и развивался на основе опыта, полученного разработчиками при работе над движками Graphene, Bitshares, Steemit. Используется собственный вариант DPoS-консенсуса.
Сейчас почти все проекты, использующие DPoS, строят свои алгоритмы очень похожим на EOS образом: это аккаунты, «голосующие» балансом токена за топ валидаторов. Валидаторы подписывают блоки по одиночке, но каждый в назначенный квант времени, согласно расписанию. Затем они коллективно фиксируют так называемый Last Irreversible Block (LIB), на котором собирается 2/3 + 1 подписей от валидаторов.
Многие форки EOS пытаются улучшить это консенсус. Например, наш вариант Haya использует для фиксации LIB другой finality gadget — RANDPA, чтобы достичь времени финальности в 2-3 секунды.
Переход к корпоративному POA-консенсусу не вызывает затруднений, так как список валидаторов управляется системными смарт-контрактами.
Смарт-контракты и управление сетью
Смарт-контракты в EOS используют модифицированную виртуальную машину WebAssembly, обычно пишутся на языке C++ и могут создаваться и использоваться любым аккаунтом. Писать смарт-контракты не сложно, во многом они перекликаются с Solidity.
В EOS, как и в POA Ethereum, управление сетью, основной токен (или токены) и типы транзакций можно реализовать в системных смарт-контрактаx (вот, например, системный токен). Интересной особенностью контрактов EOS является использование абстракции table для хранения данных контракта. В Ethereum в основном используется mapping (ассоциативный массив).
Еще одна особенность смарт-контрактов в EOS — upgradeability. Владелец контракта может заменить его, обновив логику или исправив ошибку. Это сильно отличается от Ethereum, где неизменность контрактов — важное условие, гарантирующее, что логика контракта никогда уже не будет изменена, если не произойдет хардфорк.
Для межкорпоративных блокчейнов, на мой взгляд, возможность изменять код контрактов — важное преимущество. Незаметно что-то украсть здесь все равно не получится, зато обновить код по соглашению сторон можно без всякого участия валидаторов.
В EOS возможно организовать «спонсорские» транзакции, оплачиваемые владельцами контракта, а не самими пользователями. Это мощнейшая возможность для привлечения новых пользователей. Вы ведь помните, что «бесплатных» транзакций без потери безопасности в блокчейнах не бывает?
Дополнительное ПО
BOSCore, Telos, Haya и еще десяток форков EOS доказывают, что это ПО интересно большому количеству проектов. Для EOS существует достаточно инструментов, и вам не придется с нуля реализовывать сопутствующее ПО.
Eosjs — аналог web3.js, позволяет работать с контрактами любой сети на базе EOS из браузера и любых приложений.
EOSTracker — обозреватель блоков с открытым кодом и децентрализованными приложениями для голосований за валидаторов.
У EOS нет одного большого и мощного интегратора, как POA Network для Ethereum, поэтому каждый проект строит собственное решение. Тем не менее, основной код ноды стабилен и работает под серьезными нагрузками без сбоев.
Parity Substrate
Substrate создается командой компании Parity. Разработано огромное количество ПО: кошельки, блокчейн-ноды, системы смарт-контрактов, компиляторы, виртуальные машины.
Parity Substrate позволяет разработчику достаточно легко создать свой вариант блокчейна из готовых модулей со сложным консенсусом и логикой обработки транзакций. Substrate — это конструктор блокчейнов, на котором, к примеру, можно сделать блокчейн-ноду Ethereum или биткоина.
Substrate — это часть крупного проекта Polkadot — системы, состоящей из основной цепочки и множества цепочек-шардов с индивидуальной логикой.
Преимущество «подключения» своего блокчейна к Polkadot заключается в возможности ончейн-обмена данными с другими цепочками и возможностью использовать их контракты, аккаунты, токены без дополнительного ПО.
Код блокчейн-ноды и консенсус
Код Substrate написан на языке Rust. На мой взгляд, в структуре Substrate чувствуется большой опыт команды по созданию блокчейнов, так как все компоненты отлично структурированы, разделены на отдельные модули, а в коде присутствуют подробные комментарии. Доказательством гибкости этого движка является существование клиента для сети биткоина и ZCash на основе кода Substrate.
Что касается консенсуса, то можно выбрать из нескольких готовых вариантов или написать свой собственный. В большинстве случаев это PoA или DPoS, что в случае Substrate означает использование алгоритма Aura и GRANDPA.
Производительность блокчейнов на базе Substrate высока. Основная цепочка Polkadot была протестирована нами в конфигурации с 99 валидаторами, распределенными по трем континентам, и показала отличные результаты.
Преимуществом Substrate я считаю продуманность архитектуры, стек разработки (Rust), и огромное поле для развития. Это крайне гибкая сеть, на базе которой можно построить решения любого уровня сложности.
Смарт-контракты и управление сетью
Substrate, в отличие от Ethereum и EOS, обрабатывает транзакции при помощи кода, который размещается валидаторами, а не пользователями. Это код называется “runtime” и исполняется виртуальной машиной WebAssembly.
Напомню, что runtime — это по сути один большой смарт-контракт, который обновляется валидаторами и собирается разработчиком из отдельных модулей. Модули содержат логику аккаунтов, токенов, сделок любой сложности, и т.д. Именно это свойство превращает Substrate в конструктор. Вполне возможно, для решения ваших задач потребуется просто скомбинировать несколько готовых модулей или незначительно доработать один из них.
Особого упоминания заслуживают модули пользовательских смарт контрактов: WASM и EVM. Они дают возможность пользователям размещать свои смарт-контракты, поэтому запуск универсального блокчейна на Substrate тоже возможен.
Ограничения на запуск транзакций реализуются разработчиками runtime — можно сделать все транзакции за одну и ту же цену, учитывать ресурсы с точностью до бита или сделать все бесплатным и вообще не использовать внутреннюю криптовалюту.
В плане гибкости у runtime есть множество преимуществ — разработчик может комбинировать их, создавать сложные роли, объединять управление сетью, внутреннюю логику и экономику. Учитывать следует лишь то, что обновление кода runtime проводится кворумом валидаторов.
Дополнительное ПО
Для Substrate есть ряд полезных решений: polkascan — обозреватель блоков и комплекс программ на JS для работы с Polkadot и сетями на базе Substrate. Возможно, вам пригодятся ansible-сценарии для развертывания готового кластера на базе Substrate, который мы использовали для тестирования Polkadot.
У Substrate нет богатого выбора универсального ПО, кошельков и обозревателей блоков, как у Ethereum или EOS, так как цепочки могут сильно отличаться между собой. Проект активно развивается, и множество команд параллельно создают сопутствующее ПО.
Cosmos SDK
Cosmos — это проект на базе одной основной цепочки и множества дочерних блокчейнов, называемых «zones». Дочерние цепочки строятся на основе Cosmos SDK — набора ПО для построения блокчейнов.
Cosmos — это продолжение проекта Tendermint, из которого ключевыми технологиями является надежный консенсус и концепция Application, сходная с runtime в Substrate.
Как и в случае Polkadot+Substrate, блокчейн, созданный с помощью Cosmos SDK, может жить отдельно или подключиться к экосистеме Cosmos как дочерняя цепочка.
Весь комплекс ПО Cosmos написан на Go и отлично структурирован и активно используется. На его основе уже работают несколько проектов, среди которых Binance Chain.
Если ваши разработчики пишут на Go — Cosmos SDK может вам подойти. Он работает и активно развивается в реальных проектах, чьи блокчейны и транзакции можно увидеть в публичных сетях.
Код блокчейн-ноды и консенсус
Главная концепция Cosmos называется Application. Любой блокчейн представляет собой машину состояний, и в Cosmos она вынесена в отдельную часть кода.
По сути, разработчик просто задает правила, по которым одни данные превращаются в другие при внешнем воздействии, программируя так называемую функцию state transition. Это сложно звучит, но по факту обработка транзакции — это state transition, которая меняет несколько балансов. Именно этим занимается Application — принимает некоторое воздействие извне (транзакцию) и меняет свое состояние (state). Получившиеся изменения фиксируются в блокчейне. При этом разработчик не должен решать проблемы консенсуса и сети — сеть сама договорится между собой и придет к консенсусу относительно результатов.
Консенсус в Cosmos построен на базе консенсуса Tendermint, крайне близкого к pBFT. Его особенность в том, что подтверждения валидаторов собираются на каждый блок, что означает мгновенную финальность, как только блок принят сетью. Этот алгоритм требует много сообщений между валидаторами, и в случае проблем с сетью этот консенсус будет медленнее финализировать цепочку.
Зато он является наиболее предсказуемым, защищенным от форков, имеет формальные математические доказательства надежности и, по моему мнению, является наиболее строгим и безопасным решением из всех существующих консенсусов.
Смарт-контракты и управление сетью
Application в Cosmos можно рассматривать как единый смарт-контракт, ответственный за обработку всех видов транзакций. Вот пример структуры Application для сервиса регистрации имен.
Одновременно с созданием кода для блокчейн-нод, Cosmos SDK создает код клиента, который умеет формировать транзакции нужных типов.
Для ограничения транзакций в Cosmos, как в Ethereum, используется газ. Исполняя транзакцию, валидаторы вычисляют ее стоимость в условных единицах «gas». Отправляя транзакцию, пользователь указывает цену, которую он готов платить за единицу газа и лимит, который он готов потратить. Это является основанием для вычисления цены за транзакцию.
Важным для Application в Cosmos являются требования к детерминизму кода, т.е. разрабатываемые операции не должны порождать разные результаты в разные моменты времени или на разных архитектурах, иначе блокчейн не будет работать.
Дополнительное ПО
Параллельно с созданием кода Application, Cosmos SDK позволяет сразу же получить код, который вызывает нужные функции с клиентских машин. Этот код можно использовать на сайте, работающем с Cosmos, или в кошельке (клиенте) сети.
На JavaScript я нашел несколько полезных библиотек: js-cosmos, cosmosjs и универсальную js-abci, реализующую интерфейс ABCI. Их удобно использовать, если взаимодействие с вашим блокчейном планируется из браузера. ABCI позволяет создавать Application на разных языках, среди которых Java, C++, Python. Проект lotion, например, позволяет создать блокчейн полностью на Javascript.
Cosmos бурно развивается, на этом движке запускается много разных проектов. Рекомендую обратить на него внимание, если у вас есть экспертиза в Go и вы хотите надежное работающее решение.
Подписывайтесь на канал Forklog в YouTube!
Нашли ошибку в тексте? Выделите ее и нажмите CTRL+ENTER
как Вышка отвечает на вызовы будущего – Национальный исследовательский университет «Высшая школа экономики»
занимается консультированием компаний, использующих блокчейн-технологии, а также созданием программных решений в области финансов и права
Если люди хотят оптимизировать свои отношения, сделать их более прозрачными и зафиксированными, то этой компании нужен блокчейн.
Мария Аграновская, адвокат, руководитель практики «Финтех, блокчейн и криптовалюты» в юридической компании GRAD (Источник)
В современных условиях юристы финансового рынка должны обладать не только узкоспециальной квалификацией, но и владеть знаниями на стыке наук, уметь находить правовые средства для решения экономических и управленческих задач. Технология blockchain способствует появлению огромного числа предприятий, которые самостоятельно привлекают финансовые ресурсы, управляют инфраструктурой и создают ценность для потребителя радикально новыми способами.
Данная технология бросает определенный вызов фундаментальным основам современного законодательства, что определяет спрос на юристов, ориентированных на инновации в правоприменительной деятельности. Предприятия и некоммерческие организации, основанные с применением или использующие блокчейн-технологии, сталкиваются с отсутствием чётких правил для участников рынка. Юрист, специализирующийся на технологии блокчейн, занимается консультированием организаций по вопросам соблюдения правовых норм и проектирования систем для блокчейн-проектов.
Драйверы профессии
- Стремительное развитие технологии блокчейн
- Рост числа компаний и проектов, использующих блокчейн
- Перспективы применения технологии блокчейн в здравоохранении, политике, финансовых услугах, шеринг-продуктах
- Интерес регуляторов к контролю над новыми финансовыми технологиями
Задачи, которые решает специалист
- Консультирование и правовое сопровождение клиентов, использующих технологию блокчейн
- Разработка средств законодательного регулирования и правоприменительной практики в области использования технологии блокчейн
- Разработка программных решений в области права и финансов для компаний, ориентированных на использование блокчейн-технологии
- Нахождение правовых средств минимизации рисков, возникающих на финансовых рынках
Необходимые компетенции
- Знания в области права, финансов, менеджмента и информационных технологий
- Знания в области правового регулирования финтеха (криптоактивы, блокчейн, новые механизмы финансирования бизнеса)
- Знания в области LegalTech (инновационные технологии в работе юристов на международных финансовых рынках)
- Навыки анализа существующих и возникающих рисков на финансовых рынках
- Знания в области кибербезопасности
Магистерские программы
ДРУГИЕ ПРОФЕССИИ НАПРАВЛЕНИЯ «ПЕРЕХОД К НОВОЙ МОДЕЛИ ЭКОНОМИЧЕСКОГО РОСТА»
Биткойн-термины – Blockchain Центр поддержки
Блок
Блоки находятся в цепи блокчейн биткойнов. Блоки соединяют все транзакции. Транзакции соединяются в одиночные блоки и проверяются каждые 10 минут с помощью операции майнинг. Каждый последующий блок усиливает проверку предыдущих блоков и делает невозможной дупликацию транзакции биткойна. (Смотрите дупликация ниже.)
BIP
BIP (Bitcoin Improvement Proposal, т.е. Проект развития Биткойнов) это документ, в котором описывается технический дизайн, или новые возможности для биткойнов, или новые процессы, или программная среда, меняющие протокол Биткойнов. Новые возможности, идеи и изменения дизайна протокола должны предлагаться в виде BIP. Авторы BIP несут ответственность за достижение консенсуса среди членов сообщества и за составление документа, описывающего разногласия.
Блокчейн
Блокчейн биткойнов это общедоступная запись всех биткойновых транзакций. Также встречается использoвание этого термина как «общедоступная учетная база данных.» Блокчейн содержит все записи о транзакциях биткойнов, начиная с самой первой по времени. Любой человек может загрузить и проверить весь блокчейн, то же можно сделать онлайн с помощью эксплорера блоков.
Высота блока
Высотой блока называют число блоков соединенных в блокчейн. Нулевая высота соответствует самому первому блоку, называемому «блоком творения» (англ. genesis block).
Блок-награда
Когда блок успешно добавлен к сети биткойнов, возникает плата (награда) за блок, которая поощряет работу майнеров над сохранностью и безопасностью сети. Эта награда является частью «платы за транзакцию», которая может включать в себя оплату за операцию перевода. Плата за блок уменьшается вдвое примерно каждые 4 года; смотрите также «уполовинивание.»
Сдача
Допустим, вы потратили $1.90 в магазине, и вы даете кассиру $2.00. Вы получите 10 центов сдачи. Те же правила работают и с биткойнами. Транзакции биткойнов состоят из прихода и расхода. Когда вы посылаете биткойны, вы можете сделать это только в целых единицах расхода. После этого вы получаете сдачу.
Холодное Хранилище
Термин Холодное Хранилище используется для обозначения хранения ваших биткойнов офлайн, без связи с интернетом. Противоположным этому будет горячий кошелек, или рабочий кошелек, который соединен с интернетом для осуществления транзакций. Целью холодного хранения является уменьшение вероятности похищения ваших биткойнов, оно обычно используется для хранения значительных сумм.
Подтверждение
Подтверждение означает, что транзакция биткойнов прошла проверку в сети с помощью процесса называемого майнинг. Транзакция, получившая подтверждение, уже не может быть отменена или сделана вторично. Транзакции включаются в блоки.
Криптография
Криптография используется повсеместно для обеспечения безопасности сети биткойнов. Криптография представляет собой математические и компьютерные алгоритмы шифрования и дешифровки информации, и используется в адресах биткойнов, хэш функциях и в блокчейн.
Децентрализация
Децентрализация сети биткойн является ключевым аспектом. Сеть децентрализована, если у нее отсутствует орган или компания, которая управляет этой сетью. Биткойн основан на пиринговом (P2P) протоколе, в котором все пользователи в сети работают и взаимодействуют непосредственно друг с другом, вместо того чтобы передавать свои фонды через посредника, как, например, банк или кредитная компания.
Сложность
Сложность непосредственно связана с майнингом (смотриte майнинг ниже), и с тем, насколько трудоемкой является проверка блоков в сети Биткойн. Биткойн регулирует сложность майнинга в проверке блоков каждые 2016 блоков. Сложность автоматически регулируется так, чтобы поддерживать время проверки (верификации) блоков на уровне 10 минут.
Дупликация
Дупликация, или двойная транзакция, возникает если кто-то пытается послать транзакцию биткойнов двум разным получателям одновременно. Как только транзакция биткойнов подтверждена, дупликация транзакции становится невозможной. Чем больше подтверждений имеется у транзакции, тем труднее совершить дупликацию перевода биткойнов.
Полная нода
Полная нода возникает если вы загрузите всю блокчейн используя клиент биткойна, и передаете, проверяете и сохраняете данные в этой блокчейн. Данные представляют собой транзакции биткойнов и блоки, которые проверяются во всей сети пользователей.
Уполовинивание
Конечное число биткойнов делает их труднодоступными. Полное число биткойнов, которое может быть выпущено, составляет 21 миллион. Число биткойнов, генерируемое на каждый блок, уменьшается на 50% каждые 4 года. Это называется уменьшением вдвое, уполовиниванием. Самое последнее уполовинивание произойдет в 2140 году.
Скорость хэша
Скорость хэша это показатель мощности майнинга сети Биткойн. Для того, чтобы майнеры подтвердили транзакцию и поддерживали блокчейн, их компьютеры должны выполнять множество операций, производительность которых измеряется в хешах в секунду.
Майнинг
Майнинг биткойнов состоит в использовании компьютеров для математических вычислений подтверждающих транзакции в сети Биткойн. Майнеры собирают оплату за транзакции, которые они подтверждают, и получают биткойны за каждый проверенный блок.
Пул
Майнинг пул это объединение майнеров для совместного майнинга блоков, в котором они делят награду за каждый блок. Майнинг пулы позвояют майнерам объединять ресурсы и повышать вероятность успешного майнинга блоков, а также поддерживать здоровую децентрализацию сети Биткойн.
Личный ключ
Приватный (личный) ключ это строка данных, которая показывает, что у вас есть доступ к биткойнам в каком-то кошельке. Можно рассматривать этот ключ как пароль; никогда не доверяйте никому свой ключ, поскольку он дает возможность использовать биткойны из вашего кошелька с помощью зашифрованной подписи.
Доказательство выполнения работы
Доказательство выполнения работы относится к хэшу заголовка блока (блоков транзакции биткойнов). Блок считается правильным только если его хэш ниже чем текущая цель. Каждый блок соотносится с предыдущим блоком и добавляет предыдущие доказательства выполнения работы, формируя цепь блоков, известную как блокчейн. Когда цепь (блокчейн) сформирована, она подтверждает все предыдущие транзакции биткойнов и обеспечивает сохранность сети.
Публичный адрес
Общедоступный (публичный) адрес биткойна является криптографишеским хэшем общедоступного ключа. Общедоступный адрес обычно начинается с цифры «1». Можно рассматривать публичный адрес как аналог адреса электронной почты. Он может быть опубликован где угодно, и биткойны можно послать по этому адресу, так же как письмо можно послать по е-мейлу. Прочитать о том, как получить биткойны на свой кошелек можно здесь.
Сатоси Накамото
Биткойны появились после публикации в 2008 году научной статьи, написанной девелопером по имени Сатоши Накамото. Имя Сатоши известно всем как имя изобретателя биткойнов. Вы можете почитать о Сатоши здесь.
Транзакция
Транзакцией называется пересылка данных от одного адреса биткойна на другой. Подобно финансовым транзакциям, где деньги переводятся от одного клиента к другому, в сети биткойн вы делаете то же самое, посылая данные (биткойны) друг другу. Ценность биткойнов определяется математически, в отличие от цены физических эквивалентов (золота или серебра), или от доверия централизованным институтам, в случае бумажных денег.
Кошелек
Подобно тому, как бумажные доллары хранятся в кошельке или бумажнике, кошелек биткойн работает как цифровой кошелек, пользуясь которым вы можете безопасно хранить, посылать и получать биткойны. Существует много разновидностей кошельков, доступных в интернете или в мобильных приложениях. В идеале, кошелек биткойн предоставляет вам доступ к вашему публичному и к приватному ключу. Это значит, что только вы располагаете доступом к вaшим биткойнам и можете тратить их, когда понадобится.
Как создать приложение с использованием блокчейна
Информация о блокчейне фрагментирована: сложность технологии, нехватка грамотных разработчиков, медийный ажиотаж и ошибочное отождествление с криптовалютами привели к формированию искаженного представления о блокчейне.
Однако его развитие не стоит на месте: если еще несколько лет назад блокчейн-проекты, в которых была задействована наша команда, ограничивались разработкой приложений для финансового сектора (в частности, для работы с криптовалютами), то сегодня среди наших клиентов наибольшим спросом пользуются блокчейн-приложения, обслуживающие различные сферы бизнеса — от торговли и рекламы до логистики и социальных сетей.
Одним из последних блокчейн-проектов, над которым мы работали, было приложение для торговой розничной сети. Проект направлен на автоматизацию процессов управления цепями поставок. В нашем приложении блокчейн позволяет отслеживать перемещение продуктов внутри сложной сети от производителей, поставщиков и дистрибьюторов до конечных потребителей. Алгоритмы создания смарт-контрактов и генерация цифровых подписей — прочная гарантия того, что фальсификация информации или нарушение целостности цепочки, хранящей данные о продукте и условиях транспортировки, невозможны.
Количество запросов, поступивших в нашу компанию, и актуальных проектов по разработке приложений с использованием блокчейн наглядно демонстрируют, что востребованность подобных проектов только начинает набирать обороты.
Создать собственное приложение с использованием блокчейн возможно 3 способами, выбор зависит от того, какие цели вы преследуете:
1. Используем платформу для блокчейн-приложенийСоздание приложения с использованием готового блокчейна на одной из специализированных платформ — это самый простой и быстрый способ разработки приложения.
Наиболее популярные платформы:
- Ethereum — одна из самых известных и функциональных блокчейн-платформ с развитой инфраструктурой для создания смарт-контрактов и разработки децентрализованных приложений. Основной язык программирования — Solidity, внутренняя криптовалюта — Ether (ETH).
- Hyperledger Fabric — перспективная платформа для разработки решений на базе блокчейна, ориентированных на корпоративный сегмент. Появилась при поддержке IBM и в данный момент не имеет своей криптовалюты. Актуальные языки программирования: Go, Java, JavaScript.
- Cardano — действующая блокчейн-платформа нового типа; ключевое отличие от других платформ заключается в том, что в Cardano существует разделение вычислительных слоев: первый слой предназначен для работы с внутренней криптовалютой ADA, второй — для создания и обработки смарт-контрактов, написанных на языке программирования Haskell.
Выбор платформы зависит от сложности и цели проекта. При создании своих децентрализованных проектов, мы в Umbrella IT обычно используем платформу Ethereum. Так, одной из первых наших работ на Ethereum, была блокчейн-лотерея. Технология блокчейн помогла обеспечить абсолютную честность розыгрыша, а система смарт-контрактов сделала возможным автоматические выплаты выигрышей сразу на счет участника. В ходе разработки наша команда убедилась, что платформа отвечает всем нашим критериям качества: универсальность, гибкость и скорость разработки.
Для реализации блокчейна на платформе Etherium, необходимо создать новый смарт-контракт на высокоуровневом языке Solidity, чей синтаксис похож на JavaScript, и загрузить его в сеть Etherium, где уже есть свой API и все необходимое для быстрого запуска готового продукта.
Однако не все так гладко: в данном случае, используется блокчейн-платформа, Etherium, и это значит, что с каждой транзакции и при каждом изменении, внесенном в смарт-контракт, с вас взимается комиссия в ETH за использование вычислительных ресурсов платформы, которая идет майнерам платформы, поддерживающим работу и обеспечивающим работу сети. И вместе с популярностью вашего приложения и расширением клиентской базы будет параллельно расти ваш уровень расходов.
Плюсы:
- блокчейн-платформа требует минимум усилий со стороны разработчика на начальном этапе и вместе со всеми необходимыми инструментами для разработки приложения предоставляет готовую сеть и инфраструктуру со своими серверами и майнерами.
Минусы:
- за каждое использование вычислительных ресурсов платформы с вас взимается комиссия монетами ETH. Это значит, что ваши расходы будут постоянно увеличиваться пропорционально росту популярности вашего приложения.
На разработку ядра блокчейн-приложения с использованием готового блокчейна в среднем уходит 2 недели.
2. Разворачиваем собственную сеть на базе open-source блокчейн-платформыИ тут нам на помощь снова приходит блокчейн-платформа Etherium. Etherium — это платформа с открытым исходным кодом, который опытный разработчик может адаптировать под цели и нужды конкретного проекта, развернув собственную сеть-клон Etherium, и создать уникальный, независимый децентрализованный продукт.
Данный вариант прежде всего привлекателен своей автономностью: ваша сеть — ваши правила. За счет использования открытого кода, вы экономите время и ресурсы, необходимое для создания собственной сети.
Плюсы:
- создание блокчейна на базе open-source платформы освобождает от уплаты комиссии за каждую проведенную транзакцию. Все ваши расходы будут ограничиваться статичной ежемесячной суммой на поддержание ваших серверов и инфраструктуры и не будут увеличиваться с ростом транзакций.
Минусы:
- вам придется самостоятельно создавать и поддерживать инфраструктуру: от мониторинга и масштабирования до настройки оборудования для обслуживания сети (майнинга), что предполагает дополнительные систематические расходы.
Разработка приложения с созданием собственной блокчейн-сети занимает минимум 1 месяц.
3. Создаем проект с использованием блокчейна с нуляРазработка блокчейна с нуля подразумевает создание приложения на одном из высокоуровневых языков программирования (С, С+, С#, Java) с использованием огромного количества криптографических алгоритмов. Криптографические алгоритмы — фундаментальная основа блокчейна. Для подписи и верификации любых данных внутри информационного блока проводятся различные процедуры, состоящие из сложных арифметических операций, что, по сути, переносит разработку блокчейна скорее в область математики, чем программирования.
Плюсы:
- отсутствие комиссии за использование вычислительных ресурсов платформы;
- создание блокчейна с нуля обосновано при наличии уникальных условий или ограничений (например, если для вас критично, чтобы ваша сеть функционировала в рамках конкретных государств), а также в случаях, когда существующие алгоритмы готовых блокчейнов не соответствует вашим поставленным целям и задачам.
Минусы:
- долгий срок разработки;
- так же, как и при создании собственной сети на базе open-source платформы, разработка блокчейна с нуля требует создания полноценной инфраструктуры (включая настройку серверов, администрирование оборудования и подключением майнеров), которую вам придется мониторить и поддерживать самостоятельно.
Разработка собственного блокчейна занимает минимум 6 месяцев.
От теории к практикеНаш опыт показывает, что в большинстве случаев, при необходимости разработки приложения с использованием блокчейна, наиболее оптимальным решением будет либо использование платформы для блокчейн-приложений, либо создание собственной сети на базе open-source платформы.
Именно с помощью готового блокчейна мы разработали приложение для здравоохранения. Приложение позволяет пользователю получить быструю, своевременную и качественную консультацию у врача и обеспечить безопасность и конфиденциальность всех данных с помощью криптографических алгоритмов. В качестве платежного средства использовался ETH.
Каждая из сторон — в нашем случае, в качестве децентрализованных участников коммуникации выступают пациент и врач — имеет возможность оставлять отзывы, которые доступны всем и не могут быть подделаны благодаря цифровым подписям и блокчейн-сети.
Архитектура нашего приложения выглядит так:
Эта архитектура универсальна и подходит для реализации в любой сфере и индустрии.
Уникальное приложение с использованием блокчейна, созданное опытными разработчиками, станет незаменимым инструментом для ваших клиентов и реактивным ускорителем вашего бизнеса.
Закажите приложение с использованием блокчейна прямо сейчас!
Как создать свою собственную криптовалюту: руководство для начинающих
Криптовалюта — одно из слов, от которых в наши дни нельзя избегать. Новости, блоги и даже крупные финансовые органы зациклены на этом, и теперь все должны признать: мир меняется на наших глазах. Пропустите эту подножку сейчас, и вы останетесь настолько позади, что можете никогда не выздороветь.
Итак, вот вы с этой отличной новой бизнес-идеей или готовитесь к запуску стартапа, и вы хотите воспользоваться захватывающими возможностями нового мира и создать свою собственную криптовалюту.Но как именно это сделать? Интернет полон информации, но, как это часто бывает, она противоречива, разбросана повсюду, а иногда просто трудна для понимания из-за тяжелого промышленного жаргона.
Прочитав эту статью, вы точно узнаете, что такое криптовалюта, чем токен отличается от монеты, как создать собственную криптовалюту и нужно ли это вашему бизнесу.
Как создать собственную криптовалюту за 8 шагов
- Знайте свой вариант использования
- Выберите механизм консенсуса
- Выберите платформу блокчейна
- Спроектируйте узлы
- Создайте внутреннюю структуру вашей цепочки блоков
- Позаботьтесь об API
- Разработайте интерфейс
- Сделайте вашу криптовалюту законной
Прежде чем мы перейдем к описанным выше шагам, давайте рассмотрим некоторые важные термины, которые вы должны знать при начале работы.
Разница между токеном и монетой
Прежде чем мы углубимся в технические детали того, как создать свою собственную криптовалюту, мы должны изложить наши факты прямо и взглянуть на некоторые основные определения, используемые во всех разговорах, связанных с криптовалютой.
Итак, что такое криптовалюта?
Давайте сделаем шаг назад и сначала освежим в памяти определение валюты. В то время как мы склонны думать о валютах в терминах банкнот и монет или долларов и евро, валюта — это единица хранения и счета, а также средство обмена, т.е.е. общепринятый способ получения товаров и услуг, а также хранения и распределения богатства.
Теперь криптовалюту можно определить как цифровую валюту, использующую шифрование для создания новых единиц и подтверждения транзакций. Он имеет все функции валюты с той разницей, что работает за пределами единой централизованной платформы (например, банка).
В криптовалютах нет банкнот, но есть монеты, которые часто путают с токенами. Так в чем же разница между ними? Проще говоря, все сводится к этим трем пунктам:
монет требуют собственного блокчейна, в то время как токены могут работать с существующими.Токены ограничены конкретным проектом; монеты можно использовать где угодно. Монеты покупают жетоны, но жетоны не могут покупать монеты.
Если вы хотите использовать жетоны и монеты в контексте реальной жизни, думайте о жетонах как о милях для часто летающих пассажиров, а монеты — это настоящие деньги: вы можете использовать и то, и другое, чтобы получить билет на самолет, но с количеством миль ваш выбор будет ограничен. в авиакомпанию, которая их выпустила, а с деньгами вы можете вести свой бизнес куда угодно.
Суть в том, что вам нужно построить блокчейн, если вы хотите создать криптовалюту.
Преимущества наличия собственной криптовалюты
В некоторых случаях это несложно: если вашему проекту или стартапу требуется собственный блокчейн, вам необходимо создать свою собственную цифровую валюту, чтобы стимулировать узлы, вносящие свой вклад в их вычислительную мощность. Еще одно слово о блокчейнах: многие авторитетные бизнес-аналитики предвидят большое будущее и растущий список рынков и отраслей, на которых технология блокчейнов значительно нарушит статус-кво и щедро вознаградит первых последователей.Хорошая новость заключается в том, что во многих областях технология блокчейн так и не появилась, так что еще не поздно присоединиться к числу пионеров.
Другой важный аспект заключается в том, что когда вы решите запустить криптовалюту, вы получите целый набор мощных маркетинговых инструментов и потребительских преимуществ, которые помогут вам выделиться среди конкурентов.
Вот список наиболее значительных преимуществ:
Устранение рисков мошенничества — криптовалюту невозможно подделать, и ни одна из сторон не может отменить прошлые транзакции.
Обеспечение анонимности транзакций — покупатели сами решают, что именно они хотят, чтобы продавцы знали о них.
Снижение эксплуатационных расходов — криптовалюта свободна от обменных или процентных ставок, а также от комиссии за транзакцию.
Предложение немедленных транзакций — государственные праздники, часы работы или географическое положение сторон не влияют на криптовалюту.
Обеспечение немедленного пула потенциальных клиентов — теперь вы можете вести дела с теми, у кого нет доступа к традиционным ресурсам биржи.Больше никаких торговых ограничений на любых рынках.
Обеспечение безопасности своих средств — поскольку криптовалюта является децентрализованной системой, нет такого большого брата, как банки или правительственные учреждения, которые могут арестовать или заморозить ваши активы.
Как создать цепочку блоков
Теперь, когда вы знаете, как собственная криптовалюта может способствовать развитию вашего бизнеса, давайте рассмотрим основные шаги, которые необходимо предпринять для создания цепочки блоков.
Шаг 1. Знайте свой сценарий использования.
Ваши бизнес-интересы лежат в области смарт-контрактов, аутентификации и проверки данных или в управлении интеллектуальными активами? Четко определите свои цели в самом начале.
Шаг 2. Выберите механизм консенсуса.
Для бесперебойной работы вашей цепочки блоков участвующие узлы должны договориться о том, какие транзакции следует считать законными и добавлять в блок. Механизмы консенсуса — это протоколы, которые именно это и делают. Есть из чего выбрать, что лучше всего подходит для ваших бизнес-целей.
Шаг 3. Выберите платформу блокчейна.
Ваш выбор платформы блокчейна будет зависеть от выбранного вами механизма консенсуса.Чтобы дать вам лучшее представление о том, что там есть, вот список самых популярных платформ блокчейн:
- Ethereum (доля рынка — 82,70%)
- Waves (WAVES)
- NEMNxt (NXT)
- BlockStarter
- EOS
- BitShares 2.0
- CoinList
- Hyperledger Fabric
- IBM blockchain
- MultiChain
- HydraChain
- BigChain
- DBOpenchain
- Chain Core
- QuorumIOTA
- KICKICO
Если вы представите блокчейн как стену, узлы — это кирпичики, из которых он состоит. Узел — это подключенное к Интернету устройство, поддерживающее блокчейн, выполняя различные задачи, от хранения данных до проверки и обработки транзакций. Блокчейны зависят от узлов в плане эффективности, поддержки и безопасности.
Существует ряд вариантов выбора узлов, которые вы будете использовать:
- Какие они будут с точки зрения разрешений: частные, общедоступные или гибридные?
- Будут ли они размещаться в облаке, локально или и там, и там? Выберите и получите необходимые сведения об оборудовании, такие как процессоры, память, размер диска и т. Д.
- Выберите базовую операционную систему (наиболее распространенным выбором будет Ubuntu, Windows, Red Hat, Debian, CentOS или Fedora)
Шаг 5. Установите внутреннюю архитектуру вашей цепочки блоков
Действуйте осторожно, так как некоторые параметры могут не может быть изменен после того, как платформа блокчейн уже запущена. Не торопитесь и хорошенько подумайте над следующим:
- Разрешения (определите, кто может получать доступ к данным, выполнять транзакции и проверять их, т.е. создать новые блоки)
- Форматы адресов (решите, как будут выглядеть адреса вашей цепочки блоков)
- Форматы ключей (выберите формат ключей, которые будут генерировать подписи для транзакций)
- Выдача активов (установить правила для создания и перечисление всех единиц активов)
- Повторный выпуск активов (установить правила для создания большего количества единиц открытых активов)
- Управление ключами (разработать систему для хранения и защиты закрытых ключей, предоставляющих доступ к блокчейну)
- Мультиподписи (определить количество ключей, которые потребуются вашей цепочке блоков для проверки транзакции)
- Атомарные свопы (план для смарт-контрактов, позволяющий обмениваться различными криптовалютами без доверенной третьей стороны)
- Параметры (оценка максимального размера блока, вознаграждение за майнинг блока, транзакция лимиты и т. д.)
- Собственные активы (определяют правила для собственной валюты, выпущенной в блокчейне)
- Подписи блоков (определяют, как участники блокчейна, создающие блоки, будут обязаны их подписывать)
- Рукопожатие (установить правила того, как узлы будут идентифицировать себя при подключении друг к другу)
Шаг 6. Позаботьтесь об API
Убедитесь, что вы проверили, предоставляет ли выбранная вами платформа блокчейна предварительно созданные API, поскольку не все из них поддерживают.Даже если на вашей платформе они отсутствуют, не беспокойтесь: существует множество надежных поставщиков API-интерфейсов блокчейна.
Шаг 7: Разработка интерфейса (администратор и пользователь)
Коммуникация — это ключ, а хорошо продуманный интерфейс обеспечивает бесперебойную связь между вашей цепочкой блоков и ее участниками.
Вот что следует учитывать на этом этапе:
- Веб-серверы, почтовые и FTP-серверы
- Внешние базы данных
- Языки внешнего программирования (например,г. HTML5, CSS, PHP, C #, Java, Javascript, Python, Ruby).
Шаг 8. Сделайте вашу криптовалюту законной
Медленно, но верно закон догоняет криптовалюты, и вы лучше защитите себя от любых неожиданностей, изучив тенденции, касающиеся регулирования криптовалюты, и направление, в котором они движутся.
Бонусный шаг для тех, кто преуспевает: развивайте и улучшайте свою цепочку блоков
Вы зашли так далеко, не останавливайтесь сейчас. Загляните в будущее и подумайте, как вы можете улучшить свой блокчейн, подключившись к перспективным технологиям, таким как Интернет вещей, аналитика данных, искусственный интеллект, когнитивные услуги, машинное обучение, контейнеры, биометрия, облако, боты и другие вдохновляющие развития.
Биткойн-форк как альтернатива созданию собственной цепочки блоков
Как видите, создание цепочки блоков требует много времени, ресурсов и определенных навыков. Итак, что вы можете сделать, если у вас нет всего вышеперечисленного, но все же вы хотите создать свою собственную криптовалюту? Тогда пришло время поговорить о биткойн-форках.
Как создать биткойн-форк?
Пришло время дать еще одно базовое определение, чтобы убедиться, что мы говорим на одном языке.
Что такое форки в криптовалюте?
С точки зрения непрофессионала, форк блокчейна — это обновление программного обеспечения.Все участники блокчейна (также известные как полные узлы) используют одно и то же программное обеспечение, и очень важно, чтобы они использовали одну и ту же версию этого программного обеспечения, чтобы иметь доступ к общей бухгалтерской книге для проверки транзакций и обеспечения безопасности сети. Поэтому каждый раз, когда вы захотите изменить параметры блокчейна или ввести новые функции, вам нужно будет создавать форк.
В чем разница между жесткой и софт-вилкой?
Вилки можно разделить на жесткие и мягкие.
Хард-форк требует от 90% до 95% процентов узлов для обновления программного обеспечения; система больше не будет принимать узлы с необновленной версией.
Мягкие вилки менее требовательны. Просто большинство узлов требуется для обновления программного обеспечения, и те, кто использует предыдущую версию, могут продолжать работу.
Что такое биткойн-вилки?
Теперь форки Биткойна — это изменения в сетевом протоколе Биткойн. Поскольку биткойн-код является протоколом с открытым исходным кодом, это несложное упражнение для тех, кто хочет создать свою собственную криптовалюту и опираться на существующую, добавляя новые функции или устраняя существующие недостатки.
Как создать биткойн-форк?
Вариант 1. Используйте вилочный генератор монет.
Если у вас нет навыков программирования, такие службы, как ForkGen, могут стать для вас идеальным решением. ForkGen — это автоматический генератор монет форка, в котором каждый может создать уникальное ответвление биткойнов, изменив некоторые параметры и правила.
Вариант 2. Сделай сам.
Если вы хотите жестко создать форк Биткойна и не боитесь запачкать руки, выполните следующие действия:
- Зайдите на Github, найдите, скачайте и скомпилируйте биткойн-код на свой компьютер.
- Затем начинается программная часть: вам нужно перенастроить биткойн-код, реализовать свои настройки.
- Опубликуйте код (с открытым исходным кодом) обратно на Github.
- Предоставьте веб-сайт и какую-либо документацию (обычно белую книгу). Биткойн-вилки: истории успеха
Биткойн-вилки стоит изучить, если вы хотите создать собственную криптовалюту, используя социальный и финансовый капитал вокруг имени Биткойн. Вот некоторые примеры успешных форков Биткойн:
- LitecoinBitcoin
- CashBitcoin
- GoldMain
Повторение шагов по созданию собственной криптовалюты
Подводя итог, у вас есть два способа запустить собственную криптовалюту: построить блокчейн или создать форк.
Для создания блокчейна вам необходимо:
- определить, как он будет использоваться в вашей бизнес-модели
- принять решение о механизме консенсуса
- выбрать платформу блокчейна
- разработать узлы и свойства блокчейна
- предоставить API для задач, выполняемых на вашем блокчейне
- разработайте интуитивно понятный и всеобъемлющий интерфейс администратора и пользователя
- позаботьтесь о юридической стороне бизнеса
Чтобы создать биткойн-форк, вы можете: например ForkGen
Или:
- Загрузите биткойн-код
- Настройте его
- Публикуйте и поддерживайте свой код.
Запуск новой криптовалюты: стоит ли усилий?
Прочитав до сих пор , вы уже имеете довольно четкое представление о том, что нужно для создания новой цепочки блоков. Перед началом любого нового сложного проекта всегда полезно сделать глубокий вдох и еще раз оценить, стоит ли вам вкладывать в это свое время и деньги.
Итак, как решить, нужен ли вам блокчейн в первую очередь? место? Вот список вопросов, которые помогут вам ответить на этот вопрос, прежде чем вы возьмете на себя это обязательство.
- Вам нужно хранилище данных?
- Ваши требования выходят за рамки того, что может предоставить традиционная база данных?
- Есть ли у вас несколько участников, обновляющих данные?
- Вы хотите устранить стороннего поставщика?
- Хотите создать безопасную среду для сторон, не доверяющих друг другу?
- Будет ли ваша среда иметь жесткие правила, требующие минимальных обновлений или не требующих их вообще?
- Вам нужно сохранить конфиденциальность ваших данных?
Если вы ответили «да» на 3 и более из этих вопросов, вы получите все преимущества блокчейна, в том числе:
- Повышение безопасности данных.
- Снижение транзакционных издержек.
- Предотвращение мошенничества.
- Повышение эффективности.
- Обеспечение прозрачности.
- Выполнение смарт-контрактов.
Несмотря на то, что преимущества многочисленны, объем работы, который требуется для создания вашей собственной цепочки блоков, является значительным и требует широкого спектра знаний и инструментов для выполнения всех этапов процесса наиболее эффективным по времени и с точки зрения затрат способом.
Воспользовавшись помощью профессиональных разработчиков, вы значительно сократите свои расходы в долгосрочной перспективе, исключив место для ошибок, а, следовательно, время и стоимость доработок и обновлений; подготовьте свои решения к будущему, работая с экспертами, которые следят за всеми последними отраслевыми разработками и инновациями, и высвободите ваше время для развития вашего бизнеса.
Первоначально опубликовано в блоге Ezetech
Согласны или не согласны с некоторыми идеями, представленными в этой статье?
Дайте нам знать, что вы думаете о Digg .
Ищете другие статьи о криптовалюте? Подпишитесь на нашу рассылку в нижнем колонтитуле!
Похожие истории
Теги
Присоединяйтесь к хакеру ПолденьСоздайте бесплатную учетную запись, чтобы разблокировать свой собственный опыт чтения.
Как создать собственный блокчейн криптовалюты на Python
Криптовалютыи лежащая в их основе технология блокчейнов захватили мир врасплох — от их скромного начала несколько лет назад до сегодняшних повседневных разговоров.
Обычно под блокчейном понимается технология распределенного реестра, которая представляет собой «цепочку блоков». Каждый блок в цепочке блоков имеет хэш предыдущего блока, временную метку и данные транзакции, что делает его защищенным от несанкционированного доступа.
По словам Эллиота Миннса, который имеет более чем шестилетний опыт разработки программного обеспечения и использует практические проекты, чтобы научить людей создавать криптовалюты: «Изучение того, как создавать блокчейн, поможет вам понять, как работают цифровые валюты, такие как Биткойн и Эфириум, и как вы можете экстраполировать технологию, чтобы ускорить возможности ваших приложений ».
В этой статье мы собираемся объяснить, как создать простую цепочку блоков, используя язык программирования Python.
Вот базовый план класса Python, который мы будем использовать для создания цепочки блоков:
Блок (объект) класса:
def __init __ ():
проходить
# начальная структура класса блока
def compute_hash ():
проходить
# создание криптографического хеша каждого блока
класс BlockChain (объект):
def __init __ (сам):
# построение сети
def build_genesis (сам):
проходить
# создание начального блока
def build_block (self, proof_number, previous_hash):
проходить
# строит новый блок и добавляет в цепочку
@staticmethod
def confirm_validity (блок, предыдущий_блок):
проходить
# проверяет, действителен ли блокчейн
def get_data (я, отправитель, получатель, сумма):
проходить
# объявляет данные транзакций
@staticmethod
def proof_of_work (last_proof):
проходить
# добавляет к безопасности блокчейна
@свойство
def latest_block (сам):
проходить
# возвращает последний блок в цепочке
Теперь давайте объясним, как работает класс цепочки блоков.
Начальная структура блока класса
Вот код для нашего начального класса блока:
импорт hashlib
время импорта
Класс Блок (объект):
def __init __ (self, index, proof_number, previous_hash, data, timestamp = None):
self.index = index
self.proof_number = proof_number
self.previous_hash = previous_hash
self.data = данные
self.timestamp = отметка времени или time.time ()
@свойство
def compute_hash (сам):
string_block = "{} {} {} {} {}".формат (self.index, self.proof_number, self.previous_hash, self.data, self.timestamp)
вернуть hashlib.sha256 (string_block.encode ()). hexdigest ()
Как вы можете видеть выше, конструктор класса или метод запуска ( __init __ ()
), указанный выше, принимает следующие параметры:
- self — как и любой другой класс Python, этот параметр используется для ссылки на сам класс. С его помощью можно получить доступ к любой переменной, связанной с классом.
- index — используется для отслеживания позиции блока в цепочке блоков.
- previous_hash — используется для ссылки на хэш предыдущего блока в цепочке блоков.
- данные — подробные сведения о проведенных транзакциях, например, купленная сумма.
- отметка времени — вставляет отметку времени для всех выполненных транзакций.
Второй метод в классе, compute_hash
, используется для создания криптографического хэша каждого блока на основе вышеуказанных значений.
Как видите, мы импортировали алгоритм SHA-256 в проект цепочки блоков криптовалюты, чтобы помочь в получении хэшей блоков.
После того, как значения будут помещены в модуль хеширования, алгоритм вернет 256-битную строку, обозначающую содержимое блока.
Итак, это то, что дает неизменяемость блокчейна. Поскольку каждый блок будет представлен хешем, который будет вычисляться из хеша предыдущего блока, повреждение любого блока в цепочке приведет к тому, что другие блоки будут иметь недопустимые хеши, что приведет к поломке всей сети блокчейна.
Построение цепочки
Вся концепция блокчейна основана на том факте, что блоки «связаны» друг с другом. Теперь мы создадим класс цепочки блоков, который будет играть важную роль в управлении всей цепочкой.
Он будет хранить данные транзакций и включать другие вспомогательные методы для выполнения различных ролей, таких как добавление новых блоков.
Давайте поговорим о вспомогательных методах.
Добавление метода конструктора
Вот код:
класс BlockChain (объект):
def __init __ (сам):
себя.цепь = []
self.current_data = []
self.nodes = set ()
self.build_genesis ()
Метод конструктора __init __ ()
— это то, что создает экземпляр цепочки блоков.
Вот роли его атрибутов:
- self.chain — в этой переменной хранятся все блоки.
- self.current_data — в этой переменной хранится информация о транзакциях в блоке.
- сам.build_genesis () — этот метод используется для создания начального блока в цепочке.
Создание блока Генезиса
Метод build_genesis ()
используется для создания начального блока в цепочке, то есть блока без каких-либо предшественников. Блок генезиса — это то, что представляет собой начало блокчейна.
Чтобы создать его, мы вызовем метод build_block ()
и зададим ему некоторые значения по умолчанию. Параметрам proof_number
и previous_hash
присваивается нулевое значение, хотя вы можете дать им любое значение, которое пожелаете.
Вот код:
def build_genesis (сам):
self.build_block (proof_number = 0, previous_hash = 0)
def build_block (self, proof_number, previous_hash):
block = Заблокировать (
index = len (self.chain),
proof_number = proof_number,
previous_hash = предыдущий_hash,
data = self.current_data
)
self.current_data = []
self.chain.append (блок)
возвратный блок
Подтверждение действительности блокчейна
Метод confirm_validity
имеет решающее значение для проверки целостности цепочки блоков и проверки отсутствия несоответствий.
Как объяснялось ранее, хэши имеют решающее значение для обеспечения безопасности блокчейна криптовалюты, потому что любое небольшое изменение в объекте приведет к созданию совершенно другого хэша.
Таким образом, метод confirm_validity
использует серию операторов if, чтобы оценить, был ли скомпрометирован хэш каждого блока.
Кроме того, он также сравнивает хеш-значения каждых двух последовательных блоков для выявления любых аномалий. Если цепочка работает правильно, возвращается истина; в противном случае возвращается false.
Вот код:
def confirm_validity (блок, предыдущий_блок):
если previous_block.index + 1! = block.index:
вернуть ложь
elif previous_block.compute_hash! = block.previous_hash:
вернуть ложь
elif block.timestamp <= previous_block.timestamp:
вернуть ложь
вернуть True
Объявление данных транзакций
Метод get_data
важен при объявлении данных транзакций в блоке.Этот метод принимает три параметра (информацию об отправителе, информацию о получателе и сумму) и добавляет данные транзакции в список self.current_data
.
Вот код:
def get_data (self, отправитель, получатель, сумма):
self.current_data.append ({
"отправитель": отправитель,
'Receiver': получатель,
'amount': количество
})
вернуть True
Выполнение доказательства работы
В технологии блокчейн доказательство работы (PoW) относится к сложности, связанной с майнингом или генерацией новых блоков в блокчейне.
Например, PoW может быть реализован путем определения номера, который решает проблему всякий раз, когда пользователь завершает некоторую вычислительную работу. Любой в сети блокчейн должен найти номер сложным для идентификации, но легким для проверки - это основная концепция PoW.
Таким образом, он препятствует распространению спама и нарушению целостности сети.
В этой статье мы покажем, как включить алгоритм Proof of Work в проект криптовалюты блокчейн.
Завершение с последним блоком
Наконец, вспомогательный метод latest_block ()
используется для получения последнего блока в сети, который на самом деле является текущим блоком.
Вот код:
def latest_block (self):
return self.chain [-1]
Внедрение Blockchain Mining
Это самый интересный раздел!
Изначально транзакции хранятся в списке непроверенных транзакций.Майнинг относится к процессу размещения непроверенных транзакций в блоке и решения проблемы PoW. Это можно назвать вычислительной работой, связанной с проверкой транзакций.
Если все было выяснено правильно, блок создается или добывается и объединяется вместе с другими в цепочке блоков. Если пользователи успешно добыли блок, они часто получают вознаграждение за использование своих вычислительных ресурсов для решения проблемы PoW.
Вот метод майнинга в этом простом проекте блокчейна криптовалюты:
def block_mining (self, details_miner):
себя.получить данные(
sender = "0", # это означает, что этот узел создал новый блок
Receiver = details_miner,
amount = 1, # создание нового блока (или определение номера доказательства) получает 1
)
last_block = self.latest_block
last_proof_number = last_block.proof_number
proof_number = self.proof_of_work (last_proof_number)
last_hash = last_block.compute_hash
block = self.build_block (номер_проверки, last_hash)
вернуть вары (блок)
Сводка
Вот весь код нашего класса криптоблокчейна на Python:
импорт hashlib
время импорта
Класс Блок (объект):
def __init __ (self, index, proof_number, previous_hash, data, timestamp = None):
себя.index = индекс
self.proof_number = proof_number
self.previous_hash = previous_hash
self.data = данные
self.timestamp = отметка времени или time.time ()
@свойство
def compute_hash (сам):
string_block = "{} {} {} {} {}". формат (self.index, self.proof_number, self.previous_hash, self.data, self.timestamp)
вернуть hashlib.sha256 (string_block.encode ()). hexdigest ()
def __repr __ (сам):
вернуть "{} - {} - {} - {} - {}". формат (self.index, self.proof_number, self.previous_hash, self.data, self.timestamp)
класс BlockChain (объект):
def __init __ (сам):
self.chain = []
self.current_data = []
self.nodes = set ()
self.build_genesis ()
def build_genesis (сам):
self.build_block (proof_number = 0, previous_hash = 0)
def build_block (self, proof_number, previous_hash):
block = Заблокировать (
index = len (self.chain),
proof_number = proof_number,
previous_hash = предыдущий_hash,
данные = себя.текущие данные
)
self.current_data = []
self.chain.append (блок)
блок возврата
@staticmethod
def confirm_validity (блок, предыдущий_блок):
если previous_block.index + 1! = block.index:
вернуть ложь
elif previous_block.compute_hash! = block.previous_hash:
вернуть ложь
elif block.timestamp <= previous_block.timestamp:
вернуть ложь
вернуть True
def get_data (я, отправитель, получатель, сумма):
себя.current_data.append ({
"отправитель": отправитель,
'Receiver': получатель,
'amount': количество
})
вернуть True
@staticmethod
def proof_of_work (last_proof):
проходить
@свойство
def latest_block (сам):
вернуть self.chain [-1]
def chain_validity (сам):
проходить
def block_mining (self, details_miner):
self.get_data (
sender = "0", # это означает, что этот узел создал новый блок
Receiver = details_miner,
amount = 1, # создание нового блока (или определение номера доказательства) обозначается 1
)
last_block = сам.latest_block
last_proof_number = last_block.proof_number
proof_number = self.proof_of_work (last_proof_number)
last_hash = last_block.compute_hash
block = self.build_block (номер_проверки, last_hash)
вернуть вары (блок)
def create_node (self, адрес):
self.nodes.add (адрес)
вернуть True
@staticmethod
def get_block_object (block_data):
возвратный блок (
block_data ['индекс'],
block_data ['proof_number'],
block_data ['предыдущий_хэш'],
block_data ['данные'],
timestamp = block_data ['временная метка']
)
blockchain = BlockChain ()
print («ПОДГОТОВЬТЕ МАЙНИНГ О НАЧАЛЕ»)
печать (блокчейн.цепь)
last_block = blockchain.latest_block
last_proof_number = last_block.proof_number
proof_number = blockchain.proof_of_work (last_proof_number)
blockchain.get_data (
sender = "0", # это означает, что этот узел построил другой блок
Receiver = "LiveEdu.tv",
amount = 1, # построение нового блока (или вычисление номера доказательства) получает 1
)
last_hash = last_block.compute_hash
block = blockchain.build_block (номер_проверки, last_hash)
print («Ух ты, ДОБАВЛЕНИЕ УСПЕШНО!»)
печать (блокчейн.цепь)
Теперь давайте попробуем запустить наш код, чтобы посмотреть, сможем ли мы сгенерировать несколько цифровых монет ...
Ого, заработало!
Заключение
Вот и все!
Мы надеемся, что эта статья помогла вам понять базовую технологию, на которой работают такие криптовалюты, как Биткойн и Эфириум.
Мы только что проиллюстрировали основные идеи, как намочить ноги в инновационной технологии блокчейн. Вышеупомянутый проект все еще можно улучшить, добавив другие функции, чтобы сделать его более полезным и надежным.
Конечно, если вам нужно что-то продвинутое, вы всегда можете взять учебник и полностью погрузиться в мир криптовалюты.
У вас есть вопросы или комментарии? Пожалуйста, поделитесь ими ниже.
Как построить собственный блокчейн для финансового продукта
Технологии быстро меняются; люди нет.
- Якоб Нильсен
Блокчейн - это относительно новая технология, которая, по мнению многих, используется только для покупки биткойнов.Его стараются внедрить в любой сфере, которая приходит в голову, будь то мода, образование или здравоохранение. Я бы сказал, что это нормально - прошло слишком мало времени, чтобы определить, какая область человеческой деятельности может получить наибольшую выгоду от применения этой технологии. Чтобы понять практическое применение блокчейна, мы должны сначала определить, почему он появился, а затем изучить случаи, когда блокчейн может иметь существенное значение.
Примечание: В этой статье не объясняются концепции блокчейна; вместо этого он фокусируется на разработке финтех-приложения с использованием этой технологии.Я объясню, почему финтех уже может принять блокчейн, и, что наиболее важно, сосредоточиться на разработке децентрализованного приложения с использованием этой технологии.
Дон Норман однажды написал, что многие продукты терпят неудачу, потому что они были выпущены в неподходящее время. Я могу переделать это утверждение и сказать: многие технологии не находят практического применения. Когда в начале 90-х Интернет стал широко доступным, каждая сфера попыталась применить его в своем бизнесе. Это была катастрофа, и ее последствия до сих пор видны на тысячах никогда не посещаемых веб-сайтов с ужасными интерфейсами, неуклюже созданными любым, у кого был компьютер.В настоящее время мы наблюдаем практически такую же ситуацию - наиболее перспективная технология десятилетия связана со спекуляциями на криптобиржах. Он широко используется для финансовых махинаций, хотя изначально создавался наоборот.
Источник: Microsoft Azure
Попытка исключить человеческий фактор из бизнеса была одной из причин появления блокчейна. Вот почему отрасли, в которых может быть успешно реализован блокчейн, - это те, которые (1) сильно зависят от человеческой деятельности и (2) больше всего страдают от человеческих ошибок, например, финансы.
Важно: Блокчейн применяется к различным продуктам из разных отраслей; нам просто нужно больше смелых предпринимателей, которые готовы многое поставить на карту.
Финтех занимается очень непростым делом - деньгами. Именно здесь происходит большинство мошенничества. Желание стать богаче - это один из основных механизмов, который заставляет людей делать что-то, часто плохое. Финтех-стартапы стремятся улучшить традиционные финансовые институты, например, исключив человеческий фактор из финансовой деятельности.
Использование блокчейна исключает третьи стороны из финансовых транзакций, например банк, который проверяет лицо, между которым совершается транзакция. Его можно использовать для управления запасами и логистикой, торговли товарами, оптимизации идентификации людей, отслеживания транзакций и многого другого.
-8 Это не означает, что каждый финтех-продукт может легко использовать блокчейн. Вот несколько случаев, когда вы можете захотеть использовать блокчейн:
- Вы хотите привлечь инвестиции. Нравится вам это или нет, но блокчейн до сих пор остается модным словом. Он привлекает больше инвестиций, чем обычный рабочий продукт. Хотя, чтобы получить эти средства, вы должны подготовить убедительное инвестиционное предложение, но решение блокчейна может изменить правила игры для вашего продукта.
- Вы хотите повысить свою конкурентоспособность на рынке. Если вам удастся успешно построить продукт на блокчейне, вы моментально продемонстрируете свой профессионализм и тем самым станете более привлекательным для инвесторов и клиентов.
- Вы готовы экспериментировать. Да, любой продукт на основе блокчейна - это эксперимент, потому что немногие знают, на что способна эта технология. Если вы готовы совершить прорыв в своей отрасли, блокчейн может стать правильным выбором.
Я не предлагаю внедрять блокчейн в следующих случаях:
- Вы ограничены в ресурсах. Это высокорисковый способ создания продукта, потому что (1) есть несколько инженеров по блокчейну и (2) иметь их в команде дорого.
- Вы не готовы к существенным изменениям. Изменения касаются оперативного управления и человеческих ресурсов. Если вы являетесь банком, который внедрил блокчейн, вам, скорее всего, придется уволить многих сотрудников, поскольку у людей будет меньше работы.
- У вас краткосрочное видение. Blockchain - это долгосрочная перспектива. Это не может быть реализовано за месяц или около того. Если у вас нет долгосрочного плана развития продукта, не беспокойтесь о мечтах о том, чтобы завтра все изменить.
Что вы можете сделать завтра, даже читая эту статью, - это построить простой блокчейн. Этому посвящена часть 2. Я расскажу вам об основных компонентах, которые требуются для построения блокчейна для финтех-продуктов, предложу некоторые инструменты и покажу реальные фрагменты кода с пояснениями.
Подорвать
финансовый рыноксильным продуктом
CryptoNote
CryptoNote - это проект с открытым исходным кодом, который позволяет создавать крипто-монеты.У них есть простое пошаговое руководство по созданию криптовалюты. Для его запуска вам понадобятся два узла, которые будут использоваться для запуска сервера Monero.
Полезные ссылки:
Как создать монету
Как создать кошелек
Ethereum
Популярная открытая программная платформа для создания децентрализованных приложений. Его основное внимание уделяется запуску программного кода вашего приложения на основе блокчейна. Цитата с веб-сайта Ethereum: «Ethereum - это децентрализованная платформа, на которой работают смарт-контракты: приложения, которые работают точно так, как запрограммировано, без какой-либо возможности простоя, цензуры, мошенничества или вмешательства третьих лиц.”
ZeroNet
ZeroNet используется для создания децентрализованных веб-сайтов. Он использует механизмы адресации и проверки биткойнов, а также распределенную сеть доставки контента BitTorrent для создания сайтов, которые не могут быть подвергнуты цензуре, подделке или блокированию.
Теперь, когда вы знакомы с инструментами - Cryptonote, Ethereum и ZeroNet - мы переходим к созданию собственного базового блокчейна. В этом примере я буду использовать Python, но если это не ваш основной язык программирования, вы все равно поймете логику и сможете написать ее на другом языке.
Сначала я объясню основные элементы, необходимые для построения блока. Я начну с даты создания, одноразового номера, контрольной суммы и данных транзакции. Данные транзакции в нашем случае могут быть просто строкой для упрощения кода.
Дата создания
Текущее и время в формате unix. Это необходимо для будущего развития вашего блокчейна; когда есть много работающих узлов и вы добавляете новый блок в свою ветку, узел будет решать, какой блок использовать, в зависимости от даты создания.
Nonce
Это уникальный набор символов, который нам нужно добавить в блок, чтобы построить контрольную сумму, соответствующую требованиям. Например, если значение nonce равно 5, то мы должны добавить 5 нулей (00000) к блоку данных, чтобы вычислить правильную контрольную сумму.
Контрольная сумма
Также иногда называется хеш-значением, хеш-кодом или просто хеш-кодом. Это данные блока с одноразовым значением плюс контрольная сумма предыдущего блока. SHA256 защищает цепочку бухгалтерской книги от перезаписи.
Как это работает: Узел вычисляет контрольную сумму и сравнивает ее с контрольной суммой нового блока; если они совпадают, блок добавляется в цепочку блоков.
Данные
Это набор данных, которые будут храниться в блоках и подписаны. Он может содержать любые данные: например, биткойн хранит список транзакций, а не только последнюю транзакцию; или вы можете сохранить информацию о компьютере, который создал блок, например, его MAC-адрес; или вы можете указать более подробную дату создания, скажем, добавив часовой пояс.
Доказательство работы
Доказательство работы (PoW) - это уникальный алгоритм консенсуса в сети блокчейн. Он используется для проверки операций и создания новых цепочек в сети цепочек блоков.Основная идея PoW - усложнить построение блока на стороне клиента и снизить нагрузку на сервер. Например, я говорю, что контрольная сумма должна иметь 5 ведущих нулей; это означает, что мы будем увеличивать nonce до тех пор, пока контрольная сумма не будет иметь 5 нулей отведения.
Прежде всего, я создам класс для блока. Это будет очень простой класс с конструктором, методом вычисления контрольной суммы и свойством проверки правильности этого блока. У нас будет две константы, одна для количества ведущих нулей в контрольной сумме, а вторая для определения того, какой символ мы будем использовать с одноразовым номером.
импортное время
из hashlib import sha256
блок класса:
CHECKSUM_LEAD_ZEROS = 5
NONCE_SYMBOL = 'Z'
def __init __ (self, prev_block, data):
self._prev_block = prev_block
self.data = данные
self.checksum = Нет
self.nonce = 0
self.timestamp = time.time ()
@свойство
def is_valid (сам):
контрольная сумма = self.calculate_checksum ()
возвращение (
контрольная сумма [: self.CHECKSUM_LEAD_ZEROS] == '0' * self.CHECKSUM_LEAD_ZEROS
и контрольная сумма == self.checksum
)
def calculate_checksum (самостоятельно):
data = '|' .join ([
str (self.timestamp),
self.data,
self._prev_block.checksum,
])
данные + = self.NONCE_SYMBOL * self.nonce
вернуть sha256 (байты (данные, 'utf-8')). hexdigest ()
Конструктор Конструктор принимает только два параметра; первый - это предыдущий блок, а второй - данные текущего блока.Кроме того, конструктор создает метку времени и устанавливает значение nonce равным нулю в качестве начального значения.
ДействителенСвойство, которое вычисляет контрольную сумму и сравнивает, совпадает ли текущая с вычисленной и имеет ли нужное количество нулей.
Подсчитать контрольную суммуСамый сложный метод в нашем коде. Этот метод упаковывает метку времени, данные и контрольную сумму предыдущего блока в одну строку. Затем мы добавляем строку nonce; в нашем случае это будет список «Z».Затем он вычисляет контрольную сумму строки результата.
Теперь у нас есть простой, но полностью функциональный блок. Перейду к созданию цепочки блоков. Пока это будет простая цепочка без возможности хранить и загружать данные, но она передаст основную идею.
импорт json
цепочка классов:
def __init __ (сам):
self._chain = [
self._get_genesis_block (),
]
def is_valid (сам):
prev_block = self._chain [0]
для блока в self._chain [1:]:
assert prev_block.checksum == self._prev_block.checksum
утверждать block.is_valid ()
prev_block = блок
def add_block (self, data):
block = Блок (self._chain [-1], данные)
block = self._find_nonce (блок)
self._chain.append (блок)
блок возврата
@staticmethod
def _get_genesis_block ():
genesis_block = Блокировать (Нет, Нет)
genesis_block.контрольная сумма = '00000453880b6f9179c0661bdf8ea06135f1575aa372e0e70a19b04de0d4cbc7'
вернуть genesis_block
@staticmethod
def _find_nonce (блок):
начало = '0' * Блок. CHECKSUM_LEAD_ZEROS
в то время как True:
контрольная сумма = block.calculate_checksum ()
если контрольная сумма [: Block.CHECKSUM_LEAD_ZEROS] == начало:
сломать
block.nonce + = 1
block.checksum = контрольная сумма
блок возврата
Давайте посмотрим на методы в нашем классе цепочки:
КонструкторЯ только что создал цепочку только с одним блоком - генезисным блоком.Блок Genesis - это первый блок в цепочке, имеющий только контрольную сумму. Этот блок необходим для добавления первого реального блока в цепочку, потому что настоящий блок требует контрольной суммы последнего блока в цепочке.
Добавление нового блокаИмеет только один параметр - данные для нового блока. Этот метод создает новый блок с заданными данными и запускает метод, чтобы найти правильное значение nonce. Только тогда он добавит в цепочку новый блок.
Найти одноразовый номерЭтот метод направлен на поиск правильного одноразового номера для блока.У него бесконечный цикл, в котором я увеличиваю одноразовый номер и вычисляю новую контрольную сумму. Затем он сравнивает контрольную сумму с правилами - пока это только количество нулей.
Проверить цепочкуЭтот метод сообщает нам, действительна ли цепочка. Он просматривает все блоки в цепочке и проверяет, действителен ли каждый блок.
В этой статье я попытался доказать, что создание простой, но работающей цепочки блоков не так сложно, как может показаться. Мой общий совет - взять урок, который вы усвоили здесь, и начать играть с блокчейном, экспериментируя с блоками и данными.Все замечательные продукты, включая блокчейн, когда-то были экспериментами.
Если вы работаете в индустрии финансовых технологий, я предлагаю вам больше узнать о продуктах, использующих блокчейн. Некоторые вещи о них известны; они более безопасны, более привлекательны для инвестиций и, если они добьются успеха на мировом рынке, будут названы кардинальными изменениями. Сделан первый шаг по адаптации новой технологии. Следующим шагом является распространение знаний и обучение людей особенностям блокчейна.
Следите за обновлениями в следующей части, посвященной блокчейну и финтех, скорее всего, с более сложными фрагментами кода и предложениями по его практическому применению в финтехе от нашей компании, занимающейся разработкой Python.
# 8 шагов по созданию решения для цепочки блоков
Читать 5 мин
Мнения, высказанные предпринимателями, участников являются их собственными.
Вы читаете Entrepreneur India, международную франшизу Entrepreneur Media.
Когда в 2008 году Сатоши Накамото анонсировала технологию Blockchain в документе под названием Bitcoin: A Peer-to-Peer Electronic Cash System, это была инновационная смесь криптографии с открытым ключом (изобретенная в 1970-х годах) и криптографических хэш-функций (рожденная в 1970-е годы) и доказательство работы (изобретено в 1990-е годы).
За последние несколько лет было создано множество производных проектов и проектов, вдохновленных блокчейном.Большинство из них технически не являются блокчейнами, а скорее являются системами распределенного реестра.
Давайте запишем, как построить блокчейн всего за восемь шагов. Для простоты в этой статье я использовал термины блокчейн и система распределенного реестра как синонимы.
Шаг 1. Определите подходящий вариант использования
Вокруг блокчейна много шумихи. Я читал, что блокчейны могут искоренить глобальный голод, избавить мир от коррупции, покончить с нищетой и сделать многое другое, не беспокоясь об этом.К сожалению, это не так. Итак, шаг 1 - определить вариант использования, который имеет бизнес-смысл.
Есть 3 вещи, которые блокчейны могут делать очень хорошо:
- Аутентификация и проверка данных: это включает неизменяемое хранилище, цифровые подписи и шифрование. В блокчейне можно хранить данные практически в любом формате. Блокчейны могут создавать пары открытого и закрытого ключей, а также использоваться для генерации и проверки цифровых подписей.
- Интеллектуальное управление активами: включает выпуск, оплату, обмен, условное депонирование и изъятие из обращения.Умный / криптоактив - это токенизированная версия реального актива, например золото, серебро, масло, земля.
- Смарт-контракты: Этот термин чаще всего понимают неправильно, но об этом мы поговорим в другой раз.
Шаг 2: Определите наиболее подходящий механизм консенсуса
Исходный блокчейн, на котором основана криптовалюта биткойн, использовал доказательство работы в качестве механизма консенсуса. Но сегодня существует несколько систем распределенных реестров, которые предлагают множество механизмов консенсуса, таких как доказательство доли, византийская отказоустойчивость, консенсус на основе депозита, федеративное византийское соглашение, доказательство истекшего времени, производный PBFT, избыточная византийская отказоустойчивость, упрощенная византийская отказоустойчивость. , Федеративный консенсус, Раунд Робин и Делегированное подтверждение ставки.
В зависимости от вашего варианта использования вам необходимо выбрать наиболее разумный механизм консенсуса.
Шаг 3. Определите наиболее подходящую платформу
Сегодня существует множество платформ блокчейнов, и большинство из них бесплатны и имеют открытый исходный код. В зависимости от механизма консенсуса, который вы выбрали на шаге 2, вам необходимо выбрать наиболее подходящую платформу блокчейна.
Вот некоторые из наиболее популярных платформ в алфавитном порядке:
1.BigChainDB
2. Ядро цепочки
3. Corda
4. Кредиты
5. Блокчейн Domus Tower
6. Платформа блокчейна Elements
7. Eris: db
8. Ethereum
9. HydraChain
10. Hyperledger Fabric11. Hyperledger Iroha
12. Hyperledger Sawtooth Lake
13. Multichain
14. Openchain
15.Кворум
16. Stellar
17. Сборка Symbiont
Шаг 4: Проектирование узлов
Решения Blockchain могут быть разрешенными (например, государственный земельный кадастр) или без разрешения (например, Биткойн, где любой может стать майнер). Блокчейн-решения могут быть частными (например, система управления контрактами, реализованная в фармацевтической компании), публичными (например, криптовалюта, обеспеченная активами) или гибридными (например, группа банков, использующих общую платформу KYC).
Еще один фактор, который следует учитывать на этом этапе, - будут ли узлы работать в облаке, локально или и там, и там. Затем возникают проблемы с конфигурацией оборудования, такие как процессоры, память и размер диска. Вам также необходимо определиться с базовыми операционными системами (обычно Ubuntu, CentOS, Debian, Fedora, Red Hat или Windows).
Шаг 5: Разработка экземпляра блокчейна
Большинство платформ блокчейнов нуждаются в очень тщательно спланированной настройке следующих элементов:
1.Разрешения
2. Выпуск активов
3. Перевыпуск активов
4. Атомарные обмены
5. Управление ключами
6. Множественные подписи
7. Параметры
8. Собственные активы
9. Форматы адресов
10. Форматы ключей
11. Сигнатуры блоков
12. Встряхивание рук
Некоторые параметры можно изменить во время выполнения, а некоторые нет, поэтому это очень важный шаг.
Шаг 6. Создание API
Некоторые платформы блокчейнов поставляются с готовыми API, а некоторые - нет. Основные категории API-интерфейсов, которые вам могут понадобиться:
- Создание пар ключей и адресов
- Выполнение функций, связанных с аудитом
- Аутентификация данных с помощью цифровых подписей и хэшей
- Хранение и поиск данных
- Управление жизненным циклом интеллектуальных активов - выпуск , оплата, обмен, условное депонирование и выход на пенсию
- Смарт-контракты
Шаг 7: Разработка интерфейса администратора и пользователя
На этом этапе вам нужно будет выбрать интерфейс пользователя и языки программирования (например.г. HTML5, CSS, PHP, C #, Java, Javascript, Python, Ruby, Golang, Solidity, Angular JS Nodejs). Вам также нужно будет выбрать внешние базы данных (например, MySQL, MongoDB), а также серверы (включая веб-серверы, FTP-серверы, почтовые серверы).
Шаг 8: Добавление Future Tech
Вы можете значительно расширить возможности своего решения Blockchain за счет интеграции искусственного интеллекта, биометрии, ботов, облака, когнитивных сервисов, контейнеров, аналитики данных, Интернета вещей и машинного обучения.
Как создать свою собственную криптовалюту
Фото: Игорь Игоревич (Shutterstock)
Если в последние месяцы вы полностью не избегали новостей, вы, вероятно, слышали о бешеной поездке на рынке криптовалют. Биткойн и эфир ежедневно испытывают огромные колебания в цене, в то время как Dogecoin, созданный в шутку в 2013 году, стал очень реальным (хотя и нестабильным) активом отчасти благодаря ленте в Твиттере Илона Маска и его недавнему появлению в SNL.
Тем временем Китай принимает жесткие меры в отношении сделок с криптовалютой, а IRS выслеживает инвесторов, которые не сообщили о прибыли от владений криптовалютой, поэтому, если вы продали или обменяли монеты, вы можете оказаться на крючке из-за прироста капитала или дохода. налоги.
Если вам недостаточно азарта от игры в кабинетного наблюдателя или инвестора-любителя, вы можете задаться вопросом, можно ли вмешаться, создав собственную криптовалюту . Короткий ответ - да, но есть довольно много различных вариантов, которые следует рассмотреть - и помните о предостережениях - прежде чем вы погрузитесь в них.
Во-первых, важно понимать разницу между монетами и жетонами. Обе являются криптовалютами, но хотя монета - биткойн, лайткойн, догкойн - работает на собственном блокчейне, токен живет поверх существующей инфраструктуры блокчейна, такой как Ethereum.
G / O Media может получить комиссию
Блокчейн - это, в простейшем случае, запись транзакций, выполненных и защищенных сетью.Таким образом, хотя у монет есть свои собственные независимые журналы транзакций, токены полагаются на технологию базовой сети для проверки и защиты транзакций и владения. Как правило, монеты используются для передачи богатства, а жетоны могут представлять собой «контракт» практически на все, от физических объектов до билетов на мероприятия и очков лояльности.
Токены часто выпускаются посредством краудсейла, известного как первичное предложение монет (ICO), в обмен на существующие монеты, которые, в свою очередь, финансируют такие проекты, как игровые платформы или цифровые кошельки.Вы все еще можете получить общедоступные токены после завершения ICO - аналогично покупке монет - с использованием базовой валюты для совершения покупки.
Кто угодно может создать токен и провести краудсейл, но ICO может быть непонятным, если создатели берут деньги инвесторов и запускаются. Некоторые ICO считаются ценными бумагами и, следовательно, регулируются Комиссией по ценным бумагам и биржам, которая рекомендует инвесторам провести исследование перед покупкой токенов, запущенных в ICO. SEC все активнее борется с мошенническими ICO.
На момент написания CoinMarketCap перечисляет более 5200 монет и токенов, доступных на публичных биржах. Однако не все токены попали на биржи - Etherscan, который предоставляет аналитику Ethereum, имеет в своем архиве более 403000 контрактов. В апреле 2018 года их было всего 71000 человек.
Идея криптовалюты заключается в том, что базовый код доступен для всех, но это не значит, что его легко понять. Вот способы создания ваших собственных монет и жетонов.
Оба эти метода требуют довольно больших технических знаний или помощи опытного разработчика. Поскольку монеты находятся в собственных блокчейнах, вам придется либо построить блокчейн, либо изменить существующий для своей новой монеты.
Первый требует серьезных навыков программирования, и хотя существуют учебные пособия и онлайн-курсы, которые проведут вас через процесс, они предполагают определенный уровень знаний, и вы, как правило, не завершаете процесс с полностью функционирующей монетой, готовой к публичному обмену. .
В качестве альтернативы вы можете выполнить форк существующего блокчейна, взяв открытый исходный код, найденный на Github, внеся несколько изменений и запустив новый блокчейн с новым именем (например, Garlicoin, который является форком Litecoin). Опять же, это требует от вас понимания кода, чтобы знать, что нужно изменить и почему.
Для обычного человека, не разбирающегося в тонкостях кодирования, сервис создания, который выполняет техническую работу и доставляет готовую монету или токен обратно вам это один из вариантов.Например, в WalletBuilders есть бесплатный инструмент для запуска монет для тех, кто просто хочет поэкспериментировать с процессом, а также платный пакет (0,0023 BTC на момент написания), который создает функциональную монету. Rally - это платформа для создания монет, доступная только по приглашению, которая построена на блокчейне Ethereum.
Вы также можете создать токен - который по сути является смарт-контрактом - с публичным ICO или без него. Поскольку токены могут представлять любой актив, вы даже можете создать токен, не имеющий реальной ценности или серьезной цели, кроме обмена между друзьями.
Это быстрее, проще и дешевле, чем создание монеты, поскольку не требует времени и усилий для создания и поддержки новой или разветвленной цепочки блоков, а вместо этого полагается на технологию, уже используемую для биткойнов или Ethereum.
Обычным продуктом является токен ERC-20, стандарт для токенов, построенных на блокчейне Ethereum. Код для этих токен-контрактов и краудсейла также доступен для очень амбициозных людей, и есть удобные учебные пособия и видео на YouTube, а также платформы, которые проведут вас через процесс создания токена всего за несколько кликов.
Этот генератор на Github, например, просто требует, чтобы вы установили MetaMask (утилиту блокчейна для покупки, обмена и хранения токенов) и введите некоторые данные, как описано в этом видеоуроке о токене, который вы запускаете. Есть бесплатный вариант, если вы не особо заботитесь о настройке, и планы с большим контролем стоят до 0,75 ETH на момент написания этой статьи.
Если вам интересно криптовалюта, эксперименты с токен-контрактами не наказываются. Начните с токена ERC-20, который вы можете раздать своим друзьям, а затем обналичить тех, кто покупает напитки в баре.Никакой денежной стоимости или обязательств не прилагается, но это поможет вам понять технический аспект, а также то, как работают токены. ICO, вероятно, не подойдет для случайного наблюдателя из-за правил SEC и высоких штрафов за искажение фактов.
Техническое создание криптовалюты на самом деле не самая сложная часть запуска успешного криптопроекта. Настоящая работа заключается в том, чтобы придать ценность вашей монете или токену, построить инфраструктуру, поддерживать ее и убедить других принять участие, что требует команды разработчиков и персонала.При правильной поддержке и продвижении даже мемкойны могут получить реальную ценность (опять же, подумайте о Dogecoin).
Тем не менее, многие криптовалюты не работают или даже сомнительны с юридической точки зрения, потому что ICO не было создано добросовестно или монета не вызвала длительного интереса.
Прежде чем идти ва-банк на возможный шиткойн, изучите все детали проекта самостоятельно. Не полагайтесь исключительно на то, что популярно в новостях или на то, что говорят ваши друзья.Краудсорсинговые интернет-форумы - достойное место для поиска актуальной информации о том, что реально и заслуживает доверия, а что нет, хотя, в конечном счете, здравый смысл - главное.
Эта статья была первоначально опубликована в апреле 2018 года и обновлена 24 мая 2021 года с обновленным контекстом о криптовалютном рынке, актуальной статистикой, дополнительными ссылками и более подробной информацией о процессе создания монеты.
Как создать блокчейн на Python (получить предварительно созданную среду выполнения)
Прежде чем мы объясним, как построить блокчейн на Python, давайте вернемся к самому началу.В 2008 году автор (или авторы) под псевдонимом Сатоши Накамото выпустил технический документ, описывающий чисто одноранговую версию электронных денег. Уникальность этой системы электронных денег заключается в том, что транзакции не должны полагаться на сторонние проверки для обеспечения безопасности каждой транзакции. Вместо этого каждая транзакция будет иметь отметку времени, а затем хэшируется в непрерывную цепочку доказательств работы на основе хешей.
Так что же такое хеширование и доказательство работы ? Я представлю эти концепции в этой статье и расскажу, как они закладывают основу для зашифрованной системы электронных денег или криптовалюты.Конкретная форма электронной валюты, которую Сатоши Накамото описал в своей (или ее) статье, стала известна как биткойн, первая криптовалюта. Но чем это полезно, когда вы пытаетесь построить блокчейн на Python?
Ну что ж, ныряем.
Что такое блокчейн?
Система, на которую опирается Биткойн - растущий список записей (то есть блоков), связанных друг с другом, - известна как цепочка блоков. Биткойн был первым успешным применением этой системы, и вскоре после роста его популярности другие криптовалюты были основаны на тех же принципах.Однако эта система не ограничивается хранением финансовой информации. Скорее, тип хранимых данных несущественен и не зависит от сети блокчейн.
По сути, данные, хранящиеся в цепочке блоков, должны иметь следующие характеристики:
- Неизменяемый
- Невзламываемый
- Постоянно (без потери данных)
- Распределенный
Эти качества необходимы для поддержания целостности цепочки блоков и безопасности сети, в которой происходят транзакции.Чтобы проиллюстрировать простоту и элегантность такой системы и объяснить тонкости, я проведу вас через процесс создания вашей собственной цепочки блоков на Python. Чтобы не усложнять, я предполагаю, что данные, хранящиеся в блоке, являются транзакционными данными, поскольку криптовалюты в настоящее время являются доминирующим вариантом использования блокчейна.
Создайте блокчейн на Python с помощью этой предварительно созданной среды выполнения
Чтобы следовать коду в этом руководстве, вам потребуется установить последнюю версию Python.Я буду использовать ActivePython , для которого у вас есть два варианта:
- Загрузите и установите предварительно созданную среду выполнения Blockchain (включая Python 3.6) для Windows 10, CentOS 7 или
- Создайте свою собственную среду выполнения Python, используя только те пакеты, которые вам понадобятся для этого проекта, создав бесплатную учетную запись ActiveState Platform, после чего вы увидите что-то вроде следующего изображения:
Щелкните кнопку Get Started и выберите Python 3.6 и ОС, в которой вы работаете. В дополнение к стандартным пакетам, включенным в Python, нам нужно будет добавить Flask, чтобы создать REST API, который может раскрыть блокчейн и протестировать его.
Создание первого блока
Я буду использовать стандартный формат JSON для хранения данных в каждом блоке. Данные для каждого блока выглядят примерно так:
{ "author": "author_name", "отметка времени": "время_ транзакции", "data": "transaction_data" }
Чтобы реализовать это в Python, мы сначала создаем класс блока с вышеупомянутыми атрибутами.Мы также хотим сделать каждый блок уникальным, чтобы избежать дублирования:
класс Блок : def __init__ (self, index, transaction, timestamp, previous_hash, nonce = 0): self.index = index self.transactions = транзакции self.timestamp = отметка времени self.previous_hash = previous_hash self.nonce = nonce
Пока не беспокойтесь о переменных previous_hash
или nonce
(мы обсудим их позже).
Как я уже упоминал, одной из характеристик данных в каждом блоке является неизменность, которая может быть реализована с помощью криптографической хеш-функции. Это односторонний алгоритм, который берет входные данные произвольного размера (известные как ключ) и отображает их на значения фиксированного размера (хеш-значение). Чтобы проиллюстрировать, почему хеш-функция полезна для нас, рассмотрим следующий пример:
- Алиса и Боб спешат решить сложную математическую задачу
- Алиса хочет доказать Бобу, что она сначала правильно решила ее, не делясь решением, поэтому она прогоняет свой ответ через хеш-функцию и делится полученным значением хеш-функции с Бобом
- Боб наконец-то правильно решает проблему, но получила ли Алиса правильный ответ первой?
- Алиса теперь делится своим ответом с Бобом, чтобы он мог пропустить его через хеш-функцию и проверить, совпадает ли полученное значение хеш-функции с тем, которое Алиса ему изначально предоставила.
- Значения хеш-функции совпадают, что означает, что Алиса действительно правильно решила проблему до Боба.
Python может использовать любую стандартную криптографическую хеш-функцию, например, те, которые входят в набор функций SHA-2 Агентства национальной безопасности США (NSA). Например, SHA-256 может быть реализован путем добавления метода compute_hash
в блок класса:
из hashlib импорт sha256 импорт json класс Блок : def __init__ (self, index, transaction, timestamp, previous_hash, nonce = 0): себя.index = индекс self.transactions = транзакции self.timestamp = отметка времени self.previous_hash = previous_hash self.nonce = nonce def compute_hash (сам): block_string = json.dumps (self .__ dict__, sort_keys = True ) возврат sha256 (block_string.encode ()). Hexdigest ()
Хеширование каждого блока обеспечивает безопасность каждого блока в отдельности, что делает чрезвычайно трудным вмешательство в данные внутри блоков.Теперь, когда мы создали единый блок, нам нужен способ связать их вместе.
Кодирование вашей цепочки блоков
Давайте создадим новый класс для цепочки блоков. Чтобы обеспечить неизменность всей цепочки блоков, мы будем использовать умный подход, включающий хэш предыдущего блока в текущий блок. Осведомленность обо всех данных в каждом блоке устанавливает механизм защиты целостности всей цепочки (по крайней мере, частично). Вот почему мы включили переменную previous_hash
в класс блока.Нам также нужен способ инициализации блокчейна, поэтому мы определяем create_genesis_blockmethod
. Это создает начальный блок с индексом 0 и предыдущим хешем 0. Затем мы добавляем его в цепочку списка , которая отслеживает каждый блок.
время импорта класс Блокчейн : def __init__ (самостоятельно): self.unconfirmed_transactions = [] себя.цепь = [] self.create_genesis_block () def create_genesis_block (самостоятельно): genesis_block = Блок (0, [], time.time (), «0») genesis_block.hash = genesis_block.compute_hash () self.chain.append (genesis_block) @property def last_block (сам): возврат self.chain [-1]
Система подтверждения работы для блокчейна
Хеширование, которое мы описали до сих пор, помогает нам лишь частично.В его нынешнем виде кто-то может изменить предыдущий блок в цепочке, а затем пересчитать каждый из следующих блоков, чтобы создать другую действительную цепочку. Мы также хотели бы реализовать способ, позволяющий пользователям прийти к консенсусу по единой хронологической истории цепочки в правильном порядке, в котором были совершены транзакции. Чтобы решить эту проблему, Сатоши Накамото создал систему доказательства работы.
Система Proof-of-Work постепенно усложняет выполнение работы, необходимой для создания нового блока.Это означает, что кто-то, кто модифицирует предыдущий блок, должен будет повторить работу блока и всех следующих за ним блоков. Система доказательства работы требует сканирования для значения, которое начинается с определенного количества нулевых битов при хешировании. Это значение известно как значение nonce . Количество начальных нулевых битов известно как сложность . Средняя работа, необходимая для создания блока, увеличивается экспоненциально с увеличением числа начальных нулевых битов, и поэтому, увеличивая сложность до с каждым новым блоком, мы можем в достаточной степени препятствовать пользователям изменять предыдущие блоки, поскольку практически невозможно повторить следующие блоки и догнать других.
Для реализации этой системы мы можем добавить метод proof_of_work
в класс блокчейна:
сложность = 2 def proof_of_work (self, block): block.nonce = computed_hash = block.compute_hash () , а не computed_hash.startswith ('0' * Blockchain.difficulty): block.nonce + = 1 computed_hash = block.compute_hash () возврат computed_hash
Теперь, когда у нас есть система, которая обеспечивает безопасность всей цепочки, мы добавляем еще несколько методов в класс цепочки блоков, чтобы собрать все вместе, чтобы мы могли фактически построить цепочку.Первоначально мы будем хранить данные каждой транзакции в unsfirmed_transactions
. Как только мы подтвердим, что новый блок является действительным доказательством, удовлетворяющим критериям сложности, мы можем добавить его в цепочку. Процесс выполнения вычислительной работы в этой системе широко известен как майнинг.
def add_block (self, block, proof): previous_hash = self.last_block.hash , если previous_hash! = Block.previous_hash: возврат ложь если не self.is_valid_proof (блокировать, доказывать): возврат ложь block.hash = доказательство self.chain.append (блок) возврат True def is_valid_proof (self, block, block_hash): вернуть (block_hash.startswith ('0' * Blockchain.difficulty) и block_hash == блок.compute_hash ()) def add_new_transaction (self, transaction): self.unconfirmed_transactions.append (транзакция) def mine (self): если не self.unconfirmed_transactions: возврат ложь last_block = self.last_block new_block = Блок (index = last_block.index + 1, транзакции = сам.Unfirmed_transactions, отметка времени = время.время (), previous_hash = last_block.hash) proof = self.proof_of_work (новый_блок) self.add_block (новый_блок, доказательство) self.unconfirmed_transactions = [] возврат new_block.index
REST API для блокчейна
До этого момента я объяснил основы создания блокчейна:
- Определить отдельный блок
- Определить блокчейн
- Определите систему доказательства работы
- Определить процедуру добычи
Чтобы использовать его, нам нужно будет создать интерфейс, с которым могут взаимодействовать несколько пользователей или узлов.Для этого я буду использовать Flask для создания REST-API. Flask - это легкий фреймворк для веб-приложений, написанный для Python.
из колба импортная колба, запрос импорт запросов app = Flask (__ имя__) blockchain = Блокчейн ()
Сначала мы определяем наше веб-приложение и создаем локальную цепочку блоков. Затем мы создаем конечную точку, которая позволяет нам отправлять запрос для отображения соответствующей информации о блокчейне.
@ app.route ('/ chain', methods = ['GET']) def get_chain (): chain_data = [] для блока в blockchain.chain: chain_data.append (блок .__ dict__) вернуть json.dumps ({"length": len (chain_data), "цепочка": chain_data}) app.run (отладка = True, порт = 5000)
Прежде чем мы сможем запросить его, нам сначала нужно активировать приложение блокчейна в командной строке, запустив:
блокчейн python3.py
Вы должны увидеть что-то вроде этого:
* Работает на http://127.0.0.1:5000/ (для выхода нажмите CTRL + C) * Перезагрузка со статом * Отладчик активен! * ПИН-код отладчика: 105-118-129
Затем в другой оболочке мы можем отправить запрос с cURL, запустив:
локон http://127.0.0.1:5000/chain
Вывод должен содержать всю информацию о блокчейне:
{"длина": 1, "цепочка": [{"индекс": 0, "транзакции": [], "временная метка": 1576665446.403836, «previous_hash»: «0», «nonce»: 0, «hash»: «e2a1ec32fcf89d0388f3d0d8abcd914f941d056c080df1c765a3f6035626fc94»}]}
Довольно круто, правда ?! Обратите внимание, что на данный момент в цепочке есть только один блок (генезисный блок). Не стесняйтесь воспользоваться функцией майнинга, которую мы создали, чтобы добавить больше блоков в цепочку.
Создайте блокчейн на Python: резюме
В этом руководстве мы использовали Python для создания непрерывной цепочки проверки работоспособности на основе хешей.
- Сначала мы разработали концепцию блока и цепочки блоков, включая протоколы для хеширования каждого блока и создания первого блока.
- Затем мы создали систему доказательства работы и способ добавления новых блоков с помощью майнинга.
- Наконец, мы создали приложение с Flask и запросили его.
С тех пор, как Сатоши Накамото впервые представил эти концепции в своем (или ее) техническом документе, появилось много других криптовалют, а также появилось много других идей для потенциальных приложений блокчейна.
Связанные блоги:
Как создать механизм рекомендаций на Python
Как создать цифрового виртуального помощника на Python
Создать простой блокчейн с использованием Python
import
datetime
import
hashlib
import
json
03 import Flask, jsonify
класс
Блокчейн:
сам
.цепочка
=
[]
self
.create_block (proof
=
1
, previous_hash
=
'0'
000)
def
create_block (
self
, proof, previous_hash):
block
=
'{
' index
лен
(
сам
.цепочка)
+
1
,
'timestamp'
:
str
(datetime.datetime.now ()),
'proof'
: proof,
'previous_hash'
: previous_hash}
self
.chain.append (block)
return
block
def
print_previous_block (
self
):
возврат
self
.цепь [
-
1
]
def
proof_of_work (
self
_413 , предыдущий 9_proof)
=
1
check_proof
=
False
в то время как
check_proof
9 False
=
hashlib.sha256 (
str
(new_proof
*
*
2
-
previous_proof
*
*
2
) .encode ().
если
hash_operation [:
4
]
=
=
'00000'
:
check_proof
=
9 else :
new_proof
+
=
1
return
new_proof
904 сам
, бл. ck):
encoded_block
=
json.dumps (block, sort_keys
=
True
) .encode ()
return
hashlib.sha256 (encoded_block) .hexdigest ()
self
, цепочка):
previous_block
=
цепочка [
0
]
block_index
000 =
9
9 в то время как
block_index <
len
(цепочка):
block
=
цепочка [block_index]
if
'предыдущий 90_hash ]!
=
сам
.
hash
(previous_block):
return
False
previous_proof
=
000 previous_block proof '
4'
proof
=
block [
'proof'
]
hash_operation
=
hashlib.sha256 (
str
(proof
*
*
2
-
previous_proof
*
*
2
) .encode ())
если
hash_operation [:
4
]!
=
'00000'
:
возврат
False
previous_block
=
block
block_inde
block_inde
возврат
True
приложение
=
Flask (__ name__)
Blockchain
@app
.route (
'/ mine_block'
, методы
=
[
'GET'
])
def
mine_block ():
previous_block
blockchain.print_previous_block ()
previous_proof
=
previous_block [
'proof'
]
proof
=
блокчейн.proof_of_work (previous_proof)
previous_hash
=
блокчейн.
хэш
(предыдущий_блок)
блок
=
blockchain.create_block (proof, previous_hash)
ответ
= сообщение
= сообщение
= сообщение
:
'Блок MINED'
,
'index'
: блок [
'index'
],
'timestamp'
: block [
'timestamp'
],
'proof'
: block [
'proof'
],
'previous_hash'
: block [
' previous_hash '
]}
возврат
j sonify (ответ),
200
@app
.route (
'/ get_chain'
, методы
=
[
'GET'
])
def
display_chain ():
response
=
{ 'цепочка'
: blockchain.chain,
'длина'
:
len
(blockchain.chain)}
return
jsonify (ответ),
200
@app
.маршрут (
'/ действительный'
, методы
=
[
'GET'
])
def
действительный ():
действительный
=
blockchain.chain_valid (blockchain.chain)
если
действителен:
ответ
=
{
'сообщение' Blockchain
:
' действительный.