Установка Storjshare-daemon на Odroid XU4

В прошлой статье было рассказано как установить операционную систему Ubuntu на одноплатный компьютер Odroid XU4.

В текущей заметке будет описан процесс установки Storjshare-daemon на Odroid XU4 с ранее установленной операционной системой Ubuntu 16.04.

Первое что мы делаем, так это настраиваем часовой пояс
(!) Операция выполняется из-под пользователя root, пока не будет написано иное.

Выясняем какой часовой пояс установлен в данный момент.

# ll /etc/ | grep localtime
lrwxrwxrwx  1 root root       27 May 11 02:17 localtime -> /usr/share/zoneinfo/Etc/UTC

Удаляем символьную ссылку на файл временной зоны.

# rm -f /etc/localtime

Создаем новую символьную ссылку на нужный нам файл временной зоны.

# ln -s /usr/share/zoneinfo/Europe/Moscow /etc/localtime

Проверяем текущую дату и время.

# date
Tue Jul 25 11:29:09 MSK 2017

Так как демон storjshare-daemon будет запускаться в виртуальном окружении, и данное окружение нам не требуется глобально, придется создать отдельного пользователя, что позволит также повысить безопасность системы.

Добавляем пользователя storj. Данный пользователь по-умолчанию будет использовать bash оболочку. Параметр -m сообщает утилите useradd о необходимости создать домашний каталог пользователя в папке, который будет располагаться в /home. Имя каталогу будет присвоено по имени нового пользователя.

# useradd -m -s /bin/bash storj

Проверям что домашний каталог для нового пользователя создался.

# cd /home
# ll
total 12
drwxr-xr-x  3 iroot root  4096 Jul 24 07:46 ./
drwxr-xr-x 21 iroot root  4096 Jul 21 19:30 ../
drwxr-xr-x  2 storj storj 4096 Jul 24 07:46 storj/

Проверяем что пользователь добавился общий файл пользователей.

# cat /etc/passwd
iroot:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
sys:x:3:3:sys:/dev:/usr/sbin/nologin
...
...
dnsmasq:x:108:65534:dnsmasq,,,:/var/lib/misc:/bin/false
sshd:x:109:65534::/var/run/sshd:/usr/sbin/nologin
storj:x:1000:1000::/home/storj:/bin/bash

Проверяем что для нового пользователя также была создана группа (создается автоматически при создании пользователя)

# cat /etc/group
root:x:0:
daemon:x:1:
bin:x:2:
sys:x:3:
adm:x:4:syslog,storj
tty:x:5:
...
...
storj:x:1000:

Устанавливаем пароль для нового пользователя

# passwd storj
Enter new UNIX password:
Retype new UNIX password:
passwd: password updated successfully

Даем права для использования новым пользователем команды sudo.

root@odroid:/# adduser storj sudo
Adding user `storj' to group `sudo' ...
Adding user storj to group sudo
Done.

Теперь необходимо залогиниться через ssh под новым пользователем.

ssh storj@xxx.xxx.xxx.xxx

Устанавливаем nvm окружение.

$ wget -qO- https://raw.githubusercontent.com/creationix/nvm/v0.33.2/install.sh | bash

Выходим из консоли и запускаем снова новую консоль.

Запускаем установку

$ nvm install --lts

Снова выходим из консоли и запускаем снова новую консоль.

Устанавливаем системные обновления.

$ sudo apt-get update && sudo apt-get dist-upgrade

Устанавливаем Git и набор утилит для компиляции пакетов.

$ sudo apt-get install git python build-essential -y

После установки обновлений будет выведено следующее сообщение. Данное сообщение говорит о создании нового файла boot.ini и архивации предыдущего файла в boot.ini.old

new boot.ini Odroid XU4 Ubuntu 16.04

На экран также будет выведен процесс генерации новых файлов initramfs и initrd.

Setting up odroid-platform-5422 (20170713-12) ...
Processing triggers for initramfs-tools (0.122ubuntu8.8) ...
update-initramfs: Generating /boot/initrd.img-4.9.28-38
Processing triggers for libc-bin (2.23-0ubuntu9) ...

На этом подготовка операционной системы закончена, устанавливаем непосредственно storjshare-daemon.

$ npm install --global storjshare-daemon

Чтобы убедиться в том, что storjshare-daemon установился и работает, запустим команду

$ storjshare -V
daemon: 3.5.5, core: 6.8.0, protocol: 1.1.0

