Join our telegram Join our discord Visit our website
Deploy your VPS using our referral link to get 20€ bonus
Deploy your VPS using our referral link to get 100$ free bonus for 60 days
Deploy your VPS using our referral link to get 100$ free bonus
Official documentation:
Explorer:
To generate gentx for killerqueen-1 testnet please navigate to Generate gentx for killerqueen-1 testnet
To set up monitoring for your validator node navigate to Set up monitoring and alerting for quicksilver validator
To migrate your validator to another machine read Migrate your validator to another machine
Like any Cosmos-SDK chain, the hardware requirements are pretty modest.
- 3x CPUs; the faster clock speed the better
- 4GB RAM
- 80GB Disk
- Permanent Internet connection (traffic will be minimal during testnet; 10Mbps will be plenty - for production at least 100Mbps is expected)
- 4x CPUs; the faster clock speed the better
- 8GB RAM
- 200GB of storage (SSD or NVME)
- Permanent Internet connection (traffic will be minimal during testnet; 10Mbps will be plenty - for production at least 100Mbps is expected)
You can setup your quicksilver fullnode in few minutes by using automated script below. It will prompt you to input your validator node name!
wget -O quicksilver.sh https://raw.githubusercontent.com/kj89/testnet_manuals/main/quicksilver/quicksilver.sh && chmod +x quicksilver.sh && ./quicksilver.sh
You can follow manual guide if you better prefer setting up node manually
When installation is finished please load variables into system
source $HOME/.bash_profile
Next you have to make sure your validator is syncing blocks. You can use command below to check synchronization status
quicksilverd status 2>&1 | jq .SyncInfo
Once the chain reaches the upgrade height, you will encounter the following panic error message:
ERR UPGRADE "upgrade-v0.4.1" NEEDED at height: 98000
cd $HOME
rm quicksilver -rf
git clone https://github.com/ingenuity-build/quicksilver.git --branch v0.4.1
cd quicksilver
make build
sudo chmod +x ./build/quicksilverd && sudo mv ./build/quicksilverd /usr/local/bin/quicksilverd
sudo systemctl restart quicksilverd
Once the chain reaches the upgrade height, you will encounter the following panic error message:
ERR UPGRADE "upgrade-v0.4.2" NEEDED at height: 212000
cd $HOME
rm quicksilver -rf
git clone https://github.com/ingenuity-build/quicksilver.git --branch v0.4.2
cd quicksilver
make build
sudo chmod +x ./build/quicksilverd && sudo mv ./build/quicksilverd /usr/local/bin/quicksilverd
sudo systemctl restart quicksilverd
To create new wallet you can use command below. Don’t forget to save the mnemonic
quicksilverd keys add $WALLET
(OPTIONAL) To recover your wallet using seed phrase
quicksilverd keys add $WALLET --recover
To get current list of wallets
quicksilverd keys list
Add wallet and valoper address and load variables into the system
QUICKSILVER_WALLET_ADDRESS=$(quicksilverd keys show $WALLET -a)
QUICKSILVER_VALOPER_ADDRESS=$(quicksilverd keys show $WALLET --bech val -a)
echo 'export QUICKSILVER_WALLET_ADDRESS='${QUICKSILVER_WALLET_ADDRESS} >> $HOME/.bash_profile
echo 'export QUICKSILVER_VALOPER_ADDRESS='${QUICKSILVER_VALOPER_ADDRESS} >> $HOME/.bash_profile
source $HOME/.bash_profile
In order to create validator first you need to fund your wallet with testnet tokens. To top up your wallet join Quicksilver discord server to access the faucets for QCK and ATOM. Make sure you are in the appropriate channel
- #qck-tap for QCK tokens
- #atom-tap for ATOM tokens
To check the faucet address:
$<YOUR_WALLET_ADDRESS> rhapsody
To check your balance:
$balance <YOUR_WALLET_ADDRESS> rhapsody
To request a faucet grant:
$request <YOUR_WALLET_ADDRESS> rhapsody
Before creating validator please make sure that you have at least 1 qck (1 qck is equal to 1000000 uqck) and your node is synchronized
To check your wallet balance:
quicksilverd query bank balances $QUICKSILVER_WALLET_ADDRESS
If your wallet does not show any balance than probably your node is still syncing. Please wait until it finish to synchronize and then continue
To create your validator run command below
quicksilverd tx staking create-validator \
--amount 1000000uqck \
--from $WALLET \
--commission-max-change-rate "0.01" \
--commission-max-rate "0.2" \
--commission-rate "0.07" \
--min-self-delegation "1" \
--pubkey $(quicksilverd tendermint show-validator) \
--moniker $NODENAME \
--chain-id $QUICKSILVER_CHAIN_ID
To protect you keys please make sure you follow basic security rules
Good tutorial on how to set up ssh keys for authentication to your server can be found here
Start by checking the status of ufw.
sudo ufw status
Sets the default to allow outgoing connections, deny all incoming except ssh and 26656. Limit SSH login attempts
sudo ufw default allow outgoing
sudo ufw default deny incoming
sudo ufw allow ssh/tcp
sudo ufw limit ssh/tcp
sudo ufw allow ${QUICKSILVER_PORT}656,${QUICKSILVER_PORT}660/tcp
sudo ufw enable
To monitor and get alerted about your validator health status you can use my guide on Set up monitoring and alerting for quicksilver validator
This script will help you to estimate how much time it will take to fully synchronize your node
It measures average blocks per minute that are being synchronized for period of 5 minutes and then gives you results
wget -O synctime.py https://raw.githubusercontent.com/kj89/testnet_manuals/main/quicksilver/tools/synctime.py && python3 ./synctime.py
quicksilverd q staking validators -oj --limit=3000 | jq '.validators[] | select(.status=="BOND_STATUS_BONDED")' | jq -r '(.tokens|tonumber/pow(10; 6)|floor|tostring) + " \t " + .description.moniker' | sort -gr | nl
curl -sS http://localhost:${QUICKSILVER_PORT}657/net_info | jq -r '.result.peers[] | "\(.node_info.id)@\(.remote_ip):\(.node_info.listen_addr)"' | awk -F ':' '{print $1":"$(NF)}'
Check logs
journalctl -fu quicksilverd -o cat
Start service
sudo systemctl start quicksilverd
Stop service
sudo systemctl stop quicksilverd
Restart service
sudo systemctl restart quicksilverd
Synchronization info
quicksilverd status 2>&1 | jq .SyncInfo
Validator info
quicksilverd status 2>&1 | jq .ValidatorInfo
Node info
quicksilverd status 2>&1 | jq .NodeInfo
Show node id
quicksilverd tendermint show-node-id
List of wallets
quicksilverd keys list
Recover wallet
quicksilverd keys add $WALLET --recover
Delete wallet
quicksilverd keys delete $WALLET
Get wallet balance
quicksilverd query bank balances $QUICKSILVER_WALLET_ADDRESS
Transfer funds
quicksilverd tx bank send $QUICKSILVER_WALLET_ADDRESS <TO_QUICKSILVER_WALLET_ADDRESS> 10000000uqck
quicksilverd tx gov vote 1 yes --from $WALLET --chain-id=$QUICKSILVER_CHAIN_ID
Delegate stake
quicksilverd tx staking delegate $QUICKSILVER_VALOPER_ADDRESS 10000000uqck --from=$WALLET --chain-id=$QUICKSILVER_CHAIN_ID --gas=auto
Redelegate stake from validator to another validator
quicksilverd tx staking redelegate <srcValidatorAddress> <destValidatorAddress> 10000000uqck --from=$WALLET --chain-id=$QUICKSILVER_CHAIN_ID --gas=auto
Withdraw all rewards
quicksilverd tx distribution withdraw-all-rewards --from=$WALLET --chain-id=$QUICKSILVER_CHAIN_ID --gas=auto
Withdraw rewards with commision
quicksilverd tx distribution withdraw-rewards $QUICKSILVER_VALOPER_ADDRESS --from=$WALLET --commission --chain-id=$QUICKSILVER_CHAIN_ID
Edit validator
quicksilverd tx staking edit-validator \
--moniker=$NODENAME \
--identity=<your_keybase_id> \
--website="<your_website>" \
--details="<your_validator_description>" \
--chain-id=$QUICKSILVER_CHAIN_ID \
--from=$WALLET
Unjail validator
quicksilverd tx slashing unjail \
--broadcast-mode=block \
--from=$WALLET \
--chain-id=$QUICKSILVER_CHAIN_ID \
--gas=auto
This commands will completely remove node from server. Use at your own risk!
sudo systemctl stop quicksilverd
sudo systemctl disable quicksilverd
sudo rm /etc/systemd/system/quicksilver* -rf
sudo rm $(which quicksilverd) -rf
sudo rm $HOME/.quicksilver* -rf
sudo rm $HOME/quicksilver -rf