Minimum hardware requirements :
1) Auto_install script
Copy source <( curl -s https://raw.githubusercontent.com/111STAVR111/props/refs/heads/main/Point/pointm )
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.21.6
Copy 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 17.11.23
Copy cd $HOME && mkdir -p go/bin/
git clone https://github.com/pointnetwork/point-chain
cd point-chain
git checkout tags/v0.0.5
make install
pointd version --long | grep -e commit -e version
commit: b37c22b36b291403cca1205c849514a7a1b5616d
Initiation
Copy pointd init STAVR_guide --chain - id = point_10687 - 1
pointd config chain - id point_10687 - 1
Create/recover wallet
Copy pointd keys add < walletnam e >
OR
pointd keys add < walletnam e > --recover
Download Addrbook and Genesis
Copy wget - O $HOME / . pointd / config / addrbook . json "https://server-1.stavr.tech/Mainnet/Point/addrbook.json"
wget - O $HOME / . pointd / config / genesis . json "https://server-1.stavr.tech/Mainnet/Point/genesis.json"
sha256sum $HOME/.pointd/config/genesis.json
d655a35633530c3f9d65d0c65ad287b613bba68218fd7c39549b48b958eec14f
Set up the minimum gas price and Peers/Seeds/Filter peers/MaxPeers
Copy sed -i.bak -e "s/^minimum-gas-prices *=.*/minimum-gas-prices = \"0apoint\"/;" ~/.pointd/config/app.toml
external_address = $( wget -qO- eth0.me )
sed -i.bak -e "s/^external_address *=.*/external_address = \"$external_address:26656\"/" $HOME /.pointd/config/config.toml
peers = ""
sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \"$peers\"/" $HOME /.pointd/config/config.toml
seeds = "8673c1f04c29c464189e8bf29e51fb0b38da2f19@rpc-mainnet-1.point.space:26656"
sed -i.bak -e "s/^seeds =.*/seeds = \"$seeds\"/" $HOME /.pointd/config/config.toml
sed -i 's/max_num_inbound_peers =.*/max_num_inbound_peers = 50/g' $HOME /.pointd/config/config.toml
sed -i 's/max_num_outbound_peers =.*/max_num_outbound_peers = 50/g' $HOME /.pointd/config/config.toml
Pruning (nothing)
Copy pruning = "nothing"
sed -i -e "s/^pruning *=.*/pruning = \"$pruning\"/" $HOME /.pointd/config/app.toml
Indexer (optional)
Copy indexer = "null" &&
sed -i -e "s/^indexer *=.*/indexer = \"$indexer\"/" $HOME /.pointd/config/config.toml
Create a service file
Copy sudo tee /etc/systemd/system/pointd.service > /dev/null << EOF
[Unit]
Description=pointd
After=network-online.target
[Service]
User=$USER
ExecStart=$( which pointd) start
Restart=on-failure
RestartSec=3
LimitNOFILE=65535
[Install]
WantedBy=multi-user.target
EOF
StateSync Point Mainnet
Copy systemctl stop pointd
SNAP_RPC = https://point.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 /.pointd/config/config.toml
pointd tendermint unsafe-reset-all --home /root/.pointd
wget -O $HOME /.pointd/config/addrbook.json "https://server-1.stavr.tech/Mainnet/Point/addrbook.json"
sudo systemctl restart pointd && journalctl -fu pointd -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/Point/point-snap-1.tar.lz4 | grep "last" && curl -sI https://server-1.stavr.tech/Mainnet/Point/point-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 pointd
cp $HOME /.pointd/data/priv_validator_state.json $HOME /.pointd/priv_validator_state.json.backup
rm -rf $HOME /.pointd/data
LATEST_SNAPSHOT = $( curl -s https://server-1.stavr.tech/Mainnet/Point/ | grep -oE 'point-snap-[0-9]+\.tar\.lz4' | while read SNAPSHOT ; do HEIGHT = $( curl -s "https://server-1.stavr.tech/Mainnet/Point/${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/Point/ $LATEST_SNAPSHOT | lz4 -c -d - | tar -x -C $HOME /.pointd
mv $HOME /.pointd/priv_validator_state.json.backup $HOME /.pointd/data/priv_validator_state.json
wget -O $HOME /.pointd/config/addrbook.json "https://server-1.stavr.tech/Mainnet/Point/addrbook.json"
sudo systemctl restart pointd && journalctl -fu pointd -o cat
Start
Copy sudo systemctl daemon-reload
sudo systemctl enable pointd
sudo systemctl restart pointd && journalctl -fu pointd -o cat
Create validator
Copy pointd tx staking create - validator \
--commission - rate 0.1 \
--commission - max - rate 0.2 \
--commission - max - change - rate 0.1 \
-- min - self - delegation "1" \
--amount 1000000000000000000apoint \
--pubkey $(pointd tendermint show - validator) \
-- from < wallet > \
--moniker = "STAVR_guide" \
--chain - id point_10687 - 1 \
--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 pointd
sudo systemctl disable pointd
rm /etc/systemd/system/pointd.service
sudo systemctl daemon-reload
cd $HOME
rm -rf point-chain
rm -rf .pointd
rm -rf $( which pointd )