ПАРАЛЛЕЛЬНОЕ ВЫПОЛНЕНИЕ ТРАНЗАКЦИЙ В СЕТИ БЛОКЧЕЙНОВ Российский патент 2020 года по МПК H04L29/06 

Описание патента на изобретение RU2738826C1

Уровень техники

[0001] Системы распределенных реестров (DLS), которые также могут упоминаться как консенсусные сети и/или сети блокчейнов, позволяют участвующим объектам защищенно и неизменно сохранять данные. DLS обычно упоминаются как сети блокчейнов без ссылки на конкретные случаи использования. Примеры типов сетей блокчейнов могут включать в себя открытые сети блокчейнов, закрытые сети блокчейнов и консорциальные сети блокчейнов. Консорциальная сеть блокчейнов предусмотрена для выбранной группы объектов, которые управляют консенсусным процессом, и включает в себя уровень управления доступом.

[0002] Одна проблема, с которой сталкиваются в сетях блокчейнов, представляет собой скорость, с которой обрабатываются транзакции. Обычно узлы в сети блокчейнов последовательно обрабатывают транзакции в том порядке, в котором они отправляются. Это может приводить к низкой пропускной способности проведения транзакций и задержкам между тем, когда транзакция отправляется, и тем, когда она очищается.

[0003] Были бы предпочтительны технологии для решения этих проблем производительности транзакций в сети блокчейнов.

Раскрытие изобретения

[0004] Реализации этого изобретения включают в себя реализуемые компьютером способы параллельного выполнения транзакции в сети блокчейнов. Более конкретно, реализации данного изобретения направлены на выполнение групп транзакций, имеющих совместную зависимость, параллельно с другими группами.

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

[0006] Эти и другие реализации при необходимости могут включать в себя один или более следующих признаков:

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

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

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

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

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

[0012] В некоторых реализациях, вызов в контракт представляет собой запрос на выполнение смарт–контракта, сохраненного в блокчейне, поддерживаемом посредством сети блокчейнов.

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

[0014] Кроме того, данное изобретение предусматривает систему для реализации способов, предусмотренных в настоящем документе. Система включает в себя один или более процессоров и машиночитаемый носитель хранения данных, соединенный с одним или более процессоров, имеющий сохраненные инструкции, которые, при выполнении посредством одного или более процессоров, предписывают одному или более процессоров выполнять операции в соответствии с реализациями способов, предусмотренных в данном документе.

[0015] Следует принимать во внимание, что способы в соответствии с данным изобретением могут включать в себя любую комбинацию аспектов и признаков, описанных в данном документе. Таким образом, способы в соответствии с данным изобретением не ограничены комбинациями аспектов и признаков, конкретно описанными в данном документе, но также включают в себя любое предусмотренное сочетание аспектов и признаков.

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

Краткое описание чертежей

[0017] Фиг. 1 иллюстрирует пример окружения, которое может использоваться для реализации данного изобретения.

[0018] Фиг. 2 иллюстрирует пример концептуальной архитектуры в соответствии с реализациями данного изобретения.

[0019] Фиг. 3A иллюстрирует пример порядка выполнения для транзакций в сети блокчейнов в соответствии с реализациями данного изобретения.

[0020] Фиг. 3B иллюстрирует пример параллельного порядка выполнения для транзакций в сети блокчейнов в соответствии с реализациями данного изобретения.

[0021] Фиг. 4 иллюстрирует пример процесса, который может выполняться в соответствии с реализациями данного изобретения.

[0022] Фиг. 5 иллюстрирует примеры модулей устройства в соответствии с реализациями данного изобретения.

[0023] Аналогичные условные обозначения на различных чертежах указывают аналогичные элементы.

Осуществление изобретения

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

[0025] Для представления дополнительного контекста для реализаций данного изобретения, и как представлено выше, системы распределенных реестров (DLS), которые также могут упоминаться как консенсусные сети (например, состоящие из узлов между равноправными узлами) и сети блокчейнов, позволяют участвующим объектам защищенно и неизменно проводить транзакции и сохранять данные. Термин «блокчейн» используется в данном документе в общем для обозначения DLS независимо от конкретных вариантов использования.

[0026] Блокчейн представляет собой структуру данных, которая сохраняет транзакции таким способом, что транзакции являются неизменными и могут впоследствии верифицироваться. Блокчейн включает в себя один или более блоков. Каждый блок в блокчейне сразу связывается с предшествующим ему блоком в блокчейне посредством включения криптографического хэша предыдущего блока. Каждый блок также включает в себя временную метку, собственный криптографический хэш и одну или более транзакций. Транзакции, которые уже верифицированы посредством узлов сети блокчейнов, хэшируются и кодируются в дерево Меркла. Дерево Меркла представляет собой структуру данных, в которой данные в концевых узлах дерева хэшируются, и все хэши в каждой ветви дерева конкатенируются в корне ветви. Этот процесс продолжается вверх по дереву вплоть до корня всего дерева, которое сохраняет хэш, который представляет все данные в дереве. Хэш, подразумеваемый в качестве транзакции, сохраненной в дереве, может быстро верифицироваться посредством определения, является ли он согласованным со структурой дерева.

