Сколько должно быть подтверждений в биткоин кошельке. Cколько идут биткоины на кошелек

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

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

Подтверждение биткоин-транзакции ― задача майнеров, которые создают новые блоки цепочки (размер 1 МБ) при помощи имеющихся вычислительных мощностей и получают за работу конкретное вознаграждение в 12,5 ВТС. Сумма награды ― «лакомый кусок» для пользователей сети, обеспечивающих перевод платежей и функционирование системы. Утверждение, что главное назначение майнеров состоит в добыче крипты, не совсем верно.

Как только данные об операциях «забивают» блок, звено закрывается и приобретает статус подтвержденного. Блоков нужно 6 единиц, чтобы перевод подтвердился, а денежные средства упали на счет получателя. Срок формирования blocks ― около 1 часа. На некоторых площадках отправитель вправе снизить количество проверок до 2, если речь идет о нескольких мелких переводах Биткоин. Подобная мера упростит и ускорит их подтверждение.

Почему количество подтверждений для Bitcoin транзакций равно 6? Теоретически мошенник должен обладать хотя бы 10 % сетевого хешрейта, чтобы незаконно внести изменения в блокчейн и подделать операцию. Однако потребуются миллионные долларовые инвестиции в майнинг-оборудование для получения мощнейшего хешрейта. Даже в этом случае преграда из 6 блоков ― практически невыполнимая задача. Безопасность системы повышается за счет нерентабельности указанных действий.

Награда в 12,5 ВТС доступна майнерам лишь после того, как подтвердятся 100 блоков. Пользователь может вычислить время проведения сделки (20−60 мин.), владея информацией о том, сколько нужно подтверждений для транзакций Bitcoin.

Скорость принятия зависит от других факторов, способных привести к зависанию сделки на период до 72 часов:

  1. Вес платежа. Чем больше сумма, чем выше ценится перевод. Особенно при наличии щедрой комиссии.
  2. Пропускная способность сети ограничена, что наглядно прослеживается значительной загрузке. Возникает «пробка», которая удлиняет период обработки.
  3. Комиссионный сбор. Достоверно известен следующий факт: выставляя более высокую комиссию, пользователь увеличивает шансы на быстрое проталкивание сделки.
  4. Изменчивость. Снижение/повышение курса косвенно давит на скорость подтверждения переводов Биткоин.

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

Период минимальной волатильности повышает вероятность быстрого подтверждения транзакций Биткоин. Срыв сроков подтверждения грозит следующими последствиями:

  1. Изменяется курсовая стоимость. Постоянные задержки платежей приводят к негативному отношению участников сети к Биткоину. Это может косвенным образом отразиться на колебании цены криптовалюты.
  2. Нарушаются сроки сделок. Торможение ведет к «расшатыванию» многих бизнес-процессов.
  3. Ухудшается репутация и снижается популярность Биткоина.
  4. Уменьшается объем транзакций. Пользователи начинают придерживаться иных платежных инструментов. Это наихудшим образом отражается на масштабах торгового оборота.

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

Как ускорить подтверждение транзакции Биткоин

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

Пользователи активно используют следующие методы для предотвращения задержек при отправке:

  • Централизованные сервисы типа Coinbase. Предусмотрена обязательная регистрация.

При нажатии на Sign In в верхней части экрана справа открывается форма для внесения необходимых сведений (адрес электронного ящика и придуманный/сгенерированный пароль):

На адрес указанного email придет сообщение с активной ссылкой, переход по которой завершит регистрацию бумажника Coinbase. Частные пользовательские ключи размещены на ресурсе. Проведение платежа не затрагивает цепочку блокчейн. Комиссия отсутствует, а операции проходят быстро. Минус ― отсутствует децентрализация, ведь процессом управляет конкретная площадка.

  • Мультиподпись. К примеру, кошелек GreenAddress предусматривает двухфакторную аутентификацию:

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

  • Увеличение комиссионного вознаграждения.
  • Открытые переводы. Если с транзакции снять анонимность и открыть сведения об отправителе и адресате, вероятность быстрого прогона сделки увеличится.

