Майнинг процесс добавления новых блоков транзакций

Что такое майнинг криптовалют? Гайд для чайников

Поделиться

Майнинг – это процесс, который позволяет осуществлять верификацию транзакций, добавление новой информации в базу данных и выпуск новых монет в обращение. Его важность состоит в том, что он обеспечивает функционирование криптовалют в качестве децентрализованной P2P-сети.

Это сложный и трудоемкий процесс, который, при этом, может приносить хорошую прибыль. Для того, чтобы ответить на вопрос о том, что такое майнинг криптовалюты, редакция BeInCrypto собрала всю информацию о нем в одном материале.

Функции майнинга криптовалют

Ответить на вопрос о том, что такое майнинг криптовалюты простыми словами, невозможно без детального рассмотрения основных функций этого процесса. Всего их три.

1. Выпуск новых монет

Если фиатные валюты выпускают Центробанки, то биткоины добывают. Концепция аналогична добыче золота, а разница лишь в том, что биткоин существует внутри программного обеспечения, но для вывода в обращение его нужно «намайнить». Этот процесс осуществляется посредством специализированных нодов, решающих задачи и впоследствии получающих вознаграждение в виде криптовалюты.

2. Подтверждение транзакций

Транзакция подтверждается как безопасная, если включается в блок, внедренный в блокчейн. Чем больше подтверждений, тем более безопасным считается платеж.

3. Обеспечение безопасности

Чем больше майнеров участвует в процессе, тем безопаснее сеть. Распределенная майнинговая мощность (хешрейт) обеспечивает безопасность сети. Гипотетически, откат транзакции с биткоином возможен только в том случае, если большинство (51%) участников контролирует майнинговый хешрейт сети.

Не все криптовалюты появляются вследствие майнинга, но биткоин является самым ярким примером добываемой цифровой валюты.

Как происходит майнинг криптовалюты

Представим процесс на примере самого капитализированного цифрового актива – биткоина. Криптовалюта использует блокчейн, регулируемый сетью нодов. В данном контексте есть два типа нодов:

  • Ноды – компьютеры, которые соединены с другими нодами в сети для документирования и синхронизации информации.
  • Некоторые ноды – специальные майнинговые ноды, отвечающие за принятие всех новых транзакций и добавление их в блоки, из которых состоит блокчейн.

Майнеры конкурируют между собой за решение сложных математических задач. Как только майнер находит решение, он делится им с остальными участками сети, которые подтверждают это решение и добавление блока.

Для решения блока майнеры должны подобрать последовательность цифр. Как это работает?

Майнеры должны подобрать цифру, которая в сочетании с хеш-функцией выдает число в определенном диапазоне.

Существует несколько разновидностей добычи монет. Среди них майнинг криптовалюты на процессоре, видеокартах и специальных устройствах – асиках. Выбор способа зависит от нюансов цифрового актива, добычу которого планирует осуществлять пользователь.

Например, для майнинга биткоина недостаточно мощности процессора – нужны асики и видеокарты. Из последних часто формируют конструкцию, которую в криптосообществе называют «майнинг ферма». Она представляет собой объединенные, с целью повышения мощности, видеокарты.

Что такое хеш-функция

Говоря простым языком, хеш-функция – это серия алгоритмов, которые обладают определенным свойствами, применимыми к данным и позволяющими произвести «хеш» (хеш – это просто цифра). Существуют базовые и криптографические хеш-функции. Вторые используются в блокчейне.

В каждом биткоине есть специальная часть блока, которую можно заполнить рандомной цифрой, известной в индустрии как nonce (однократно используемое число). Майнер берет информацию из уже известных ему блоков (из пула памяти) и выстраивает из них новый блок.

После хеширования каждой транзакции они организуются в пары и затем, хешируются в так называемое дерево Меркла или хеш-дерево. По сути, для решения хеша майнеру необходимо методом проб и ошибок угадать, какую последовательность цифр использовать в качестве однократно используемого числа.

Если выход из алгоритма меньше целевого значения, он признается действительным и принимается остальными участниками сети. Если же хеш блока превышает размер целевой цифры, майнер должен корректировать данные при выполнении функции хеширования до тех пор, пока не будет найдено правильное решение.

Теоретически можно получить корректных хеш путем изменения деталей транзакций, существующих в блокчейне. Именно поэтому здесь необходимо доказательство выполненной работы, и майнер должен делиться своим решением с другими нодами для проверки данных.

Читайте также:  Драйвер для радеон для майнинга