[0027] Исходя из того, что блокчейн представляет собой структуру данных для сохранения транзакций, сеть блокчейнов представляет собой сеть вычислительных узлов, которые управляют, обновляют и поддерживают одну или более блокчейнов. Как представлено выше, сеть блокчейнов может быть предусмотрена в виде открытой сети блокчейнов, закрытой сети блокчейнов или консорциальной сети блокчейнов. В открытой сети блокчейнов, консенсусный процесс управляется посредством узлов консенсусной сети. Например, сотни, тысячи, даже миллионы объектов могут взаимодействовать в открытой сети блокчейнов, каждый из которых управляет по меньшей мере одним узлом в открытой сети блокчейнов. Соответственно, открытая сеть блокчейнов может считаться открытой сетью относительно участвующих объектов. В некоторых примерах, большинство объектов (узлов) должны подписывать каждый блок для того, чтобы блок был достоверным и добавлялся в блокчейнблокчейн (распределенный реестр) сети блокчейнов. Примерные открытые сети блокчейнов включают в себя конкретные платежные сети между равноправными узлами, которые используют распределенный реестр, называемый «"блокчейном»". Тем не менее, как отмечено выше, термин «блокчейн» используется в общем для обозначения распределенных реестров без конкретного указания на конкретные сети блокчейнов.

[0028] В общем, консорциальная сеть блокчейнов является закрытой между участвующими объектами. В консорциальной сети блокчейнов, консенсусный процесс управляется посредством авторизованного набора узлов, причем один или более узлов управляются посредством соответствующего объекта (например, финансового учреждения, страховой компании). Например, консорциум из десяти (10) объектов (например, финансовых учреждений, страховых компаний) может управлять консорциальной сетью блокчейнов, каждый из которых управляет по меньшей мере одним узлом в консорциальной сети блокчейнов. Соответственно, консорциальная сеть блокчейнов может считаться закрытой сетью относительно участвующих объектов. В некоторых примерах, каждый объект (узел) должен подписывать каждый блок для того, чтобы блок был достоверным и добавлялся в блокчейн. В некоторых примерах по меньшей мере поднабор объектов (узлов) (например по меньшей мере 7 объектов) должен подписывать каждый блок для того, чтобы блок был достоверным и добавлялся в блокчейн.

[0029] Реализации данного изобретения могут быть реализованы в любом соответствующем типе сети блокчейнов.

[0030] Ниже более подробно описаны реализации данного изобретения в данном документе с учетом вышеизложенного контекста. Более конкретно, и как представлено выше, реализации данного изобретения направлены на выполнение групп транзакций, имеющих совместно используемую зависимость, параллельно с другими группами. Поскольку транзакции в различных группах не имеют зависимости друг от друга (например, не затрагивают одинаковые счета в сети блокчейнов), порядок, в котором транзакции в различных группах выполняются относительно друг друга, не затрагивает общее состояние сети блокчейнов. Таким образом, эти транзакции могут выполняться параллельно, что может приводить к увеличению пропускной способности проведения транзакций в сети блокчейнов.

[0031] Фиг. 1 иллюстрирует пример окружения 100, которое может использоваться для того, чтобы выполнять реализации данного изобретения. В некоторых примерах, окружение 100 обеспечивает возможность объектам участвовать в открытой сети 102 блокчейнов. Окружение 100 включает в себя вычислительные устройства 106, 108 и сеть 110. В некоторых примерах, сеть 110 включает в себя локальную вычислительную сеть (LAN), глобальную вычислительную сеть (WAN), Интернет либо комбинацию вышеозначенного и соединяет веб–узлы, пользовательские устройства (например, вычислительные устройства) и внутренние интерфейсные системы. В некоторых примерах, к сети 110 может осуществляться доступ по линии проводной и/или беспроводной связи. В некоторых примерах, сеть 110 обеспечивает связь с/в пределах открытой сети 102 блокчейнов. В общем, сеть 110 представляет одну или более сетей связи. В некоторых случаях, вычислительные устройства 106, 108 могут представлять собой узлы облачной вычислительной системы (не показана), либо вычислительное устройство 106, 108 может представлять собой отдельную облачную вычислительную систему, включающую в себя множество компьютеров, взаимно соединенных посредством сети, и функционирующую в качестве системы распределенной обработки.

[0032] В проиллюстрированном примере, вычислительные системы 106, 108 могут включать в себя любую соответствующую вычислительную систему, которая обеспечивает участие в качестве узла в открытой сети 102 блокчейнов. Примеры вычислительных устройств включают в себя, без ограничения, сервер, настольный компьютер, переносной компьютер, планшетное вычислительное устройство и смартфон. В некоторых примерах, вычислительные системы 106, 108 размещают одну или более реализуемых компьютером служб для взаимодействия с открытой сетью 102 блокчейнов. Например, вычислительная система 106 может размещать реализуемые компьютером службы первого объекта (например, участника A), к примеру, систему управления транзакциями, которую использует первый объект для того, чтобы управлять своими транзакциями с одним или более других объектов (например, других участников). Вычислительная система 108 может размещать реализуемые компьютером второго объекта (например, участника B), к примеру, систему управления транзакциями, которую использует второй объект для того, чтобы управлять своими транзакциями с одним или более других объектов (например, других участников). В примере по фиг. 1, открытая сеть 102 блокчейнов представляется как сеть с равноправными узлами узлов, и вычислительные системы 106, 108 обеспечивают узлы первого объекта и второго объекта, соответственно, которые участвуют в открытой сети 102 блокчейнов.