Если отправка денег уже состоялась, можно воспользоваться другими вариантами подтверждения транзакции Биткоин в блокчейн-бумажнике:

Способ Особенности
Специальные сервисы-ускорители Один из самых популярных ускорителей для подтверждения транзакций Биткоин ― ViaBTC. Алгоритм работы с сервисом:

1. Уточнить статус сделки через сайт-проводник (btc.com, chain.so, blockchain.com и т. д.).

2. Скопировать ID-код и перейти на страницу pool.viabtc.com/tools/txaccelerator/.

3. В форме указать ID-код и пройти капчу. Ускорить подтверждение можно платным либо безвозмездным способом. Плата значительно увеличивает шанс на скорое проталкивание платежа.

Оформление транзакции в определенный временной промежуток На некоторых сервисах лимит ограничений обновляется 1 раз в час. Многие участники сети пользуются своеобразной «фишкой»: запускают транзакцию Биткоин в последние минуты часа (к примеру, между 17:58 и 18:00). При покупке в пуле после майнингового контракта выделяется пять бесплатных ускорений.
Двойная трата Опцию поддерживают не все электронные бумажники. Доступ предоставлен в кошельках полного цикла Bitcoin Knots и . Руководство к действию:

1. Заранее закрыть бумажник.

2. Открыть командную строку и внести запись zapwalletettxes.

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

4. В разделе «Вход» найти прежнюю сделку и добавить вход с нового платежа.

CPFP Способ эффективен, когда адресат условно получил деньги (платеж не подтвержден). Комиссия оплачивается за две транзакции. Действия в бумажнике Биткоин Кор:

1. Зайти в параметры настроек.

2. В разделе «Кошелек» включить опцию контроля входов.

3. Разрешить тратить сдачу.

4. В разделе «Отправка» проставить галочку рядом с необходимой транзакцией.

5. Указать сведения о получателе и дать согласие на обработку информации.

6. Прописать пересылаемую сумму и сделать запрос на вычет комиссии.

Replace-by-Fee Функция позволяет увеличивать комиссию действующей транзакции Биткоин. Поддерживается многими бумажниками: Electrum, GreenAddress, Bitcoin Core. При проталкивании платежа в кошельке отображаются сообщения с указанием возможности изменения комиссии после занесения операции в очередь.

Транзакция долго не подтверждается

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

Во временном хранилище Memory Pool копится огромное количество приоритетных переводов с высокими комиссионными сборами, которые обходят «живую» очередь. Пользователь вынужден ждать. При зависании транзакции на срок более 72 часов происходит удаление операции из реестра записей, а деньги возвращаются отправителю.

Вконтакте

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

Тем не менее, выводить получаемые на -кошелёк монеты всё же приходится, соответственно, – приходится иметь дело и с подтверждением, которое может длиться от часа до шести-семи часов, а нередко и до целых суток.

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

Что из себя представляет система битоин-блокчейна?

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

Общедоступная информация каждой транзакции состоит из:

  • Адреса открытого -ключа – того места, откуда идёт перечисление монет.
  • Исходных данных, содержащих в себе сведения о -адресе, с которого были получены монеты btc.
  • Конкретной суммы, перечисляемой на другой счёт криптовалюты.
  • Хеш-кода транзакции, включающей в себя информацию о вознаграждении (комиссии) за процесс создания нового блока.

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

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

Многих активных пользователей системы Bitcoin интересует вполне закономерный вопрос – можно ли ускорить процесс подтверждение транзакций?

Несколько способов ускорения действительно существуют, и стоит обратить на них внимание.

1) Использование специализированных сервисов с отдельной от централизованной -системы спецификой проведения транзакций. Среди подобного рода сервисов, предлагающих практически мгновенный перевод биткоинов, можно выделить, к примеру, ooinbase.

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