Если майнер находит решение, которое соответствует правилу о том, что размер хеша должен быть меньше целевого значения, он делится ответом с другими нодами, которые его верифицируют.

Метрика сложности

Уровень сложности задачи определяется числом пользователей и вычислительной мощностью сети. По мере увеличения числа майнеров уровень сложности задачи возрастает во избежание роста стоимости создания блока. Это обеспечивает стабильный процесс добычи криптовалюты. На сегодняшний день среднее время формирования блока составляет 10 минут.

Вознаграждение

За каждый успешно добытый блок майнер получает вознаграждение в криптовалюте. Для обеспечения устойчивого предложения размер вознаграждения сокращается вдвое после каждых 210 тысяч блоков, на создание которых уходит около четырех лет. По состоянию на октябрь 2019 года было добыто 18 миллионов биткоинов из возможных 21 миллионов.

Где хранить намайненные криптовалюты

Рынок цифровых активов, включая сферу майнинга, по-прежнему плохо урегулирован. В России контролирующие органы в течение нескольких лет пытаются создать правовую базу. Некоторые нормы регулирования вступят в силу с 1 января 2020 года. Например, криптовалюту нельзя будет использовать в качестве альтернативы национальной валюты – рубля.

Также Минфин РФ предлагает ограничить возможности майнеров. В том числе, команда ведомства считает, что легальность дохода от добычи криптовалют нужно подвергнуть проверкам.

На фоне действующих и грядущих ограничений, лучший вариант для хранения цифровых активов – полностью анонимные биржи. Пример такой платформы – StormGain.

Биржа не собирает информацию о своих пользователях, а значит данные не утекут в сеть, и ими не смогут воспользоваться регуляторы для поимки участников криптосообщества. Еще одно преимущество StormGain – наличие бонусной программы. Например, при регистрации по ссылке каждый получит 25 USDT на пополнение депозита.

Будущее майнинга

Нынешняя майнинговая система помогает защищать сеть от атак, но сам процесс добычи цифровых токенов требует наличия дорогостоящего и, что немаловажно, энергоемкого компьютерного оборудования.

Сейчас разрабатываются многие альтернативные методы консенсуса для разрешения этой проблемы, так что в дальнейшем необходимость в добыче ряда криптовалют может полностью отпасть. Поэтому заинтересованные в вопросе о том, как начать майнинг криптовалюты пользователи, в случае промедления, рискуют упустить некоторые возможности заработать.

А каким вы видите будущее майнинга? Предлагаем обсудить вопрос в нашем Telegram-чате с другими участниками криптосообщества.

Источник

Руководство: Как работает майнинг и подтверждение транзакций в блокчейне

Когда-нибудь задумывались, как работает майнинг в блокчейне, или как транзакции подтверждаются и добавляются в блокчейн? И я тоже. Но из-за того, что мне так и не попалось чёткое и доступное пошаговое объяснение этого процесса, я решил написать его сам. Итак, представляю вам результат моего исследования на тему, как обрабатываются транзакции в блокчейне. И всего за семь шагов.

Шаг 1: Пользователь, намереваясь переслать кому-то другому некую сумму в криптовалюте или токен, подтверждает транзакцию в своём приложении-кошельке.

Шаг 2: Транзакция затем транслируется приложением кошелька в сеть соответствующего блокчейна. Там она попадает в «пул неподтверждённых транзакций», где и будет находится до тех пор, пока её не подберёт какой-нибудь майнер (тот, кто занимается майнингом). Такой пул представляет собой скопление неподтверждённых транзакций, ожидающих обработки. Чаще всего неподтверждённые транзакции собираются не в одном гигантском пуле, а в небольших разделённых локальных пулах.

Шаг 3: Майнеры, находящиеся в сети (иногда называемые узлами или нодами, но это не совсем то же самое, что и майнеры!), выбирают транзакции из пулов и собирают из них новый «блок». Блок, по сути, это набор транзакций (на этот момент времени всё ещё неподтверждённых транзакций), плюс дополнительные метаданные. Каждый майнер собирает свой собственный блок транзакций. Одни и те же транзакции могут быть добавлены разными майнерами в свои блоки.