[0033] Фиг. 2 иллюстрирует пример концептуальной архитектуры 200 в соответствии с реализациями данного изобретения. Пример концептуальной архитектуры 200 включает в себя системы 202, 204, 206 участников, которые соответствуют участнику A, участнику B и участнику C, соответственно. Каждый участник (например, пользователь, организация) участвует в сети 212 блокчейнов, сформированной в качестве сети с равноправными узлами, включающей в себя множество узлов 214 по меньшей мере некоторые из которых неизменно записывают информацию в блокчейн 216. Хотя в сети 212 блокчейнов схематично проиллюстрирован один блокчейн 216 , в сети 212 блокчейнов поддерживается множество копий блокчейна 216, как подробнее описано в данном документе.

[0034] В проиллюстрированном примере каждая система 202, 204, 206 участников обеспечивается участником A, участником B и участником C или от их имени, соответственно, и функционирует в качестве соответствующего узла 214 в сети блокчейнов. При использовании в данном документе, узел в общем означает отдельную систему (например, компьютер, сервер), которая соединяется с сетью 212 блокчейнов и обеспечивает возможность соответствующему участнику участвовать в сети блокчейнов. В примере по фиг. 2, участник соответствует каждому узлу 214. Тем не менее, предполагается, что участник может управлять множеством узлов 214 в сети 212 блокчейнов, и/или множество участников могут совместно использовать узел 214. В некоторых примерах, системы 202, 204, 206 участников обмениваются данными с/через сеть 212 блокчейнов с использованием протокола (например, протокола защищенной передачи гипертекста (HTTPS)) и/или с использованием удаленных вызовов процедур (RPC).

[0035] Узлы 214 могут иметь различные степени участия в сети 212 блокчейнов. Например, некоторые узлы 214 могут участвовать в консенсусном процессе (например, в качестве узлов–майнеров, которые добавляют блоки в блокчейн 216), в то время как другие узлы 214 не участвуют в консенсусном процессе. В качестве другого примера, некоторые узлы 214 сохраняют полную копию блокчейна 216, в то время как другие узлы 214 сохраняют копии только частей блокчейна 216. Например, привилегии доступа к данным могут ограничивать данные блокчейнов, которые соответствующий участник сохраняет в соответствующей системе. В примере по фиг. 2, системы 202, 204, 206 участников сохраняют соответствующие полные копии 216', 216'', 216''' блокчейна 216.

[0036] Блокчейн (например, блокчейн 216 по фиг. 2) состоит из блокчейна, в котором каждый блок хранит данные. Примеры данных включают в себя данные транзакции, представляющие транзакцию между двумя или более участников. Хотя транзакции используются в данном документе в качестве неограничивающего примера, предполагается, что любые соответствующие данные могут сохраняться в блокчейне (например, документы, изображения, видео, аудио). Примеры транзакций могут включать в себя, без ограничения, обмены чем–либо, имеющим стоимость (например, активами, продуктами, услугами). Данные транзакции неизменно сохраняются в блокчейне. Таким образом, данные транзакции не могут изменяться.

[0037] До сохранения в блоке данные транзакции хэшируются. Хэширование представляет собой процесс преобразования данных транзакции (обеспечиваются в виде строковых данных) в хэш–значение фиксированной длины (также обеспечивается в виде строковых данных). Невозможно дехэшировать хэш–значение, чтобы получать данные транзакции. Хэширование гарантирует, что даже небольшое изменение данных транзакции приводит к совершенно другому хэш–значению. Дополнительно и как отмечено выше, хэш–значение имеет фиксированную длину. Таким образом, независимо от размера данных транзакции, длина хэш–значения является фиксированной. Хэширование включает в себя обработку данных транзакции через хэш–функцию, чтобы формировать хэш–значение. Примеры хэш–функции включают в себя, без ограничения, защищенный хэш–алгоритм (SHA)–256, который выводит 256–битовые хэш–значения.

[0038] Данные транзакции для множества транзакций хэшируются и сохраняются в блоке. Например, хэш–значения двух транзакций обеспечиваются и непосредственно хэшируются для обеспечения другого хэша. Этот процесс повторяется до тех пор, пока для всех транзакций, которые должны сохраняться в блоке, не будет обеспечено одно хэш–значение. Это хэш–значение упоминается как корневой хэш Меркла и сохраняется в заголовке блока. Изменение любой из транзакций должно приводить к изменению ее хэш–значения и, в конечном счете, к изменению корневого хэша Меркла.

[0039] Блоки добавляются в блокчейн через консенсусный протокол. Множество узлов в сети блокчейнов участвуют в консенсусном протоколе и конкурируют за то, чтобы добавлять блок в блокчейн. Такие узлы упоминаются как майнеры (или узлы–майнеры). POW, введенное выше, используется в качестве неограничивающего примера.

