Гайд для witness/seed ноды
Рекомендованные (минимальные) системные требования:
  • 4 Гб оперативной памяти и 70 Гб SSD накопителя
  • Linux-система, напр. Ubuntu 18.04/20.04 + стабильный интернет

Устанавливаем Docker

sudo apt-get update &&
sudo apt-get install \
ca-certificates \
curl \
gnupg \
lsb-release
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
echo \
"deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu \
$(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update &&
sudo apt-get install docker-ce docker-ce-cli containerd.io -y

Устанавливаем ноду

Скачиваем файл цепочки блоков (без него синхронизация от seed-нод занимает около 2 суток), либо полный бэкап (с ним запуск займёт менее часа). Только цепочка блоков (реплей займёт 4-8 часов):
Германия 1
Финляндия 1
Германия 2
Финляндия 2
wget -P ~/home/blockchain --user=u237308-sub1 --password=3oOk8579Ff8ceKdy https://u237308-sub1.your-storagebox.de/block_log.index https://u237308-sub1.your-storagebox.de/block_log
wget -P ~/home/blockchain --user=u245960-sub1 --password=7USy9jS9GS2Yka3c https://u245960-sub1.your-storagebox.de/block_log.index https://u245960-sub1.your-storagebox.de/block_log
wget -P ~/home/blockchain --user=u223265-sub1 --password=tXjXAmNBcu8PmmbQ https://u223265-sub1.your-storagebox.de/block_log.index https://u223265-sub1.your-storagebox.de/block_log
wget -P ~/home/blockchain --user=u233417-sub1 --password=xCbthClwoWSVGIt1 https://u233417-sub1.your-storagebox.de/block_log.index https://u233417-sub1.your-storagebox.de/block_log
Полный бэкап (реплей не требуется, менее часа):
Германия 1
Финляндия 1
Германия 2
Финляндия 2
wget -P ~/home/blockchain --user=u237308-sub1 --password=3oOk8579Ff8ceKdy https://u237308-sub1.your-storagebox.de/block_log.index https://u237308-sub1.your-storagebox.de/block_log https://u237308-sub1.your-storagebox.de/shared_memory.bin
wget -P ~/home/blockchain --user=u245960-sub1 --password=7USy9jS9GS2Yka3c https://u245960-sub1.your-storagebox.de/block_log.index https://u245960-sub1.your-storagebox.de/block_log https://u245960-sub1.your-storagebox.de/shared_memory.bin
wget -P ~/home/blockchain --user=u223265-sub1 --password=tXjXAmNBcu8PmmbQ https://u223265-sub1.your-storagebox.de/block_log.index https://u223265-sub1.your-storagebox.de/block_log https://u223265-sub1.your-storagebox.de/shared_memory.bin
wget -P ~/home/blockchain --user=u233417-sub1 --password=xCbthClwoWSVGIt1 https://u233417-sub1.your-storagebox.de/block_log.index https://u233417-sub1.your-storagebox.de/block_log https://u233417-sub1.your-storagebox.de/shared_memory.bin

Генерируем ключи

Для облегчения получения ключей, вместо запуска ноды без них, использования команды suggest_brain_key в cli-wallet для генерирования, правки конфига и перезапуска ноды, можно сразу сгенерировать их здесь, или на раз / два.
Только в Public-key (публичном ключе) заменить три начальных символа VIZ на GLS. Этот ключ нам понадобится для объявления себя делегатом позднее, а Private-key (приватный ключ) уже на следующем шаге.

Загружаем конфиг

Предварительно заменив значения witness и private-key на свои. В качестве witness запишем логин без @ от своего аккаунта на Голосе, private-key тот что сгенерировали на шаге выше.
mkdir ~/config && echo 'p2p-endpoint = 0.0.0.0:4243
webserver-thread-pool-size = 4
webserver-http-endpoint = 0.0.0.0:8090
webserver-ws-endpoint = 0.0.0.0:8091
read-wait-micro = 500000
max-read-wait-retries = 2
write-wait-micro = 500000
max-write-wait-retries = 3
single-write-thread = true
enable-plugins-on-push-transaction = false
block-num-check-free-size = 7200
plugin = chain p2p json_rpc webserver network_broadcast_api witness database_api witness_api
clear-votes-before-block = 4294967295
store-account-metadata = false
store-memo-in-savings-withdraws = false
store-comment-extras = false
skip-virtual-ops = true
enable-stale-production = false
required-participation = 33
witness = "ЛОГИН-ДЕЛЕГАТА"
private-key = ПРИВАТНЫЙ-КЛЮЧ-НОДЫ
mining-threads = 0
[log.console_appender.stderr]
stream=std_error
[log.file_appender.p2p]
filename=logs/p2p/p2p.log
[logger.default]
level=debug
appenders=stderr
[logger.p2p]
level=none
appenders=stderr' | sudo tee -a ~/config/config.ini