Любопытно, что некоторые сервисы независимых -кошельков включают в транзакцию помимо стандартной информации о подписи и свою мультиподпись (в качестве подтверждения надёжности перевода). Так, в сервисе GreenAddress реализована функция replace-by-fee, позволяющая в том числе и ускорять процесс движения криптовалюты.


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

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

Выводы

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

Среди факторов, влияющих на приоритетность скорости передачи биткоинов, можно выделить:

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

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

Каждый элемент цепи блоков сети блокчейна хранит :

  • историю о предыдущих операциях;
  • информацию о новых транзакциях.

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

Навигация по материалу:

Что такое транзакции в сети Bitcoin

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

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

Чтобы проверить подлинность операций с криптовалютой, транзакции должны быть валидированы в блокчейн. Он представляет собой распределенную БД. Ее части хранятся на множестве компьютеров в сети Bitcoin.

Подтверждение транзакции – это ее присоединение к списку транзакций в блоке.

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

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

Если верификации перевода криптоденег не произошло, то система возвращает средства обратно на кошелек отправителя.

Время транзакции в блокчейне Bitcoin

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

Время ожидания зависит от загруженности сети блокчейна. За последние два года количество операций с биткоинами выросло более чем в 8 раз. Это видно на графике ниже:

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

Методы сокращения времени транзакции :

  • Повышение комиссии для майнеров – специалисты советуют «не жадничать» и отдавать за подтверждение от 0,0002 ВТС и более.
  • Объем переводимых средств – чем больше криптовалюты переводите, тем статус операции выше в «криптосети».
  • Использование специализированных площадок наподобие coinbase.com – на таких сервисах покупатели и продавцы сохраняют свои ключи. Благодаря этому подтверждение происходит в рамках этой платформы, а не в общей сети.

Как проверить биткоин транзакцию?

Отследить свою биткоин транзакцию можно с помощью публичных сервисов (регистрация не требуется):

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

Подтвержденные и неподтвержденные транзакции

Процесс включения транзакции в состав найденного блока называется подтверждением транзакции. Включение в 1 блок = 1 подтверждение, когда таких подтверждений набирается 6 и выше транзакция считается подтвержденной. Такая функция была введена для защиты от повторной траты одних и тех же биткоинов.

Классический Bitcoin-клиент будет отображать транзакцию как «неподтвержденную» пока не наберется 6 подтверждений (6 найденных блоков). Сайты или сервисы, которые принимают Bitcoin для оплаты своих товаров или услуг, могут ставить свои ограничения на количество блоков нужных для подтверждения транзакции.

Цифра 6 была выбрана не случайно: она основывается на теории, что вероятность того, что злоумышленник сможет накопить более 10% от хешрейта сети для подделки транзакций, мала, и что незначительный риск (менее 0,1%) является приемлемым.

Как ускоритель биткоин транзакцию?

Рассмотрим несколько способов, как использовать систему блокчейн в «скоростном режиме»:

  • Использование централизованных сервисов с отдельной системой транзакций. Существуют ресурсы, предлагающие услуги создания и использования , которые проводят транзакции цифровой валюты между своими клиентами, не задействовав экосистему блокчейна. Подобные сервисы предлагают своим клиентам мгновенные транзакции, но только в том случае, если перевод валюты происходит внутри системы. Один из таких сервисов – Coinbase. Он имеет отдельную от блокчейна систему транзакций, благодаря которой можно проводить переводы практически мгновенно.
  • Использование мультиподписи для ускорения подтверждения транзакции в системе Биткоин. Некоторые компании, такие как GreenAddress, кроме стандартной подписи транзакции, предусмотренной системой, ставят свою мультиподпись, как подтверждение надежности перевода. Система блокчейн рассматривает подобные транзакции, как надежные и они быстрее принимаются в генерируемый блок. Кроме того, использование технологии мультиподписей повышают безопасность криптовалютных транзакций.
  • Использование открытых транзакций и доверительных серверов. Суть в том, что открытая транзакция, когда присутствует вся информация об отправляющей и принимающей стороне, быстрее получает подтверждение системы путем принятия данных в генерируемый блок. Но мало кто использует открытые Биткоин-транзакции, поскольку это противоречит самой идее использования цифровой валюты, а именно – анонимности денежных переводов.