На экран будет выведена информация о версиях демона, протокола и ядра. Все работает.

Настала очередь накопителей.

Посмотрим какие накопители установлены в системе.

$ sudo fdisk -l | grep sd
Disk /dev/sdb: 931.5 GiB, 1000204886016 bytes, 1953525168 sectors
Disk /dev/sda: 931.5 GiB, 1000204886016 bytes, 1953525168 sectors

Два диска по 1 терабайту. Позднее на каждый из накопителей будет подключена нода.

Создаем раздел на диске через fdisk

$ sudo fdisk /dev/sda

Экран приветствия утилиты fdisk

Welcome to fdisk (util-linux 2.27.1).
Changes will remain in memory only, until you decide to write them.
Be careful before using the write command.

Device does not contain a recognized partition table.
Created a new DOS disklabel with disk identifier 0x82e94d28.

Получаем текущую информацию о разделах на накопителе.

Command (m for help): p
Disk /dev/sda: 931.5 GiB, 1000204886016 bytes, 1953525168 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0x82e94d28

На диске разделов не оказалось, поэтому создаем все с нуля.

Command (m for help): n
Partition type
   p   primary (0 primary, 0 extended, 4 free)
   e   extended (container for logical partitions)
Select (default p):

Using default response p.
Partition number (1-4, default 1):
First sector (2048-1953525167, default 2048):
Last sector, +sectors or +size{K,M,G,T,P} (2048-1953525167, default 1953525167):

Created a new partition 1 of type 'Linux' and of size 931.5 GiB.

После создания разделов на накопителе необходимо выбрать тип раздела.

