Minimum hardware requirements:
1) Auto_install script
source <(curl -s https://raw.githubusercontent.com/111STAVR111/props/refs/heads/main/Kyve/Testnet/kyvet)
2) Manual installation
Preparing the server
sudo apt update && sudo apt upgrade -y
sudo apt install curl tar wget clang pkg-config libssl-dev jq build-essential bsdmainutils git make ncdu gcc git jq chrony liblz4-tool -y
GO 1.21.6
ver="1.21.6"
wget "https://golang.org/dl/go$ver.linux-amd64.tar.gz"
sudo rm -rf /usr/local/go
sudo tar -C /usr/local -xzf "go$ver.linux-amd64.tar.gz"
rm "go$ver.linux-amd64.tar.gz"
echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.bash_profile
source $HOME/.bash_profile
go version
Build 28.03.25
cd $HOME && mkdir -p go/bin/
wget -O kyved https://github.com/KYVENetwork/chain/releases/download/v2.0.0-kaon2/kyved_kaon_linux_amd64
chmod +x kyved
sudo mv kyved $HOME/go/bin/kyved
kyved version --long | grep -e commit -e version
commit: e7aa07bdf93d0314d5d3a53e657d6b0607bc500f
Initiation
kyved init STAVR_guide --chain-id=kaon-1
Create/recover wallet
kyved keys add <walletname>
OR
kyved keys add <walletname> --recover
Download Genesis and Addrbook
wget -L -O $HOME/.kyve/config/genesis.json https://server-1.stavr.tech/Testnet/Kyve/genesis.json
wget -O $HOME/.kyve/config/addrbook.json "https://server-1.stavr.tech/Testnet/Kyve/addrbook.json"
sha256sum $HOME/.kyve/config/genesis.json
fd509e5d7142374288f4a8cb6bd1752f02aa2911587c33b195944cddbe7b8e7a
Set up the minimum gas price and Peers/Seeds/Filter peers/MaxPeers
sed -i.bak -e "s/^minimum-gas-prices *=.*/minimum-gas-prices = \"0.0tkyve\"/;" ~/.kyve/config/app.toml
sed -i -e "s/^filter_peers *=.*/filter_peers = \"true\"/" $HOME/.kyve/config/config.toml
external_address=$(wget -qO- eth0.me)
sed -i.bak -e "s/^external_address *=.*/external_address = \"$external_address:26656\"/" $HOME/.kyve/config/config.toml
peers=""
sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \"$peers\"/" $HOME/.kyve/config/config.toml
seeds=""
sed -i.bak -e "s/^seeds =.*/seeds = \"$seeds\"/" $HOME/.kyve/config/config.toml
sed -i 's/max_num_inbound_peers =.*/max_num_inbound_peers = 50/g' $HOME/.kyve/config/config.toml
sed -i 's/max_num_outbound_peers =.*/max_num_outbound_peers = 10/g' $HOME/.kyve/config/config.toml
Pruning (optional)
pruning="custom"
pruning_keep_recent="1000"
pruning_keep_every="0"
pruning_interval="10"
sed -i -e "s/^pruning *=.*/pruning = \"$pruning\"/" $HOME/.kyve/config/app.toml
sed -i -e "s/^pruning-keep-recent *=.*/pruning-keep-recent = \"$pruning_keep_recent\"/" $HOME/.kyve/config/app.toml
sed -i -e "s/^pruning-keep-every *=.*/pruning-keep-every = \"$pruning_keep_every\"/" $HOME/.kyve/config/app.toml
sed -i -e "s/^pruning-interval *=.*/pruning-interval = \"$pruning_interval\"/" $HOME/.kyve/config/app.toml
Indexer (optional)
indexer="null" &&
sed -i -e "s/^indexer *=.*/indexer = \"$indexer\"/" $HOME/.kyve/config/config.toml
Create a service file
sudo tee /etc/systemd/system/kyved.service > /dev/null <<EOF
[Unit]
Description=kyve
After=network-online.target
[Service]
User=$USER
ExecStart=$(which kyved) start
Restart=on-failure
RestartSec=3
LimitNOFILE=65535
[Install]
WantedBy=multi-user.target
EOF
StateSync Kyve Testnet
SnapShot Mainnet updated every 5 hours
Start
sudo systemctl daemon-reload
sudo systemctl enable kyved
sudo systemctl restart kyved && sudo journalctl -fu kyved -o cat
Create validator
#pubkey
kyved tendermint show-validator --home $HOME/.kyve
cd $HOME
nano $HOME/.kyve/validator.json
{
"pubkey": {"@type":"/cosmos.crypto.ed25519.PubKey","key":"gGxxxxxxxxxxxxxxxxxxxxxxxxxxEgQ0vsnRjPlA="},
"amount": "1000000tkyve",
"moniker": "",
"identity": "F2F91999ECCC092F",
"website": "https://stavr.tech",
"security": "",
"details": "",
"commission-rate": "0.05",
"commission-max-rate": "0.2",
"commission-max-change-rate": "0.2",
"min-self-delegation": "1"
}
kyved --home $HOME/.kyve tx staking create-validator $HOME/.kyve/validator.json --from WalletName --chain-id kaon-1 --fees 160224334tkyve --gas 80112167 -y
Monitoring
Security
You can create secure management of your wallet and your node by following this links.
Delete node
sudo systemctl stop kyved
sudo systemctl disable kyved
rm /etc/systemd/system/kyved.service
sudo systemctl daemon-reload
cd $HOME
rm -rf .kyve
rm -rf $(which kyved)