Ускорение транзации с помощью функции Opt-In Replace-by-fee

Самый простой способ заставить вашу транзакцию перепрыгнуть очередь – использование опции под названием Opt-InReplace-by-Fee (Opt-InRBF). С её помощью можно повторно отправить ту же самую транзакцию, но с более высокой комиссией.

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

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

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

В настоящее время, функцию Opt-InRBF поддерживают как минимум два кошелька: Electrum и GreenAddress. В Bitcoin Core она поддерживается при обработке транзакций, однако создавать собственные RBF транзакции возможно только с помощью сторонних скриптов. В зависимости от кошелька, может потребоваться обновление Opt-InRBF в настройках меню до отправления (первой) транзакции.

Комиссии за транзакции в сети биткоин

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

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

Какую комиссию ставить что бы транзакция не зависла — таблица!

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

Ниже приведена таблица приоритетов включения транзакции в блок. Рекомендованная комиссия спрогнозированна с учетом нагрузки сети Bitcoin для быстрого подтверждения Вашей транзакции.

Последний столбец в таблице показывает прогноз попадания платежа с комиссией за транзакцию соответствующий этой строке во временной интервал подтверждения от 0 до 25 мин.

Как проводить анонимные транзакции в сети Bitcoin?

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

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

Также будет полезно ознакомиться с (некоторые из которых до сих пор находятся в размработке).

Многие наверняка уже столкнулись с проблемой зависших битков (при отправке и получении).
В большинстве случаев, виною этому спам сети и выставление малой платы майнерам (далее комиссия).
Перед отправкой битков, я бы посоветовал вам смотреть на состояние сети и выставлять комиссию, которую рекомендуют данные сервисы:
https://btc.com/stats/unconfirmed-tx

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

Берем свой th(id) транзакции:
Пример:

И вбиваем id cюда:


Примечание!

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

Вы можете получить, такое сообщение:

Submissions are beyond limit. Please try later.

Нажмите, чтобы раскрыть...

Вам нужно вбивать до тех пор, пока не получите статус: Успешно.

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

Что делать, если ваша биткоин транзакция не подтверждается ("зависла")?

Сначала можно просто подождать. Если прошло уже несколько часов (или даже суток) и ждать надоело, то есть несколько вариантов:

  1. Cделать даблспенд . Особенности: может сделать только отправитель.
  2. Использовать CPFP . Особенности: может сделать получатель и обычно отправитель.
  3. Использовать replace-by-fee . Особенности: может только отправитель и если заранее позаботился; не все кошельки могут.
  4. Использовать "ускоритель" от viabtc . Особенности: может получатель и отправитель, но сервис часто перегружен и есть ограничения на транзакцию.
Как сделать даблспенд (двойную трату)?

Действуем по следующему алгоритму (алгоритм описан для кошелька Bitcoin Core; для других кошельков действия аналогичны, но команды будут другими):

SpoilerTarget">Спойлер: алгоритм

1) Убеждаемся, что она ждёт подтверждения. Для этого копируем id вашей транзакции, вставляем в строку поиска сервиса blockchain.info (а также bitaps.com, blocktrail.com/BTC или аналогичного). Далее ищем глазами строку "неподтвержденная транзакция" ("unconfirmed transaction"). Нашли? Значит, транзакция ждет подтверждения.
Примечание. На "Приблизительное время подтверждения" ("Estimated Confirmation Time") на странице с вашей транзакцией blockchain.info не смотрим -- там неизвестно что.

