Advertisement
Guest User

Untitled

a guest
Apr 25th, 2018
61
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 37.31 KB | None | 0 0
  1. # Raspberry Pi 3 B/B+ Vertcoin Full Node Installation Guide for Windows
  2.  
  3. `*`
  4. ###### anything marked with an asterisk is an optional step
  5.  
  6. add merged mining with unitus
  7.  
  8. https://github.com/unitusdev/unitus/releases
  9. https://cdn.discordapp.com/attachments/370500771168518155/415547042807676929/Merged-Mining_Guide.pdf
  10.  
  11.  
  12. ##
  13.  
  14. #### Why a Vertcoin Full node?
  15. >Vertcoin is a digital currency supported by a peer-to-peer network. In order to run efficiently and effectively, it needs peers run by different people... and the more the better. [1]
  16.  
  17. >This tutorial will describe how to create a Vertcoin “full node” (a Vertcoin server that contains the full blockchain and propagates transactions throughout the Vertcoin network via peers). This system will not mine for Vertcoins... it will play its part to keep the Vertcoin peer-to-peer network healthy and strong. For a detailed explanation for why it is important to have a healthy Vertcoin peer-to-peer network, read this [article](https://medium.com/@lopp/bitcoin-nodes-how-many-is-enough-9b8e8f6fd2cf) about Bitcoin full nodes. [2]
  18.  
  19. >Also please note this will be a “headless” server... meaning we will not be using a GUI to configure Vertcoin or check to see how things are running. In fact, once the server is set up, you will only interact with it using command line calls over SSH. The idea is to have this full node be simple, low-power, and something that “just runs” in your basement, closet, etc.
  20.  
  21. #### Why a Raspberry Pi?
  22. >Raspberry Pi is an inexpensive computing hardware platform that generates little heat, draws little power, and can run silently 24 hours a day without having to think about it. [1]
  23.  
  24. ## Table of Contents
  25. 1. `Parts List`
  26. 2. `* OPTIONAL: Download and sync Vertcoin Core`
  27. 3. `Format USB Flash Drive`
  28. 4. `Install Raspbian Stretch Lite`
  29. 5. `Copy Blockchain to USB Flash Drive`
  30. 6. `Setup Raspberry Pi`
  31. 7. `Setup USB Flash Drive and Auto-Mount`
  32. 8. `Create vertcoin.conf and soft link to USB Flash Drive`
  33. 9. `Configure firewall to allow Vertcoin Core traffic`
  34. 10. `* OPTIONAL: Setup Unitus Full Node for merged mining with p2pool-vtc`
  35. 11. `* OPTIONAL: Setup p2pool-vtc`
  36.  
  37.  
  38. ##
  39.  
  40.  
  41.  
  42.  
  43. ### 1.) Parts List
  44.  
  45. | Parts | Price | Link |
  46. |--------------------------------------------------------------|------------|---------------------------------------------------------------------------------|
  47. | CanaKit Raspberry Pi 3 B+ | $49.99 USD | https://www.amazon.com/CanaKit-Raspberry-Power-Supply-Listed/dp/B07BC6WH7V/ |
  48. | Samsung 32GB 95MB/s (U1) MicroSD EVO Select Memory Card | $12.99 USD | https://www.amazon.com/Samsung-MicroSD-Adapter-MB-ME32GA-AM/dp/B06XWN9Q99/ |
  49. | SanDisk Ultra Fit 128GB USB 3.0 Flash Drive | $27.49 USD | https://www.amazon.com/SanDisk-Ultra-128GB-Flash-Drive/dp/B01BGTG2A0/ |
  50. | Transcend USB 3.0 SDHC / SDXC / microSDHC / SDXC Card Reader | $9.23 USD | https://www.amazon.com/Transcend-microSDHC-Reader-TS-RDF5K-Black/dp/B009D79VH4/ |
  51. | *OPTIONAL: Zebra Black Ice Case for Raspberry Pi by C4Labs | $14.95 USD | https://www.amazon.com/Zebra-Black-Case-Raspberry-C4labs/dp/B00M6G9YBM/ |
  52.  
  53.  
  54. You may change the USB Flash Drive to match your preference. I highly recommend that a USB Flash Drive (16GB - 128GB) or an External Hard Drive is paired with the Raspberry Pi.
  55.  
  56. The case in the parts list is a personal preference, it is your choice how you wish to protect your Raspberry Pi. The Zebra Black Ice case was chosen for its cut out on the bottom of the case, allowing for the placement of a heatsink on the RAM of the Raspberry Pi.
  57.  
  58.  
  59.  
  60. ## 2.) `* OPTIONAL:` Download and sync Vertcoin Core
  61.  
  62. This step is optional but recommended. [Download](https://github.com/vertcoin-project/vertcoin-core/releases) the latest stable release of Vertcoin Core and launch `vertcoin-qt.exe` to begin the syncing process. I use my desktop PC to sync the blockchain first because it has better specs than a $35 Raspberry Pi. The PC will sync headers, download blocks and verify blocks faster than the Raspberry Pi can.
  63.  
  64. We will use this copy of the blockchain that is syncing to side-load onto our Raspberry Pi later.
  65.  
  66. `Vertcoin Core Download Link: https://github.com/vertcoin-project/vertcoin-core/releases`
  67. `Default Windows Directory (Vertcoin): C:\Users\%USER%\AppData\Roaming\Vertcoin`
  68.  
  69.  
  70.  
  71.  
  72. ## 3.) Format USB Flash Drive
  73.  
  74. >The Vertcoin blockchain is about 4GB today (4/23/2018) which means that a 16GB USB Flash Drive will have more than enough space to store everything we need, but you can easily future proof with a 128GB USB Flash Drive.
  75.  
  76. Insert the USB Flash Drive into your Windows PC. Then access the drive with Windows Explorer `Win+E`, right click on the removable drive you wish to format and `Format...`
  77.  
  78. Format the USB Flash Drive to an `NTFS` File system.
  79.  
  80. This USB Flash Drive will contain our Vertcoin data directory as well as our swap space file. We will give the Raspberry Pi some extra memory to work with we will ensure a swap file large enough to handle the memory demand to bootstrap the blockchain.
  81.  
  82. It is worth mentioning that constantly writing data to the MicroSD card can be damaging, in this guide we will configure the swap file to reside off of the card.
  83.  
  84.  
  85.  
  86. ## 4.) Install Raspbian Stretch Lite
  87.  
  88. I recommend downloading the latest stable version of [Raspbian Stretch Lite](https://www.raspberrypi.org/downloads/raspbian/).
  89.  
  90. We will utilize the software 'Win32 Disk Imager' to format and install Raspbian on the MicroSD card. Please follow the [guide](https://www.raspberrypi.org/documentation/installation/installing-images/windows.md) below for details on installing the Rasbian image to the MicroSD card.
  91.  
  92.  
  93. `Raspberry Pi - Installing Operating System Images Using Windows: https://www.raspberrypi.org/documentation/installation/installing-images/windows.md`
  94.  
  95. Once Win32 Disk Imager is finished writing to the MicroSD card please access the 'boot' partition of the MicroSD card with Windows Explorer `Win+E`. Create a new empty text file named `ssh` like so...
  96.  
  97. ![MicroSD card - ssh](https://i.imgur.com/m14rGdV.png)
  98. This enables SSH access on the Raspberry Pi's first boot sequence. Please safely remove the USB Card Reader / MicroSD card as to ensure the data is not corrupted.
  99.  
  100. ##### Links
  101. `Raspian Download Link: https://www.raspberrypi.org/downloads/raspbian/`
  102. `Win32 Disk Imager Documentation: https://www.raspberrypi.org/documentation/installation/installing-images/windows.md`
  103.  
  104.  
  105. ## 5.) Copy Blockchain to USB Flash Drive
  106. Once Vertcoin Core is finished syncing the blockchain please navigate to the data directory for Vertcoin.
  107.  
  108. `Default Windows Directory (Vertcoin): C:\Users\%USER%\AppData\Roaming\Vertcoin`
  109.  
  110. Create a new folder named `vertcoin` on your USB Flash Drive that was formatted as an `NTFS` file system earlier and copy the folders `blocks` and `chainstate` to the `vertcoin` folder on your USB Flash Drive. This will allow us to side-load the Vertcoin blockchain and bootstrap faster than if we had the Raspberry Pi do all the work.
  111.  
  112. ## 6.) Setup Raspberry Pi
  113.  
  114. Please insert the MicroSD card that was safely removed into the slot located on the bottom of the Raspberry Pi. Connect an Ethernet cable to the Raspberry Pi that has internet access. When you are ready to power on the Pi, plug the power supply in and the Raspberry Pi will immediately begin to boot.
  115.  
  116. We will access our Raspberry Pi through an SSH session on our Windows PC. I like to use `Git Bash` which is included in the Windows [download](https://git-scm.com/downloads) of `Git`.
  117.  
  118. `Git download link: https://git-scm.com/downloads`
  119.  
  120. Open a web browser page and navigate to your router page and identify the `IP` address of the freshly powered on Raspberry Pi. In my case the `IP` address is `192.168.1.2`, please make note of your Raspberry Pi's `IP` address as we will need to use it to login via `SSH`.
  121.  
  122. \# Open `Git Bash` and ...
  123. `~ $ ssh 192.168.1.2 -l pi`
  124. `default password: raspberry`
  125.  
  126. \# Download and install latest system updates
  127. `pi@raspberrypi:~ $ sudo apt-get update ; sudo apt-get upgrade -y`
  128.  
  129.  
  130. \# Remove orphaned packages and clean `apt`
  131. `pi@raspberrypi:~ $ sudo apt-get autoremove ; sudo apt-get autoclean`
  132.  
  133.  
  134. \# Initiate `raspi-config` script
  135. `pi@raspberrypi:~ $ sudo raspi-config`
  136.  
  137. ```
  138. 1.) [8] Update # update raspi-config script first
  139. 2.) [1] Change User Password # change password for current user
  140. 3.) [4] Localization Options #
  141. > [I2] Change Timezone # set your timezone
  142. 4.) [7] Advanced Options #
  143. > [A1] Expand Filesystem # expand filesystem
  144. ```
  145. `<Finish>` and choose to reboot.
  146.  
  147. \# Wait a minute, then log back in via `SSH`
  148. `ssh 192.168.1.2 -l pi`
  149.  
  150. \# Download and install useful software packages
  151. `pi@raspberrypi:~ $ sudo apt-get install git ntfs-3g`
  152.  
  153. \# Install bitcoin dependencies
  154. `pi@raspberrypi:~ $ sudo apt-get install build-essential libtool autotools-dev automake pkg-config libssl-dev libevent-dev bsdmainutils`
  155.  
  156. ##
  157.  
  158. \# `* OPTIONAL:` Disable Wireless and Bluetooth
  159. `pi@raspberrypi:~ $ cd /etc/modprobe.d/`
  160.  
  161. \# Create our blacklist file
  162. `pi@raspberrypi:/etc/modprobe.d $ sudo nano raspi-blacklist.conf`
  163.  
  164. ```
  165. # disable wireless
  166. blacklist brcmfmac
  167. blacklist brcmutil
  168.  
  169. # disable bluetooth
  170. blacklist btbcm
  171. blacklist hci_uart
  172. ```
  173. `ctrl+x` to save
  174.  
  175. \# Reboot Raspberry Pi for changes to take effect
  176. `pi@raspberrypi:/etc/modprobe.d $ sudo reboot`
  177.  
  178. \# Wait a minute, then log back in via `SSH`
  179. `ssh 192.168.1.2 -l pi`
  180. ##
  181.  
  182. \# Download latest stable version of vertcoin-core for `ARM` architecture to Raspberry Pi
  183. `pi@raspberrypi:~ $ wget https://github.com/vertcoin-project/vertcoin-core/releases/download/0.12.0/vertcoin-v0.12.0-linux-arm.zip`
  184.  
  185. \# Unzip `vertcoin-v0.12.0-linux-arm.zip`
  186. ```
  187. pi@raspberrypi:~ $ unzip vertcoin-v0.12.0-linux-arm.zip
  188. Archive: vertcoin-v0.12.0-linux-arm.zip
  189. inflating: vertcoin-cli
  190. inflating: vertcoind
  191. inflating: vertcoin-tx
  192. ```
  193. \# Remove `vertcoin-v0.12.0-linux-arm.zip`
  194. `pi@raspberrypi:~ $ rm *.zip`
  195.  
  196. \# Move `vertcoin-cli`, `vertcoind`, `vertcoin-tx` to `/usr/bin/`
  197. `pi@raspberrypi:~ $ sudo mv vertcoin* /usr/bin/`
  198.  
  199.  
  200.  
  201. ## 7.) Setup USB Flash Drive and Auto-Mount
  202.  
  203. Please insert the USB Flash Drive that contains the folders `blocks` and `chainstate` into the Raspberry Pi. We will mount the USB Flash Drive to the Raspberry Pi and configure the device to auto-mount on reboot ensuring the blockchain stays accessible to the Vertcoin daemon after reboot.
  204.  
  205. \# Find your USB Flash Drive
  206. ```
  207. pi@raspberrypi:~ $ sudo blkid
  208. /dev/mmcblk0p1: LABEL="boot" UUID="5DB0-971B" TYPE="vfat" PARTUUID="efbdd15e-01"
  209. /dev/mmcblk0p2: LABEL="rootfs" UUID="060b57a8-62bd-4d48-a471-0d28466d1fbb" TYPE="ext4" PARTUUID="efbdd15e-02"
  210. /dev/mmcblk0: PTUUID="efbdd15e" PTTYPE="dos"
  211. /dev/sda1: UUID="0DC965316518EB7C" TYPE="ntfs" PARTUUID="00e3d476-01"
  212. ```
  213. My USB device appears as `/dev/sda1` which shows a filesystem type of `NTFS`, your device may be listed differently. Please take note of the `/dev/*` information that identifies your USB Flash Drive.
  214.  
  215. \# Make sure a mount point exists for the USB Flash Drive
  216. ```
  217. pi@raspberrypi:~ $ sudo mkdir /mnt
  218. mkdir: cannot create directory ‘/mnt’: File exists
  219. ```
  220. \# Give `/mnt` privileges
  221. `pi@raspberrypi:~ $ sudo chmod 755 /mnt`
  222.  
  223. \# Mount USB Flash Drive to mount point
  224. `pi@raspberrypi:~ $ sudo mount /dev/sda1 /mnt`
  225.  
  226. \# Confirm USB Flash Drive was successfully mounted to `/mnt`
  227. ```
  228. pi@raspberrypi:~ $ ls /mnt/vertcoin/
  229. blocks chainstate
  230. ```
  231. \# Setup `fstab` file to auto-mount the USB Flash Drive on reboot
  232. `pi@raspberrypi:~ $ sudo nano /etc/fstab`
  233. ```
  234. proc /proc proc defaults 0 0
  235. PARTUUID=efbdd15e-01 /boot vfat defaults 0 2
  236. PARTUUID=efbdd15e-02 / ext4 defaults,noatime 0 1
  237.  
  238. # replace /dev/sda1 with your USB device, [tab] between each value
  239. /dev/sda1 /mnt ntfs defaults 0 0
  240.  
  241. # a swapfile is not a swap partition, no line here
  242. # use dphys-swapfile swap[on|off] for that
  243. ```
  244. `ctrl+x` to save
  245.  
  246. \# Reboot to confirm auto-mount is successful
  247. `pi@raspberrypi:~ $ sudo reboot `
  248.  
  249. \# Wait a minute, then log back in via `SSH`
  250. `ssh 192.168.1.2 -l pi`
  251.  
  252. \# Confirm USB Flash Drive auto-mounted
  253. ```
  254. pi@raspberrypi:~ $ ls /mnt/vertcoin
  255. blocks chainstate
  256. ```
  257.  
  258. ## 8.) Create `vertcoin.conf` and soft link to USB Flash Drive
  259.  
  260. \# Change directory to `/mnt/vertcoin`
  261. `pi@raspberrypi:~ $ cd /mnt/vertcoin`
  262.  
  263. \# Create `vertcoin.conf` for Vertcoin Core
  264. `pi@raspberrypi:/mnt/vertcoin $ sudo nano vertcoin.conf`
  265. ```
  266. server=1
  267. rpcuser=node
  268. rpcpassword=yoursecurepasswordgoeshere
  269.  
  270. # makes client run in background
  271. daemon=1
  272.  
  273. # https://jlopp.github.io/bitcoin-core-config-generator/ lopp.net optimizations
  274. dbcache=100
  275. maxorphantx=10
  276. maxmempool=50
  277. maxconnections=40
  278. maxuploadtarget=5000
  279. ```
  280. `ctrl+x` to save
  281.  
  282. ##
  283. `* OPTIONAL:` A quick and easy way to generate a random password is taking the `md5sum` of a file
  284. ```
  285. pi@raspberrypi:/mnt/vertcoin $ touch randomfilename
  286. pi@raspberrypi:/mnt/vertcoin $ md5sum randomfilename
  287. d41d8cd98f00b204e9800998ecf8427e randomfilename
  288.  
  289. # Clean up
  290. pi@raspberrypi:~/.vertcoin $ rm randomfilename
  291. ```
  292. ##
  293.  
  294. \# Change directory back home
  295. ```
  296. pi@raspberrypi:/mnt/vertcoin $ cd
  297. pi@raspberrypi:~ $ pwd
  298. /home/pi
  299. ```
  300. \# Create soft link (symbolic link) connecting `/mnt/vertcoin/` <---> `/home/pi/.vertcoin`
  301. `pi@raspberrypi:~ $ sudo ln -s /mnt/vertcoin/ /home/pi/.vertcoin`
  302.  
  303. \# List all files in home
  304. ```
  305. pi@raspberrypi:~ $ ls -a
  306. . .. .bash_history .bash_logout .bashrc .config .profile .vertcoin .wget-hsts
  307. ```
  308. \# List files in `/home/pi/.vertcoin`, confirm blockchain and `vertcoin.conf` is there
  309. ```
  310. pi@raspberrypi:~ $ ls .vertcoin
  311. blocks chainstate vertcoin.conf
  312. ```
  313.  
  314. #### Create swap file space for Raspberry Pi
  315.  
  316. Here we ensure that `dphys-swapfile` is installed and configured to save the swap file in `/mnt/swap`, allocate `500MB` of swap file space, uncomment `CONF_SWAPFACTOR` and `CONF_MAXSWAP` lines.
  317.  
  318. \# Install `dphys-swapfile`
  319. ```
  320. pi@raspberrypi:~ $ sudo apt-get install dphys-swapfile
  321. Reading package lists... Done
  322. Building dependency tree
  323. Reading state information... Done
  324. dphys-swapfile is already the newest version (20100506-3).
  325. 0 upgraded, 0 newly installed, 0 to remove and 15 not upgraded.
  326. ```
  327.  
  328. \# Configure swap file
  329. `pi@raspberrypi:~ $ sudo nano /etc/dphys-swapfile`
  330. ```
  331. # /etc/dphys-swapfile - user settings for dphys-swapfile package
  332. # author Neil Franklin, last modification 2010.05.05
  333. # copyright ETH Zuerich Physics Departement
  334. # use under either modified/non-advertising BSD or GPL license
  335.  
  336. # this file is sourced with . so full normal sh syntax applies
  337.  
  338. # the default settings are added as commented out CONF_*=* lines
  339.  
  340.  
  341. # reconfigure swapfile to reside on /mnt/swap
  342. CONF_SWAPFILE=/mnt/swap
  343.  
  344. # set size to absolute value, leaving empty (default) then uses computed value
  345. # you most likely don't want this, unless you have an special disk situation
  346.  
  347. # set swapsize to 500
  348. CONF_SWAPSIZE=500
  349.  
  350. # set size to computed value, this times RAM size, dynamically adapts,
  351. # guarantees that there is enough swap without wasting disk space on excess
  352. CONF_SWAPFACTOR=2
  353.  
  354. # restrict size (computed and absolute!) to maximally this limit
  355. # can be set to empty for no limit, but beware of filled partitions!
  356. # this is/was a (outdated?) 32bit kernel limit (in MBytes), do not overrun it
  357. # but is also sensible on 64bit to prevent filling /var or even / partition
  358. CONF_MAXSWAP=2048
  359. ```
  360. `ctrl+x` to save
  361.  
  362. \# Restart swap file service
  363. ```
  364. pi@raspberrypi:~ $ sudo /etc/init.d/dphys-swapfile stop
  365. [ ok ] Stopping dphys-swapfile (via systemctl): dphys-swapfile.service.
  366. ```
  367. ```
  368. pi@raspberrypi:~ $ sudo /etc/init.d/dphys-swapfile start
  369. [ ok ] Starting dphys-swapfile (via systemctl): dphys-swapfile.service.
  370. ```
  371.  
  372. #### Setup Vertcoin Core Crontab for auto-start on reboot
  373.  
  374. Here we will configure the `crontab` file to start `vertcoind` as a daemon on reboot and on each hour to ensure `vertcoind` always has a process thats alive. If `vertcoind` is already running when the hourly `crontab` executes it will simply fail to spawn a new process.
  375.  
  376. \# Configure `crontab` file to start `vertcoind` hourly and on reboot
  377.  
  378. `pi@raspberrypi:~ $ crontab -u pi -e`
  379. ```
  380. no crontab for pi - using an empty one
  381.  
  382. Select an editor. To change later, run 'select-editor'.
  383. 1. /bin/ed
  384. 2. /bin/nano <---- easiest
  385. 3. /usr/bin/vim.tiny
  386.  
  387. Choose 1-3 [2]: 2
  388. ----------------------------------------------------------------------
  389. # Edit this file to introduce tasks to be run by cron.
  390. #
  391. # Each task to run has to be defined through a single line
  392. # indicating with different fields when the task will be run
  393. # and what command to run for the task
  394. #
  395. # To define the time you can provide concrete values for
  396. # minute (m), hour (h), day of month (dom), month (mon),
  397. # and day of week (dow) or use '*' in these fields (for 'any').#
  398. # Notice that tasks will be started based on the cron's system
  399. # daemon's notion of time and timezones.
  400. #
  401. # Output of the crontab jobs (including errors) is sent through
  402. # email to the user the crontab file belongs to (unless redirected).
  403. #
  404. # For example, you can run a backup of all your user accounts
  405. # at 5 a.m every week with:
  406. # 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
  407. #
  408. # For more information see the manual pages of crontab(5) and cron(8)
  409. #
  410. # m h dom mon dow command
  411.  
  412. @reboot vertcoind -daemon
  413. @hourly vertcoind -daemon
  414. ```
  415. `ctrl+x` to save
  416.  
  417. \# Reboot and confirm `vertcoind` process spawns on reboot
  418. `pi@raspberrypi:~ $ sudo reboot `
  419.  
  420. \# Wait a minute, then log back in via SSH
  421. `ssh 192.168.1.2 -l pi`
  422. ```
  423. pi@raspberrypi:~ $ ps aux | grep vertcoin
  424. pi 406 99.9 9.5 169160 90256 ? Rsl 22:43 1:46 vertcoind -daemon
  425. pi 530 0.0 0.0 4372 560 pts/0 S+ 22:45 0:00 grep --color=auto vertcoin
  426. ```
  427. ##
  428. ### Quick note about blockchain syncing
  429. Vertcoin Core is now synchronizing to the side-loaded blockchain located in `/mnt/` (linked to `/home/pi/.vertcoin`). This process can take ~3-5 hours to sync headers and verify all of the downloaded blocks. You can monitor system resources by issuing the `htop` command and check up on `vertcoind` by issuing the following commands:
  430.  
  431. \# Display output of Vertcoin `debug.log`; `ctrl+c` to stop
  432. `pi@raspberrypi:~ $ tailf .vertcoin/debug.log`
  433.  
  434. \# Show blockchain information
  435. `pi@raspberrypi:~ $ vertcoin-cli getblockchaininfo`
  436.  
  437. \# Show current block
  438. `pi@raspberrypi:~ $ vertcoin-cli getblockcount`
  439.  
  440. ###### You may continue on while `vertcoind` catches up to the blockchain ...
  441.  
  442.  
  443. ## 9.) Configure firewall to allow Vertcoin Core traffic
  444.  
  445. ##### Please note that your `IP` range may be different than what I have listed below. If your router `IP` address is `192.168.1.1` then the instructions above require no alterations. If your `IP` address is something like `192.168.56.1` or `10.0.0.1` then you will need to modify the 'ufw allow from `192.168.1.0/24` to any port 22' to 'ufw allow from `192.168.56.0/24`(...)' or 'ufw allow from `10.0.0.0/24`(...)' respectively.
  446.  
  447. \# Install `UFW`
  448. `pi@raspberrypi:~ $ sudo apt-get install ufw`
  449.  
  450. \# Escalate to `root` and configure `UFW`
  451.  
  452. `pi@raspberrypi:~ $ sudo su`
  453. `root@raspberrypi:/home/pi# ufw default deny incoming`
  454. ```
  455. Default incoming policy changed to 'deny'
  456. (be sure to update your rules accordingly)
  457. ```
  458. `root@raspberrypi:/home/pi# ufw default allow outgoing`
  459. ```
  460. Default outgoing policy changed to 'allow'
  461. (be sure to update your rules accordingly)
  462. ```
  463. `root@raspberrypi:/home/pi# ufw allow from 192.168.1.0/24 to any port 22 comment 'allow SSH from local LAN'`
  464. `root@raspberrypi:/home/pi# ufw allow 5889 comment 'allow vertcoin core'`
  465. `root@raspberrypi:/home/pi# ufw enable`
  466. ```
  467. Command may disrupt existing ssh connections. Proceed with operation (y|n)? y
  468. Firewall is active and enabled on system startup
  469. ```
  470. `root@raspberrypi:/home/pi# systemctl enable ufw`
  471. ```
  472. Synchronizing state of ufw.service with SysV service script with /lib/systemd/systemd-sysv-install.
  473. Executing: /lib/systemd/systemd-sysv-install enable ufw
  474. ```
  475. `root@raspberrypi:/home/pi# ufw status`
  476. ```
  477. Status: active
  478.  
  479. To Action From
  480. -- ------ ----
  481. 22 ALLOW 192.168.1.0/24 # allow SSH from local LAN
  482. 5889 ALLOW Anywhere # allow vertcoin core
  483. 5889 (v6) ALLOW Anywhere (v6) # allow vertcoin core
  484. ```
  485. \# Give up `root`
  486. `root@raspberrypi:/home/pi# exit`
  487.  
  488. Open a browser window and navigate to your router page, from there you can port forward your Raspberry Pi.
  489. `TCP/UDP Port: 5889`
  490.  
  491. ##### This will make your node public, supporting the health of the Vertcoin network by keeping it decentralized and populated with one more node.
  492.  
  493.  
  494.  
  495. ## 10.) `* OPTIONAL:` Setup Unitus Full Node for merged mining with p2pool-vtc
  496.  
  497. A Unitus full node may be setup to allow for merged mining rewards when mining with `p2pool-vtc`. Running two full nodes together on the same Raspberry Pi will mean that you will be storing two blockchains on your USB Flash Drive rather than one, and you will be using more resources on load and at idle. We can modify our `crontab` arguments to allow each process time to load and verify blocks with ample resources.
  498.  
  499. ##### `* OPTIONAL:` Refer back to step [2.) `*OPTIONAL:` Download and sync Vertcoin Core] ; Instead of downloading and syncing Vertcoin Core you will want to download and sync Unitus Core
  500.  
  501. \# Install dependencies
  502. `pi@raspberrypi:~ $ sudo apt-get install libqt5gui5 libqt5core5a libqt5dbus5 qttools5-dev qttools5-dev-tools libprotobuf-dev protobuf-compiler libqt4-dev libprotobuf-dev protobuf-compiler libboost-all-dev libminiupnpc-dev libqrencode-dev build-essential libtool autotools-dev automake pkg-config libssl-dev libevent-dev bsdmainutils`
  503.  
  504. \# Clone Unitus repo into /home/pi/
  505. `pi@raspberrypi:~ $ git clone https://github.com/unitusdev/unitus.git`
  506.  
  507. \# Download Berkley database
  508. ```
  509. # Download and configure BerkleyDB
  510. pi@raspberrypi:~ $ wget http://download.oracle.com/berkeley-db/db-4.8.30.NC.tar.gz
  511. pi@raspberrypi:~ $ tar -xzvf db-4.8.30.NC.tar.gz
  512. pi@raspberrypi:~ $ cd db-4.8.30.NC/build_unix/
  513. pi@raspberrypi:~/db-4.8.30.NC/build_unix $ ../dist/configure --enable-cxx
  514. pi@raspberrypi:~/db-4.8.30.NC/build_unix $ make -j4
  515.  
  516. # Compile and install BerkleyDB
  517. pi@raspberrypi:~/db-4.8.30.NC/build_unix $ sudo make install
  518.  
  519. # Change directories to the cloned git repo in home
  520. pi@raspberrypi:~/db-4.8.30.NC/build_unix $ cd
  521. pi@raspberrypi:~ $ cd unitus/
  522.  
  523. # Configure unitus
  524. pi@raspberrypi:~/unitus $ ./configure CPPFLAGS="-I/usr/local/BerkeleyDB.4.8/include -O2" LDFLAGS="-L/usr/local/BerkeleyDB.4.8/lib" --enable-upnp-default
  525.  
  526. # Compile
  527. pi@raspberrypi:~/unitus $ make
  528. ```
  529.  
  530. \# Change directory to `/mnt/`
  531. `pi@raspberrypi:~ $ cd /mnt/`
  532.  
  533. \# Create a directory for Unitus Core
  534. `pi@raspberrypi:/mnt $ sudo mkdir unitus`
  535.  
  536. \# Change to the `unitus` directory
  537. `pi@raspberrypi:/mnt $ cd unitus`
  538.  
  539. \# Create `unitus.conf` for Unitus Core
  540. `pi@raspberrypi:/mnt/vertcoin $ sudo nano unitus.conf`
  541. ```
  542. server=1
  543. rpcuser=node
  544. rpcpassword=yoursecurepasswordgoeshere
  545.  
  546. # makes client run in background
  547. daemon=1
  548.  
  549. # https://jlopp.github.io/bitcoin-core-config-generator/ lopp.net optimizations
  550. dbcache=100
  551. maxorphantx=10
  552. maxmempool=50
  553. maxconnections=40
  554. maxuploadtarget=5000
  555. ```
  556. `ctrl+x` to save
  557.  
  558. ##
  559. `* OPTIONAL:` A quick and easy way to generate a random password is taking the `md5sum` of a file
  560. ```
  561. pi@raspberrypi:/mnt/unitus $ touch randomfilename
  562. pi@raspberrypi:/mnt/unitus $ md5sum randomfilename
  563. d41d8cd98f00b204e9800998ecf8427e randomfilename
  564.  
  565. # Clean up
  566. pi@raspberrypi:/mnt/unitus $ rm randomfilename
  567. ```
  568. ##
  569.  
  570. \# Change directory back home
  571. ```
  572. pi@raspberrypi:/mnt/unitus $ cd
  573. pi@raspberrypi:~ $ pwd
  574. /home/pi
  575. ```
  576. \# Create soft link (symbolic link) connecting `/mnt/unitus/` <---> `/home/pi/.unitus`
  577. `pi@raspberrypi:~ $ sudo ln -s /mnt/unitus/ /home/pi/.unitus`
  578.  
  579. \# List all files in home
  580. ```
  581. pi@raspberrypi:~ $ ls -a
  582. . .. .bash_history .bash_logout .bashrc .config .nano .profile .selected_editor .unitus .vertcoin .wget-hsts
  583. ```
  584. \# List files in `/home/pi/.unitus`, confirm our configuration file `unitus.conf` is there
  585. ```
  586. pi@raspberrypi:~ $ ls .unitus
  587. unitus.conf
  588. ```
  589.  
  590. \# We must `poweroff` our Raspberry Pi so we can copy the Unitus blockchain over to the USB Flash Drive
  591. ```
  592. pi@raspberrypi:~ $ vertcoin-cli stop
  593. pi@raspberrypi:~ $ sudo poweroff
  594. ```
  595.  
  596. ##### Copy Unitus Blockchain to USB Flash Drive
  597. Once the Raspberry Pi is off unplug the micro USB power cable from it, then remove the USB Flash Drive from the Pi and insert it into the computer that you synced Unitus Core on. When Unitus Core is finished syncing the blockchain please navigate to the data directory for Unitus.
  598.  
  599. Default Windows Directory (Unitus): C:\Users\%USER%\AppData\Roaming\Unitus
  600.  
  601. Copy the folders `blocks` and `chainstate` to the `unitus` folder on your USB Flash Drive. This will allow us to side-load the Unitus blockchain and bootstrap faster than if we had the Raspberry Pi do all the work. Once you have copied the `blocks` and `chainstate` folders for Unitus to the `unitus` folder on the USB Flash Drive please safely remove it as to make sure we do not corrupt the drive.
  602.  
  603. Place the USB Flash Drive back into the Raspberry Pi and plug the micro USB cable back into the Raspberry Pi. It will begin to boot, return to your `ssh` command window
  604.  
  605. \# Wait a minute, then log back in via `SSH`
  606. `ssh 192.168.1.2 -l pi`
  607.  
  608. \# Confirm the Unitus blockchain is in `/home/pi/.unitus`
  609. ```
  610. pi@raspberrypi:~ $ ls .unitus
  611. blocks chainstate unitus.conf
  612. ```
  613.  
  614. ##### Edit `crontab` file to start Unitus hourly and on reboot to ensure the process is alive
  615. Here we will configure the crontab file to start vertcoind as a daemon on reboot and on each hour to ensure vertcoind always has a process thats alive. If vertcoind is already running when the hourly crontab executes it will simply fail to spawn a new process.
  616.  
  617. \# Configure crontab file to start `unitusd` hourly and on reboot ; sleep `unitusd` for 9 minutes then execute
  618. `pi@raspberrypi:~ $ crontab -u pi -e`
  619. ```
  620. # Edit this file to introduce tasks to be run by cron.
  621. #
  622. # Each task to run has to be defined through a single line
  623. # indicating with different fields when the task will be run
  624. # and what command to run for the task
  625. #
  626. # To define the time you can provide concrete values for
  627. # minute (m), hour (h), day of month (dom), month (mon),
  628. # and day of week (dow) or use '*' in these fields (for 'any').#
  629. # Notice that tasks will be started based on the cron's system
  630. # daemon's notion of time and timezones.
  631. #
  632. # Output of the crontab jobs (including errors) is sent through
  633. # email to the user the crontab file belongs to (unless redirected).
  634. #
  635. # For example, you can run a backup of all your user accounts
  636. # at 5 a.m every week with:
  637. # 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
  638. #
  639. # For more information see the manual pages of crontab(5) and cron(8)
  640. #
  641. # m h dom mon dow command
  642.  
  643. @reboot vertcoind -daemon
  644. @hourly vertcoind -daemon
  645. # sleep 9 minutes then start unitus daemon
  646. @reboot sleep 540; unitusd -daemon
  647. ```
  648.  
  649.  
  650. ## 11.) `* OPTIONAL:` Setup p2pool-vtc
  651.  
  652. This section gives you the option of setting up an instance of a Vertcoin P2Pool on the Raspberry Pi to run alongside the `vertcoind` daemon.
  653.  
  654. >P2Pool is a decentralized Bitcoin mining pool that works by creating a peer-to-peer network of miner nodes.
  655.  
  656. >P2Pool creates a new block chain in which the difficulty is adjusted so a new block is found every 30 seconds. The blocks that get into the P2Pool block chain (called the "share chain") are the same blocks that would get into the Bitcoin block chain, only they have a lower difficulty target. Whenever a peer announces a new share found (new block in the P2Pool block chain), it is received by the other peers, and the other peers verify that this block contains payouts for all the previous miners who found a share (and announced it) that made it into the P2Pool share chain. This continues until some peer finds a block that has a difficulty that meets the Bitcoin network's difficulty target. This peer announces this block to the Bitcoin network and miners who have submitted shares for this block are paid in the generation transaction, proportionally to how many shares they have found in the last while. - Unknown author [3]
  657. >
  658. > Decentralized payout pooling solves the problem of centralized mining pools degrading the decentralization of Bitcoin and avoids the risk of hard to detect theft by pool operators.
  659. >
  660. > Miners are configured to connect to a P2Pool node that can be run locally, alongside the miner. P2Pool users must run a full Bitcoin node which serves the purpose of independently validating transactions and the Bitcoin blockchain.
  661. >
  662. > P2Pool nodes work on a chain of shares similar to Bitcoin's blockchain. Each node works on a block that includes payouts to the previous shares' owners and the node itself, which can also result in a share if it meets P2Pool's difficulty.
  663.  
  664. \# Install `p2pool-vtc` dependencies and `python-pip`
  665.  
  666. `pi@raspberrypi:~ $ sudo apt-get install python-rrdtool python-pygame python-scipy python-twisted python-twisted-web python-imaging python-pip`
  667.  
  668. \# Install `bitcoin` dependencies and `libffi-dev`
  669.  
  670. `pi@raspberrypi:~/p2pool-vtc $ sudo apt-get install build-essential libtool autotools-dev automake pkg-config libffi-dev libssl-dev libevent-dev bsdmainutils python3`
  671.  
  672. \# Clone `p2pool-vtc`
  673. ```
  674. pi@raspberrypi:~ $ git clone https://github.com/vertcoin-project/p2pool-vtc.git
  675. Cloning into 'p2pool-vtc'...
  676. remote: Counting objects: 8393, done.
  677. remote: Total 8393 (delta 0), reused 0 (delta 0), pack-reused 8393
  678. Receiving objects: 100% (8393/8393), 2.54 MiB | 0 bytes/s, done.
  679. Resolving deltas: 100% (5611/5611), done.
  680. ```
  681.  
  682. \# Change directory to `p2pool-vtc`
  683. `pi@raspberrypi:~ $ cd p2pool-vtc/`
  684.  
  685. \# Install `requirements.txt` dependencies
  686. `pi@raspberrypi:~/p2pool-vtc $ pip install -r requirements.txt`
  687.  
  688. \# Configure P2Pool
  689. `pi@raspberrypi:~/p2pool-vtc $ cd lyra2re-hash-python/`
  690. `pi@raspberrypi:~/p2pool-vtc/lyra2re-hash-python $ git submodule init`
  691. `pi@raspberrypi:~/p2pool-vtc/lyra2re-hash-python $ git submodule update`
  692. `pi@raspberrypi:~/p2pool-vtc/lyra2re-hash-python $ sudo python setup.py install`
  693.  
  694. \# Download alternate web frontend for P2Pool
  695. `pi@raspberrypi:~/p2pool-vtc/lyra2re-hash-python $ cd`
  696. `pi@raspberrypi:~ $ git clone https://github.com/hardcpp/P2PoolExtendedFrontEnd.git`
  697. `pi@raspberrypi:~ $ cd P2PoolExtendedFrontEnd`
  698.  
  699. \# Move all files in `P2PoolExtendedFrontEnd` to the `web-static` folder in `p2pool-vtc`
  700. `pi@raspberrypi:~/P2PoolExtendedFrontEnd $ mv * /home/pi/p2pool-vtc/web-static/`
  701. `pi@raspberrypi:~/P2PoolExtendedFrontEnd $ cd`
  702.  
  703. \# Clean up
  704. `pi@raspberrypi:~ $ sudo rm -r P2PoolExtendedFrontEnd/`
  705.  
  706.  
  707. #### Network 1 - Firewall Configuration
  708. > If you are a smaller miner with 2 graphics cards or less or are using your CPU, it is recommended to use Network 2. If you are a larger miner with multiple cards and/or a hash rate larger than 100Mh, it is recommended to use Network 1.
  709.  
  710. \# Escalate to `root`
  711. `pi@raspberrypi:~ $ sudo su`
  712. `root@raspberrypi:/home/pi# ufw allow 9346 comment 'allow --network 1 p2p port'`
  713. `root@raspberrypi:/home/pi# ufw allow 9171 comment 'allow --network 1 mining port'`
  714.  
  715. \# Give up `root`
  716. `root@raspberrypi:/home/pi# exit`
  717.  
  718. #### Network 2 - Firewall Configuration
  719. > If you are a smaller miner with 2 graphics cards or less or are using your CPU, it is recommended to use Network 2. If you are a larger miner with multiple cards and/or a hash rate larger than 100Mh, it is recommended to use Network 1.
  720.  
  721. \# Escalate to `root`
  722. `pi@raspberrypi:~ $ sudo su`
  723. `root@raspberrypi:/home/pi# ufw allow 9347 comment 'allow --network 2 p2p port'`
  724. `root@raspberrypi:/home/pi# ufw allow 9181 comment 'allow --network 2 mining port'`
  725.  
  726. \# Give up `root`
  727. `root@raspberrypi:/home/pi# exit`
  728.  
  729. ##
  730.  
  731. #### `* OPTIONAL:` Setup P2Pool bash script for execution on reboot
  732. ###### Note: This walkthrough uses the default settings.
  733. ```
  734. pi@raspberrypi:~/p2pool-vtc $ python run_p2pool.py --help
  735. usage: run_p2pool.py [-h] [--version]
  736. [--net {bitcoin,btcregtest,fastcoin,litecoin,terracoin,vertcoin,vertcoin2}]
  737. [--testnet] [--debug] [-a ADDRESS] [-i NUMADDRESSES]
  738. [-t TIMEADDRESSES] [--datadir DATADIR]
  739. [--logfile LOGFILE] [--web-static WEB_STATIC]
  740. [--merged MERGED_URLS]
  741. [--give-author DONATION_PERCENTAGE] [--iocp]
  742. [--irc-announce] [--no-bugreport] [--p2pool-port PORT]
  743. [-n ADDR[:PORT]] [--disable-upnp] [--max-conns CONNS]
  744. [--outgoing-conns CONNS] [--external-ip ADDR[:PORT]]
  745. [--disable-advertise] [-w PORT or ADDR:PORT]
  746. [-f FEE_PERCENTAGE]
  747. [--miner-share-rate SHARES_PER_MINUTE]
  748. [--address-share-rate SHARES_PER_MINUTE]
  749. [--min-difficulty DIFFICULTY]
  750. [--bitcoind-config-path BITCOIND_CONFIG_PATH]
  751. [--bitcoind-address BITCOIND_ADDRESS]
  752. [--bitcoind-rpc-port BITCOIND_RPC_PORT]
  753. [--bitcoind-rpc-ssl]
  754. [--bitcoind-p2p-port BITCOIND_P2P_PORT]
  755. [BITCOIND_RPCUSERPASS [BITCOIND_RPCUSERPASS ...]]
  756.  
  757. ```
  758.  
  759. #### `* OPTIONAL:` Setup P2Pool bash script for execution on reboot
  760. `pi@raspberrypi:~ $ nano start-p2pool.sh`
  761. ```
  762. #!/bin/bash
  763. #
  764. # run p2pool with pre-configured settings
  765. #
  766. # network 1 = --net vertcoin
  767. # network 2 = --net vertcoin2
  768. #
  769. cd p2pool-vtc
  770. python run_p2pool.py --net vertcoin
  771. ```
  772.  
  773. \# Give execute privileges to `start-p2pool.sh`
  774. `pi@raspberrypi:~ $ chmod +x start-p2pool.sh`
  775.  
  776. \# Configure `crontab` file to execute `start-p2pool.sh` on reboot
  777. `pi@raspberrypi:~ $ crontab -u pi -e`
  778. ```
  779. # Edit this file to introduce tasks to be run by cron.
  780. #
  781. # Each task to run has to be defined through a single line
  782. # indicating with different fields when the task will be run
  783. # and what command to run for the task
  784. #
  785. # To define the time you can provide concrete values for
  786. # minute (m), hour (h), day of month (dom), month (mon),
  787. # and day of week (dow) or use '*' in these fields (for 'any').#
  788. # Notice that tasks will be started based on the cron's system
  789. # daemon's notion of time and timezones.
  790. #
  791. # Output of the crontab jobs (including errors) is sent through
  792. # email to the user the crontab file belongs to (unless redirected).
  793. #
  794. # For example, you can run a backup of all your user accounts
  795. # at 5 a.m every week with:
  796. # 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
  797. #
  798. # For more information see the manual pages of crontab(5) and cron(8)
  799. # m h dom mon dow command
  800. @reboot vertcoind -daemon
  801. @hourly vertcoind -daemon
  802.  
  803. # sleep 15 minutes then start p2pool
  804. @reboot sleep 900; /home/pi/start-p2pool.sh
  805. ```
  806. Note: Running P2Pool 15 minutes after reboot allows the Raspberry Pi resources and time to verify, load the blockchain and catch up if needed.
  807.  
  808. \# `* OPTIONAL:` Display output of P2Pool's `debug` log; `ctrl+c` to stop
  809. `pi@raspberrypi:~ $ tailf p2pool-vtc/data/vertcoin/log`
  810.  
  811. #### Documentation
  812. `https://github.com/vertcoin-project/p2pool-vtc`
  813. `https://github.com/bitcoin/bitcoin/blob/master/doc/build-unix.md`
  814.  
  815. ##
  816.  
  817.  
  818.  
  819. ##
  820. ## Congratulations!
  821. You have successfully setup a full Vertcoin Core node on a Raspberry Pi. Thank you for following along and contributing to the Vertcoin network by helping keep it populated with nodes and distributed. You help give meaning to 'the peoples' coin'!
  822. ```
  823. pi@raspberrypi:~ $ vertcoin-cli getblockchaininfo
  824. {
  825. "chain": "main",
  826. "blocks": 888507,
  827. "headers": 915979,
  828. "bestblockhash": "c56f7d9fbddd4073c68d18e901944dd50cad072b3fa39bbd0047e476b5297898",
  829. "difficulty": 45108.82829895391,
  830. "mediantime": 1520320068,
  831. "verificationprogress": 0.9595547815279806,
  832. "initialblockdownload": true,
  833. "chainwork": "0000000000000000000000000000000000000000000000015f56d79735e934ce",
  834. "size_on_disk": 3240624105,
  835. "pruned": false,
  836. "bip9_softforks": {
  837. "csv": {
  838. "status": "active",
  839. "startTime": 1488326400,
  840. "timeout": 1519862400,
  841. "since": 691488
  842. },
  843. "segwit": {
  844. "status": "active",
  845. "startTime": 1488326400,
  846. "timeout": 1519862400,
  847. "since": 713664
  848. },
  849. "nversionbips": {
  850. "status": "active",
  851. "startTime": 1488326400,
  852. "timeout": 1519862400,
  853. "since": 691488
  854. }
  855. },
  856. "warnings": ""
  857. }
  858. ```
  859.  
  860.  
  861.  
  862. ## References
  863. `[1] How to Create Your Own Bitcoin Full Node With a Raspberry Pi http://www.raspberrypifullnode.com/`
  864. `[2] Jameson Lopp - Bitcoin Nodes, how many is enough? https://medium.com/@lopp/bitcoin-nodes-how-many-is-enough-9b8e8f6fd2cf`
  865. `[3] Bitcoin Wiki - P2Pool https://en.bitcoin.it/wiki/P2Pool`
  866.  
  867. ``
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement