Читаем 1c2b9509b53cb0837976a7dc6c8bcd37 полностью

размер зависит от разных параметров — скорости создания новых блоков, количества транзакций, содержащихся в них, размеров самих транзакций. В

зависимости от этих параметров, а также «возраста» базы данных ее размер

уже через несколько лет активной работы может исчисляться сотнями гигабайт

информации, которая постоянно копируется и синхронизируется между

участниками системы. Решение задачи оптимизации размера базы данных в

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

противном случае это может создать дополнительные препятствия для

развития перспективной технологии. Впрочем, предложения по решению этой

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

вопросам масштабирования технологии блокчейн.

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

практических реализациях структура блоков всегда отличается, но у них есть

ряд общих элементов, которые встречаются в том или ином виде почти в

каждом проекте. Как правило, первое, с чего начинается любой блок — это его

порядковый номер. Самый первый блок называется «генезисным», он

отличается от прочих тем, что не содержит ссылки на предыдущий блок по

причине отсутствия такового. Обычно в блоке есть информация о номере его

версии — это бывает необходимо, если впоследствии структура блока

претерпит изменения, и в зависимости от номера версии алгоритмы

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

блока для поддержания целостности данных всей цепочки.

Важным элементом заголовка также является время создания блока. Оно

записывается в виде числа, равного количеству секунд, прошедших с 1 января

1970 года — формат, принятый в многопользовательских и многозадачных

операционных системах, таких, например, как Unix и совместимых с ней.

Отдельно заметим, что число это достаточно велико, и через пару десятков

лет должно произойти переполнение 32-битной ячейки памяти, обычно

выделяемой для переменных, хранящих это значение в различном

программном обеспечении. В случае если разработчики этих программ не

внесут необходимые исправления, увеличив размер переменной, хранящей

значения времени до 64 бит, то 19 января 2038 года по всему миру могут

произойти массовые программные сбои. Произойдет это потому, что значения

этого числа в силу специфики построения компьютерной архитектуры при

выполнении программ будут интерпретироваться как имеющие отрицательные

значения — со всеми вытекающими из этого алгоритмическими

последствиями.

И, наконец, переходим к части заголовка, посвященной содержащимся в блоке

транзакциям. Одним из значений в заголовке является число транзакций в

блоке, а вот второе значение имеет загадочное название «корень Меркла».

Это не что иное, как совокупный хеш всех транзакций, находящихся в данном

блоке, вычисленный определенным образом. В 1979 году американский

криптограф Ральф Меркл запатентовал алгоритм вычисления

результирующего хеша для набора данных, построенных в виде двоичного

дерева:

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

транзакций изначально было нечетным и последней транзакции не хватает

пары, то в этом случае ее собственный хеш просто удваивается. На

следующем уровне «дерева» количество хешей уже вдвое меньше и их число

уже гарантированно четное. Хеши опять разбиваются по парам, эти пары

суммируются, и так далее, пока из них не останется только одно конечное

число. В итоге на вершине дерева образуется результирующий, или корневой

хеш, который и называется «корнем Меркла» и является фактически единым

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

любой из транзакций в блоке все хеши дерева Меркла сразу же пересчитаются

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

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

блока в его собственном заголовке. Будучи «подхешированным» к общим

данным заголовка и, таким образом, опосредованно включенным в заголовок

следующего блока, корень Меркла играет роль дополнительной гарантии

неизменности транзакций, ранее записанных в блокчейн.

Помимо вышеописанных параметров структуры блока, в нем могут

присутствовать элементы, связанные с непосредственным получением права

на создание блока и его защиты от возможных будущих изменений. Речь идет

о создании новых блоков в системах с доказательством работы. Но в данный

момент говорить об этом несколько преждевременно, поэтому сначала

ознакомимся со структурой транзакций и принципами ведения балансов в

блокчейн-системах.

Транзакции и балансы

Все мы привыкли иметь дело с классическими банками: открывать счета, осуществлять платежи с одного расчетного счета на другой, получать на свой

счет денежные средства. В последние пару десятилетий широкое

Перейти на страницу:

Похожие книги

Linux
Linux

