Vana. Node (ПРИОСТАНОВЛЕНО)
Vana — это децентрализованная платформа, созданная для того, чтобы люди могли вернуть контроль над своими персональными данными. Она позволяет пользователям собирать, управлять и монетизировать свою информацию, которая раньше находилась под контролем крупных корпораций.
Платформа важна потому, что в современном цифровом мире персональные данные чаще всего используются без прямого участия или выгоды для их владельцев. Vana решает эту проблему, предлагая инструменты для управления данными и возможности получать вознаграждения за их использование третьими лицами. Это способствует созданию прозрачной и справедливой экономики данных, где каждый пользователь имеет контроль над своей информацией и может извлекать из неё пользу.
Инвесторы: Paradigm, Polychain, Coinbase Ventures и другие
Характеристики: 1CPU/8RAM/10SSD - минимальные
Арендовать сервер: Hetzner, Contabo
Операционная сеть: Ubuntu 22.04
Подготовка к установке:
- Скачиваем и устанавливаем Termius
Для Windows - тут
Для macOS - тут
- Арендуем север (рекомендую всем начинать свой путь с Hetzner - на нем лучшее соотношение цены и качества, а также зарегистрируясь по рефке вы получите 20€ на свой аккаунт, которые сможете использовать для оплаты серверов. Гайд по аренде сервера на Hetzner.
- Открываем Termius и жмём New Host
- Откроется панель для ввода данных, где нам понадобится ввести IP который предоставит нам провайдер после аренды сервера в строке "IP or Hostname"; Любое название, которое вам нравится в "Label"; в строке "Username" вводим root, в строке "Password" вводим выданный пароль:
Приступим к установке:
1. Обновление системы и установка необходимых инструментов разработки
sudo apt-get update -y && sudo apt upgrade -y
sudo apt-get install git -y
sudo apt install unzip
sudo apt install nano
sudo apt install software-properties-common -y
sudo add-apt-repository ppa:deadsnakes/ppa
sudo apt update sudo apt install python3.11 -y
python3.11 --version
sudo apt install python3-pip python3-venv curl -y
curl -sSL https://install.python-poetry.org | python3 -
export PATH="$HOME/.local/bin:$PATH"
source ~/.bashrc
poetry --version
- Если команда показывает
Poetry version x.x.x
, то всё установилось верно (вместо x.x.x покажет номер версии) - Устанавливаем Node.js и npm
curl -fsSL https://fnm.vercel.app/install | bash
source ~/.bashrc
fnm use --install-if-missing 22
node -v && npm -v
apt-get install nodejs -y
npm install -g yarn
yarn --version
2. Устанавливаем ноду:
git clone https://github.com/vana-com/vana-dlp-chatgpt.git cd vana-dlp-chatgpt
cp .env.example .env
poetry install
pip install vana
vanacli wallet create --wallet.name default --wallet.hotkey default
Вам нужно будет придумать и ввести пароль, не забудьте записать этот пароль. Также вам выдаст две мнемоник-фразы — Coldkey и Hotkey, обязательно сохраните их
Network name: Vana Moksha Testnet
RPC URL: https://rpc.moksha.vana.org
Block Explorer: https://moksha.vanascan.io
vanacli wallet export_private_key
Enter wallet name (default): жмите Enter
Enter key type [coldkey/hotkey] (coldkey): жмите Enter
Do you understand the risks? (yes/no): yes
Enter your coldkey password: введите ранее сохраненный пароль
vanacli wallet export_private_key
Enter wallet name (default): жмите Enter
Enter key type [coldkey/hotkey] (coldkey): hotkey
Do you understand the risks? (yes/no): yes
Работа с кошельком Metamask
- Повторяем все то же самое для второго приватного ключа от Hotkey
- Запрашиваем токены из крана https://faucet.vana.org
Кран даёт токены раз в сутки, поэтому после запроса на первый кошелёк, включите VPN, обновите страницу и запросите токены на второй кошелёк. Можно не подписываться на Twitter, просто нажмите на кнопку и закройте Twitter
Создание DLP
./keygen.sh
- Нас попросит ввести моникер (название), почту и срок действия ключей(по умолчанию 0, так и оставляем, поэтому просто нажмите Enter)
- Будет сгенерировано 4 ключа
Деплой смарт-контракта DLP
cd $HOME rm -rf vana-dlp-smart-contracts git clone https://github.com/Josephtran102/vana-dlp-smart-contracts cd vana-dlp-smart-contracts
npm install -g yarn yarn --version
yarn install
cp .env.example .env nano .env
DEPLOYER_PRIVATE_KEY=0x... (ваш coldkey приватный ключ)
OWNER_ADDRESS=0x... (ваш coldkey адрес кошелька)
DLP_NAME=... (ваше DLP имя (придумайте))
DLP_TOKEN_NAME=... (ваше DLP имя токена)
DLP_TOKEN_SYMBOL=... (ваш DLP токен символ)
Если на кошельке не будет тестовых токенов, то деплой выдаст ошибку. Не нужно пытаться деплоить, пока вы не убедитесь, что на Coldkey и Hotkey есть тестовые токены
npx hardhat deploy --network moksha --tags DLPDeploy
- Как и раньше, нужно сохранить вывод после деплоя, а именно DataLiquidityPoolToken и DataLiquidityPool, эти два адреса нам понадобятся при запуске валидатора.
Установка валидатора
Для этого переходим по этой ссылке, авторизуемся в своем аккаунте или создаем новый, нажимаем на кнопку "+Create new secret key", вписываете любое имя, создаем API и обязательно копируем в надежное место
cat /root/vana-dlp-chatgpt/public_key_base64.asc
- Это команда выдаст огромный набор цифр, букв и символов, весь этот огромный вывод сохраните в надежное место
- Переходим в папку vana-dlp-chatgpt
cd cd vana-dlp-chatgpt
nano .env
# The network to use, currently Vana Moksha testnet
OD_CHAIN_NETWORK=moksha
OD_CHAIN_NETWORK_ENDPOINT=https://rpc.moksha.vana.org
# Optional: OpenAI API key for additional data quality check
OPENAI_API_KEY="ВАШ_API_КЛЮЧOPENAI_API_KEY_sk-aIKhy1wmK6Vfx.............._CIJvZx7uZl2HjAA"
# Optional: Your own DLP smart contract address once deployed to the network, useful for local testing
DLP_MOKSHA_CONTRACT=ВАШ_DataLiquidityPool
# Optional: Your own DLP token contract address once deployed to the network, useful for local testing
DLP_TOKEN_MOKSHA_CONTRACT=ВАШ_DataLiquidityPoolToken
# The private key for the DLP, follow "Generate validator encryption keys" section in the README
PRIVATE_FILE_ENCRYPTION_PUBLIC_KEY_BASE64="ВАШ_ОГРОМНЫЙ_ВЫВОД"
- В этом блоке заменяем на свои значения следующие поля:
- Сохраняем последовательным нажатием Cntr+X, Y, Enter
DLP_MOKSHA_CONTRACT=0x... (DataLiquidityPool address)
DLP_TOKEN_MOKSHA_CONTRACT=0x... (DataLiquidityPoolToken address)
PRIVATE_FILE_ENCRYPTION_PUBLIC_KEY_BASE64=... (content of public_key_base64.asc)
Отправьте 10 токенов (у меня это LOCI) на свой Hotkey кошелек и на свой Coldkey кошелек (в официальной документации так и сказано)
./vanacli dlp register_validator --stake_amount 10
./vanacli dlp approve_validator --validator_address=<ВАЩ_АДРЕС_КОШЕЛЬКА_HOTKEY>
poetry run python -m chatgpt.nodes.validator
- Теперь нажимаем Ctrl+C и останавливаем валидатора
- Создаем сервисный файл, чтобы валидатор работал в фоновом режиме. Для этого ищем путь к poetry
echo $(which poetry)
- Команда для создания сервисного файла, не забудьте заменить пути к poetry, если у вас он отличается (копируйте весь блок и вставляйте в терминал)
sudo tee /etc/systemd/system/vana.service << EOF [Unit] Description=Vana Validator Service After=network.target [Service] Type=simple User=root WorkingDirectory=/root/vana-dlp-chatgpt ExecStart=/root/.local/bin/poetry run python -m chatgpt.nodes.validator Restart=on-failure RestartSec=10 Environment=PATH=/root/.local/bin:/usr/local/bin:/usr/bin:/bin:/root/vana-dlp-chatgpt/myenv/bin Environment=PYTHONPATH=/root/vana-dlp-chatgpt [Install] WantedBy=multi-user.target EOF
sudo systemctl daemon-reload && \ sudo systemctl enable vana.service && \ sudo systemctl start vana.service && \ sudo systemctl status vana.service
sudo journalctl -u vana.service -f