[0040] Узлы–майнеры выполняют консенсусный процесс, чтобы добавлять транзакции в блокчейн. Хотя множество узлов–майнеров участвуют в консенсусном процессе, только один узел–майнер может записывать блок в блокчейн. Таким образом, узлы–майнеры конкурируют в консенсусном процессе за то, чтобы добавлять свой блок в блокчейн. Подробнее, узел–майнер периодически собирает отложенные транзакции из пула транзакций (например, вплоть до предварительно заданного предела для числа транзакций, которые могут быть включены в блок, если таковые имеются). Пул транзакций включает в себя сообщения по транзакциям от участников сети блокчейнов. Узел–майнер конструирует блок и добавляет транзакции в блок. До добавления транзакций в блок, узел–майнер проверяет, включена ли уже какая–либо из транзакций в блок блокчейна. Если транзакция уже включена в другой блок, транзакция отбрасывается.

[0041] Узел–майнер формирует заголовок блока, хэширует все транзакции в блоке и комбинирует хэш–значение в пары, чтобы формировать дополнительные хэш–значения, до тех пор, пока одно хэш–значение не будет обеспечено для всех транзакций в блоке (корневой хэш Меркла). Этот хэш добавляется в заголовок блока. Майнер также определяет хэш–значение последнего блока в блокчейне (т.е. последнего блока, добавленного в блокчейн). Узел–майнер также добавляет значение одноразового номера и временную метку в заголовок блока. В процессе майнинга, узел–майнер пытается находить хэш–значение, которое удовлетворяет обязательным параметрам. Узел–майнер продолжает изменять значение одноразового номера до нахождения хэш–значения, которое удовлетворяет обязательным параметрам.

[0042] Каждый майнер в сети блокчейнов пытается найти хэш–значение, которое удовлетворяет обязательным параметрам, и в силу этого конкурируют друг с другом. В конечном счете один из узлов–майнеров находит хэш–значение, которое удовлетворяет обязательным параметрам, и сообщает его во все другие узлы–майнеры в сети блокчейнов. Другие узлы–майнеры верифицируют хэш–значение, и если оно определено как корректное, верифицируют каждую транзакцию в блоке, подтверждают блок и добавляют блок в свою копию блокчейна. Таким образом, глобальное состояние блокчейна является согласованным для всех узлов–майнеров в сети блокчейнов. Вышеописанный процесс представляет собой консенсусный POW–протокол.

[0043] Неограничивающий пример содержит ссылку на фиг. 2. В этом примере, участник A хочет отправлять сумму участнику B. Участник A формирует сообщение по транзакции (например, включающее в себя поля From, To и Value) и отправляет сообщение по транзакции в сеть блокчейнов, которая добавляет сообщение по транзакции в пул транзакций. Каждый узел–майнер в сети блокчейнов создает блок и принимает все транзакции из пула транзакций (например, вплоть до предварительно заданного предела для номера транзакции, который может добавляться в блок, если таковые имеются) и добавляет транзакции в блок. Таким образом, транзакция, опубликованная посредством участника A, добавляется в блоки узлов–майнеров.

[0044] В некоторых сетях блокчейнов, криптография реализуется, чтобы поддерживать конфиденциальность транзакций. Например, если два узла хотят поддерживать транзакцию закрытой таким образом, что другие узлы в сети блокчейнов не могут различать подробности транзакции, узлы могут шифровать данные транзакции. Примеры криптографических способов включают в себя, без ограничения, симметричное шифрование и асимметричное шифрование. Симметричное шифрование означает процесс шифрования, который использует один ключ для шифрования (формирования зашифрованного текста из простого текста) и дешифрования (формирования простого текста из зашифрованного текста). При симметричном шифровании, одинаковый ключ доступен для множества узлов, так что каждый узел может шифровать/дешифровать данные транзакции.

[0045] Асимметричное шифрование использует пары ключей, которые включают в себя закрытый ключ и открытый ключ, причем закрытый ключ известен только для соответствующего узла, и открытый ключ известен для всех других узлов в сети блокчейнов. Узел может использовать открытый ключ другого узла, чтобы шифровать данные, и зашифрованные данные могут дешифроваться с использованием закрытого ключа другого узла. Например, и обращаясь вновь к фиг. 2, участник A может использовать открытый ключ участника B, чтобы шифровать данные и отправлять зашифрованные данные участнику B. Участник B может использовать свой закрытый ключ для того, чтобы дешифровать зашифрованные данные (зашифрованный текст) и извлекать исходные данные (простой текст). Сообщения, зашифрованные с помощью открытого ключа узла, могут дешифроваться только с использованием закрытого ключа узла.

[0046] Асимметричное шифрование используется для обеспечения цифровых подписей, что позволяет участникам транзакции подтверждать других участников транзакции, а также достоверность транзакции. Например, узел может снабжать цифровой подписью сообщение, и другой узел может подтверждать, что сообщение отправлено посредством упомянутого узла, на основании цифровой подписи участника A. Цифровые подписи также могут использоваться для предотвращения несанкционированного изменения сообщений в процессе передачи. Например, и обращаясь вновь к фиг. 2, участник A должен отправлять сообщение участнику B. Участник A формирует хэш сообщения и затем, с использованием своего закрытого ключа, шифрует хэш для обеспечения цифровой подписи в качестве зашифрованного хэша. Участник A добавляет цифровую подпись в сообщение и отправляет сообщение с цифровой подписью участнику B. Участник B дешифрует цифровую подпись с использованием открытого ключа участника A и извлекает хэш. Участник B хэширует сообщение и сравнивает хэши. Если хэши являются идентичными, участник B может подтверждать то, что сообщение фактически исходит от участника A и не изменено несанкционированно.

