-
Notifications
You must be signed in to change notification settings - Fork 77
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'ian/update-indexer-docs' (#373)
update indexer docs
- Loading branch information
Showing
3 changed files
with
228 additions
and
67 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
182 changes: 116 additions & 66 deletions
182
packages/docs/pages/integrating-with-namada/indexer.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,103 +1,153 @@ | ||
import Expandable from '../../components/Expandable'; | ||
import { Callout } from 'nextra-theme-docs' | ||
import { Callout, Steps } from 'nextra-theme-docs' | ||
|
||
# Namada Indexer | ||
# Namada Indexers | ||
|
||
In collaboration with [Zondax](https://zondax.ch/), an indexer for the Namada blockchain has been born. | ||
There are two actively maintained indexers built for Namada -- *Undexer* and *namada-indexer*. | ||
|
||
The Namada indexer (a.k.a `namadexer`) constantly queries the Namada blockchain, and together with the [SDK](./sdk.mdx), is able to map blocks, transactions, along with other valuable information into a relational database (postgres). | ||
## Undexer | ||
|
||
This is especially useful for performing analytics over the blockchain, including storing historical data in a way that could be easily queried. | ||
[Undexer](https://github.com/hackbg/undexer) is a community-led project developed by the Mandragora and HackBG teams. It indexes transaction details, validator set updates, | ||
governance proposals and more, and serves the indexed data via a REST api. | ||
|
||
## Setting up | ||
Detailed installation and usage instructions for *Undexer* can be found on the project's [repo](https://github.com/hackbg/undexer). | ||
|
||
The namada indexer's source code can be found [here](https://github.com/zondax/namadexer) and is simple to set up. | ||
## Namada-Indexer | ||
|
||
The `namadexer` works best together with [Docker](https://www.docker.com/products/docker-desktop) | ||
The [namada-indexer](https://github.com/anoma/namada-indexer) crawls a Namada blockchain to map details such as transactions, validator set updates, POS rewards, | ||
governance proposals and more. It stores the results in a Postgres database where it can be queried via a REST api. | ||
|
||
```bash | ||
git clone https://github.com/Zondax/namadexer.git | ||
cd namadexer | ||
make compose | ||
``` | ||
*Namada-indexer* was created to power the [Namadillo](./interface.mdx) interface; however it can be generally useful for any application that needs to query historical data | ||
or perform analytics over the blockchain. | ||
|
||
## Running the server and db | ||
Once the DockerFile has run, it is straightforward to both set up the postgres database as well as the server that will query the database. | ||
The remainder of this page will detail the process of configuring, running, and querying *namada-indexer*. | ||
|
||
Make sure that `postgres` [is installed](https://www.postgresql.org/download/) on the local machine. | ||
## Setting up | ||
|
||
**Run postgres in docker** | ||
```bash | ||
make postgres | ||
# or run (and change arguments, e.g port): | ||
# docker run --name postgres -e POSTGRES_PASSWORD=wow -e POSTGRES_DB=blockchain -p 5432:5432 -d postgres | ||
``` | ||
Once the postgres server is up and running, it is time to set up the server that will query the postgres db. | ||
The *namada-indexer* source code can be found [here](https://github.com/anoma/namada-indexer). | ||
|
||
Execute the following command in order to set up the server | ||
``` | ||
make run_server | ||
``` | ||
It's recommended to use [Docker/Docker Compose](https://www.docker.com/products/docker-desktop) to run the indexer. | ||
|
||
If successful, the server should be running as a daemon on the localhost at port `30303`. | ||
### Prerequisites | ||
- *(required)*: an available Namada RPC node | ||
- *(required)*: [Docker and Docker Compose](https://www.docker.com/products/docker-desktop) | ||
- *(optional but recommended)*: [Just](https://github.com/casey/just) -- see the project's README for installation instructions for your system | ||
|
||
## Run the indexer | ||
### RPC configuration | ||
To configure your RPC node to serve historical data to the indexer, you will need to open its `config.toml` file (located in `~/.local/share/namada/$CHAIN_ID` by default) | ||
and find the setting `storage_read_past_height_limit`. Change the default value of `3600` to an appropriately high number. | ||
|
||
First, ensure that the `Settings.toml` within `config/Settings.toml` is configured correctly. | ||
If you see the following error in your logs when running the indexer, it indicates that you have this value configured too low: | ||
``` | ||
Info log: RPC error: Cannot query more than 3600 blocks in the past (configured via `shell.storage_read_past_height_limit`)., error code: 1 | ||
``` | ||
|
||
<Expandable> | ||
```toml | ||
log_level = "info" | ||
network = "public-testnet-14" | ||
## Running the indexer | ||
The following steps will help you configure and run *namada-indexer*. | ||
<Steps> | ||
### Clone repo | ||
Begin by cloning the indexer repo: | ||
```bash | ||
git clone https://github.com/anoma/namada-indexer.git | ||
cd namada-indexer | ||
``` | ||
|
||
[database] | ||
host = "0.0.0.0:5435" | ||
user = "postgres" | ||
password = "wow" | ||
dbname = "blockchain" | ||
# Optional field to configure a timeout if database connection | ||
# fails. | ||
connection_timeout = 20 | ||
### Set environment variables | ||
The indexer configuration is stored in its `.env` file, found in the base directory of the repo. Refer to `.env_sample` to see which values can be set. | ||
|
||
Create that file now: | ||
``` | ||
cp .env_sample .env | ||
``` | ||
|
||
[server] | ||
serve_at = "0.0.0.0" | ||
port = 30303 | ||
It will have the following default values: | ||
``` | ||
DATABASE_URL=postgres://postgres:password@postgres:5432/namada-indexer | ||
TENDERMINT_URL=http://host.docker.internal:27657 | ||
CACHE_URL=redis://dragonfly:6379 | ||
WEBSERVER_PORT=5000 | ||
``` | ||
|
||
[indexer] | ||
tendermint_addr = "0.0.0.0" | ||
port = 26657 | ||
Change the value of `TENDERMINT_URL` to the url of your RPC node. | ||
|
||
[jaeger] | ||
enable = false | ||
host = "localhost" | ||
port = 6831 | ||
### (Recommended) Change Postgres username and password | ||
The default username and password (`postgres` and `password` respectively) will work for local development, however they should be changed if your indexer will be publicly accessible. | ||
|
||
[prometheus] | ||
host = "0.0.0.0" | ||
port = 9000 | ||
First, open the file `docker-compose-db.yml` and change the default values to something more secure: | ||
``` | ||
environment: | ||
POSTGRES_PASSWORD: NEW_PASSWORD | ||
POSTGRES_USER: NEW_USERNAME | ||
PGUSER: NEW_USERNAME | ||
POSTGRES_DB: namada-indexer | ||
``` | ||
|
||
</Expandable> | ||
Then, update the Postgres url in your `.env` file with the new values. | ||
|
||
<Callout type="info" emoji="👀"> | ||
**Interpreting the toml** | ||
The schema for the url is `postgres://{user_name}:{password}@{host}:{port}/{database_name}` | ||
``` | ||
DATABASE_URL=postgres://NEW_USERNAME:NEW_PASSWORD@postgres:5432/namada-indexer | ||
``` | ||
|
||
It is important to change the following parameters: | ||
### Build the containers | ||
Build the indexer containers by running: | ||
``` | ||
docker compose build | ||
``` | ||
|
||
1. `indexer.tendermint_addr` - This should be the address and corresponding port of a synced Namada full node | ||
Instead of building yourself, you can check the repo's [container registry](https://github.com/anoma/namada-indexer/pkgs/container/namada-indexer) for | ||
recent images. | ||
|
||
2. `database.host` - This should be the tcp address (with port) where the postgres database is running. | ||
### Start the indexer | ||
Start all indexer containers with this command: | ||
``` | ||
just docker-up | ||
``` | ||
You can expect to see some database connection errors in the logs during the time the database is being initialized -- these are normal and will resolve within a couple minutes. | ||
<Callout type="info"> | ||
Assuming you want to keep the indexer running persistently in the background, you will likely want to perform this step using something like `screen` or `tmux`. | ||
|
||
*Eg.* In Ubuntu, using `screen`: | ||
1. Start a new screen session: `screen -S indexer` | ||
2. Start the indexer: `just docker-up` | ||
3. Detach from the session, allowing it to run in the background: Press `Ctrl+A` and then `d` | ||
4. To re-attach to the session at a later time: `screen -d -r indexer` | ||
</Callout> | ||
Stop the indexer with `Ctrl+c`. Remove all associated data with `docker compose down --volumes`. | ||
</Steps> | ||
|
||
Once the setup is complete, it is possible to start the indexer | ||
## REST API | ||
Once the indexer has been started, the `webserver` container will serve requests at the port given by `WEBSERVER_PORT` in the `.env` file. | ||
|
||
```bash | ||
make run_indexer | ||
Available endpoints are documented in the `swagger.yml` file inside the repo. | ||
|
||
*Eg.* to query the latest indexed block: | ||
``` | ||
curl localhost:5000/api/v1/chain/block/latest | ||
## Querying the database | ||
# response | ||
{"block":"163445"} | ||
``` | ||
|
||
The pre-defined endpoints to query the database are described in the documentation [here](https://github.com/Zondax/namadexer/blob/main/docs/04-server.md). | ||
## Querying the database | ||
You can also query the Postgres database directly. | ||
|
||
*Eg.* to perform a simple query using `pgcli` on Ubuntu: | ||
<Steps> | ||
### Install `pgcli` | ||
``` | ||
sudo apt install pgcli | ||
``` | ||
### Connect to the database | ||
(If you changed your Postgres username and/or password above, use the updated values.) | ||
``` | ||
pgcli postgres://postgres:password@localhost:5435/namada-indexer | ||
``` | ||
### Run a query | ||
*Eg.* Find a wrapper transaction by its hash: | ||
``` | ||
SELECT * FROM wrapper_transactions WHERE id = 'cece56db36322f9b0728a0f2e127ef33c410a9fab74e2b9e135f97903c6c2c4e'; | ||
``` | ||
</Steps> | ||
|
||
If you prefer to use a GUI, there are many free options available such as [Beekeeper Studio](https://www.beekeeperstudio.io/get-community) and [pgAdmin](https://www.pgadmin.org/download/). |
110 changes: 110 additions & 0 deletions
110
packages/docs/pages/integrating-with-namada/namadexer.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,110 @@ | ||
import Expandable from '../../components/Expandable'; | ||
import { Callout } from 'nextra-theme-docs' | ||
|
||
# Namadexer (deprecated) | ||
|
||
<Callout type="info"> | ||
Namadexer has been deprecated and is not compatible with Namada versions later than `v0.31.4`. Please refer to the section [Using the Indexer](./indexer.mdx) instead for | ||
up-to-date instructions on configuring and using one of the currently maintained Namada indexing options. | ||
|
||
The original documentation for Namadexer follows below for reference purposes only. | ||
</Callout> | ||
|
||
In collaboration with [Zondax](https://zondax.ch/), an indexer for the Namada blockchain has been born. | ||
|
||
The Namada indexer (a.k.a `namadexer`) constantly queries the Namada blockchain, and together with the [SDK](./sdk.mdx), is able to map blocks, transactions, along with other valuable information into a relational database (postgres). | ||
|
||
This is especially useful for performing analytics over the blockchain, including storing historical data in a way that could be easily queried. | ||
|
||
## Setting up | ||
|
||
The namada indexer's source code can be found [here](https://github.com/zondax/namadexer) and is simple to set up. | ||
|
||
The `namadexer` works best together with [Docker](https://www.docker.com/products/docker-desktop) | ||
|
||
```bash | ||
git clone https://github.com/Zondax/namadexer.git | ||
cd namadexer | ||
make compose | ||
``` | ||
|
||
## Running the server and db | ||
Once the DockerFile has run, it is straightforward to both set up the postgres database as well as the server that will query the database. | ||
|
||
Make sure that `postgres` [is installed](https://www.postgresql.org/download/) on the local machine. | ||
|
||
**Run postgres in docker** | ||
```bash | ||
make postgres | ||
# or run (and change arguments, e.g port): | ||
# docker run --name postgres -e POSTGRES_PASSWORD=wow -e POSTGRES_DB=blockchain -p 5432:5432 -d postgres | ||
``` | ||
Once the postgres server is up and running, it is time to set up the server that will query the postgres db. | ||
|
||
Execute the following command in order to set up the server | ||
``` | ||
make run_server | ||
``` | ||
|
||
If successful, the server should be running as a daemon on the localhost at port `30303`. | ||
|
||
## Run the indexer | ||
|
||
First, ensure that the `Settings.toml` within `config/Settings.toml` is configured correctly. | ||
|
||
<Expandable> | ||
```toml | ||
log_level = "info" | ||
network = "public-testnet-14" | ||
|
||
[database] | ||
host = "0.0.0.0:5435" | ||
user = "postgres" | ||
password = "wow" | ||
dbname = "blockchain" | ||
# Optional field to configure a timeout if database connection | ||
# fails. | ||
connection_timeout = 20 | ||
|
||
|
||
[server] | ||
serve_at = "0.0.0.0" | ||
port = 30303 | ||
|
||
[indexer] | ||
tendermint_addr = "0.0.0.0" | ||
port = 26657 | ||
|
||
[jaeger] | ||
enable = false | ||
host = "localhost" | ||
port = 6831 | ||
|
||
[prometheus] | ||
host = "0.0.0.0" | ||
port = 9000 | ||
``` | ||
|
||
</Expandable> | ||
|
||
<Callout type="info" emoji="👀"> | ||
**Interpreting the toml** | ||
|
||
It is important to change the following parameters: | ||
|
||
1. `indexer.tendermint_addr` - This should be the address and corresponding port of a synced Namada full node | ||
|
||
2. `database.host` - This should be the tcp address (with port) where the postgres database is running. | ||
</Callout> | ||
|
||
Once the setup is complete, it is possible to start the indexer | ||
|
||
```bash | ||
make run_indexer | ||
``` | ||
|
||
## Querying the database | ||
|
||
The pre-defined endpoints to query the database are described in the documentation [here](https://github.com/Zondax/namadexer/blob/main/docs/04-server.md). | ||
|
||
|