Skip to content

Skyminer Skywire Installation Guide

Asgaror edited this page Mar 29, 2019 · 20 revisions

skywire logo

Skywire Installation Guide

This guide assumes that you have read and understood the readme.md, downloaded the official images and do every step exactly the way it is described. Misconduct will lead to the inability to connect and to potential reflashing. It is very important that there is no IP collision with your existing home router subnet. The default settings of the official images, as well as the router of the skyminer, are using the 192.168.0.0/24 subnet. Installation from source does not demand certain prevalent network settings.

Table of Contents

Introduction

The following guide will describe the necessary steps to install Skywire using the prepared official images on orange pi primes or other H5 boards.

For stable operation of Skywire, we suggest not deploying Skyminer to any type of public networks, including those in the café, on the campus, in the office towers etc.

When Skyminer nodes run for the first time, it takes them a while to finish the initialization process. Don’t switch them off in 5 minutes after power on, otherwise, the Micro SD cards need to be flashed again with the images.


Requirements

  • orange pi prime or similar H5 chipboard
  • etcher or similar software to flash images on sd cards
  • micro sd card adapter + sd card reader
  • laptop/computer with LAN port + LAN cable
  • Image of a Linux distribution of your choice that matches the board(s) you are using

Setup

This section covers the installation of Skywire using the prepared images or installing it from source.

**Do not forget to submit your application using the new Skywire Whitelisting System. Follow this guide if you need any help using it.

Prepared Images

Using The Prepared Images (Old UI)

The prepared images are yet to be updated and therefore come with the old user interface. The update script will be released very soon until then you are advised to install Skywire from source if you want to work with the new user interface right from the start.

First, you need to download the images, make sure to get all 8 images, each image is prepared to run on a separate orange pi prime.

  • Unzip the downloaded 'tar.gz' files, you'll end up with '.img' file.
  • Unzip one image at a time and rename them (!) to display the node they are representing. By default each images is called OrangePiH5_Prime.img and you are advised to rename them to manager.img, node1.img,node2.img ,node3.img ,node4.img ,node5.img ,node6.img ,node7.img .

Download balenaEtcher. BalenaEtcher is cross platform image flashing software that does all the hard work for you. Run balenaEtcher as administrator and select the manager image file while the Micro SD disk is inserted into your computer (you need a micro SD card reader/SD card reader + micro SD to SD card adapter) and click on ‘Flash’.

After flashing ended successfully, please eject the Micro SD and insert it into an Orange Pi Prime in Skyminer.

Note down which Orange Pi Prime runs which image, this will come in handy in case you'll encounter issues.

Repeat this procedure until all of the 8 images are flashed and inserted into the 8 Orange Pi Primes.


Once the flashing is done you have two options:

  • connect only manager and node1-6 to the skyminer router and use the 8th port for your computer/laptop
  • Use the networking guide beforehand to prepare the router for access from within your home network

This section will cover the setup choosing option 1, regardless of that, you need to make sure you don't have IP conflicts as mentioned in the beginning. Your home network needs to be different than 192.168.0.0/24*. By choosing option 1 you won't be able to view all 8 nodes in the manager, one LAN port of the skyminer router will be used for your computer/laptop to connect to it.

Plugin all previously flashed micro sd cards, connect all orange pi prime to the LAN ports of Skyminer router.

Make sure that all the switches next to Orange Pi and on the socket are OFF.

Connect the power cable, then turn on the socket switch, and wait until all the LEDs on the router go off, which indicates the finish of booting, before carrying out the next step.

Then connect Skyminer WAN port to one of the LAN ports of house router, with LEDs lighting up accordingly. Turn on the switch of the Skywire Manager node, and wait until its LAN status LED lights up on Skyminer router, before carrying out the next step. After that, turn on the switches of other nodes one by one, with a recommended interval of 15 seconds between booting any two nodes. When all the 8 LAN LEDs on Skyminer router goes on, all the nodes have booted up successfully.

