Jump to content

Почему блокчейн состоит именно из блоков, а не из транзакций?


aanovik
 Share

Recommended Posts

Уже второй день пытаюсь ответить себе на вопрос о том, почему в блокчейне биткоина информация объединяется в блоки, а не проверяется в виде отдельных транзакций. Я прочитал уже очень большое количество статей на русском и английском (начав с white paper Сатоши), но везде блоки упоминаются как данность.

 

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

 

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

Edited by aanovik
Link to comment
Share on other sites

@rammendo, спасибо за отклик.

 

В каком смысле "подписывать"? Транзакции в любом случае подписываются и при нынешнем алгоритме работы.

Link to comment
Share on other sites

Мне вот дали ссылку на статью, в которой содержится следующее высказывание:

 

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

https://habrahabr.ru/company/bitfury/blog/327468/

То есть в теории всё-таки можно проверять не блоки, а транзакции, и весь вопрос только в рациональности такого подхода?

Link to comment
Share on other sites

Уже второй день пытаюсь ответить себе на вопрос о том, почему в блокчейне биткоина информация объединяется в блоки, а не проверяется в виде отдельных транзакций. Я прочитал уже очень большое количество статей на русском и английском (начав с white paper Сатоши), но везде блоки упоминаются как данность.

 

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

 

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

Что эффективней - сварить котел борща и накормить 100 человек или варить отдельно 100 тарелок борща?

Link to comment
Share on other sites

Что эффективней - сварить котел борща и накормить 100 человек или варить отдельно 100 тарелок борща?

Если дело только в этом, то вопрос закрыт :)

Link to comment
Share on other sites

@aanovik, тут ещё есть вопрос со сложностью майнинга. С блоками: сложность подстраивается под скорость нахождения 1 блок/10 минут. С транзакциями как будете делать?

Edited by sankopolo
Link to comment
Share on other sites

@sankopolo, но мы же знаем, что блок, как правило, появляется не раз в 10 минут, там дисперсия нехилая. Сложность задачи для транзакции вполне возможно определить точно так же, как и для блока. Другое дело, что да, это всё не очень рационально.

Edited by aanovik
Link to comment
Share on other sites

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

Edited by alexe13
Link to comment
Share on other sites

 

 

В ethereum, например, для решения этой проблемы разработали технологию GHOST

Хорошо, спасибо.

Link to comment
Share on other sites

@aanovik,

 

но мы же знаем, что блок, как правило, появляется не раз в 10 минут, там дисперсия нехилая.
Ну при чём здесь дисперсия-то? 2016 блоков всегда находятся за примерно 2 недели (12-15 дней на практике).

 

 

Сложность задачи для транзакции вполне возможно определить точно так же, как и для блока.
Да ну? Будете требовать 2016 транзакций за 2 недели? Или сколько? Что будете делать, если транзакций пользователи шлют больше или меньше?
Link to comment
Share on other sites

Если помещать в сеть только транзакции- то возникнет одна очень большая проблема. Назовём её: проблема первичного распределения монет.

Представим что вы Сатоши Накамото, и разрабатываете биткоин сейчас. И цель по прежнему: планетарная платёжная система, для любого жителя земли. Но вот проблема- как в этой системе распределить деньги между участниками, чтоб распределение было честным, и при этом нельзя обращаться ни к какой третьей стороне? Ответ- с помощью цены за блок.
В случае с блоками- четко определена плата. Первые 210 тыс блоков стоят 50 монет. Потом 210 тыс блоков стоят 25  монет и т.д- количество монет падает в 2 раза через 210 тыс блоков.

В случае с транзакциями- как распределять их стоимость? Одна транзакция равна 0.000001 монеты? А если найдется некто, кто задумает создать 100500 транзакций чтоб нарубить себе 100500 биткоинов?

 

Link to comment
Share on other sites

 

 

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

 

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

Link to comment
Share on other sites

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

 

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

 

Интервал между блоками сатоши выбрал не просто так. 10 минут вполне достаточная величина, чтоб одновременно и накопить в ОЗУ ферм достаточно транзакций для записи в новый блок, и чтоб уменьшить шанс создания орфан блоков.

 