[0047] Для представления дополнительного контекста для реализаций данного изобретения, фиг. 3A иллюстрирует пример порядка 300 выполнения для транзакций в сети блокчейнов в соответствии с реализациями данного изобретения. Как показано, порядок 300 выполнения включает в себя множество транзакций (305, 310, 315, 320), упорядоченных согласно порядку, в котором они должны выполняться посредством узлов сети блокчейнов. Транзакция 305a, 305b и 305c представляет собой вызовы в смарт–контракты. Помимо вызовов в смарт–контракты, порядок 300 выполнения включает в себя множество групп транзакций, совместно использующих общую зависимость (обозначаемую посредством перекрестной штриховки), такую как, например, затрагивание одинакового счета. Транзакции 310a, 310b представляют первую группу, транзакции 315a–e представляют вторую группу, и 320a–c представляют третью группу. Как описано ниже, каждая группа транзакций может выполняться параллельно посредством узлов сети блокчейнов согласно реализациям данного изобретения.

[0048] Фиг. 3B иллюстрирует пример параллельного порядка 350 выполнения для транзакций в сети блокчейнов в соответствии с реализациями данного изобретения. Как показано, в параллельном порядке 350 выполнения, группы 355, 360, 365, 370 и 375 транзакций идентифицированы. Узлы сети блокчейнов могут выполнять группы транзакций параллельно, как показано на фиг. 3B и пояснено. В некоторых случаях, все транзакции в группе совместно используют общую зависимость и в силу этого выполняются последовательно согласно исходному порядку выполнения. Это обеспечивает то, что состояние сети блокчейнов (например, баланса счетов) должно быть идентичным результату выполнения транзакций согласно параллельному порядку 350 выполнения, каким оно должно быть после выполнения транзакций согласно порядку 300 выполнения на фиг. 3A.

[0049] Рассмотрим пример, в котором счет A имеет баланс в 0$ до выполнения любой из транзакций на фиг. 3B, причем транзакция 310a представляет платеж на счет A со счета B на сумму 300$, и транзакция 310b представляет платеж со счета A на счет C в 50$. Если транзакции 310a и 310b выполняются последовательно (как первоначально описано в порядке 300 выполнения), счет A сначала должен финансироваться на 300$ и затем дебетоваться на 50$, оставляя баланс в 250$. Тем не менее, если транзакции 310a и 310b не выполняются последовательно, и транзакция 310b выполняется, то перед 310a, счет A должен иметь баланс в 0$, когда платеж транзакции 310b выполняется. Счет A имеет недостаточный баланс для того, чтобы финансировать платеж, в этом сценарии, что может приводить к отклонению транзакции 310b посредством сети блокчейнов.

[0050] На основе этого примера, рассмотрим случай, в котором транзакция 320a представляет платеж со счета D на счет E 100$. Поскольку счета, затрагиваемые посредством транзакции 320a (счета D и E), не включают в себя ни счета, затрагиваемые посредством транзакций 310a и 310b (счета A, B и C), транзакция 320a не имеет общей зависимости с транзакциями 310a и 310b. Таким образом, транзакция 320a может выполняться параллельно с транзакциями 310a и 310b.

[0051] В некоторых реализациях, транзакции, которые должны выполняться последовательно, могут группироваться. Например, как показано в фиг. 3B, транзакции 310a–b группируются в 355, транзакции 315a, 315b и 315c группируются в 360, и транзакция 320a группируется в 365. Каждая из групп 355, 360 и 365 может выполняться параллельно посредством узлов сети блокчейнов. Выполнение групп 355, 360 и 365 транзакций параллельно может приводить к увеличению пропускной способности проведения транзакций в сети блокчейнов, поскольку сеть теперь выполняет три транзакции в любой момент параллельно, вместо только одной, если все транзакции выполнены последовательно.

[0052] Фиг. 3B также включает в себя вызовы 305a–c в контракты. Вызовы в контракты представляют точку синхронизации, в которой сходится параллельное выполнение. Поскольку вызовы в контракты приводят к выполнению инструкций, составляющих смарт–контракт, может быть невозможным определять объем счетов, которые затрагивает конкретный вызов в контракт. Например, рассмотрим простой смарт–контракт, который принимает конкретный счет и сумму платежа в качестве параметров и применяет сумму платежа к конкретному счету, если некоторое условие является истинным. Поскольку вызывающая сторона этого смарт–контракта указывает конкретный счет, когда смарт–контракт вызывается, невозможно определять, из определения непосредственно смарт–контракта (т.е. его исходного кода), то, какие счета затрагивает конкретный вызов в смарт–контракт. По этой причине, в некоторых реализациях, вызов в контракт может рассматриваться в качестве транзакции с потенциалом затрагивать все счета в сети блокчейнов, которые в силу этого не могут выполняться параллельно с другими транзакциями. Таким образом, параллельный порядок 350 выполнения сходится, когда он достигает вызова в контракт. Например, как показано, группы 355, 360 и 365 выполняются параллельно до достижения вызова 305b в контракт. В этот момент, сеть блокчейнов ожидает до тех пор, пока не завершено выполнение всех транзакций в группах 355, 360 и 365, и затем продолжается с выполнением вызова 305b в смарт–контракт.