2) Теперь закрываем кошелек и запускаем его из командной строки с параметром -zapwallettxes и ждем пока он откроется. Когда кошелек запустится, все неподтвержденные транзакции из него исчезнут (но они ещё есть в сети!). Для bitcoin core 0.14 потребуется перед запуском ещё переименовать или перенести файл mempool.dat (мемпул в этой версии сохраняется в файл и старая транзакция остается там).
Примечание. Почему не с параметром -salvagewallet? -zapwallettxes не затронет имена ваших ключей, а -salvagewallet удалит их. Кроме того, bitcoin core иногда падает при запуске с -salvagewallet и тогда ваш wallet.dat будет поврежден. Правда, рядом с ним заранее будет создана копия.

3) Теперь можно создавать новую транзакцию, не забыв поставить адекватную комиссию. Но! Поскольку ваша старая транзакция ещё осталась в сети, она может когда-нибудь неожиданно подтвердиться. Если вас это не устраивает, то у новой транзакции хотя бы один из входов должен будет совпадать с одним из входов старой. Для этого смотрим на странице вашей транзакции на сайте blocktrail.com/BTC или аналоге графу "inputs", запонинаем точный размер входа в битках. После этого при создании транзакции в кошельке нажимаем на кнопку "inputs...", находим в списке такое же точно число в битках и выбираем его (если их несколько, то выбирайте с тем же адресом получения и временем). После этого выбираем ещё какие-нибудь входы, чтобы общая сумма была больше суммы транзакции с будущей комиссией; лучше выбирать с запасом. Далее заполняем все поля как обычно, (не забываем про комиссию!) и отправляем.


Как использовать CPFP? Как быть, если я не отправитель, а получатель транзакции?

Такой способ есть и он подходит для получателей; для отправителя он также подойдёт, если у вашей транзакции была "сдача" (обычно она есть). Этот способ немного дороже и сколько пулов его поддерживают - неизвестно (по состоянию на начало 2017 года как минимум два пула его поддерживают). Можно попробовать задействовать механизм CPFP (child pays for parent). Для этого вы должны потратить один из выходов проблемной транзакции с комиссией, которой хватит на обе транзакции сразу - новую и старую. То есть просто создаёте транзакцию с одним входом (это должен быть один из выходов проблемной, например - сдача) и пересылаете биткоины себе же. Комиссию ставите такую, чтобы её хватило на обе сразу: для этого суммируете их размеры, умножаете на число из пункта "Как выбрать адекватную комиссию?", делите на размер новой в килобайтах и вписываете в графу "custom transaction fee" при отправке транзакции. Подробнее для кошелька Bitcoin Core под спойлером:

SpoilerTarget">Спойлер

Пусть для примера вы получатель и должны получить 0.08500148 btc. Для того, чтобы воспользоваться CPFP, в Bitcoin Core нажимаем "Настройки" -> "Параметры" -> "Бумажник" ("Settings" -> "Options" -> "Wallet") ; ставим галочки у "включить управление входами" ("Enable coin control features") и "тратить неподтвержденную сдачу" ("Spend unconfirmed change"), если они не стоят (потом можно будет их убрать); теперь закрываем окно настроек и нажимаем "Отправить" ("Send"), там нажимаем кнопку "Входы..." ("Inputs...") и ставим галочку у суммы 0.08500148; потом "Ок", получателем ставите свой адрес; количество ставите 0.08500148 и галочку "вычесть комиссию из суммы" ("subtract fee from amount"); комиссию ставите "выборочно" ("custom"), "за килобайт" ("per kilobyte") и пишете с рассчетом на 2 транзакции по формуле ((размер старой транзакции)/(размер новой транзакции) + 1)*(адекватная комиссия за килобайт и лучше побольше). Отправляете.

Всё. Теперь ждёте. Те пулы, которые "понимают" эту схему, с радостью возьмут обе транзакции сразу. Возможно, это будет не быстро, если таких пулов мало.


Как отменить транзакцию? Может ли транзакция отмениться сама?

Если транзакция подтвердилась (включена в блок), отмениться или быть отменена она не может. Чтобы отменить неподтвержденную транзакцию, необходимо создать конкурирующую с ней транзакцию и добиться её включения в блок - смотрите пункт (2) ответа на вопрос "Что делать, если отправленная вами биткоин транзакция не подтверждается ("зависла")?". В любом случае, гарантии успеха тут нет.

