Skip to content

A daemon that synchronizes IRITA blockchain data into a database

Notifications You must be signed in to change notification settings

heziyi/cosmos-sync

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

cosmos-sync

A server that synchronize cosmos chain data into a database

SetUp

Build And Run

  • Build: make all
  • Run: make run
  • Cross compilation: make build-linux

Env Variables

  • CONFIG_FILE_PATH: option string config file path

Config Descriptiom

[database]
node_uri= "mongodb://root:[email protected]:27017/?connect=direct&authSource=temp"
database= "bifrost-sync"

[server]
node_urls="tcp://192.168.150.40:26657"
thread_num_parse_tx = 1
worker_num_create_task=1
worker_num_execute_task=30
worker_max_sleep_time=120
block_num_per_worker_handle=100
max_connection_num=100
init_connection_num=5
bech32_acc_prefix=""
chain_id=""
chain_block_interval=5
behind_block_num=0
promethous_port=9090
support_modules="" 
deny_modules=""
support_types=""
ignore_ibc_header=false

Db config

  • node_uri: required string db connection uri(example: mongodb://root:[email protected]:27017/?connect=direct&authSource=temp, ...
  • database:required string database name(example:DB_DATABASE

Server config

  • node_urls: required string full node uri(example: tcp://127.0.0.1:26657, tcp://127.0.0.2:26657, ...

  • thread_num_parse_tx: required int the thread num to parse tx with goroutine concurrency

  • worker_num_create_task: required int the maximum time (in seconds) that create task are allowed (default: 1 example: 1

  • worker_num_execute_task: required int the maximum time (in seconds) that synchronization TX threads are allowed to be out of work(example: 30

  • worker_max_sleep_time: required int num of worker to create tasks(unit: seconds)(example: 90

  • block_num_per_worker_handle: required int number of blocks per sync TX task(example: 50

  • max_connection_num: required int client pool config total max connection

  • init_connection_num: required int client pool config idle connection

  • bech32_acc_prefix: option string block chain address prefix(default(cosmoshub): `` example(irishub): iaa

  • chain_block_interval: option int block interval; default 5 (example: 5)

  • behind_block_num: option int wait block num to handle when retry failed; default 0 (example: 0)

  • promethous_port: option int promethous metrics server port

  • support_modules: option string setting only support module tx sync,default support all module (default: `` example: bank,nft)

  • deny_modules: option string disable support module tx sync

  • support_types: option string setting only support msgType tx sync,default support all types(default: `` example: transfer,recv_packet)

  • ignore_ibc_header: option boolean setting update_client header info for tx collection ,default not ignore ibc header info(default: false example: false)

  • chain_id: option string setting collection name by chain_id

Note:

synchronizes cosmos data from specify block height(such as:17908 current time:1576208532) At first,stop the cosmos-sync and create the task. Run:

db.sync_task.insert({
    'start_height':NumberLong(17908),
    'end_height':NumberLong(0),
    'current_height':NumberLong(0),
    'status':'unhandled',
    'worker_id' : '',
     'worker_logs' : [],
    'last_update_time' : NumberLong(0)
})

About

A daemon that synchronizes IRITA blockchain data into a database

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 98.7%
  • Other 1.3%