[0053] После того, как вызов 305b в контракт завершается, группы (например, 370 и 375) транзакций могут снова выполняться параллельно посредством сети блокчейнов, до тех пор, пока не встречается другой вызов (например, 305c) в смарт–контракт, причем в этот момент, параллельное выполнение снова сходится до выполнения вызова в смарт–контракт.

[0054] Фиг. 4 иллюстрирует пример процесса 400, который может выполняться в соответствии с реализациями данного изобретения. В некоторых реализациях, процесс 400 может выполняться с использованием одной или более машиноисполняемых программ, выполняемых с использованием одного или более вычислительных устройств.

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

[0056] На 404, группы транзакций идентифицируются во множестве транзакций, при этом каждая транзакция в каждой группе ассоциирована с тем же счетом в сети блокчейнов, что и другие транзакции в группе.

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

[0058] На 408, выполняется определение в отношении того, что узлы сети блокчейнов завершили выполнение всех групп транзакций. В некоторых реализациях, определение того, что узлы сети блокчейнов завершили выполнение всех групп транзакций, включает в себя определение того, что все транзакции во множестве транзакций включены в один или более блоков, сохраненных в блокчейне, поддерживаемом посредством сети блокчейнов.

[0059] В 410, в ответ на определение того, что узлы сети блокчейнов завершили выполнение всех групп транзакций, узлам сети блокчейнов предписывается выполнять вызов в контракт.

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

[0061] Фиг. 5 иллюстрирует примеры модулей устройства 500 в соответствии с реализациями данного изобретения. Устройство 500 может представлять собой примерную реализацию устройства, выполненного с возможностью обеспечения параллельного выполнения транзакций в сети блокчейнов, такой как консорциальная сеть блокчейнов. Устройство 500 может соответствовать вариантам реализации, описанным выше, и устройство 500 включает в себя следующее: первый блок идентификации или первый блок 502 идентификации для идентификации множества транзакций, которые должны выполняться в блокчейне, при этом транзакции размещаются в порядке выполнения, при этом порядок выполнения включает в себя вызов в контракт, размещаемый после множества транзакций; второй блок идентификации или второй блок 504 идентификации для идентификации групп транзакций во множестве транзакций, при этом каждая транзакция в каждой группе ассоциирована с тем же счетом в сети блокчейнов, что и другие транзакции в группе; первый блок предписания или первый блок 506 предписания для предписания узлам сети блокчейнов выполнять каждую из групп транзакций параллельно, при этом выполнение каждой группы транзакций включает в себя выполнение транзакций в группе последовательно и согласно порядку выполнения; блок определения или блок 508 определения для определения того, что узлы сети блокчейнов завершили выполнение всех групп транзакций; и второй блок предписания или второй блок 510 предписания для предписания узлам сети блокчейнов выполнять вызов в контракт в ответ на определение того, что узлы сети блокчейнов завершили выполнение всех групп транзакций.

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

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

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

[0065] Обращаясь вновь к фиг. 5, он может интерпретироваться как иллюстрирующий внутренний функциональный модуль и структуру устройства для обеспечения возможности параллельного выполнения транзакций в сети блокчейнов. Устройство для параллельного выполнения может представлять собой пример устройства, выполненного с возможностью обеспечения параллельного выполнения транзакций в сети блокчейнов.

[0066] Реализации объекта изобретения и действий и операций, описанных в данном подробном описании, могут реализовываться в цифровой электронной схеме, в реализованном на материальном носителе компьютерном программном обеспечении или микропрограммном обеспечении, в компьютерных аппаратных средствах, включающих в себя структуры, раскрытые в данном подробном описании, и их структурные эквиваленты, либо в сочетаниях одного или более из вышеупомянутого. Реализации объекта изобретения, описанного в данном подробном описании, могут быть реализованы в виде одной или более компьютерных программ, т.е. одного или более модулей компьютерных программных инструкций, кодированных в компьютерной среде передачи программ, для выполнения или управления работой устройства обработки данных. Передающая среда может представлять собой материальный постоянный компьютерный носитель хранения данных. В качестве альтернативы или дополнения, среда передачи может представлять собой искусственно сформированный распространяемый сигнал, например, сформированный аппаратными средствами электрический, оптический или электромагнитный сигнал, который формируется для кодирования информации для передачи в подходящее приемное устройство для выполнения посредством устройства обработки данных. Компьютерный носитель хранения данных может представлять собой или составлять часть машиночитаемого устройства хранения данных, машиночитаемой платы хранения данных, запоминающего устройства с произвольным или последовательным доступом либо сочетания одного или более из вышеуказанного. Компьютерный носитель хранения данных не представляет собой распространяемый сигнал.

[0067] Термин «устройство обработки данных» охватывает все виды устройств и машин для обработки данных, включающие в себя, в качестве примера, программируемый процессор, компьютер либо множество процессоров или компьютеров. Устройство обработки данных может включать в себя логическую схему специального назначения, например, FPGA (программируемую пользователем вентильную матрицу), ASIC (специализированную интегральную схему) или GPU (графический процессор). Устройство также может включать в себя, в дополнение к аппаратным средствам, код, который создает среду выполнения для компьютерных программ, например, код, который составляет микропрограммное обеспечение процессора, стек протоколов, систему управления базами данных, операционную систему либо комбинацию одного или более из означенного.

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

