Testnet setup guide for running a DMD Diamond v4 Blockchain Node. This guide has been developed for ubuntu 18 and ubuntu 20 systems. We suggest Ubuntu 20.04 LTS.
Copy the file from this repository on your node software. A convenient way to do that, is using git to download and keeping your tools up to date.
# install git
apt install git -y
# clone repository for the dmdv4 testnet
git clone https://github.com/DMDcoin/dmdv4-testnet.git
# switch into the new directory
cd dmdv4-testnet
# downloads binaries and mark them executable.
Now you need to build diamond-node. This involves 2 steps: preparing your machine to be able to build. and building.
# preparing the build environment for you machine has to be done only once
./setup-build-from-source.sh
The build script get's the latest source version, and builds the binaries. This can take up to an hour depending of the performance of the machine.
./build-from-source.sh
Running a validator Node without participating as validator is relativly easy.
run
# starts diamond-node, using a full node configuration.
./diamond-node -c=fullnode.toml
This section of the guide is currently for invited closed alpha users only.
Running a validator node is a bit more complex, since it requires a dedicated unlocked account to allow the hbbft engine to sign your block contributions.
# create a mining key for your new node.
# there are 2 locations where your mining key get's stored:
# - ./data/keys/DPoSChain/dmd_miner_key.json in keystore format.
# - ./data/network/key in private key format.
# this tool simplifies that job for you.
./dmd create_miner
copy your public key for later usage copy your address to the clipboard
open the example config in your favorite text editor like
# copy the template we prepared.
cp template-validator.toml validator_node.toml
# edit the config file.
nano validator_node.toml
replace the two occurences of put your address here
with your address that got just generated.
# starts your Node using the new config file.
./start.sh
You should verify the log output if the enode id contains the public key you have created with the dmd tool. Verify that the node is able to sync to the latest state of the blockchain.
Node that the hbbft consensus algorithm is not prone to forks, either it creates blocks, or it get's stuck.
If your node ends up importing individual blocks every now and then, that is a good sign that it is in sync.
INFO import Imported #1040 0xabfe…f189 (0 txs, 0.00 Mgas, 29 ms, 0.56 KiB)
Another source what is the latest block can be found here: http://explorer.uniq.diamonds
You need to have a web3 wallet that supports the DMD Diamond v4 Network, such as Metamask Browser Extension or the Brave Browser.
You need to add the DMD Network:
Network Name: DMDv4 Alpha4
RPC URL: http://rpc.uniq.diamonds:8540
Chain ID: 777012
Symbol: tDMD
Block Explorer URL: http://explorer.uniq.diamonds/
If you want to use your own server as RPC Endpoint instead, you can also spin up your own RPC Server with ./diamond-node -c=rpcnode.toml
and replace the url: 93.104.209.46 with the IP Address of your own Server.
Now your wallet should be connected to the network, so let us know what is your address - so we can fund you for the next step.
Once your node is running and you have 10000 tDMD, you can visit http://staking.uniq.diamonds/
Now you need your public key from the setup step again.
If you don't have it anymore, and you used the dmd tool, your public key is written to ./public_key.txt
Your public key is also outputed when you start your node Public node URL:
devp2p2 INFO network Public node URL: enode://123abc..567def@127.0.0.1:30301
The hex numeric section in the middle of your enode is your public key.
Enter this public key without leading 0x in the input field public key
in the staking UI.
If everything is alright, the tool will calculate a 'mining key'.
This 'mining key' must be the same that you had configured in the 'validator_node.toml'.
For staking amount (DMD)
choose a value between 10000 and 50000.
When you click the Add Pool
button, your wallet should ask for confirmation.
After confirmation, your Pool should become available.
To achieve that your node remains available you should run it in a screen, a tmux session, or as a systemd service, or a similar solution.
screen is installed by default on most systems.
Just do
screen
# (you will be forwarded to a new terminal session)
# now, start your node here
./diamond-node -c=validator_node.toml
# now you can press (CTRL+a), d to detach from your session again.
# OR just close the terminal program you are using.
check if it works, by reattaching to your screen session
screen -r