A RPC server serving major RPC requests from PostgreSQL database streamed by the solana-geyser-plugin-postgres plugin.
Do the following to build
cargo build [--release]
The RPC server requires a PostgreSQL database has already been setup. Please consult with solana-geyser-plugin-postgres on setting up the plugin and database. In addition, run the following script to create some of the stored functions and procedures in the database which are used for serving RPC queries.
psql -U solana -p 5433 -h 10.138.0.9 -w -d solana -f sql/query_account.sql
PGPASSWORD=solana psql -U solana -p 5432 -h localhost -w -d solana -f sql/query_account.sql\
Execute the command similar to the following to run the RPC server listening on port 8888.
solana-postgres-rpc-server --db-config ~/postgres-db-config.json --rpc-port 8888 --rpc-threads 100 -o -
Use the following to see the detailed arguments of the command line.
solana-postgres-rpc-server --help
The postgres-db-config.json
file specifies the connection information to the PostgreSQL database in JSON format.
For example,
{
"host": "postgres-server",
"user": "solana",
"port": 5433,
}
The host
, user
, and port
control the PostgreSQL configuration
information. For more advanced connection options such as passwords, please use the
connection_str
field. Please see Rust Postgres Configuration.
The Server currently supports the following RPC calls.
- getAccountInfo
- getMultipleAccounts
- getProgramAccounts
There is plan to add support for other RPC calls related to blocks, accounts and transactions.
Please see JSON RPC API for details on these APIs.
For example to get the account info for an account, do the following
curl http://localhost:8888 -X POST -H "Content-Type: application/json" -d '
{
"jsonrpc": "2.0",
"id": 1,
"method": "getAccountInfo",
"params": [
"GruSFAjP7gtmJ9k3SBAiCrMXyUByGJKR885MhKWM9KJD",
{
"encoding": "base58"
}
]
}
'
Response
{
"id": 1,
"jsonrpc": "2.0",
"result": {
"context": {
"slot": 126599223
},
"value": {
"data": [
"",
"base58"
],
"executable": false,
"lamports": 1974219920,
"owner": "11111111111111111111111111111111",
"rentEpoch": 293
}
}
}
psql -U solana -p 5432 -h 10.42.0.168 -w -d solana
SPL Token: CkhzyKJUhs9ARyQY44pQFUyQutr2BkwZQFPyAjtK8nUj ATA: 2wDL6knRJrQZfWW9PcRxYEDewa3vMLVF1btSeZokFn3P
curl http://localhost:8888 -X POST -H "Content-Type: application/json" -d ' {"jsonrpc":"2.0", "id":1, "method":"getProgramAccounts", "params":["2wDL6knRJrQZfWW9PcRxYEDewa3vMLVF1btSeZokFn3P"]} '
curl http://localhost:8888 -X POST -H "Content-Type: application/json" -d ' { "jsonrpc": "2.0", "id": 1, "method": "getAccountInfo", "params": [ "2wDL6knRJrQZfWW9PcRxYEDewa3vMLVF1btSeZokFn3P", { "encoding": "base58" } ] } '
curl http://localhost:8888 -X POST -H "Content-Type: application/json" -d ' { "jsonrpc": "2.0", "id": 1, "method": "getProgramAccounts", "params": [ "CkhzyKJUhs9ARyQY44pQFUyQutr2BkwZQFPyAjtK8nUj", { encoding: "jsonParsed", filters: [ { dataSize: 165 }, { memcmp: { offset: 0, bytes: col.address } } ] } ] } '
curl http://localhost:8888 -X POST -H "Content-Type: application/json" -d '
{
"jsonrpc": "2.0",
"id": 1,
"method": "getProgramAccounts",
"params": [
"TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA",
{
"encoding": "base64+zstd",
"filters": [
{
"memcmp": {
"offset": 0,
"bytes": "CkhzyKJUhs9ARyQY44pQFUyQutr2BkwZQFPyAjtK8nUj"
}
}
]
}
]
}
'
encoding: "jsonParsed",
filters: [
{
dataSize: 165
},
{
memcmp: {
offset: 0,
bytes: col.address
}
}
]