Всего за 349 руб. Купить полную версию
Тем не менее, выход есть.
Если раньше вы создавали файл первичного блока, инициализировали блокчейн и запускали майнинг, то на этом уроке мы будем использовать другой, возможно, более удобный способ создания тестовой сети. Мы создадим ее, запустив Geth с параметром dev, специально предназначенным для этого случая. Разумеется, такой способ можно применять и на обычных серверах, физических и виртуальных.
Подготовка Raspberry Pi 3 к работе
Установите в микрокомпьютер карту памяти MicroSD объемом не меньше 8 Гбайт.
После того как установка и настройка Rasberian будут завершены, монитор и клавиатуру можно будет отключить.
Хорошую инструкцию по начальной подготовке Raspberry Pi 3 к работе можно найти здесь: http://dmitrysnotes.ru/raspberry-pi-3-obzor-i-nachalo-raboty.
Установка Rasberian
Далее нужно скачать дистрибутив Raspbian с сайта https://www.raspberrypi.org/downloads/raspbian/. Для наших целей подойдет версия Raspbian Stretch Lite. Загрузите архив Zip и распакуйте его. В итоге вы получите файл с расширением имени img, например, 2018-04-18-raspbian-stretch-lite.img.
Запишите этот файл на предварительно отформатированную карту памяти MicroSD. Это можно сделать с помощью бесплатной утилиты Rufus. Загрузите ее с сайта https://rufus.akeo.ie/.
Далее установите подготовленную таким способом карту в Raspberry Pi и включите питание. Проследите процесс начальной загрузки Rasberian на мониторе.
В первый раз для подключения через консоль используйте имя пользователя pi и пароль raspberry. После подключения сразу смените пароль с помощью утилиты passwd.
Установка обновлений
Прежде всего установите обновления пакетов до актуальной версии:
sudo apt-get update
sudo apt-get upgrade
Включение доступа SSH
sudo raspi-config
Выберите в списке строку 5. Interfacing options, найдите в списке SSH и включите.
Установка статического адреса IP
sudo nano /etc/dhcpcd.conf
Уберите символы комментария # со следующих строк:
interface eth0
static ip_address=192.168.0.38/24
static ip6_address=fd51:42f8:caae:d92e::ff/64
static routers=192.168.0.1
static domain_name_servers=192.168.0.1 8.8.8.8 fd51:42f8:caae:d92e::1
Также в строке static ip_address укажите нужный адрес IP. Заметим, что этот адрес нужно исключить из DHCP соответствующей настройкой вашего роутера.
После изменения файла перезагрузите микрокомпьютер:
sudo shutdown -r now
Теперь вы можете подключиться к нему удаленно с помощью любого клиента SSH по статическому адресу. Если удаленный доступ работает, вы можете отключить клавиатуру и монитор от Raspberry Pi и продолжить работу через SSH.
Дальнейшие действия очень похожи на то, что мы делали в предыдущем уроке. Однако есть и отличия.
Установка необходимых утилит
# apt-get install vim
# apt-get install sudo
# apt-get install git
Создайте пользователя book и при помощи команды visudo добавьте этому пользователю возможность работать с командой sudo, как мы это делали на предыдущем уроке.
Установка Go
Загрузка дистрибутива Go
Подключимся к нашему микрокомпьютеру Raspberry Pi пользователем book и загрузим архив Go нужной версии:
$ curl -O https://dl.google.com/go/go1.9.6.linux-armv6l.tar.gz
Как и на предыдущем уроке, вам нужно добавить возможность работать пользователю book с командой sudo, для чего нужно воспользоваться командой visudo.
Добавьте в конец файла /etc/sudoers строку:
book ALL=(ALL) ALL
Подключитесь к консоли с правами пользователя book и распакуйте загруженный архив в каталог /usr/local:
$ sudo tar -C /usr/local -xzf go1.9.6.linux-armv6l.tar.gz
Обратите внимание, что здесь мы распаковываем файл дистрибутива для процессоров ARM.
Установка переменных окружения
$ mkdir -p ~/go; echo "export GOPATH=$HOME/go" >> ~/.bashrc
$ echo "export PATH=$PATH:$HOME/go/bin:/usr/local/go/bin" >> ~/.bashrc
$ source ~/.bashrc
Проверьте, что переменные окружения установлены:
$ printenv | grep go
GOPATH=/root/go
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/root/go/bin:/usr/local/go/bin
Проверка версии Go
$ go version
go version go1.9.6 linux/arm
Установка Geth и Swarm
Загрузите исходный код Geth из репозитория на GitHub:
$ mkdir -p $GOPATH/src/github.com/ethereum
$ cd $GOPATH/src/github.com/ethereum
$ git clone https://github.com/ethereum/go-ethereum
$ cd go-ethereum
$ git checkout master
$ go get github.com/ethereum/go-ethereum
Запустите компиляцию клиента
Geth и Swarm:
go install -v ./cmd/geth
go install -v ./cmd/swarm
Если при компиляции появились ошибки, попробуйте установить Go другой версии. Перед этим удалите все каталоги, созданные в процессе предыдущей установки.
Если же все хорошо, то осталось только проверить версию установленного Geth и Swarm:
$ geth version
Geth
Version: 1.8.9-unstable
Architecture: arm
Protocol Versions: [63 62]
Network Id: 1
Go Version: go1.9.6
Operating System: linux
GOPATH=/home/book/go
GOROOT=/usr/local/go
$ swarm version
Swarm
Version: 1.8.9-unstable
Network Id: 0
Go Version: go1.9.6
OS: linux
GOPATH=/home/book/go
GOROOT=/usr/local/go
Обратите внимание, что команда geth version сообщает о том, что она работает на процессоре с архитектурой ARM.