This repository contains the rust kernel implementation and releases for the Aion Network. This is different from the Java kernel implementation.
Mainstream adoption of blockchains is limited because of scalability, privacy, and interoperability challenges. Aion is a multi-tier blockchain network designed to address these challenges.
The Aion White Papers provides more details on our design and project roadmap.
Follow this guide to install the Aion Rust kernel on your system.
- Ubuntu 16.04 or Ubuntu 18.04
- 4GB RAM
- 2 core CPU
- 24GB Hard Drive Space (Mainnet DB about 12GB)
-
Update your system and install the build dependencies:
sudo apt-get update sudo apt install g++ gcc libjsoncpp-dev python-dev libudev-dev llvm-4.0-dev cmake wget curl git pkg-config lsb-release -y
-
Install Rust
v1.28.0
:curl https://sh.rustup.rs -sSf | sh -s -- --default-toolchain 1.28.0 --default-host x86_64-unknown-linux-gnu
Select option
1
when prompted. -
Initialize the Rust install and check that it is working:
source $HOME/.cargo/env cargo --version > cargo 1.28.0 (96a2c7d16 2018-07-13)
-
Install Boost
v1.65.1
-
Ubuntu
16.04
:wget https://dl.bintray.com/boostorg/release/1.65.1/source/boost_1_65_1.tar.bz2 tar xf boost_1_65_1.tar.bz2 cd boost_1_65_1 ./bootstrap.sh --libdir=/usr/lib/x86_64-linux-gnu/ ./b2 ./b2 install
-
Ubuntu
18.04
:sudo apt-get install libboost-all-dev -y
-
-
Install ZMQ:
sudo apt-get install libzmq3-dev -y
-
This step is optional. If you plan on modifying the Protobuf message, you need to install Google Protobuf. You will also need to make sure that
protoc
is added to yourPATH
once Profobuf is installed.
Once you have installed the prerequisites, follow these steps to build the kernel.
-
Download the Aion Rust git repository:
git clone https://github.com/aionnetwork/aionr.git cd aionr
-
Build the kernel from source:
./scripts/package.sh aionr-package
aionr-package
is the name that will be given to the Rust package when it as finished building. You can set this to anything you want by changing the last argument in the script call:./scripts/package.sh example-package-name
The package takes about 10 minutes to finish building.
-
When the build has finished, you can find the finished binary at
package/aionr-package
.
-
Navigate to the binary location:
cd package/aionr-package
-
Run the
aion
package. Make sure to include any commands you want the kernel to execute. You can find more information on supplying commands in the user manual. Kernel will print configuration path, genesis file path, db directory and keystore location at the top of its log.
$ ./aion
> Create config file /home/aion/.aion/config.toml, you can modify it if needed
> 2019-01-23 09:12:40 Config path /home/aion/.aion/config.toml
> 2019-01-23 09:12:40 Load built-in Mainnet Genesis Spec.
> 2019-01-23 09:12:40 Keys path /home/aion/.aion/keys/mainnet
> 2019-01-23 09:12:40 DB path /home/aion/.aion/chains/mainnet/db/a98e36807c1b0211
> 2019-01-23 09:12:40
> _____ ____ _ _
> /\ |_ _| / __ \ | \ | |
> / \ | | | | | | | \| |
> / /\ \ | | | | | | | . ` |
> / ____ \ _| |_ | |__| | | |\ |
> /_/ \_\ |_____| \____/ |_| \_|
>
>
> 2019-01-23 09:12:40 Starting Aion(R)/v0.1.1.f9610e1/x86_64-linux-gnu/rustc-1.28.0
> 2019-01-23 09:12:40 Configured for Mainnet using POWEquihashEngine engine
> 2019-01-23 09:12:41 Genesis hash: 30793b4ea012c6d3a58c85c5b049962669369807a98e36807c1b02116417f823
> 2019-01-23 09:12:41 State DB configuration: archive
> 2019-01-23 09:12:41 Wallet API is disabled.
> 2019-01-23 09:12:41 local node loaded: [email protected]:30303
> 2019-01-23 09:12:46 Listening on: 0.0.0.0:30303
> 2019-01-23 09:12:46 Local node fill back!
> 2019-01-23 09:12:46 ======================================================== Sync Statics =========================================================
We provides quick launch scripts to connect to Mainnet, Mastery and custom network. Running the quick scripts will load the configuration and the genesis in each network folder. You can modify those files in each directory. See launch examples Kernel Deployment Examples
RPC services can be connected from the following addresses:
- HTTP: Port
8545
- WebSocket: Port
8546
- ICP:
$Home/.aion/jsonrpc.ipc
See the user manual or CMD & Config wiki to find how to change RPC port settings.
If you're interested in mining on the Aion networks, refer to our Aion Mining Docs
If you're interested in interacting with blockchain applications and using AION
coins, refer to our Aion Desktop Wallet Docs.
To keep up to date by joining the following channels:
For more information about Aion Community please refer to Aion Community
Aion is released under the GPL-V3 license