# Useful commands

<figure><img src="https://raw.githubusercontent.com/StakeandRelax-Validator/documentation/main/Logos/osmosis.png" alt="" width="150"><figcaption></figcaption></figure>

**Chain ID**: osmosis-1 | **Latest Version Tag**: 31.0.0

## 🔑 Key management

#### Add new key

```bash
osmosisd keys add wallet
```

#### Recover existing key

```bash
osmosisd keys add wallet --recover
```

#### List all keys

```bash
osmosisd keys list
```

#### Delete key

```bash
osmosisd keys delete wallet
```

#### Export key to the file

```bash
osmosisd keys export wallet
```

#### Import key from the file

```bash
osmosisd keys import wallet wallet.backup
```

#### Query wallet balance

```bash
osmosisd q bank balances $(osmosisd keys show wallet -a)
```

## 👷 Validator management

{% hint style="info" %}
Please make sure you have adjusted **moniker**, **identity**, **details** and **website** to match your values.
{% endhint %}

#### Create new validator

```bash
osmosisd tx staking create-validator \
--amount=1000000 \
--pubkey=$(osmosisd tendermint show-validator) \
--moniker="YOUR_MONIKER_NAME" \
--identity="YOUR_KEYBASE_ID" \
--details="YOUR_DETAILS" \
--website="YOUR_WEBSITE_URL"
--chain-id=osmosis-1 \
--commission-rate=0.05 \
--commission-max-rate=0.20 \
--commission-max-change-rate=0.01 \
--min-self-delegation=1 \
--from=wallet \
--gas-adjustment=1.4 \
--gas=auto \
-y
```

#### Edit existing validator

```bash
osmosisd tx staking edit-validator \
--moniker="YOUR_MONIKER_NAME" \
--identity="YOUR_KEYBASE_ID" \
--details="YOUR_DETAILS" \
--website="YOUR_WEBSITE_URL"
--chain-id=osmosis-1 \
--commission-rate=0.05 \
--from=wallet \
--gas-adjustment=1.4 \
--gas=auto \
-y
```

#### Unjail validator

```bash
osmosisd tx slashing unjail --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto -y
```

#### Jail reason

```bash
osmosisd query slashing signing-info $(osmosisd tendermint show-validator)
```

#### List all active validators

```bash
osmosisd 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
```

#### List all inactive validators

```bash
osmosisd q staking validators -oj --limit=3000 | jq '.validators[] | select(.status=="BOND_STATUS_UNBONDED")' | jq -r '(.tokens|tonumber/pow(10; 6)|floor|tostring) + " \t " + .description.moniker' | sort -gr | nl
```

#### View validator details

```bash
osmosisd q staking validator $(osmosisd keys show wallet --bech val
```

## 💲 Token management

#### Withdraw rewards from all validators

```bash
osmosisd tx distribution withdraw-all-rewards --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto -y
```

#### Withdraw commission and rewards from your validator

```bash
osmosisd tx distribution withdraw-rewards $(osmosisd keys show wallet --bech val -a) --commission --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto --y
```

#### Delegate tokens to yourself

```bash
osmosisd tx staking delegate $(osmosisd keys show wallet --bech val -a) 1000000 --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto -y
```

#### Delegate tokens to validator

```bash
osmosisd tx staking delegate <TO_VALOPER_ADDRESS> 1000000.osmosisd --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto -y
```

#### Redelegate tokens to another validator

```bash
osmosisd tx staking redelegate $(osmosisd keys show wallet --bech val <TO_VALOPER_ADDRESS> 1000000 --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto -y
```

#### Unbond tokens from your validator

```bash
osmosisd tx staking unbond $(osmosisd keys show wallet --bech val -a) 1000000 --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto -y
```

#### Send tokens to the wallet

```bash
osmosisd tx bank send wallet <TO_WALLET_ADDRESS> 1000000 --from wallet --chain-id osmosis-1
```

## 🗳 Governance

#### List all proposals

```bash
osmosisd query gov proposals
```

#### View proposal by id

```bash
osmosisd query gov proposal 1
```

#### Vote 'Yes'

```bash
osmosisd tx gov vote 1 yes --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto -y
```

#### Vote 'No'

```bash
osmosisd tx gov vote 1 no --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto -y
```

#### Vote 'Abstain'

```bash
osmosisd tx gov vote 1 abstain --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto -y
```

#### Vote 'NoWithVeto'

```bash
osmosisd tx gov vote 1 nowithveto --from wallet --chain-id osmosis-1 --gas-adjustment 1.4 --gas auto -y
```

## ⚡️ Utility

#### Update ports

