Minimum hardware requirements :
1) Auto_install script
Copy source <( curl -s https://raw.githubusercontent.com/111STAVR111/props/refs/heads/main/Planq/planqm )
2) Manual installation
Preparing the server
Copy 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.23.1
Copy ver = "1.23.1"
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 23.10.24
Copy cd $HOME && mkdir -p go/bin/
git clone https://github.com/planq-network/planq.git
cd planq
git checkout v2.0.5
make install
planqd version --long | grep -e commit -e version
commit: d189923e07ec90d66f9bc7b0dde80c51ada519d6
Initiation
Copy planqd init STAVR_guide --chain - id = planq_7070 - 2
planqd config chain - id planq_7070 - 2
Create/recover wallet
Copy planqd keys add < walletnam e >
OR
planqd keys add < walletnam e > --recover
Download Genesis
Copy wget -L -O $HOME /.planqd/config/genesis.json https://server-1.stavr.tech/Mainnet/Planq/genesis.json
sha256sum $HOME/.planqd/config/genesis.json
a4bca4e9d4de3ee747452aa5dcd80acebb6a69e99dd19b5ce0af1c6606d847f7
Set up the minimum gas price and Peers/Seeds/Filter peers/MaxPeers
Copy sed -i.bak -e "s/^minimum-gas-prices *=.*/minimum-gas-prices = \"0aplanq\"/;" ~/.planqd/config/app.toml
external_address = $( wget -qO- eth0.me )
sed -i.bak -e "s/^external_address *=.*/external_address = \"$external_address:26656\"/" $HOME /.planqd/config/config.toml
peers = ""
sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \"$peers\"/" $HOME /.planqd/config/config.toml
seeds = ""
sed -i.bak -e "s/^seeds =.*/seeds = \"$seeds\"/" $HOME /.planqd/config/config.toml
sed -i 's/max_num_inbound_peers =.*/max_num_inbound_peers = 50/g' $HOME /.planqd/config/config.toml
sed -i 's/max_num_outbound_peers =.*/max_num_outbound_peers = 50/g' $HOME /.planqd/config/config.toml
Pruning (optional)
Copy pruning = "custom"
pruning_keep_recent = "1000"
pruning_keep_every = "0"
pruning_interval = "10"
sed -i -e "s/^pruning *=.*/pruning = \"$pruning\"/" $HOME /.planqd/config/app.toml
sed -i -e "s/^pruning-keep-recent *=.*/pruning-keep-recent = \"$pruning_keep_recent\"/" $HOME /.planqd/config/app.toml
sed -i -e "s/^pruning-keep-every *=.*/pruning-keep-every = \"$pruning_keep_every\"/" $HOME /.planqd/config/app.toml
sed -i -e "s/^pruning-interval *=.*/pruning-interval = \"$pruning_interval\"/" $HOME /.planqd/config/app.toml
Indexer (optional)
Copy indexer = "null" &&
sed -i -e "s/^indexer *=.*/indexer = \"$indexer\"/" $HOME /.planqd/config/config.toml
Download addrbook
Copy wget -O $HOME /.planqd/config/addrbook.json "https://server-1.stavr.tech/Mainnet/Planq/addrbook.json"
Create a service file
Copy sudo tee /etc/systemd/system/planqd.service > /dev/null << EOF
[Unit]
Description=planqd
After=network-online.target
[Service]
User=$USER
ExecStart=$( which planqd) start
Restart=on-failure
RestartSec=3
LimitNOFILE=65535
[Install]
WantedBy=multi-user.target
EOF
StateSync Planq Mainnet
Copy systemctl stop planqd
SNAP_RPC = https://planq.rpc.m.stavr.tech:443
LATEST_HEIGHT = $( curl -s $SNAP_RPC /block | jq -r .result.block.header.height ); \
BLOCK_HEIGHT = $(( LATEST_HEIGHT - 1000 )); \
TRUST_HASH = $( curl -s "$SNAP_RPC/block?height=$BLOCK_HEIGHT" | jq -r .result.block_id.hash )
echo $LATEST_HEIGHT $BLOCK_HEIGHT $TRUST_HASH
sed -i.bak -E "s|^(enable[[:space:]]+=[[:space:]]+).*$|\1true| ; \
s|^(rpc_servers[[:space:]]+=[[:space:]]+).*$|\1\"$SNAP_RPC,$SNAP_RPC\"| ; \
s|^(trust_height[[:space:]]+=[[:space:]]+).*$|\1$BLOCK_HEIGHT| ; \
s|^(trust_hash[[:space:]]+=[[:space:]]+).*$|\1\"$TRUST_HASH\"| ; \
s|^(seeds[[:space:]]+=[[:space:]]+).*$|\1\"\"|" $HOME /.planqd/config/config.toml
planqd tendermint unsafe-reset-all --home /root/.planqd
wget -O $HOME /.planqd/config/addrbook.json "https://server-1.stavr.tech/Mainnet/Planq/addrbook.json"
sudo systemctl restart planqd && journalctl -fu planqd -o cat
SnapShot Mainnet updated every 5 hours
You can check the size and time of snapshot creation with this command
curl -sI https://server-1.stavr.tech/Mainnet/Planq/planq-snap-1.tar.lz4 | grep "last" && curl -sI https://server-1.stavr.tech/Mainnet/Planq/planq-snap-1.tar.lz4 | grep content-length | awk '{printf "%.2f GB\n", $2/1024/1024/1024}'
Copy cd $HOME
apt install lz4
sudo systemctl stop planqd
cp $HOME /.planqd/data/priv_validator_state.json $HOME /.planqd/priv_validator_state.json.backup
rm -rf $HOME /.planqd/data
LATEST_SNAPSHOT = $( curl -s https://server-1.stavr.tech/Mainnet/Planq/ | grep -oE 'planq-snap-[0-9]+\.tar\.lz4' | while read SNAPSHOT ; do HEIGHT = $( curl -s "https://server-1.stavr.tech/Mainnet/Planq/${SNAPSHOT % .tar.lz4}-info.txt" | awk '/Block height:/ {print $3}' ); echo "$SNAPSHOT $HEIGHT" ; done | sort -k2 -nr | head -n 1 | awk '{print $1}' )
curl -o - -L https://server-1.stavr.tech/Mainnet/Planq/ $LATEST_SNAPSHOT | lz4 -c -d - | tar -x -C $HOME /.planqd
mv $HOME /.planqd/priv_validator_state.json.backup $HOME /.planqd/data/priv_validator_state.json
wget -O $HOME /.planqd/config/addrbook.json "https://server-1.stavr.tech/Mainnet/Planq/addrbook.json"
sudo systemctl restart planqd && journalctl -fu planqd -o cat
Start
Copy sudo systemctl daemon-reload
sudo systemctl enable planqd
sudo systemctl restart planqd && journalctl -fu planqd -o cat
Create validator
Copy planqd tx staking create - validator \
--commission - rate 0.1 \
--commission - max - rate 0.2 \
--commission - max - change - rate 0.1 \
-- min - self - delegation "1" \
--amount = 1000000000000000000aplanq \
--pubkey $(planqd tendermint show - validator) \
-- from < wallet > \
--moniker = "STAVR_guide" \
--chain - id planq_7070 - 2 \
--identity = "" \
--website = "" \
--details = "" - y
Monitoring
You can set up your node status alarm here - Monitoring
Security
You can create secure management of your wallet and your node by following this links.
TMKMS Wallet Security
Delete node
Copy sudo systemctl stop planqd
sudo systemctl disable planqd
rm /etc/systemd/system/planqd.service
sudo systemctl daemon-reload
cd $HOME
rm -rf planq
rm -rf .planqd
rm -rf $( which planqd )
Last updated 18 hours ago