2018-05-27 12:13:55 -07:00
# Nimbus: an Ethereum 2.0 Sharding Client for Resource-Restricted Devices
2018-02-06 21:20:06 +02:00
2018-12-27 15:32:35 +01:00
[![Windows build status (Appveyor) ](https://img.shields.io/appveyor/ci/nimbus/nimbus/master.svg?label=Windows "Windows build status (Appveyor )")](https://ci.appveyor.com/project/nimbus/nimbus)
2018-04-06 16:52:10 +02:00
[![Build Status (Travis) ](https://img.shields.io/travis/status-im/nimbus/master.svg?label=Linux%20/%20macOS "Linux/macOS build status (Travis )")](https://travis-ci.org/status-im/nimbus)
2018-09-04 21:03:10 -06:00
[![License: Apache ](https://img.shields.io/badge/License-Apache%202.0-blue.svg )](https://opensource.org/licenses/Apache-2.0)
2018-04-06 16:52:10 +02:00
[![License: MIT ](https://img.shields.io/badge/License-MIT-blue.svg )](https://opensource.org/licenses/MIT)
![Stability: experimental ](https://img.shields.io/badge/stability-experimental-orange.svg )
2018-02-07 18:50:28 +02:00
2018-03-17 16:39:13 +08:00
Join the Status community chats:
2018-08-31 16:23:51 -06:00
[![Gitter: #status-im/nimbus ](https://img.shields.io/badge/gitter-status--im%2Fnimbus-orange.svg )](https://gitter.im/status-im/nimbus)
2018-03-17 16:39:13 +08:00
[![Riot: #nimbus ](https://img.shields.io/badge/riot-%23nimbus%3Astatus.im-orange.svg )](https://chat.status.im/#/room/#nimbus:status .im)
2018-09-04 21:01:33 -06:00
[![Riot: #dev-status ](https://img.shields.io/badge/riot-%23dev--status%3Astatus.im-orange.svg )](https://chat.status.im/#/room/#dev -status:status.im)
2018-03-17 16:39:13 +08:00
2018-05-16 21:51:17 -07:00
## Rationale
2019-01-23 13:59:26 +01:00
2019-06-30 10:00:07 +00:00
[Nimbus: an Ethereum 2.0 Sharding Client ](https://our.status.im/nimbus-for-newbies/ ). The code in this repository is currently focusing on Ethereum 1.0 feature parity, while all 2.0 research and development is happening in parallel in [nim-beacon-chain ](https://github.com/status-im/nim-beacon-chain ).
2018-04-06 16:52:10 +02:00
2018-12-27 15:32:35 +01:00
## Development Updates
To keep up to date with changes and development progress, follow the [Nimbus blog ](https://our.status.im/tag/nimbus/ ).
2018-06-19 21:19:07 +02:00
## Building & Testing
2019-03-30 00:54:36 +01:00
_We currently do not guarantee that Nimbus will work on Windows._
2018-06-24 17:34:32 +03:00
### Prerequisites
2019-03-14 14:33:06 -06:00
#### Rocksdb
2018-12-24 17:03:27 +01:00
2019-03-14 14:33:06 -06:00
A recent version of Facebook's [RocksDB ](https://github.com/facebook/rocksdb/ ) is needed - it can usually be installed using a package manager of your choice:
```bash
# MacOS
brew install rocksdb
# Fedora
dnf install rocksdb-devel
2019-03-14 13:54:27 -07:00
# Debian and Ubuntu
sudo apt-get install librocksdb-dev
2019-03-25 16:32:29 +02:00
# Arch (AUR)
pakku -S rocksdb
2019-03-14 14:33:06 -06:00
```
On Windows, you can [download pre-compiled DLLs ](#windows ).
2019-03-30 00:54:36 +01:00
You can also build and install it by following [their instructions ](https://github.com/facebook/rocksdb/blob/master/INSTALL.md ).
2019-03-14 14:33:06 -06:00
2019-08-07 11:09:45 +02:00
### PCRE
If you don't already have it, you will also need PCRE to build Nimbus.
```bash
# MacOS
brew install pcre
# Fedora
dnf install pcre
# Debian and Ubuntu
sudo apt-get install libpcre libpcre-dev
# Arch (AUR)
pakku -S pcre-static
```
On Windows, the aforementioned DLL download will take care of this for you ([download pre-compiled DLLs ](#windows )).
2019-03-14 14:33:06 -06:00
#### Developer tools
GNU make, Bash and the usual POSIX utilities
2018-06-19 21:19:07 +02:00
2018-09-25 01:25:17 +03:00
#### Obtaining the prerequisites through the Nix package manager
2018-06-24 17:34:32 +03:00
2019-03-14 14:33:06 -06:00
*Experimental*
2018-06-24 17:34:32 +03:00
Users of the [Nix package manager ](https://nixos.org/nix/download.html ) can install all prerequisites simply by running:
``` bash
2019-03-11 23:03:29 +01:00
nix-shell default.nix
2018-06-24 17:34:32 +03:00
```
2018-12-24 17:03:27 +01:00
### Build & Develop
2018-06-24 17:34:32 +03:00
2018-12-24 17:03:27 +01:00
#### POSIX-compatible OS
2018-06-19 21:19:07 +02:00
2018-12-24 17:03:27 +01:00
To build Nimbus (in "build/nimbus"), just execute:
2018-09-25 01:25:17 +03:00
2018-08-31 16:23:51 -06:00
```bash
2018-12-24 17:03:27 +01:00
make
2018-08-31 16:23:51 -06:00
```
2018-07-20 22:02:52 +02:00
2018-12-24 17:03:27 +01:00
Running `./build/nimbus --help` will provide you with a list of
the available command-line options. To start syncing with mainnet, just execute `./build/nimbus`
2018-09-25 01:25:17 +03:00
without any parameters.
2018-07-20 22:02:52 +02:00
2018-09-25 01:25:17 +03:00
To execute all tests:
2018-08-31 16:23:51 -06:00
```bash
2018-12-24 17:03:27 +01:00
make test
```
To pull the latest changes in all the Git repositories involved:
```bash
2019-02-12 16:06:00 +01:00
git pull
2018-12-24 17:03:27 +01:00
make update
```
To run a command that might use binaries from the Status Nim fork:
```bash
2019-03-14 14:33:06 -06:00
./env.sh bash
which nim
2018-08-31 16:23:51 -06:00
```
2018-07-20 22:02:52 +02:00
2018-09-25 01:25:17 +03:00
Our Wiki provides additional helpful information for [debugging individual test cases][1]
and for [pairing Nimbus with a locally running copy of Geth][2].
2018-12-24 17:03:27 +01:00
#### Windows
2018-07-20 22:02:52 +02:00
2019-03-30 00:54:36 +01:00
_Experimental support!_
2018-12-24 17:03:27 +01:00
Install Mingw-w64 for your architecture using the "[MinGW-W64 Online
Installer](https://sourceforge.net/projects/mingw-w64/files/)" (first link
under the directory listing). Run it and select your architecture in the setup
menu ("i686" on 32-bit, "x86\_64" on 64-bit), set the threads to "win32" and
the exceptions to "dwarf" on 32-bit and "seh" on 64-bit. Change the
installation directory to "C:\mingw-w64" and add it to your system PATH in "My
Computer"/"This PC" -> Properties -> Advanced system settings -> Environment
Variables -> Path -> Edit -> New -> C:\mingw-w64\mingw64\bin (it's "C:\mingw-w64\mingw32\bin" on 32-bit)
2018-12-27 15:32:35 +01:00
2018-12-24 17:03:27 +01:00
Install [Git for Windows ](https://gitforwindows.org/ ) and use a "Git Bash" shell to clone and build Nimbus.
If you don't want to compile RocksDB and SQLite separately, you can fetch pre-compiled DLLs with:
2018-12-27 15:32:35 +01:00
```bash
2018-12-24 17:03:27 +01:00
mingw32-make fetch-dlls
2018-12-27 15:32:35 +01:00
```
2018-12-24 17:03:27 +01:00
This will place the right DLLs for your architecture in the "build/" directory.
You can now follow those instructions in the previous section by replacing `make` with `mingw32-make` (regardless of your 32-bit or 64-bit architecture).
2018-12-27 15:32:35 +01:00
2019-06-27 15:29:57 +02:00
#### Raspberry PI
2019-06-27 15:29:23 +02:00
*Experimental* The code can be compiled on a Raspberry PI:
* Raspberry PI 3b+
* 64gb SD Card (less might work too, but the default recommended 4-8GB will probably be too small)
* [Rasbian Buster Lite ](https://www.raspberrypi.org/downloads/raspbian/ ) - Lite version is enough to get going and will save some disk space!
Assuming you're working with a freshly written image:
```bash
# Start by increasing swap size to 2gb:
sudo vi /etc/dphys-swapfile
# Set CONF_SWAPSIZE=2048
# :wq
sudo reboot
# Install prerequisites
sudo apt-get install git libgflags-dev libsnappy-dev
mkdir status
cd status
# Install rocksdb
git clone https://github.com/facebook/rocksdb.git
cd rocksdb
make shared_lib
sudo make install
cd..
# Raspberry pi doesn't include /usr/local/lib in library search path - need to add
export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
git clone https://github.com/status-im/nimbus.git
cd nimbus
# Follow instructions above!
```
2019-01-06 23:06:26 +01:00
### Development tips
- you can switch the DB backend with a Nim compiler define:
`-d:nimbus_db_backend=...` where the (case-insensitive) value is one of
2019-01-23 13:59:26 +01:00
"rocksdb" (the default), "sqlite", "lmdb"
- the Premix debugging tools are [documented separately ](premix/readme.md )
2019-01-06 23:06:26 +01:00
2019-03-29 18:08:39 +01:00
- you can control the Makefile's verbosity with the V variable (defaults to 0):
2019-02-16 22:23:17 +01:00
```bash
2019-03-29 18:08:39 +01:00
make V=1 # verbose
make V=2 test # even more verbose
2019-02-16 22:23:17 +01:00
```
2019-03-11 20:45:46 +01:00
- same for the [Chronicles log level ](https://github.com/status-im/nim-chronicles#chronicles_log_level ):
```bash
make LOG_LEVEL=DEBUG nimbus # this is the default
make LOG_LEVEL=TRACE nimbus # log everything
```
2019-03-12 12:09:33 +01:00
- pass arbitrary parameters to the Nim compiler:
```bash
2019-03-17 01:54:30 +01:00
make NIMFLAGS="-d:release"
2019-03-12 12:09:33 +01:00
```
2019-06-12 13:51:07 +02:00
- if you want to use SSH keys with GitHub (also handles submodules):
2019-02-21 23:46:28 +01:00
```bash
make github-ssh
```
2019-06-12 13:51:07 +02:00
- force a Nim compiler rebuild:
```bash
rm vendor/Nim/bin/nim
make -j8 build-nim
```
2019-02-12 16:06:00 +01:00
#### Git submodule workflow
Working on a dependency:
```bash
cd vendor/nim-chronicles
git checkout -b mybranch
# make some changes
git status
git commit -a
git push origin mybranch
# create a GitHub PR and wait for it to be approved and merged
git checkout master
git pull
git branch -d mybranch
# realise that the merge was done without "--no-ff"
git branch -D mybranch
# update the submodule's commit in the superproject
cd ../..
git status
git add vendor/nim-chronicles
git commit
```
It's important that you only update the submodule commit after it's available upstream.
You might want to do this on a new branch of the superproject, so you can make
a GitHub PR for it and see the CI test results.
Don't update all Git submodules at once, just because you found the relevant
Git command or `make` target. You risk updating submodules to other people's
latest commits when they are not ready to be used in the superproject.
Adding the submodule "https://github.com/status-im/foo" to "vendor/foo":
```bash
./add_submodule.sh status-im/foo
```
Removing the submodule "vendor/bar":
```bash
git submodule deinit -f -- vendor/bar
git rm -f vendor/bar
```
Checking out older commits, either to bisect something or to reproduce an older build:
```bash
git checkout < commit hash here >
2019-03-12 15:48:39 +01:00
make clean
make -j8 update
2019-02-12 16:06:00 +01:00
```
2019-02-15 03:11:20 +01:00
Running a dependency's test suite using `nim` instead of `nimble` (which cannot be
convinced not to run a dependency check, thus clashing with our jury-rigged
"vendor/.nimble/pkgs"):
```bash
cd vendor/nim-blscurve
../../nimble.sh test
```
2018-12-24 17:03:27 +01:00
### Troubleshooting
Report any errors you encounter, please, if not [already documented ](https://github.com/status-im/nimbus/issues )!
* Turn it off and on again:
2019-03-29 16:18:33 +01:00
2018-12-24 17:03:27 +01:00
```bash
2019-03-12 15:48:39 +01:00
make clean
make update
2018-12-24 17:03:27 +01:00
```
2018-04-06 16:52:10 +02:00
## License
2018-12-27 15:32:35 +01:00
Licensed and distributed under either of
* MIT license: [LICENSE-MIT ](LICENSE-MIT ) or http://opensource.org/licenses/MIT
or
2019-01-02 14:50:44 +01:00
* Apache License, Version 2.0, ([LICENSE-APACHEv2 ](LICENSE-APACHEv2 ) or http://www.apache.org/licenses/LICENSE-2.0)
2018-04-06 16:52:10 +02:00
2019-01-23 13:59:26 +01:00
at your option. These files may not be copied, modified, or distributed except according to those terms.
2018-12-24 17:03:27 +01:00
[1]: https://github.com/status-im/nimbus/wiki/Understanding-and-debugging-Nimbus-EVM-JSON-tests
[2]: https://github.com/status-im/nimbus/wiki/Debugging-state-reconstruction