Сама неподтвержденная транзакция отмениться не может - может лишь поменяться отображение в вашем кошельке. Далее смотрите ответ на вопрос "Моя транзакция висела неподтвержденной несколько дней, а затем пропала и деньги вернулись обратно. Теперь все хорошо и я могу просто отправить деньги ещё раз?".

Моя транзакция висела неподтвержденной несколько дней, а затем пропала и деньги вернулись обратно. Теперь все хорошо и я могу просто отправить деньги ещё раз?

Нет! Ваша старая транзакция ещё есть в сети и может неожиданно подтврдиться. Чтобы этого избежать, смотрите пункт (2) ответа на вопрос "Что делать, если отправленная вами биткоин транзакция не подтверждается ("зависла")?" (под спойлером). Если вы вообще передумали делать тот перевод, то можно будет сделать перевод себе самому.

Как обезопаситься от зависания транзакций?

  1. Выставлять адекватную комиссию.
  2. Включить в кошельке механизм replace-by-fee и помечать все транзакции как replaceable, если ваш кошелёк его поддерживает (вроде бы electrum поддерживает). Это позволит при возникновении проблемы легко повысить комиссию.

13.02.201717:21


Борис Оболикшто
эксперт

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

Зависшие Bitcoin-платежи: как это происходит? Фото: mmgp.ru

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

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

Скриншот 1. Чтобы пополнить счет биткоинами, нужно всего пару кликов

Пополнить счет просто: заходишь на сайт сервиса, вводишь свой номер телефона, выбираешь сумму пополнения счета и получаешь адрес для перевода BTC-шек из своего кошелька сервис-провайдеру (см. скриншот 1). Если кошелек на мобильном устройстве, то еще проще: QR-код поможет быстро передать все параметры и выполнить оплату. Обычно так все и происходит: вы наводите камеру на QR-код, кошелек формирует транзакцию и выполняет оплату. Но в тот раз что-то пошло не так… Нет-нет, читатель, нет причин волноваться - все хорошо кончилось, но не будем забегать вперед.

Итак, с точки зрения пользователя все как обычно: кошелек (это был Bitcoin Core - самый традиционный из возможных) сформировал транзакцию, отправил ее в сеть и… И ничего не произошло. Не пришло подтверждения перевода, поступающего как правило минут через пять-пятнадцать (реже - через полчаса-час). И на следующий день кошелек сообщал о статусе транзакции неутешительное: «Status: 0/unconfirmed, in memory pool» («Статус: неподтверждена, в пуле»). Как наверное знает читатель, транзакции в биткоине безотзывные, то есть нет способа их отменить, деньги перечисляемые из кошелька ушли, а к получателю не пришли. Зависли, и теперь и в кошельке их нет, и счет мобильного не пополнен.

Ситуация «зависшей» биткоин-транзакции не уникальна, даже на русском языке Google дает тысячи ссылок по запросу «зависшие биткоин транзакции» (в выдаче по запросу «Bitcoin Transaction Pending» несколько сотен тысяч позиций, обширное обсуждение зависших транзакций на русском языке ). Постараемся разобраться, что произошло, но для этого нам нужно более подробное представление о том, как происходят транзакции, чем «нажал кнопку - и ОК».

Не буду дублировать рассказ о том, как устроен биткоин (можно прочитать ), остановимся только на процессе выполнения транзакции. Ваше биткоин-приложение, запросив из какого кошелька, сколько и кому вы переводите, сформирует и отправляет в сеть запрос на транзакцию, описывающую всё перечисленное в надлежащем формате. Транзакция попадет в пул (memory pool - mempool) и будет там ожидать майнера, который поместит ее в блок. Когда блок с этой транзакцией попадет в блокчейн, перевод завершится. Как помнит читатель, блокчейн состоит не из отдельных транзакций, а из блоков, то есть наборов транзакций и удостоверяющих их данных. Блоки формируют майнеры, которые получают за это два вида вознаграждений: плату за блок (сейчас это 12,5 BTC) и комиссию за транзакции, включенные в блок.

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