Пример: Рассмотрим двух майнеров, майнера А и майнера Б. Оба этих майнера могут решить включить некую транзакцию Х в свои блоки. В каждом блокчейне установлены свои ограничения максимального размера блока. В Биткойн-блокчейне максимальный размер блока составляет 1 мегабайт (Мб) данных. Прежде чем добавить транзакцию в блок, майнеру необходимо проверить отвечает ли транзакция требованиям к исполнению, в соответствии с историей транзакций в блокчейне. Если на балансе кошелька отправителя находится достаточно средств согласно существующей истории транзакций блокчейна, транзакция считается действительной и может быть добавлена в блок. Если владелец биткойнов захочет ускорить процесс обработки своей транзакции, он может предложить более высокую награду за майнинг. В этом случае, как правило, майнеры присвоят более высокий приоритет этой транзакции по сравнению с другими, в связи с возможностью получить большее вознаграждение за процесс майнинга.

Читайте также:  Как увеличить финансовую доходность

Шаг 4: Выбирая транзакции и добавляя их в свой блок, майнеры тем самым создают блок транзакций. Для того, чтобы блок в последующем мог быть добавлен в блокчейн (что означает, что все узлы в блокчейне зарегистрируют транзакции, находящиеся в этом блоке), в первую очередь блоку необходима подпись, также называемая «доказательством выполнения работы» (англ. Proof-of-work или PoW). Эта подпись создаётся путём решения очень сложной математической задачи, которая является уникальной для каждого блока транзакций. Разным блокам соответствуют разные математические задачи, так что каждый майнер будет работать над решением своей задачи, уникальной для сформированного им блока. Все задачи одинаково трудны для решения. При решении такой математической проблемы затрачиваются большие вычислительные мощности (а, соответственно, и большое количество электроэнергии). Вы можете сравнить это с выполнением вычислений на калькуляторе, только в данном случае всё гораздо сложнее и делается на персональном компьютере. Этот процесс называется майнингом. Если вы хотите узнать более подробно о том, что за математические задачи приходится решать в процессе (на самом деле, это не так сложно), тогда, пожалуйста, продолжайте читать дальше. В противном случае, если нужен материал «полегче», сразу переходите к «шагу 5».

Майнинг, также известный как хэширование (алгоритм консенсуса «доказательство выполнения работы»/Proof of Work)

Математическая задача, которую приходится решать каждому майнеру при попытке добавления блока в блокчейн, заключается в нахождении хэш-суммы (также называемой цифровой подписью) для данных в этом блоке. Причём подпись должна начинаться с определённого количества идущих подряд нулей. Выглядит весьма трудной задачей, не так ли? На самом деле всё не так сложно. Позвольте мне попытаться объяснить это в упрощённом виде.

Прежде чем мы продолжим, важно знать, что такое хэш-функция. Говоря простым языком, хэш-функция представляет из себя математическую задачу, которую очень сложно решить, но при этом полученный ответ очень просто проверить.

Хэш-функция берёт строку входных данных, состоящую из цифр и букв (любую, в прямом смысле этого слова, строку случайных букв, чисел и/или символов) и преобразовывает её в новую 32-символьную строку, состоящую из случайных букв и цифр. Эта 32-символьная строка и есть хэш-сумма. Если изменяется любая цифра или буква во входящей строке, то хэш-сумма также изменится случайным образом. Однако, одна и та же строка входных данных всегда на выходе будет иметь одну и ту же хэш-сумму.

Теперь примите во внимание, что данные внутри блока – это входные данные для хэширования (та самая строка данных). В результате обработки этих входных данных хэш-функцией мы получаем хэш-сумму (32-символьную строку). Правилами блокчейна Биткойна оговаривается, что только те блоки могут быть добавлены в блокчейн, чьи подписи (хэш-сумма) начинаются с определённого количества нулей. Однако, сгенерированная выходная строка является всегда случайной для разных строк данных на входе. А что если строка данных блока в результате обработки хэш-функцией не даёт на выходе подпись (хэш-сумму), начинающуюся с того определённого количества идущих подряд нулей? Так это и является причиной того, что майнерам приходится многократно изменять некий фрагмент данных своего блока, называемый «нонс» (англ. nonce). Каждый раз, когда майнер изменяет нонс, это влечёт за собой незначительное изменение компоновки данных блока. А когда меняется структура данных внутри блока (то есть, его входные данные), также изменяется и его подпись (или его выходные данные). Итак, каждый раз, когда меняется нонс блока, этот блок получает новую случайную подпись.

Такая процедура изменения нонса повторяется майнерами бесконечное число раз, пока в конечном итоге они случайно не наткнутся на выходную строку, удовлетворяющую требованиям к подписи блока (определённое количество нулей в самом её начале). Ниже приведён пример, иллюстрирующий этот процесс. В примере используется семь нулей, но количество нулей на самом деле зависит от сложности блока в блокчейне. Сложность блока – это несколько более продвинутая тема, поэтому предлагаю вам ознакомиться с ней позднее.

