Введение в технологию Блокчейн. Тимур Сергеевич Машнин

Введение в технологию Блокчейн - Тимур Сергеевич Машнин


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

      Узлы запускают скрипт для каждого предыдущего выхода, который тратится, и проверяют, чтобы скрипт вернул true.

      Во-вторых, они проверяют, чтобы выходы, потраченные в этой транзакции, еще не были потрачены.

      В-третьих, они не будут передавать уже полученную ранее транзакцию.

      В-четвертых, по умолчанию, узлы будут принимать и ретранслировать «стандартные» скрипты на основе небольшого белого списка скриптов.

      Все эти проверки – это просто проверки на основе здравомыслия.

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

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

      Вот почему, желательно, чтобы каждый узел выполнял эти проверки.

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

      Это становится особенно интересным и важным, когда есть попытка двойной траты.

      Предположим, что Алиса пытается заплатит один и тот же биткойн как Бобу, так и Чарли, и отправляет две транзакции примерно в одно и то же время.

      Некоторые узлы сначала услышат о транзакции Алиса → Боб, а другие сначала услышат о транзакции Alice → Charlie.

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

      Узел откажется от последней транзакции и не будет ретранслировать ее или добавлять ее в пул транзакций.

      В результате временно между узлами возникнет разногласие о том, какие транзакции следует поместить в следующий блок.

      Это называется созданием условия гонки.

      Хорошей новостью является то, что все будет в порядке.

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

      Скажем, транзакция Алисы → Чарли попадает в блок.

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

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

      Так что больше не будет никакого разногласия, когда этот блок распространится в сеть.

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

      Если две конфликтующие транзакции или блока будут объявлены в двух разных позициях в сети, оба они начнут распространяться по всей сети и какая транзакция узла будет


Скачать книгу