Но пока вернемся к пулу - месту, где «живут» транзакции, еще не подтвержденные и не отвергнутые (подробнее ). Майнеры отбирают из пула транзакции, пытаясь сформировать из них блоки. Так как размер блока ограничен, то в блок чаще всего отбирается лишь часть транзакций из пула (сейчас, когда я пишу эти строки, в пуле почти 41 тысяча неподтвержденных транзакций, занимающих более 42 МБ - понятно, что их все не поместить в один блок). Если мы проследим судьбу типичной транзакции, то увидим фазы ее жизни (см. скриншоты 2 и 3).

Скриншот 2. Транзакция появилась в пуле

Скриншот 3. Транзакция подтверждена и появилась в блокчейне

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

  • Когда транзакция включается в блок (подтверждается);
  • Когда транзакция или один из ее источников начинает конфликтовать с другой транзакцией, уже подтвержденной (деньги источника потратили раньше, чем подошла очередь транзакции);
  • Когда транзакция обладает наименьшим приоритетом в пуле, пул достиг максимально допустимого размера и в него добавляется транзакция с более высоким приоритетом (вытеснение);
  • Когда транзакция умирает по тайм-ауту (по умолчанию через 72 часа);
  • Когда транзакция заменяется (это относительно новая возможность, мы ее обсудим позже).

Нашей транзакции не повезло: то ли рука дрогнула при отправке оплаты, то ли еще какая-то непредвиденность случилась, но в транзакции, которая ушла в пул, оказалась нулевая комиссия (fee). Здесь нужно пояснение. Формально протокол биткоин-сети не требует комиссии. Когда биткоин только появился, были возможны бесплатные транзакции (увы, не все следят за переменами, и до сих пор иногда можно услышать от неофитов, что переводы биткоин бесплатны).

Когда технология стала популярной и темп появления транзакций вырос, возникло несколько причин для появления платы за транзакцию (transaction fee). Во-первых, чтобы избавиться от спама - бессмысленных транзакций, порождаемых злоумышленниками, атакующими ресурсы сообщества, или ошибками неумелых разработчиков. Во-вторых - необходимостью ранжировать транзакции, чтобы дать возможность пользователям ускорить прохождение своих платежей. У транзакций с нулевой комиссией немного шансов попасть в блок и стать подтвержденной в наше время, когда запросов на транзакции более чем достаточно. Поэтому судьба у нашей транзакции должна была быть незавидной: умереть по таймауту или вытесниться из пула.

В зависимости от того, каким кошельком вы пользуетесь, обычная судьба «убитой» транзакции может быть различной. Например, транзакция может быть объявлена несостоявшейся, и неотправленные средства вновь появятся в кошельке. Но возможна и повторная попытка кошелька отправить транзакцию на исполнение в пул. В таком случае транзакция «возродится» в пуле и будет висеть там, периодически возобновляясь, неограниченно долго. В последнем случае ваши средства оказываются замороженными: они недоступны ни вам, ни получателю. Именно такой случай чаще всего описывают столкнувшиеся с зависшими транзакциями пользователи (см. например, заметку об экспериментах с нулевой комиссией). На первый взгляд, именно с такой ситуацией и столкнулся мой знакомый - кошелек упорно сообщает все то же: «Status: 0/unconfirmed, in memory pool».

В описанных случаях (см., в частности, ссылки выше), зависшие средства удается вернуть в кошелек, используя специальные ключи перезагрузки или перезагрузив программу с нуля (в последнем случае блокчейн загружается вновь путем запросов к сети, то есть не попавшие в него транзакции будут проигнорированы, и средства вернутся в кошелек). Процедура полной перезагрузки хлопотная и может занимать очень много времени (не шутка же - перезагрузить более 100 ГБ данных блокчейна), тем не менее, мой знакомый выполнил ее. И ничего хорошего не увидел. Даже спустя пару месяцев популярный сервис анализа блокчейна blockchain.info сообщал: «Transaction rejected by our node. Reason: Fee is too low / Not sufficient priority» («Транзакция отвергнута нашим узлом. Причина: Комиссия слишком мала / Недостаточный приоритет»). То есть, транзакцию по-прежнему видел, но выполнять ее отказывался. Печальная ситуация.