Now you can unplug the Ethernet cable of a non-manager node (orange pi prime with images of node1-7) and connect your computer/laptop to the vacant port, in order to manage your nodes in the browser.


Old User Interface (UI)

Open a new browser tab and visit 192.168.0.2:8000. The Skywire manager web interface will appear:

manager_login

Login with the password 1234, you are forced to change it immediately and re-login afterwards. A successful installation should look like this:

manager_7nodes

Note: keep in mind 1 node is missing due to the fact that your laptop is connected. You are advised to follow the networking guide to fix this. In this example node1 was unplugged from the Skyminer router, node0 represents the manager node.

If you click on the 64-character key of the node, it should look like the following:

manager_node

The red rectangles mark the public key and the app key of the node app of your node.

You should verify for all nodes that they are connected to the correct discovery server. By clicking on settings you should look at this screen with a green checkmark next to it.

green_hook

Additional to that you should look for your keys on the discovery website to be sure that your uptime is being counted. Checkout this guide to get further instructions on how to stay online.

If everything looks good you can label them by their IP addresses using this method. Adding a label to the list can be accomplished by simply clicking on it and entering the label content with your keyboard.


New User Interface (UI)

This section covers the new manager UI. The prepared images right now do not include this UI since they need to be updated.

Open a new browser tab and visit 192.168.0.2:8000. The Skywire manager web interface will appear:

manager_login_new_UI

Login with the password 1234, you are forced to change it immediately and re-login afterward. A successful installation should look like this:

manager_7nodes_new_UI

Note: keep in mind 1 node is missing due to the fact that your laptop is connected. You are advised to follow the networking guide to fix this. In this example node1 was unplugged from the Skyminer router, node0 represents the manager node.

If you click on the 64-character key of the node, it should look like the following:

manager_node_new_UI

You should verify for all nodes that they are connected to the correct discovery server. By clicking on settings you should look at this screen with the following discovery server address

discovery.skycoin.net:5999-034b1cd4ebad163e457fb805b3ba43779958bba49f2c5e1e8b062482904bacdb68

discovery_new_UI

Additional to that you should look for your keys on the discovery website to be sure that your uptime is being counted. Checkout this guide to get further instructions on how to stay online.

If everything looks good you can label them by their IP addresses using this method. Adding a label to the list can be accomplished by simply clicking on it and entering the label content with your keyboard.


Installation From Source

This section assumes that you previously downloaded & flashed the Linux images (for example Armbian Ubuntu Server) on the boards and are able to connect to them via SSH. If you have troubles find the IP of the board(s) you are trying to set up, check out this guide to find its/their IP address(es).

Log in via SSH, default password is often times 1234. First, update and upgrade via

sudo apt-get update && sudo apt-get upgrade -y

Next, install the dependencies:

sudo apt-get install -y curl git mercurial make binutils gcc bzr bison libgmp3-dev screen gcc build-essential

Install Golang

Download the respective Golang (Go) version matching your CPU, the following commands are for 64-bit ARM architectures:

cd ~
curl -sS https://dl.google.com/go/go1.11.linux-arm64.tar.gz > go$1.11.linux-arm64.tar.gz
tar xvf go1.11.linux-arm64.tar.gz
rm go1.11.linux-arm64.tar.gz

then install Go, create symbolic links and create Go directories:

sudo mv go /usr/local/go
sudo ln -s /usr/local/go/bin/go /usr/local/bin/go
sudo ln -s /usr/local/go/bin/godoc /usr/local/bin/godoc
sudo ln -s /usr/local/go/bin/gofmt /usr/local/bin/gofmt
mkdir -p $HOME/go/{bin,pkg,src}

Next, setup the enviroment variables in .bashrc:

cd ~
nano .bashrc

This opens .bashrc in the nano text editor. Paste the following lines at the end of the file:

export GOROOT=/usr/local/go
export GOPATH=$HOME/go
export GOBIN=$GOPATH/bin
export PATH=$PATH:$GOBIN