Использование Docker-Compose

Для тех кто разбирается, обратите внимание на этот пост.

Запускаем контейнер

sudo docker run -it \
-p 4243:4243 \
-v ~/config/config.ini:/etc/golosd/config.ini \
-v ~/home/blockchain:/var/lib/golosd/blockchain \
-v ~/wallet:/golosd \
--log-opt max-size=500m \
--name golosd golosblockchain/golos:latest
Начнётся загрузка образа ноды и реплей (наполнение файла оперативных данных shared_memory.bin из блоков), который будет продолжаться от пары часов до суток (в зависимости от производительности вашего сервера).
Можно оставить окно терминала или закрыть его, подключившись позднее и зайдя в логи ноды командой:
sudo docker logs -f --tail 50 golosd
С появлением в логах ноды подобных сообщений о получении блоков, окно терминала можно закрыть (всё в порядке).

Телеграм-бот о пропуске блоков

Для отслеживания работы делегатских нод и пропуска ими блоков можно использовать бот @golos_witness_monitor_bot

Работа с cli-wallet

Эти действия нужны лишь для первого запуска ноды.
Заходим в cli_wallet ноды.
sudo docker exec -it golosd cli_wallet \
-w /golosd/wallet.json \
-s ws://localhost:8091
Добавляем свой пароль к cli_wallet (запишите его и сохраните):
set_password 123456789
Разблокируем доступ:
unlock 123456789
Импортируем в cli_wallet наш приватный активный ключ аккаунта-делегата (ключ, который смотреть тут https://golos.id/@lex/permissions, начинается с цифры 5).
import_key 5Js............
Объявляем себя делегатом, с публичным ключом GLS (который мы сгенерировали ранее в паре к приватному ключу для конфига ноды).
Нужно заменить логин, ссылку на пост/аккаунт делегата + публичный ключ.
update_witness "ЛОГИН" "https://golos.id/@ЛОГИН" GLS............. true
Публикуем свой первый прайс-фид, заменив на свой логин-делегата.
publish_feed ЛОГИН {"quote":"1.000 GOLOS", "base":"0.500 GBG"} true
Для выхода из cli_wallet вводим команду:
quit

Публикация прайсфидов

Запускаем в докере ещё один контейнер, подробнее об этом скрипте можно прочитать здесь.
sudo docker run -it \
-e NODE=ws://localhost:8091 \
-e WITNESS=ЛОГИН-ДЕЛЕГАТА \
-e KEY=ПРИВАТНЫЙ-АКТИВНЫЙ-КЛЮЧ \
--log-opt max-size=500m \
--name feed --net=container:golosd vvk123/golos-witness-tools ./update_price_feed.py --monitor
* нужно заменить логин и приватный активный ключ аккаунта-делегата на свои
Пример скриншота после выполнения команды:
После появления логов с калькуляцией курса GBG, закрываем окно терминала.

Изменения в конфиге

Заходим в конфиг командой:
sudo nano ~/config/config.ini
Вносим нужные правки, нажимаем Ctrl+O, подтверждаем Enter, выходим Ctrl+X.
Перезапускаем контейнер ноды.
sudo docker restart golosd

Делегатские параметры

Заходим на https://golos.id/~witnesses и напротив своего делегата в столбце “Параметры” нажимаем на значок настроек (описание каждого параметра возникает при наведении мышкой).
Подробнее о значении медианных параметров. Изменить параметры можно и через cli_wallet ноды, заменив логин и выполнив команду:
16ХФ
19ХФ
22ХФ
23ХФ
24ХФ
26ХФ
update_chain_properties ЛОГИН {"account_creation_fee":"1.000 GOLOS", "maximum_block_size":65536, "sbd_interest_rate":0, "create_account_min_golos_fee":"0.100 GOLOS", "create_account_min_delegation":"1.000 GOLOS", "create_account_delegation_time":2592000, "min_delegation":"1.000 GOLOS"} true
update_chain_properties ЛОГИН {"max_referral_interest_rate":1000, "max_referral_term_sec":15552000, "min_referral_break_fee":"1.000 GOLOS", "max_referral_break_fee":"100.000 GOLOS", "posts_window":3, "posts_per_window":1, "comments_window":200, "comments_per_window":10, "votes_window":15, "votes_per_window":5, "auction_window_size":0, "max_delegated_vesting_interest_rate":8000, "custom_ops_bandwidth_multiplier":10, "min_curation_percent":7500, "max_curation_percent":7500, "curation_reward_curve":"square_root", "allow_distribute_auction_reward":true, "allow_return_auction_reward_to_fund":true} true
update_chain_properties ЛОГИН {"worker_request_creation_fee":"100.000 GBG", "worker_request_approve_min_percent":1500, "sbd_debt_convert_rate":100, "vote_regeneration_per_day":10, "witness_skipping_reset_time":21600, "witness_idleness_time":7776000, "account_idleness_time":15552000} true
update_chain_properties ЛОГИН {"claim_idleness_time":86400, "min_invite_balance":"10.000 GOLOS"} true
update_chain_properties ЛОГИН {"asset_creation_fee":"2000.000 GBG", "invite_transfer_interval_sec":60} true
update_chain_properties ЛОГИН {"worker_emission_percent":100, "vesting_of_remain_percent":8000, "convert_fee_percent":500, "min_golos_power_to_curate":"1000.000 GOLOS", "negrep_posting_window":1440, "negrep_posting_per_window":3} true

Обновление ноды

Ставим “пустой ключ” для ноды чтобы приостановить подпись блоков через параметры на странице https://golos.id/@lex/witness (заменив на свой логин). Или через cli_wallet ноды командой
update_witness "ЛОГИН" "https://golos.id" GLS1111111111111111111111111111111114T1Anm true
Останавливаем докер-контейнер ноды и удаляем его
sudo docker stop golosd && sudo docker rm golosd
Если в анонсе обновления было указано что нужен реплей, удаляем файл shared_memory.bin
sudo rm ~/home/blockchain/shared_memory.bin
Останавливаем докер-контейнер скрипта прайсфида и удаляем его
sudo docker stop feed && sudo docker rm feed
Удаляем образы для ноды и скрипта прайсфида
sudo docker rmi golosblockchain/golos && sudo docker rmi vvk123/golos-witness-tools
Запускаем контейнер с новой версией
sudo docker run -it \
-p 4243:4243 \
-v ~/config/config.ini:/etc/golosd/config.ini \
-v ~/home/blockchain:/var/lib/golosd/blockchain \
-v ~/wallet:/golosd \
--log-opt max-size=500m \
--name golosd golosblockchain/golos:latest
После появления логов вида handle_block "Got 0 transactions on block 34563842 by ...", закрываем окно терминала.
Возвращаем публичный ключ ноды GLS.............. который ранее сбрасывали через параметры на странице https://golos.id/@lex/witness или через cli_wallet, заменив в команде ниже логин, ссылку на пост/аккаунт делегата + публичный ключ на свои:
update_witness "ЛОГИН" "https://golos.id/@ЛОГИН" GLS................. true
Возвращаем докер-контейнер скрипта публикации прайсфида (заменив логин и приватный активный ключ аккаунта-делегата на свои)
sudo docker run -it \
-e NODE=ws://localhost:8091 \
-e WITNESS=ЛОГИН-ДЕЛЕГАТА \
-e KEY=ПРИВАТНЫЙ-АКТИВНЫЙ-КЛЮЧ \
--log-opt max-size=500m \
--name feed --net=container:golosd vvk123/golos-witness-tools ./update_price_feed.py --monitor
После появления логов с калькуляцией курса GBG, закрываем окно терминала.

Есть вопросы?

Можно уточнить в чате делегатов https://t.me/golos_witnesses
Copy link
On this page
Устанавливаем Docker
Устанавливаем ноду
Генерируем ключи
Загружаем конфиг
Использование Docker-Compose
Запускаем контейнер
Телеграм-бот о пропуске блоков
Работа с cli-wallet
Публикация прайсфидов
Изменения в конфиге
Делегатские параметры
Обновление ноды
Есть вопросы?