Но нам повезло! 21 января дело дошло до нашей транзакции, и она (ура!!!) выполнилась. И в описании транзакции видно, что было необычным. Рассмотрим скриншот 4.

Скриншот 4. «Наша» транзакция подтверждена!

Кроме нулевой комиссии (Fees), транзакция отличается от показанной на третьем скриншоте еще и полем «Lock Time». Этот параметр транзакции показывает, начиная с какого блока майнеры могут включать в блок транзакцию. Многие кошельки ставят 0, разрешая включать немедленно. А кошелек Bitcoin Core, по праву первооснователя считающий себя обязанным следить за безопасностью всей биткоин-сети, устанавливает в значение ближайшего генерируемого блока, что препятствует возможности злоумышленнику атаковать сеть, выстраивая из поздних транзакций конкурирующую с уже существующими блоками ветвь. Но блок 427560 оказался как раз тем редким блоком, который заполучил конкурента. Два майнера почти одновременно, с отличием менее двух секунд, сгенерировали блоки с таким номером (правильнее говорить «такой высоты» - порядковый номер блока в блокчейне называют высотой).

Блоки, которые порождали точки разветвления, отображает, например, Blockchain.info

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

С одной стороны, по мере роста интереса к технологии и числа активных кошельков, растет число запросов на транзакции, а значит и конкуренция за подтверждение транзакций (то есть, выполнение платежей). С другой стороны - ситуация улучшается потому, что новые кошельки поддерживают динамическое задание комиссии в зависимости от наполненности пула. А разработчики вводят новые возможности, в частности, возможность увеличить комиссию для уже отправленной в пул, но все никак не подтверждаемой транзакции (функция Opt-In Replace-by-fee (RBF)). Естественно, новые возможности появляются не сразу и не во всех кошельках, что заставляет пользователей следить за ситуацией, быть может, более внимательно, чем хотелось бы. Можно посоветовать, в частности, перевод относительно свежей заметки «Что делать, если «зависла» транзакция в сети Биткоина?»

Сервис поддержки пользователей мог бы стать еще одним фактором, стимулирующим распространение биткоин-платежей. Но пока спасение утопающих дело рук… Пусть не только самих утопающих, но еще и энтузиастов, подсказывающих на форумах что делать. Однако хотелось бы видеть постоянно действующие сервисы/горячие линии, пусть хотя бы на уровне объявлений на столбах: «Настрою биткоин-платежи, помогу вернуть зависшие транзакции». Понятное дело, здесь есть проблема: пока платежей немного, сервис не может быть рентабелен, пока сервиса нет - трудно рассчитывать на взрывной рост числа платежей (кстати, рост должен бы создавать и сервисы-надстройки, позволяющие выполнять клиринг платежей между участниками сервиса, снижая нагрузку на блокчейн).

Еще один вопрос касается уже не технологии, а права. Коль скоро транзакция может происходить достаточно долго, а волатильность биткоина немаленькая, то нужны правила, поскольку привычные «три банковских дня» перестают соответствовать нашим представлениям о справедливости. В примере, на котором мы рассматривали зависший платеж, средства были зачтены по курсу на момент создания транзакции. Но с момента транзакции курс биткоина вырос в полтора раза! Ок, мой заждавшийся перевода приятель был рад и этому. Но вряд ли такие риски приемлемы для массовых платежей. С трудом представляю себе и обратную ситуацию, когда пришедшая на третий день транзакция потеряла заметную часть стоимости. Возможно, ситуацию бы поправила страховка биткоин-платежей? Но и о таких услугах я не слышал.

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