```bash
CUSTOM_PORT=125
sed -i -e "s%^proxy_app = \"tcp://127.0.0.1:26658\"%proxy_app = \"tcp://127.0.0.1:${CUSTOM_PORT}58\"%; s%^laddr = \"tcp://127.0.0.1:26657\"%laddr = \"tcp://127.0.0.1:${CUSTOM_PORT}57\"%; s%^pprof_laddr = \"localhost:6060\"%pprof_laddr = \"localhost:${CUSTOM_PORT}60\"%; s%^laddr = \"tcp://0.0.0.0:26656\"%laddr = \"tcp://0.0.0.0:${CUSTOM_PORT}56\"%; s%^prometheus_listen_addr = \":26660\"%prometheus_listen_addr = \":${CUSTOM_PORT}60\"%" $HOME/.osmosisd/config/config.toml
sed -i -e "s%^address = \"tcp://0.0.0.0:1317\"%address = \"tcp://0.0.0.0:${CUSTOM_PORT}17\"%; s%^address = \":8080\"%address = \":${CUSTOM_PORT}80\"%; s%^address = \"0.0.0.0:9090\"%address = \"0.0.0.0:${CUSTOM_PORT}90\"%; s%^address = \"0.0.0.0:9091\"%address = \"0.0.0.0:${CUSTOM_PORT}91\"%" $HOME/.osmosisd/config/app.toml
```

#### Update Indexer

**Disable indexer**

```bash
sed -i -e 's|^indexer *=.*|indexer = "null"|' $HOME/.osmosisd/config/config.toml
```

**Enable indexer**

```bash
sed -i -e 's|^indexer *=.*|indexer = "kv"|' $HOME/.osmosisd/config/config.toml
```

#### Update pruning

```bash
sed -i \
  -e 's|^pruning *=.*|pruning = "custom"|' \
  -e 's|^pruning-keep-recent *=.*|pruning-keep-recent = "100"|' \
  -e 's|^pruning-keep-every *=.*|pruning-keep-every = "0"|' \
  -e 's|^pruning-interval *=.*|pruning-interval = "19"|' \
  $HOME/.osmosisd/config/app.toml
```

## 🚨 Maintenance

#### Get validator info

```bash
osmosisd status 2>&1 | jq .ValidatorInfo
```

#### Get sync info

```bash
osmosisd status 2>&1 | jq .SyncInfo
```

#### Get node peer

```bash
echo $(osmosisd tendermint show-node-id)'@'$(curl -s ifconfig.me)':'$(cat $HOME/.osmosisd/config/config.toml | sed -n '/Address to listen for incoming connection/{n;p;}' | sed 's/.*://; s/".*//')
```

#### Check if validator key is correct

```bash
[[ $(osmosisd q staking validator $(osmosisd keys show wallet --bech val -a) -oj | jq -r .consensus_pubkey.key) = $(osmosisd status | jq -r .ValidatorInfo.PubKey.value) ]] && echo -e "\n\e[1m\e[32mTrue\e[0m\n" || echo -e "\n\e[1m\e[31mFalse\e[0m\n"
```

#### Get live peers

```bash
curl -sS http://localhost:26657/net_info | jq -r '.result.peers[] | "\(.node_info.id)@\(.remote_ip):\(.node_info.listen_addr)"' | awk -F ':' '{print $1":"$(NF)}'
```

#### Set minimum gas price

```bash
sed -i -e "s/^minimum-gas-prices *=.*/minimum-gas-prices = \"0.osmosisd\"/" $HOME/.osmosisd/config/app.toml
```

#### Enable prometheus

```bash
sed -i -e "s/prometheus = false/prometheus = true/" $HOME/.osmosisd/config/config.toml
```

#### Reset chain data

```bash
osmosisd tendermint unsafe-reset-all --home $HOME/.osmosisd --keep-addr-book
```

#### Remove node

{% hint style="danger" %}
Please, before proceeding with the next step! All chain data will be lost! Make sure you have backed up your **priv\_validator\_key.json**!
{% endhint %}

```bash
cd $HOME
sudo systemctl stop osmosisd
sudo systemctl disable osmosisd
sudo rm /etc/systemd/system/osmosisd.service
sudo systemctl daemon-reload
rm -f $(which osmosisd)
rm -rf $HOME/.osmosisd
rm -rf $HOME/osmosis
```

## ⚙️ Service Management

#### Reload service configuration

```bash
sudo systemctl daemon-reload
```

#### Enable service

```bash
sudo systemctl enable osmosisd
```

#### Disable service

```bash
sudo systemctl disable osmosisd
```

#### Start service

```bash
sudo systemctl start osmosisd
```

#### Stop service

```bash
sudo systemctl stop osmosisd
```

#### Restart service

```bash
sudo systemctl restart osmosisd
```

#### Check service status

```bash
sudo systemctl status osmosisd
```

#### Check service logs

```bash
sudo journalctl -u osmosisd -f --no-hostname -o cat
```


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://services.stakeandrelax.net/mainnet/osmosis/useful-commands.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
