diff --git a/doc/src/SUMMARY.md b/doc/src/SUMMARY.md index 45e49d2ac..018d7d28a 100644 --- a/doc/src/SUMMARY.md +++ b/doc/src/SUMMARY.md @@ -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 diff --git a/doc/src/testnet/merge-mining.md b/doc/src/testnet/merge-mining.md index 9bf3005f0..82579a625 100644 --- a/doc/src/testnet/merge-mining.md +++ b/doc/src/testnet/merge-mining.md @@ -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 diff --git a/doc/src/testnet/node.md b/doc/src/testnet/node.md index 3be3675fd..43244cc74 100644 --- a/doc/src/testnet/node.md +++ b/doc/src/testnet/node.md @@ -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