- О базовых понятиях (hash, share, reject) в майнинге
- Почему в майнинге используются термины, взятые из криптографии?
- Что делают майнеры при проведении криптографических вычислений?
- О связи заработка майнеров с найденными в ходе вычислений решениями
- Почему идут реджекты при майнинге
- Реджекты, сложность шар, настройка сложности шар
- zomba_mine
О базовых понятиях (hash, share, reject) в майнинге
При майнинге криптовалют используются технологии, связанные с криптографией, функционированием компьютерного оборудования и каналов связи. Человеку, не занимавшемуся ранее изучением криптографии, техники связи и компьютерных технологий, сложно понять значение некоторых терминов, широко использующихся в сленге «криптовалютчиков» и майнеров.
В связи с этим стоит разобраться со значением ряда терминов, использующихся в ходе этой деятельности.
Почему в майнинге используются термины, взятые из криптографии?
Основным предназначением криптовалют является использование в качестве удобного, безопасного платежного средства, работающего в недоверенной среде без посредников.
Важность платежей такого рода неуклонно растет параллельно с цифровизацией всех сфер деятельности человеческого общества, распространением во всех уголках земного шара скоростного интернета и широкой доступностью смартфонов.
Наиболее удачной попыткой создания защищенного и удобного для использования цифрового актива стал биткоин. Он был создан в 2009 году автором, скрывающимся под псевдонимом Сатоши Накамото (или коллективом авторов, возможно, спецслужбами) был создан биткоин.
При его создании использовались существующие наработки в области криптографических вычислений, компьютерных сетей и телекоммуникации, а также были разработаны новые уникальные технологии, например, блокчейн.
Создание биткоина и других криптовалют имеет огромное значение, простирающееся не только на финансовую сферу.
Необходимость использования криптографии в криптовалютной сфере обусловлена тем, что именно эта наука занимается вопросами обеспечения конфиденциальности (защиты от посторонних), аутентификации (проверки подлинности), целостности и шифрованием информации. Обеспечение должного уровня этих составляющих является одним из главных требований к любому цифровому активу.
Майнерами, добывающими биткоины или другие криптовалюты, работающие на алгоритме консенсуса PoW, производится поиск решений, соответствующих криптографическому алгоритму, заложенному в основу функционирования блокчейна добываемой ими монеты.
Графическая иллюстрация работы, которую производят майнеры при проведении вычислений для криптовалюты биткоин:
Кроме алгоритма PoW, существуют и другие виды консенсуса, каждый из которых имеет свои преимущества и недостатки.
Преимущества и недостатки некоторых алгоритмов консенсуса (PoW, PoS, PoET. BFT, Federated BFT):
Блокчейн представляет собой глобальный реестр, содержащий информацию об отдельных блоках, из которых он состоит:
Каждый блок обязательно содержит следующую информацию: номер блока, хеш предыдущего блока и подпись, защищенную от подделки/взлома криптографическим способом (новый хеш):
Кроме того, в блоке может хранится и другая информация, например, отметки времени, одноразовый код (number used once или nonce) и т.д:
В показанном в качестве примера случае хеш выполняет функцию уникального идентификатора блока, содержащего информацию о трех транзакциях.
Пример 64-символьного хеша блока в сети биткоина:
Совокупность блоков представляет собой реестр, который хранится на большом количестве компьютеров, находящихся во множестве уголков земного шара (образуется глобально распределенный реестр, в котором хранятся одинаковые данные). Каждый блок связан с соседним криптографической подписью (хешем), поэтому изменить (подменить, исказить) информацию, хранящуюся в таком реестре невозможно без переписывания всех блоков, следующих за измененным:
Реестр данных (блокчейн) большинства криптовалют открыт, поэтому любой желающий может найти информацию о любой транзакции за все время его существования. Это обеспечивает прозрачность и необратимость проведенных транзакций.
Выполнение сложных криптографических вычислений продиктовано необходимостью обеспечить максимальный уровень безопасности в недоверенной среде, каковой является интернет.
Что делают майнеры при проведении криптографических вычислений?
Использование криптографических функций обеспечивает уникальность и защищённость от взлома полученных в результате проведения вычислений результатов.
При проведении вычислений майнерами производится математическая обработка исходных данных (их майнер получает от пула или от других узлов сети) в соответствии с заданной криптографической хеш-функцией (она задана в коде программы-майнера) — хеширование:
Обычно при майнинге поиск решений состоит в переборе разных числовых значений с проверкой на соответствие заданному условию. В качестве исходных данных обычно берется заголовок предыдущего найденного блока, данные о транзакциях, которые будут включены в блок и другая информация. Полученные в результате вычислений решения называются хешами.
Хеши уже давно используются в компьютерной сфере. Например, для создания и проверки контрольной суммы файлов, программ, архивов используется хеширование по алгоритмам MD5, SHA256 или SHA512/ SHA1 (подробнее в статье «Как проверить контрольную сумму файла и почему это нужно делать»).
- Пример использования криптографической функции для шифрования текста:
Найденные майнером хеши (решения) приводятся к виду, определенному стандартами конкретной криптовалюты, например, преобразуются в строки определенной длины. Полученный результат отправляется в сеть, где проверяется узлами на предмет соответствия заданным условиям, в том числе необходимому уровню сложности. Когда определенное число узлов подтвердит правильность блока, подписанного найденным майнером хешем, он записывается в реестр (включается в блокчейн). За это майнер получает вознаграждение, которое выплачивается за счет сгенерированных при создании блока монет.
Прохождение транзакции в сети PoW-криптовалюты требует участия майнеров и узлов сети-валидаторов:
Так как сложность проведения вычислений и связанная с этим вероятность нахождения правильного блока очень мала, при майнинге используется объединение мощностей с помощью пулов.
Пулы распределяют между множеством майнеров работу по нахождению решений, соответствующих сложности майнинга нужной криптовалюты. Майнеры производят поиск нужных хешей и отправляют их на пул. Каждая выполненная и отправленная майнерами на пул работа называется шарой (от английского share). Шара теоретически может стать новым блоком. Для этого она должна отвечать ряду требований, включая соответствие выбранному алгоритму майнинга, текущей сложности и своевременности.
О связи заработка майнеров с найденными в ходе вычислений решениями
Чем больше правильных шар находит майнер, тем больше доля его участия в работе пула, соответственно больше получаемая им часть награды от найденного блока.
Так как после нахождения майнером верного решения и его получением на пуле проходит некоторое время, случается, что share приходит на пул уже после того, как найден блок. Такое решение называют запоздалым (stale share). Хотя это и верное решение, оно уже никому не нужно. После нахождения блока в сети начинается поиск решений с другими условиями, поэтому запоздалая шара в большинстве случаев не оплачивается.
Статистика, отображающая количество найденных решений на пуле ezil при дуал-майнинг ETC+ZIL:
Для уменьшения количества таких случаев нужно уменьшать время задержек канала связи, чаще уточнять условия выполнения вычислений для майнинга (подробнее в статье «Как уменьшить количество stale shares при майнинге»).
Если по каким-либо причинам (сбои в работе компьютера, битая память, переразгон, недостатки в исходном коде майнера, неверно выбранный алгоритм и т.д.) майнер находит хеш, который не проходит проверку узлами сети (пулом), то решение отклоняется, его называют реджектом (от английского слова reject). Пулы совместного майнинга при наличии большого числа неверных решений (invalides) со стороны майнера обычно отключают с ним связь.
Отключение связи со стороны пула (zergpool) при майнинге монеты Luxcore (LUX) из-за наличия ошибок:
Наличие режектов является серьезной проблемой, которую нужно решать в самые короткие сроки, так как оборудование майнера работает, потребляет энергию, а результат даже не нулевой, а отрицательный из-за необходимости оплачивать электроэнергию, услуги связи и амортизационные расходы.
Источник
Почему идут реджекты при майнинге
Собственно хотелось обсудить наиболее вероятные и распространенные причины реджектов майнинга.
У меня опыт в майнинге небольшой, сейчас столкнулся с большим количеством реджектов и пока не пойму причин .
@okela что, чем и где майниш?
Майню лайтик в исследовательских целях на FPGA-девайсе при помощи пула litecoinpool.org.
Про FPGA не смогу подсказать, не сталкивался, но навскидку попробовать поменять пул, и по питанию FPGA проверить.
Про FPGA не смогу подсказать, не сталкивался, но навскидку попробовать поменять пул, и по питанию FPGA проверить.
Ну про пулы у меня была мысль. Кстати, а почему на разных пулах количество реджектов может отличаться ?
Про FPGA не смогу подсказать, не сталкивался, но навскидку попробовать поменять пул, и по питанию FPGA проверить.
Ну про пулы у меня была мысль. Кстати, а почему на разных пулах количество реджектов может отличаться ?
А вы посмотрите соответствует ли мощность вашего устройства минимально допустимой на пуле? Если ваше устройство не соответствует минимальным требованиям по хешрейту то пул будет вас отсекать, отсюда могут быть реджекты(это при условии что само устройство исправно)
@optimus Спасибо за информацию, не знал об этом. Щаз посмотрю на минимальные требования хешрейта.
Источник
Реджекты, сложность шар, настройка сложности шар
zomba_mine
Новичок
Многие сталкивались с большим количеством отклоненных шар на различных пулах, либо с очень редкой выдачей вашим майнером шар по сравнению с другими пулами на тех же алгоритмах, я в их числе, поэтому прежде чем уходить с пула, пару дней искал в интернете инструкции по кастомной настройке сложности шар на пулах, где это возможно, но ничего толкового не нашел, решил разобраться самостоятельно и теперь поделюсь с вами результатами.
Дано:
1) Многие пулы поддерживают функцию кастомной настройки сложности шар для каждого воркера отдельно в поле пароля, либо через подключение к различным портам пула с разной сложностью.
2)Чем ниже настройка сложности шар, тем их больше выдает ваша ферма в минуту/час/сутки. но при этом повышается количество отклоненных шар (реджектов) по многим причинам, которые здесь описывать долго и неохота.
3) Отклоненная шара-это потерянное процессорное время. Для вас это потерянное время=потерянным деньгам, т.е. если у вас 5% реджектов в сутки, значит вы потеряли 5% денег за эти сутки от заработанного.
4) Значит сложность шар нужно повышать для того чтобы реджектов стало меньше, но чем выше настроенная сложность шар, тем реже ваш майнер будет их выдавать и если вы слишком завысите сложность, то многие блоки будут вычислены пулом без вашего участия, то есть ваш майнер не успеет кинуть хотя бы 1 шару на каждый блок, поэтому вы не получите ни единой копейки с тех блоков, которые прошли мимо вас пока вы считали по нему 1-ю шару, что также равно потерянному процессорному времени=потерянным деньгам.
5) Есть и хорошие новости: если в вашем риге как минимум 4-5 GTX1060 либо RX470 или круче и больше, то у вас существует «золотой коридор» сложности, в котором ваша ферма и успевает накинуть на каждый блок свою шару и количество реджектов близко к нулю.
Как найти свой «золотой коридор» сложности:
Начинаем с самой низкой сложности и следим за реджектами (отклоненными шарами) и в майнере и на пуле. Для себя я выбрал оптимальным диапазон в 0,5-1% реджектов в сутки и потихоньку поднимал сложность до тех пор пока их столько и стало. Вначале реджектов было по 20%, удвоил сложность, снизилось до 3-5%, добавил ещё, стало 0,5% в сутки. Сейчас регулярно проверяю количество реджектов и если их меньше 0,5%-уменьшаю сложность, если больше 1%-повышаю.
Диапазон в 0,5-1% я определил для себя сам в соответствии со своей жалностью и производительностью моей фермы. Вы для своей фермы и жадности можете выбрать и другой вариант=)
ЗЫ: прошу сильно не ругать данный пост, так как писался он человеком с образованием в IT сфере на уровне бейсика =)
Источник