[0069] Компьютерная программа может, но не обязательно должна, соответствовать файлу в файловой системе. Компьютерная программа может сохраняться в части файла, который хранит другие программы или данные (например, один или более сценариев, сохраняемых в документе на языке разметки), в одном файле, выделенном для рассматриваемой программы, или во множестве координированных файлов (например, в файлах, которые сохраняют один или более модулей, подпрограмм либо частей кода).

[0070] Процессы и логические последовательности операций, поясненные в данном описании изобретения, могут выполняться посредством одного или более компьютеров, выполняющих одну или более компьютерных программ, чтобы осуществлять операции посредством обработки входных данных и формирования вывода. Процессы и логические последовательности операций также могут выполняться посредством логической схемы специального назначения, например, FPGA, ASIC или GPU, либо посредством комбинации логической схемы специального назначения и одного или более запрограммированных компьютеров.

[0071] Компьютеры, подходящие для выполнения компьютерной программы, могут быть основаны на микропроцессорах общего или специального назначения либо на том и на другом, либо на любом другом виде центрального процессора. В общем, центральный процессор принимает инструкции и данные из постоянного запоминающего устройства или оперативного запоминающего устройства, либо из того и из другого. Элементы компьютера могут включать в себя центральный процессор для выполнения инструкций и одно или более запоминающих устройств для сохранения инструкций и данных. Центральный процессор и запоминающее устройство могут дополняться или включаться в логическую схему специального назначения.

[0072] Обычно, компьютер должен соединяться по меньшей мере с одним постоянным машиночитаемым носителем данных (также называемым «машиночитаемым запоминающим устройством»). Носитель данных, соединенный с компьютером, может представлять собой внутренний компонент компьютера (например, интегрированный жесткий диск) или внешний компонент (например, жесткий диск по стандарту универсальной последовательной шины (USB) или систему хранения данных, доступную по сети). Примеры носителей данных могут включать в себя, например, магнитные, магнитооптические или оптические диски, полупроводниковые накопители, сетевые ресурсы хранения, к примеру, системы облачного хранения данных или другие типы носителей хранения данных. Тем не менее, компьютер не должен обязательно иметь такие устройства. Кроме того, компьютер может быть встроен в другое устройство, например, в мобильный телефон, карманный персональный компьютер (PDA), мобильный аудио– или видеопроигрыватель, игровую приставку, приемник на основе глобальной системы позиционирования (GPS) или портативное устройство хранения данных, например, флэш–накопитель по стандарту универсальной последовательной шины (USB), помимо прочего.

[0073] Для обеспечения взаимодействия с пользователем, реализации объекта изобретения, описанного в данном подробном описании, могут быть реализованы или конфигурированы с возможностью обмена данными с компьютером, имеющим устройство отображения, например, монитор ЖК–дисплея (жидкокристаллического дисплея), для отображения информации пользователю и устройство ввода, посредством которого пользователь может обеспечивать ввод в компьютер, например, клавиатуру и указательное устройство, например, мышь, шаровой манипулятор или сенсорную панель. Для обеспечения взаимодействия с пользователем также могут использоваться другие виды устройств; например, обратная связь, выдаваемая пользователю, может представлять собой любую форму сенсорной обратной связи, такую как визуальная обратная связь, акустическая обратная связь или тактильная обратная связь; и ввод от пользователя может приниматься в любой форме, включающей в себя акустический, речевой или тактильный ввод. Помимо этого, компьютер может взаимодействовать с пользователем посредством отправки документов и приема документов из устройства, которое используется пользователем; например, посредством отправки веб–страниц в веб–браузер на устройстве пользователя в ответ на запросы, принимаемые из веб–браузера, либо посредством взаимодействия с приложением, выполняющимся на пользовательском устройстве, например, на смартфоне или электронном планшетном компьютере. Кроме того, компьютер может взаимодействовать с пользователем посредством отправки текстовых сообщений или других форм сообщения в персональное устройство, например, в смартфон, который выполняет приложение обмена сообщениями и принимает ответные сообщения от пользователя в ответ.

[0074] В данном описании изобретения используется термин «выполнен с возможностью» в отношении систем, устройств и компьютерных программных компонентов. Для системы из одного или более компьютеров, «выполненный с возможностью» выполнения конкретных операций или действия означает, что система имеет установленное на ней программное обеспечение, микропрограммное обеспечение, аппаратные средства либо комбинацию означенного, которая при работе предписывает системе выполнять операции или действия. Для одной или более компьютерных программ, «выполненный с возможностью» с возможностью выполнять конкретные операции или действия означает то, что одна или более программ включают в себя инструкции, которые, при выполнении посредством устройства обработки данных, предписывают устройству выполнять операции или действия. Для логической схемы специального назначения, «выполненный с возможностью» с возможностью выполнения конкретных операций или действия означает, что схема имеет электронную логику, которая выполняет операции или действия.

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

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

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

Похожие патенты RU2738826C1

название год авторы номер документа
БЕЛЫЕ СПИСКИ СМАРТ-КОНТРАКТОВ 2018
  • Ся, Нин
  • Се, Гуйлу
  • Дэн, Фуси
