A standalone mining implementation intended for mining epic against a running Epic node.
This branch is customized for RandomX using Johannes Hahn's randomx-rs repo so it will build and run on aarch64 Raspberry Pi4
git clone https://github.com/gbkelley/epic-miner-pi
cd epic-miner-pi
cargo build
Note: Sample Cargo.toml file included. Modify and leave in epic-server-pi folder. Leave hard_aes = false.
At present, only mining plugins for linux-x86_64 and MacOS exist. This will likely change over time as the community creates more solvers for different platforms.
-
The requirements for building the miner are the same from the epic server. You can check them in the topic Requirements in the Epic server build instructions
-
If you want to mine using CUDA (which requires an NVIDIA GPU):
- You will need the Cuda toolkit 9+ (you can check if you have it installed by executing the command in the terminal: nvcc --version)
-
If you want to mine using CPUs/GPUs
- You will need to install opencl-dev
For Debian-based distributions (Debian, Ubuntu, Mint, etc) you can install the opencl-dev with the following command in the terminal:
sudo apt install ocl-icd-opencl-dev
git clone https://gitlab.com/epiccash/epic-miner
cd epic-miner
git submodule update --init --recursive
To build the project you will have to specify if you are going to mine using only CPU
, OPENCL
or CUDA
. To mine using only CPU, execute the following line in the terminal:
cargo build
To mine using CPUs/GPUs use OPENCL
. Execute the following line in the terminal to build with OPENCL
:
cargo build --features opencl
If you have NVIDIA GPUs and your system has the latest nvidia drivers and the Cuda toolkit 9+ installed, you can build the cuda plugins using the following command:
cargo build --no-default-features --features cuda,tui
A successful build gets you:
target/debug/epic-miner
- the main epic-miner binarytarget/debug/plugins/*
- mining plugins
To run the epic-miner you also need an epic server (with the stratum server enabled) running and an epic wallet listening.
-
Instruction of how to run the epic server and the epic wallet (in listening mode) using the .deb packages can be found here.
-
If you want to build the epic server from source code, instructions can be found here.
-
If you want to build and execute epic wallet (in listening mode) from source code, instructions can be found here.
-
To enable the stratum server in the epic server, we need to edit the server configuration file called
epic-server.toml
. If you are using the epic server default configutation, this file is under your home directory in the folder~/.epic/main
. Open this file with your text editor and find the following line:enable_stratum_server = false
Then, change it to:
enable_stratum_server = true
More information about this can be found on the topic Configuring the Epic Server to work with the miner in the testnet documentation.
Make sure you always run epic-miner within a directory that contains an
epic-miner.toml
configuration file.
After you have your epic server running (with the stratum server enabled) and a wallet listening to it, to execute the epic miner follow the instructions:
-
Open a new terminal window in the root directory of your Epic miner installation.
-
To execute epic miner, you need to specify if you built it with
OPENCL
orCUDA
. To run the epic miner compiled withOPENCL
execute the following line in terminal:cargo run --features opencl
And to execute your miner built with the cuda plugin, execute the command:
cargo run --features cuda
Epic-miner can be further configured via the epic-miner.toml
file.
This file contains inline documentation on all configuration
options, and should be the first point of reference. Also, you can see Topic Configuring your epic-miner in the testnet documentation for further information.