Читайте также:  Тарифные планы сбербанка для инвестиций

Именно таким образом майнерам приходится искать подходящую подпись для своего блока, и это также является причиной, по которой требуются так много вычислительных мощностей для решения этой математической проблемы. Перебор настолько огромного количества нонсов в попытке угадать правильный занимает много времени и больших вычислительных мощностей. Также следует учитывать то, что с ростом мощности хэширования (количества майнеров) в блокчейне увеличится и сложность математической задачи, что повлечёт за собой увеличение средних расходов на электричество, требуемого для решения блока. Вы большие молодцы, если дочитали до этого момента! Давайте продолжим и перейдём к шагу 5.

Примечание: На самом деле этот процесс не определяется как математическая задача, но скорее является чем-то детерминированным – компьютеры выполняют предопределённые операции над числом, чтобы выяснить, является ли результат именно тем, что требуется.

Шаг 5: Майнер, первый нашедший для своего блока удовлетворяющую требованиям подпись, транслирует этот блок и его подпись всем остальным майнерам.

Шаг 6: Другие майнеры теперь проверяют легитимность подписи, беря строку данных транслируемого блока и хэшируя её, чтобы проверить, действительно ли полученная хэш-сумма в результате приводит к включённой в блок подписи с правильным количеством нулей (помните, да? – трудно решить, но легко проверить). Если подпись действительна, то все остальные майнеры подтвердят её достоверность и придут к согласию, что этот блок может быть добавлен в блокчейн (то есть они достигнут консенсуса, говоря другими словами – все согласятся друг с другом – отсюда и термин алгоритм консенсуса). Из этого же проистекает термин «доказательство выполнения работы/proof-of-work». Подпись как раз и является требуемым «доказательством», что работа была произведена (были израсходованы вычислительные мощности). Теперь блок может быть добавлен в блокчейн и разослан всем другим узлам в сети. Те, в свою очередь, примут блок и сохранят его, добавив к своим данным транзакций, при условии, что все транзакции внутри этого блока могут быть исполнены в соответствии с историей, записанной в блокчейне.

Шаг 7: После того, как блок был добавлен в цепочку, все другие блоки, которые будут добавлены после него, будут считаться «подтверждением» для этого блока. Например, если моя транзакция включена в блок 502, а длина блокчейна составляет 507 блоков, это означает, что моя транзакция имеет 5 подтверждений (507-502). Это называется подтверждением, потому что каждый раз, когда новый блок добавляется после вашего, блокчейн вновь достигает консенсуса по поводу всей истории совершённых транзакций, включая вашу транзакцию и ваш блок. Можно также сказать, что на данный момент блокчейн подтвердил вашу транзакцию 5 раз. На это же опирается и Etherscan, когда показывает вам подробные детали вашей транзакции. Чем больше подтверждений будет у вашей транзакции (другими словами – чем глубже в цепочке находится ваш блок), тем сложнее будет для злоумышленников подменить её. После того, как новый блок добавлен в блокчейн, всем майнерам нужно начинать заново с «шага 3» и сформировать новый блок транзакций. Майнеры не могут продолжать (на самом деле могут, но это несколько выходит за рамки темы, обсуждаемой в данной статье) майнить тот же самый блок, другими словами – решать задачу – того же самого блока, над которым они работали ранее по двум причинам:

Первая: он может содержать транзакции, которые были подтверждены последним блоком, уже добавленным в блокчейн (помните, что разные майнеры могут выбирать/включать одну и ту же транзакцию(ии) в блок, который они решают). Любые из тех транзакций в случае, если они будут запущены вновь, могут быть признаны недействительными, потому что на балансе кошелька отправителя уже может быть недостаточно средств.

И вторая: каждый блок должен добавить хэш-сумму (подпись) последнего добавленного в блокчейн блока в свои метаданные. Именно это и делает блокчейн блокчейном (цепочкой блоков). Если майнер вдруг продолжит майнить тот же самый блок, над которым он уже работал, другие майнеры заметят, что его хэш-сумма не соответствует той, что была в последнем добавленном в блокчейн блоке и, вследствие этого, отвергнут этот блок.

Будь в курсе! Подписывайся на Криптовалюта.Tech в Telegram.
Обсудить актуальные новости и события на Форуме

Источник

Оцените статью