RU2744827C2
ПАРАЛЛЕЛЬНОЕ ВЫПОЛНЕНИЕ ТРАНЗАКЦИЙ В СЕТИ ЦЕПОЧЕК БЛОКОВ НА ОСНОВЕ БЕЛЫХ СПИСКОВ СМАРТ-КОНТРАКТОВ 2018
  • Ся, Нин
  • Се, Гуйлу
  • Дэн, Фуси
RU2731417C1
УСЛУГА СМАРТ-КОНТРАКТА ВНЕ ЦЕПОЧКИ НА ОСНОВЕ ДОВЕРЕННОЙ СРЕДЫ ИСПОЛНЕНИЯ 2018
  • Сун, Сюйян
  • Янь, Ин
  • Цю, Хунлинь
  • Чжао, Божань
  • Линь, Ли
RU2729700C1
СПОСОБ УДАЛЕННОЙ ВЕРИФИКАЦИИ ДОКУМЕНТОВ 2019
  • Арзуманян Григорий Рачикович
RU2707700C1
ПЛАТФОРМА "ФУНКЦИЯ-КАК-УСЛУГА" (FaaS) В БЛОКЧЕЙН СЕТЯХ 2018
  • Шао, Кайлай
  • Лу, Сюймин
RU2744322C2
СПОСОБ ВЫПОЛНЕНИЯ ЗАДАЧИ В КОМПЬЮТЕРНОЙ СИСТЕМЕ 2019
  • Сингатуллин Рафик Равильевич
  • Шелестов Денис Робертович
RU2741279C2
ОТОБРАЖЕНИЕ ФИЗИЧЕСКИХ ОБЪЕКТОВ НА СТРУКТУРУ БЛОКЧЕЙНА 2018
  • Ради, Макс Адель
RU2786646C2
СПОСОБ И СИСТЕМА АВТОРИЗАЦИИ ВЕБ-САЙТА В ВЕБ-БРАУЗЕРЕ 2018
  • Кортунов Антон Сергеевич
  • Заитов Эльдар Тимурович
RU2718480C2
Система децентрализованного цифрового расчетного сервиса 2018
  • Ефремов Александр Васильевич
RU2679532C1
СПОСОБ И УСТРОЙСТВО СВЕРКИ ТРАНЗАКЦИЙ В БЛОКЧЕЙНЕ И ЭЛЕКТРОННОЕ УСТРОЙСТВО 2019
  • Ху, Даньцин
  • Линь, Сэнь
  • Чжан,Цзюньлян
RU2747449C2

Иллюстрации к изобретению RU 2 738 826 C1

Реферат патента 2020 года ПАРАЛЛЕЛЬНОЕ ВЫПОЛНЕНИЕ ТРАНЗАКЦИЙ В СЕТИ БЛОКЧЕЙНОВ

Заявленное изобретение относится к системам распределительных реестров, позволяющим участвующим объектам защищенно и неизменно сохранять данные. Реализации данного изобретения включают в себя идентификацию множества транзакций, которые должны выполняться в блокчейне, при этом транзакции размещены в порядке выполнения, при этом порядок выполнения включает в себя вызов в контракт, размещенный после множества транзакций; идентификацию группы транзакций во множестве транзакций, при этом каждая транзакция в каждой группе ассоциирована с тем же счетом в сети блокчейнов, что и другие транзакции в группе; предписание узлам сети блокчейнов выполнять каждую из групп транзакций параллельно, при этом выполнение каждой группы транзакций включает в себя выполнение транзакций в группе последовательно и согласно порядку выполнения; определение, что узлы сети блокчейнов завершили выполнение всех групп транзакций; и, в ответ, предписание узлам сети блокчейнов выполнять вызов в контракт. Изобретение обеспечивает повышение скорости исполнения той или иной процедуры сети блокчейна. 3 н. и 3 з.п. ф-лы, 6 ил.

Формула изобретения RU 2 738 826 C1

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

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

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

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

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

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

- определяют, что узлы сети блокчейнов завершили выполнение первого вызова в контракт;

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

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

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

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

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

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

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

– один или более компьютеров; и

– одно или более машиночитаемых запоминающих устройств, соединенных с одним или более компьютерами и имеющих сохраненные на нём инструкции, которые выполняются посредством одного или более компьютеров для выполнения способа по любому из пп. 1-4.

Документы, цитированные в отчете о поиске Патент 2020 года RU2738826C1

CN 108846659 A, 20.11.2018
CN 108269072 A, 10.07.2018
CN 109064171A, 21.12.2018
КОНТЕКСТ УСТОЙЧИВОЙ АВТОРИЗАЦИИ НА ОСНОВЕ ВНЕШНЕЙ АУТЕНТИФИКАЦИИ 2008
  • Мауэрс Дэвид Р.
  • Дубровкин Дэниэл
  • Лейбэн Рой
  • Шмидт Дональд И.
  • Висванатан Рэм
  • Брезак Джон И.
  • Уорд Ричард Б.
RU2390838C2

RU 2 738 826 C1

Авторы

Ся, Нин

Се, Гуйлу

Дэн, Фуси

Даты

2020-12-17Публикация

2018-12-28Подача