doc/testnet/merge-mining: more descriptive steps added

This commit is contained in:
skoupidi
2025-11-24 15:49:56 +02:00
parent 3ddfe3a608
commit b4a9071da2
3 changed files with 137 additions and 62 deletions

View File

@@ -17,6 +17,7 @@
- [Atomic Swap](testnet/atomic-swap.md)
- [DAO](testnet/dao.md)
- [Contracts](testnet/contract.md)
- [Merge Mining](testnet/merge-mining.md)
- [DarkIRC](misc/darkirc/darkirc.md)
- [Private Message](misc/darkirc/private_message.md)
- [Node Configurations](misc/nodes/node-configurations.md)
@@ -25,7 +26,6 @@
- [I2p Nodes](misc/nodes/i2p-guide.md)
- [Nym Nodes](misc/nodes/nym-guide.md)
- [Network Troubleshooting](misc/network-troubleshooting.md)
- [Merge Mining](testnet/merge-mining.md)
# Developer Doc

View File

@@ -1,52 +1,123 @@
DarkFi x Monero Merge Mining using p2pool and xmrig
===================================================
**DISCLAIMER: This is a work in progress and not available on the
current deployed testnet as of 22-May-2025.**
DarkFi x Monero Merge Mining using `p2pool` and `xmrig`
=======================================================
This document provides a way to set up a Monero testnet that is
able to merge-mine DarkFi using p2pool.
able to merge-mine DarkFi using `p2pool` and `xmrig`.
Please read the whole document first before executing commands, to
understand all the steps required and how each component operates.
Unless instructed otherwise, each daemon runs on its own shell, so
don't stop a running one to start another.
Each command to execute will be inside a codeblock, on its first line,
marked by the user `$` symbol, followed by the expected output. For
longer command outputs, some lines will be emmited to keep the guide
simple.
## Build binaries from source
We can build Monero, p2pool, and xmrig from their respective source
code repositories.
We can build Monero, `p2pool` and `xmrig` from their respective source
code repositories. Make sure you are not in the DarkFi repository
folder as we are going to retrieve external repos.
For Monero, we'll take the latest release tag:
### Monero
```
First install its [dependencies][1] and then retrieve its repo and
checkout the latest release tag:
```shell
$ git clone --recursive https://github.com/monero-project/monero
$ git checkout v0.18.4.0
$ cd monero
$ git checkout $(git describe --tags "$(git rev-list --tags --max-count=1)")
$ git submodule update --init
```
Now we can build it:
```shell
$ make -j$(nproc)
...
make[1]: Leaving directory '/home/anon/monero/build/Linux/_HEAD_detached_at_v0.18.4.4_/release'
```
Navigate to the directory listed at the end of build command where the
compiled binaries exist:
```shell
$ cd build/Linux/_HEAD_detached_at_v0.18.4.4_/release
$ cd bin
```
The path might look different in your system depending on your OS and
latest tag.
### p2pool
Enter a new shell outside of previously build Monero repo folder,
install `p2pool` [dependencies][2] and then retrieve its repo and
checkout the latest release tag:
```shell
$ git clone --recursive https://github.com/SChernykh/p2pool
$ cd p2pool
$ git checkout $(git describe --tags "$(git rev-list --tags --max-count=1)")
$ git submodule update --init
```
Now we can build it:
```shell
$ mkdir build
```
If you have already build `p2pool` above command will fail as folder
already exists, so just continue to next ones:
```shell
$ cd build
$ cmake ..
$ make -j$(nproc)
```
Same for p2pool:
The binary now exists in the current directory.
```
$ git clone --recursive https://github.com/SChernykh/p2pool
$ git checkout v4.6
$ mkdir build && cd build && cmake .. && make -j$(nproc)
```
### xmrig
And xmrig:
Enter a new shell outside of previously build `p2pool` repo folder,
install `xmrig` [dependencies][3] and then retrieve its repo and
checkout the latest release tag:
```
$ git clone --recursive https://github.com/xmrig/xmrig
$ git checkout v6.22.2
$ mkdir build && cd build && cmake .. && make -j$(nproc)
$ cd xmrig
$ git checkout $(git describe --tags "$(git rev-list --tags --max-count=1)")
```
Copy the resulting binaries into a working directory where we'll be
doing the network setup. We'll need `monerod`, `monero-wallet-cli`,
`p2pool`, and `xmrig`.
Now we can build it:
```shell
$ mkdir build
```
If you have already build `xmrig` above command will fail as folder
already exists, so just continue to next ones:
```shell
$ cd build
$ cmake ..
$ make -j$(nproc)
```
The binary now exists in the current directory.
## Monero setup
We should first sync the Monero Testnet locally. We can simply do this
by starting up `monerod` and waiting for the sync to finish:
by returning back to our Monero shell, starting up `monerod` and
waiting for the sync to finish:
```
```shell
$ ./monerod --testnet --no-igd --data-dir bitmonero --log-level 0 --hide-my-port --add-peer 125.229.105.12:28081 --add-peer 37.187.74.171:28089 --fast-block-sync=1
2025-05-22 13:04:16.492 I Synced 3601/2754128 (0%, 2750527 left)
@@ -61,41 +132,41 @@ After the sync is finished, we will take the node offline and continue
our work locally. So quit the `monerod` node, and restart it offline
with fixed difficulty that will make our mining process faster:
```
```shell
$ ./monerod --testnet --no-igd --data-dir bitmonero --log-level 1 --hide-my-port --fixed-difficulty 20000 --disable-rpc-ban --offline --zmq-pub tcp://127.0.0.1:28083
```
Now we should also create a Monero wallet. Run `monero-wallet-cli` and
follow the wizard to create a wallet:
Now we should also create a Monero wallet. On a new shell in the same
directory run `monero-wallet-cli` and follow the wizard to create a
wallet:
```
```shell
$ ./monero-wallet-cli --testnet --trusted-daemon
Generated new wallet: 9zMUzh73iWm5pXha95quaQjW1BnL5w2kBA8np1RqNsaSKoK7nA3ZPg1VPmtpHjhDV1WHd6sVyuePPGdaWiQqyQTcN6RuQA4
Generated new wallet: 9zMU...uQA4
View key: xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
**********************************************************************
Your wallet has been generated!
```
Now we have our Monero address `9zMUzh73iWm5pXha95quaQjW1BnL5w2kBA8np1RqNsaSKoK7nA3ZPg1VPmtpHjhDV1WHd6sVyuePPGdaWiQqyQTcN6RuQA4`
that we can use with p2pool to receive mining rewards.
Now we have our Monero address that we can use with p2pool to receive
mining rewards.
## p2pool setup (without merge-mining)
First we'll start p2pool without merge-mining to make sure everything
works in order. After we get xmrig set up, we'll restart p2pool with
merge-mining enabled.
First we'll start `p2pool` without merge-mining to make sure everything
works in order. After we get `xmrig` set up, we'll restart `p2pool`
with merge-mining enabled.
p2pool connects to `monerod`'s JSONRPC and ZMQ Pub ports in order to
`p2pool` connects to `monerod`'s JSONRPC and ZMQ Pub ports in order to
retrieve necessary mining data. It also provides a Stratum mining
endpoint that `xmrig` is able to connect to in order to receive
mining jobs and actually mine the proposed blocks.
endpoint that `xmrig` is able to connect to in order to receive mining
jobs and actually mine the proposed blocks.
We can start p2pool with the following command:
We can start `p2pool` with the following command:
```
$ ./p2pool --host 127.0.0.1 --rpc-port 28081 --zmq-port 28083 --wallet 9zMUzh73iWm5pXha95quaQjW1BnL5w2kBA8np1RqNsaSKoK7nA3ZPg1VPmtpHjhDV1WHd6sVyuePPGdaWiQqyQTcN6RuQA4 --stratum 127.0.0.1:3333 --data-dir ./p2pool-data --no-igd
```shell
$ ./p2pool --host 127.0.0.1 --rpc-port 28081 --zmq-port 28083 --wallet {YOUR_WALLET_ADDRESS_HERE} --stratum 127.0.0.1:3333 --data-dir ./p2pool-data --no-igd
```
Once started, it should connect to `monerod` and retrieve the latest
@@ -104,13 +175,13 @@ blocks.
## xmrig setup
xmrig is pretty simple. Just start it with a chosen number of threads
and point it to p2pool's Stratum port. `-u x+1 20000` is defined by the
`xmrig` is pretty simple. Just start it with a chosen number of threads
and point it to `p2pool` Stratum port. `-u x+1 20000` is defined by the
`--fixed-difficulty` setting we started `monerod` with. `-t 1` is the
number of CPU threads to use for mining. With a low difficulty, one
thread should be enough.
```
```shell
$ ./xmrig -u x+1 20000 -o 127.0.0.1:3333 -t 1
```
@@ -120,38 +191,39 @@ or press `p` to pause mining.
## p2pool setup (with merge-mining)
Now that everything is in order, we can use p2pool with merge-mining
Now that everything is in order, we can use `p2pool` with merge-mining
enabled in order to merge mine DarkFi. For receiving mining rewards
on DarkFi, we'll need a DarkFi wallet address. In this example we'll
use the following:
```
GCP5e1aGWPTy347WzAbn4uA5yT8mzQ25GV3gpp3MBihS
```
on DarkFi, we'll need a DarkFi wallet address so make sure you have
[initialized](node.md#wallet-initialization) your wallet and grab your
address.
We will also need `darkfid` running. Make sure you enable the RPC
endpoint that will be used by p2pool in darkfid's config:
```
```toml
[network_config."testnet".mm_rpc]
rpc_listen = "http+tcp://127.0.0.1:8341"
```
Then start `darkfid` as usual.
Stop p2pool if it's running, and re-run it with the merge-mining
Stop `p2pool` if it's running, and re-run it with the merge-mining
parameters appended:
```
```shell
$ ./p2pool --host 127.0.0.1 --rpc-port 28081 --zmq-port 28083 --wallet 9zMUzh73iWm5pXha95quaQjW1BnL5w2kBA8np1RqNsaSKoK7nA3ZPg1VPmtpHjhDV1WHd6sVyuePPGdaWiQqyQTcN6RuQA4 --stratum 127.0.0.1:3333 --data-dir ./p2pool-data --no-igd --merge-mine 127.0.0.1:8341 GCP5e1aGWPTy347WzAbn4uA5yT8mzQ25GV3gpp3MBihS
```
Now p2pool should communicate with both `monerod` and `darkfid` in
order to pick up Monero blocktemplates and inject them with DarkFi
data necessary for merge-mining verification on the DarkFi side.
Re-run xmrig and now we should be mining blocks again. Once blocks
are found, they will be submitted to both `monerod` and `darkfid` and
Now `p2pool` should communicate with both `monerod` and `darkfid` in
order to pick up Monero blocktemplates and inject them with DarkFi data
necessary for merge-mining verification on the DarkFi side. Re-run
`xmrig` and now we should be mining blocks again. Once blocks are
found, they will be submitted to both `monerod` and `darkfid` and
`darkfid` should verify them and release block rewards to the address
provided to p2pool's merge-mine parameters.
provided to `p2pool` merge-mine parameters.
Happy mining!
[1]: https://github.com/monero-project/monero?tab=readme-ov-file#dependencies
[2]: https://github.com/SChernykh/p2pool?tab=readme-ov-file#prerequisites
[3]: https://xmrig.com/docs/miner/build

View File

@@ -1,6 +1,9 @@
Compiling and Running a Node
=========================
**DISCLAIMER: This is a work in progress and functionalities may not be
available on the current deployed testnet as of 22-May-2025.**
Please read the whole document first before executing commands, to
understand all the steps required and how each component operates.
Unless instructed otherwise, each daemon runs on its own shell, so don't