Skip to content

fredericzha/aionr

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

AionR

Join the chat at https://gitter.im/aionnetwork license contributions welcome

drawing

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.

Install the Kernel

Follow this guide to install the Aion Rust kernel on your system.

System Requirements

  • Ubuntu 16.04 or Ubuntu 18.04
  • 4GB RAM
  • 2 core CPU
  • 24GB Hard Drive Space (Mainnet DB about 12GB)

Prerequisites Installation

  1. 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
  2. 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.

  3. Initialize the Rust install and check that it is working:

    source $HOME/.cargo/env
    cargo --version
    
    > cargo 1.28.0 (96a2c7d16 2018-07-13)
  4. 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
  5. Install ZMQ:

    sudo apt-get install libzmq3-dev -y
  6. 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 your PATH once Profobuf is installed.

Build the Kernel

Once you have installed the prerequisites, follow these steps to build the kernel.

  1. Download the Aion Rust git repository:

    git clone https://github.com/aionnetwork/aionr.git
    cd aionr
  2. 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.

  3. When the build has finished, you can find the finished binary at package/aionr-package.

Launch Aion Rust Kernel

  1. Navigate to the binary location:

    cd package/aionr-package
  2. 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

Connecting to JSON RPC Services

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.

Miners

If you're interested in mining on the Aion networks, refer to our Aion Mining Docs

Users

If you're interested in interacting with blockchain applications and using AION coins, refer to our Aion Desktop Wallet Docs.

Contact

To keep up to date by joining the following channels:

For more information about Aion Community please refer to Aion Community

License

Aion is released under the GPL-V3 license

About

Aion Network - Rust Implementation

Resources

License

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Rust 79.1%
  • C++ 20.2%
  • C 0.3%
  • CMake 0.3%
  • Python 0.1%
  • Shell 0.0%