Книга посвящена операционной системе Linux. Приводятся подробные сведения о ее особенностях и возможностях, идеологии файловой системы, инсталляции и основных командах, вопросах компиляции ядра, настройках и сервисах. Большое внимание уделяется организации на базе Linux различных серверов и служб: электронной почты, WWW, FTP, INN, Proxy, NTP, а также проблемам администрирования сети, обеспечения безопасной работы и другим вопросам. Описаны способы настройки под Linux рабочих станций, в т. ч. и бездисковых, установки и эксплуатации на них графических сред типа X Window, а также конфигурирование модемных соединений, принтеров и сканеров, отладка взаимодействия с Linux-машинами такой «экзотической» периферии, как карманные компьютеры, мобильные телефоны, TV-тюнеры и т. п. Рассматриваемые в книге конфигурационные файлы и структура каталогов соответствуют дистрибутиву Red Hat Linux 7.x, тем не менее, при минимальной адаптации все упоминаемые в книге пакеты устанавливаются в любом дистрибутиве Linux.Для начинающих администраторов или пользователей Linux.

Алексей Александрович Стахнов

ОС и Сети, интернет
Атака на Internet
Атака на Internet

Эта книга является одним из первых специализированных изданий, написанных отечественными авторами, которое посвящено обстоятельному анализу безопасности сети Internet. В книге предлагаются и подробно описываются механизмы реализации основных видов удаленных атак как на протоколы TCP/IP и инфраструктуру Сети, так и на многие популярные сетевые операционные системы и приложения.Особое внимание авторы уделили причинам возникновения и успеха удаленных атак, а также их классификации. Были также рассмотрены основные способы и методы защиты от удаленных атак.Издание предназначено для сетевых администраторов и пользователей Internet, администраторов безопасности, разработчиков систем защит, системных сетевых программистов, студентов и аспирантов вузов, а также для всех интересующихся вопросами нарушения и обеспечения информационной безопасности компьютерных сетей.

Дмитрий Геннадьевич Леонов , Илья Давыдович Медведовский , Павел Валентинович Семьянов

ОС и Сети, интернет / Интернет / Книги по IT
Как раскрутить и разрекламировать Web-сайт в сети Интернет
Как раскрутить и разрекламировать Web-сайт в сети Интернет

Настоящая книга заинтересует всех, кто столкнулся с вопросами подготовки, размещения в Сети и популяризации Internet ресурсов различного уровня: от домашней странички до корпоративного сайта. В ней вы найдете все, что необходимо для оптимизации Web сайтов под поисковые системы: приемы написания Web-страниц, описание множества самых популярных специализированных программ, предназначенных для подготовки сайта и его раскрутки, создания удачного HTML-кода страниц с правильными метаданными.Книга является практическим руководством для разработчиков Web сайтов и всех, занимающихся их продвижением. Автор приводит множество советов, касающихся создания и анонсирования Web страниц. Рассмотрены средства автоматизации для повышения эффективности разработки и маркетинга при создании и обслуживании сайта. Описание программных и сетевых средств, автоматизирующих процессы тестирования и отладки сайта, обеспечивающих проверку работоспособности и корректности гиперссылок, синтаксиса HTML кода и грамматики размещенного на странице текста, занимает центральное место в книге. Подробно излагаются возможности таких программ, как Linkbot Developer Edition, Domain NameChecker, Retrieve, CyberSpyder Link Test, HTML Link Validator, CSE HTML Validator, A Real Validator, MetaTag ToolKit, MetaMan, WebQA.Отдельная глава посвящена регистрации Web ресурсов в поисковых системах и каталогах. Описываются программы автоматической регистрации (WebPosition, Page Promoter, Web Регистратор), способы взаимодействия с индексирующими роботами поисковых машин, правила применения метаданных. Рассматриваются приемы и методы рекламы сайтов в Internet, указаны критерии ее эффективности.Издание рассчитано на широкий круг читателей и будет полезно как начинающим создателям Web сайтов, так и профессионалам, которые хотят научиться более качественно продвигать в Сети свой Web продукт.

Александр Петрович Загуменнов

ОС и Сети, интернет