Если уменьшить время между блоками до 1 минуты, то количество орфан блоков намного увеличится, и плюс не забывайте о пересчете сложности. Сейчас выбрано 14 суток. Это вполне нормальная величина, чтоб трезво оценивать ситуацию с происходящим на рынке. Банально за 7 суток цена биткоина вполне может вырасти и упасть на 50%. Если делать пересчет раз в 4 дня например, то это вполне может привести к тому, что желающие майнить сегодня в очередь выстраиваются, а завтра разбегаются- словно стая птиц в которые бросили камень.

 

Те сегодня сложность выросла на 300%, а через 5 дней- наоборот нехватка мощностей и блоки запаздывают в 3 раза

Link to comment
Share on other sites

 

 

А вообще, возникает интересный вопрос - почему вместо увеличения размера блока не пошли по пути уменьшения интервала между блоками?
Можно было бы уменьшать интервал и сеть стала бы комфортнее, но:
  1. Увеличить лимит на размер блока проще - это одна константа в одном месте кода, в случае с интервалом надо будет вносить изменения в несколько большем числе мест.
  2. В "первоначальном биткоине" блок не имел ограничения 1 мб и это ограничение появилось как временная мера против спама. Т е увеличение лимита можно рассматривать как возврат к "Satoshi way".
  3. Даже с учетом (1) и (2) у увеличения лимита на размер блока было (и есть) много противников, включая текущих разработчиков bitcoin core. Т е договориться об уменьшении интервала между блоками было бы практически нереально.
Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
 Share

  • Recently Browsing   0 members

    • No registered users viewing this page.
  • Similar Topics

    • Исследование: американские финансовые компании инвестируют в блокчейн

      FTI Consulting провела опрос руководителей 150 американских финансовых компаний о блокчейне. Оказалось, что фирмы крайне заинтересованы в технологии и вкладывают в нее значительные средства. Как отмечается в отчете FTI Consulting, американские финансовые компании в среднем вкладывают по $176.4 млн за год в разработки в области блокчейна. При этом 92% опрошенных ожидают «полноценного принятия блокчейна» уже в течение трех лет.   «Около 70% респондентов считают, что блокчейн фундамента

      in Новости криптовалют

    • Минфин Великобритании собирается исключить из закона о криптовалютах блокчейн и DLT

      Казначейство Ее Величества (HMT) предлагает прописать в законодательстве свод отдельных правил для регулирования каждого конкретного случая DеFi. HMT в январском отчете о состоянии крипторынка констатирует, что большинство современных криптовалютных проектов используют в качестве базовой технологию распределенного реестра (DLT) или блокчейн. Однако, считают в британском минфине, со временем это может измениться, а значит уже сейчас пора применить термины, «ориентированные на будущее криптои

      in Новости криптовалют

    • Вопрос почему майнинг так просел

      Майнил пол года назад на gtx 1060 6gb, 27 июня курс битка был около 30, а курс эфира 2, и майнило по 1.5$ +- . Сейчас же курс битка 40, а курс эфира 3.2, а майнит по 1.1$. Это сложность добывания изменилась, или же в чем дело? Просто не следил и щас гуглю а найти не могу.

      in Флейм

    • Требуется блокчейн разрабочик

      Вакансия -  Blockchain Payment Integration Developer Компания - Alfacash Форма работы - удаленка Зарплатная вилка - рассматриваются ожидания кандидатов  Занятость - полная , долгосрочное сотрудничество  Обязанности: Умение работать самостоятельно и в команде Самостоятельное подключение новых криптовалют с учетом текущей архитектуры backend Понимание новых криптовалют, разбор софта, парсинг транзакций, подпись транзакций и т.д Изучение архитектуры криптовалюты  Разворачи

      in Поиск блокчейн разработчиков

    • Минтранспорта США планирует применить блокчейн для решения проблем с нехваткой парковочных мест

      Министерство транспорта США разместило тендер на разработку решения на базе блокчейна для координации действий водителей в связи с потенциальным ростом проблем с парковочными местами. Данная инициатива запущена в рамках программы Министерства транспорта США по исследованию инноваций в малом бизнесе (SBIR). В документе уточняется, что токенизация решит вопрос парковочных мест, который становится актуальным по мере того, как все больше сотрудников возвращаются на рабочие места после снятия огр

      in Новости криптовалют

×
×
  • Create New...