Save .bashrc via ctrl+x and y and then activate your changes via:

source ~/.bashrc

Install Skywire

Download the files from the GitHub repository:

mkdir -p $GOPATH/src/github.com/skycoin
cd $GOPATH/src/github.com/skycoin
git clone https://github.com/skycoin/skywire.git

Install Skywire using the following commands:

cd $GOPATH/src/github.com/skycoin/skywire/cmd
go install -v ./...

That's it, the installation of Skywire is finished. Test your installation by running a manager and node process as described in the readme. Verification steps that your nodes are online are outlined in this guide.


Troubleshooting

Change the IP address of the images

To do this disconnect any cable going into the WAN port of the skyminer router (or DIY router) and connect your computer to a free LAN port. You need to run the pi's within a 192.168.0.0/24 subnet, otherwise, you won't be able to connect to them.

Now login to the first pi via SSH or open a terminal in the manager. If you use SSH or Putty you need to specify the IP of the pi itself and not the skyminer router!

You need to edit three files:

  • /etc/network/interfaces.d/eth0
  • /etc/resolv.conf
  • /etc/rebuild.sh

Let's say you want to start with the manager node and change its IP address. Type in a terminal: ssh [email protected] Type in your password.

The first thing we need to change is the static IP address to match a different subnet, in this example we'll change it from the 192.168.0.1/24 subnet to the 192.168.1.0/24 subnet. You can replace 192.168.1.0/24 (router IP would be 192.168.1.1) in the following section to the specific subnet you choose to operate in.

Check the existing static ip via cat /etc/network/interfaces.d/eth0 The output will look like this:

eth0_unchanged

As you can see the file contains static IP settings for all 8 images, but only one address is active since all others are commented out ('#' at beginning of the line). You need to change 3 lines.

address 192.168.0.2
gateway 192.168.0.1
dns-nameservers 192.168.0.1 8.8.8.8

to

address 192.168.1.2
gateway 192.168.1.1
dns-nameservers 192.168.1.1 8.8.8.8

Leave the rest as it is, save the changes via 'Ctrl+X' and confirm with yes.

Next, you need to edit the file resolv.conf, located in /etc. To do this, type:

nano /etc/resolv.conf

Change nameserver 192.168.0.1 to nameserver 192.168.1.1

Safe the changes via 'Ctrl+X' and confirm with yes.

The last file we need to change is the startup script rebuild.sh. Type nano /etc/rebuild.sh

For the manager the script should look like this:

cd  /usr/local/skywire/go/bin
nohup ./manager -web-dir /usr/local/skywire/go/src/github.com/skycoin/skywire/static/skywire-manager > $
sleep 3
nohup ./node -connect-manager -manager-address 192.168.1.2:5998 -manager-web 192.168.1.2:8000 -discover$
cd /

For nodes 1-7 the script should look like this:

cd  /usr/local/skywire/go/bin
#nohup ./manager -web-dir /usr/local/skywire/go/src/github.com/skycoin/skywire/static/skywire-manager > $
sleep 3
nohup ./node -connect-manager -manager-address 192.168.1.2:5998 -manager-web 192.168.1.2:8000 -discover$
cd /

Safe the changes via 'Ctrl+X' and confirm with yes.

You need to change all 8 nodes for this to work. The IP addresses of the nodes need to be pairwise distinct.

Since the router only has 8 ports and you need one for your laptop you have to change the connected pis at some point.

After you're done editing all files on all nodes please reboot the pis and the router. Then, while the pis are turned off, connect a LAN cable to the WAN port to the skyminer router (or DIY router) and set the IP to 192.168.1.1 (or whatever subnet you'd like to use and configured in the steps above). Once that is done disconnect your laptop and reboot the skyminer router again.

Proceed with starting the manager first and the other nodes within an interval of ~10 seconds. You should now be able to view the manager via these instructions as if it was running on the default settings.


Clone this wiki locally