74 lines
2.6 KiB
Markdown
Raw Normal View History

# Install dependencies
2020-05-02 21:14:19 +08:00
The Nimbus beacon chain can run on Linux, macOS, Windows, and Android. At the moment, Nimbus has to be built from source, which means you'll need to install some dependencies.
2020-06-19 21:14:12 +08:00
2020-07-03 18:03:06 +02:00
## Time
2020-08-10 12:10:36 +02:00
The beacon chain relies on your computer having the correct time set (plus or minus 0.5 seconds).
2020-07-03 18:03:06 +02:00
2020-08-04 00:15:49 +02:00
We recommended you run a high quality time service on your computer such as:
2020-07-03 18:03:06 +02:00
* GPS
2020-08-10 12:10:36 +02:00
* NTS (network time security, [IETF draft](https://tools.ietf.org/html/draft-ietf-ntp-using-nts-for-ntp-19))
* [Roughtime](https://roughtime.googlesource.com/roughtime) (google)
2020-07-03 18:03:06 +02:00
2020-08-10 12:10:36 +02:00
At a minimum, you should run an NTP client on the server.
2020-08-04 00:15:49 +02:00
> **Note:** Most operating systems (including macOS') automatically sync with NTP by default.
If the above sounds like latin to you, don't worry. You should be fine as long as you haven't messed around with the time and date settings on your computer (they should be set automatically).
2020-07-03 18:03:06 +02:00
2020-06-19 21:14:12 +08:00
## External Dependencies
2020-05-02 21:14:19 +08:00
- Developer tools (C compiler, Make, Bash, Git)
2020-06-19 21:14:12 +08:00
Nimbus will build its own local copy of Nim, so Nim is not an external dependency,
2020-05-02 21:14:19 +08:00
### Linux
2020-05-02 21:14:19 +08:00
2020-08-10 12:10:36 +02:00
On common Linux distributions the dependencies can be installed with
2020-06-19 21:14:12 +08:00
2020-05-02 21:14:19 +08:00
```sh
# Debian and Ubuntu
sudo apt-get install build-essential git
2020-05-02 21:14:19 +08:00
# Fedora
dnf install @development-tools
2020-05-02 21:14:19 +08:00
# Archlinux, using an AUR manager
yourAURmanager -S base-devel
2020-05-02 21:14:19 +08:00
```
2020-06-19 21:14:12 +08:00
### macOS
2020-05-02 21:14:19 +08:00
Assuming you use [Homebrew](https://brew.sh/) to manage packages
```sh
brew install cmake
2020-05-02 21:14:19 +08:00
```
### Windows
To build Nimbus on windows, the Mingw-w64 build environment is recommened.
Install Mingw-w64 for your architecture using the "[MinGW-W64 Online Installer](https://sourceforge.net/projects/mingw-w64/files/)":
* select your architecture in the setup menu (`i686` on 32-bit, `x86_64` on 64-bit)
* set threads to `win32`
* set 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` (`C:\mingw-w64\mingw32\bin` on 32-bit)
Install [Git for Windows](https://gitforwindows.org/) and use a "Git Bash" shell to clone and build nimbus-eth2.
2020-05-02 21:14:19 +08:00
### Android
2020-06-19 21:14:12 +08:00
- Install the [Termux](https://termux.com) app from FDroid or the Google Play store
- Install a [PRoot](https://wiki.termux.com/wiki/PRoot) of your choice following the instructions for your preferred distribution.
2020-08-10 12:10:36 +02:00
Note, the Ubuntu PRoot is known to contain all Nimbus prerequisites compiled on Arm64 architecture (the most common architecture for Android devices).
2020-05-02 21:14:19 +08:00
2020-08-10 12:10:36 +02:00
Assuming you use Ubuntu PRoot
2020-05-02 21:14:19 +08:00
```sh
apt install build-essential git
2020-05-02 21:14:19 +08:00
```