Command (m for help): t
Selected partition 1
Partition type (type L to list all types): L

 0  Empty           24  NEC DOS         81  Minix / old Lin bf  Solaris
 1  FAT12           27  Hidden NTFS Win 82  Linux swap / So c1  DRDOS/sec (FAT-
 2  XENIX root      39  Plan 9          83  Linux           c4  DRDOS/sec (FAT-
 3  XENIX usr       3c  PartitionMagic  84  OS/2 hidden or  c6  DRDOS/sec (FAT-
 4  FAT16 <32M      40  Venix 80286     85  Linux extended  c7  Syrinx
 5  Extended        41  PPC PReP Boot   86  NTFS volume set da  Non-FS data
 6  FAT16           42  SFS             87  NTFS volume set db  CP/M / CTOS / .
 7  HPFS/NTFS/exFAT 4d  QNX4.x          88  Linux plaintext de  Dell Utility
 8  AIX             4e  QNX4.x 2nd part 8e  Linux LVM       df  BootIt
 9  AIX bootable    4f  QNX4.x 3rd part 93  Amoeba          e1  DOS access
 a  OS/2 Boot Manag 50  OnTrack DM      94  Amoeba BBT      e3  DOS R/O
 b  W95 FAT32       51  OnTrack DM6 Aux 9f  BSD/OS          e4  SpeedStor
 c  W95 FAT32 (LBA) 52  CP/M            a0  IBM Thinkpad hi ea  Rufus alignment
 e  W95 FAT16 (LBA) 53  OnTrack DM6 Aux a5  FreeBSD         eb  BeOS fs
 f  W95 Ext'd (LBA) 54  OnTrackDM6      a6  OpenBSD         ee  GPT
10  OPUS            55  EZ-Drive        a7  NeXTSTEP        ef  EFI (FAT-12/16/
11  Hidden FAT12    56  Golden Bow      a8  Darwin UFS      f0  Linux/PA-RISC b
12  Compaq diagnost 5c  Priam Edisk     a9  NetBSD          f1  SpeedStor
14  Hidden FAT16 <3 61  SpeedStor       ab  Darwin boot     f4  SpeedStor
16  Hidden FAT16    63  GNU HURD or Sys af  HFS / HFS+      f2  DOS secondary
17  Hidden HPFS/NTF 64  Novell Netware  b7  BSDI fs         fb  VMware VMFS
18  AST SmartSleep  65  Novell Netware  b8  BSDI swap       fc  VMware VMKCORE
1b  Hidden W95 FAT3 70  DiskSecure Mult bb  Boot Wizard hid fd  Linux raid auto
1c  Hidden W95 FAT3 75  PC/IX           bc  Acronis FAT32 L fe  LANstep
1e  Hidden W95 FAT1 80  Old Minix       be  Solaris boot    ff  BBT
Partition type (type L to list all types): 83
Changed type of partition 'Linux' to 'Linux'.

Проверяем что наш новый раздел создался.

Command (m for help): p
Disk /dev/sda: 931.5 GiB, 1000204886016 bytes, 1953525168 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0x82e94d28

Device     Boot Start        End    Sectors   Size Id Type
/dev/sda1        2048 1953525167 1953523120 931.5G 83 Linux

Сохраняем изменения на накопителе.

Command (m for help): w
The partition table has been altered.
Calling ioctl() to re-read partition table.
Syncing disks.

Далее, на новом разделе необходимо создать файловую систему. На данный момент я везде использую ext4.

$ sudo mkfs.ext4 /dev/sda1
mke2fs 1.42.13 (17-May-2015)
Creating filesystem with 244190390 4k blocks and 61054976 inodes
Filesystem UUID: fb0b2abd-a3ac-4401-a41a-8d9ca2b637a7
Superblock backups stored on blocks:
	32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208,
	4096000, 7962624, 11239424, 20480000, 23887872, 71663616, 78675968,
	102400000, 214990848

Allocating group tables: done
Writing inode tables: done
Creating journal (32768 blocks): done
Writing superblocks and filesystem accounting information: done

Создаем директорию для подключения накопителя.

$ mkdir /home/storj/disk1

Производим монтирование накопителя к директории.

$ sudo mount /dev/sda1 /home/storj/disk1/
[sudo] password for storj:

Производим аналогичным образом подключение второго накопителя.

Создаем папку для хранения лог файлов storjshare-daemon.

cd ~
$ mkdir storjshare-logs

Мы подошли к моменту создания ноды. Для создания ноды необходимо выполнить следуюущую команду.
storjshare create --storj 0xbFf0e37C6D2AEC703xxxxxxxxxxxxxxxxxxxxdF8 --storage /home/storj/disk1 --size 900GB --rpcaddress 91.105.xxx.151 --rpcport 4000 --maxtunnels 0 --tunnelportmin 0 --tunnelportmax 0 --logdir /home/storj/storjshare-logs/ --verbosity 3
storjshare create
  • команда на создание новой ноды
--storj 0xbFf0e37C6D2AEC703xxxxxxxxxxxxxxxxxxxxdF8
  • номер ETH ERC20 совместимого кошелька. Я использую MEW
--storage /home/storj/disk1
  • папка, которая была ранее смонтирована, и куда будут складываться размещаемые клиентами данные.
--size 900GB
  • размер выделенного нами пространства на накопителе.
--rpcaddress 91.105.xxx.151
  • внешний IP адрес ноды
--rpcport 4000
  • порт, который будет использовать нода
--maxtunnels 0
  • количество предоставляемых нодой туннелей в безвозмездное пользование другим нодам, которые используют туннели для подключение к Storj сети.
--tunnelportmin 0
  • начальный порт для туннелей (тоже ставим 0)
--tunnelportmax 0
  • конечный порт для туннелей (тоже ставим 0)
--logdir /home/storj/storjshare-logs/
  • директория для хранения лог-файлов ноды
--verbosity 3
  • уровень логирования

После запуска команды должен создаться конфигурационный файл ноды.

Чтобы убедиться, что конфигурационный файл создался, надо зайти в папку с конфигурационными файлами

cd /home/storj/.config/storjshare/configs

и посмотреть список файлов

$ ll
total 12
drwxrwxr-x 2 storj storj 4096 Jul 24 11:23 ./
drwxrwxr-x 5 storj storj 4096 Jul 24 11:08 ../
-rw-rw-r-- 1 storj storj 3197 Jul 24 11:23 c489612bc87e8c998a213e6f747e0df8fd56af9d.json

На листинге мы видим что конфигурационный файл создался.

Теперь необходимо отключить настройки NAT для ноды, так как мы используем белый статический IP адрес.

В конфигурационном файле ноды меняем настройку

"doNotTraverseNat": false,

на

"doNotTraverseNat": true,

Теперь можно запустить ноду

storjshare start --config /home/storj/.config/storjshare/configs/c489612bc87e8c998a213e6f747e0df8fd56af9d.json

Если никаких ошибок при запуске не возникнет, то нода будет запущена.

Статус ноды можно проверить командой

storjshare --status

или

storjshare-status

Вывод команды будет примерно следующего вида.

На этом установка и настройка Storjshare-daemon закончена, нода начала работать и принимать данные на хранение.

Comments: