-
Notifications
You must be signed in to change notification settings - Fork 267
Configuration file reference
- peer
- database
- vm
- sync
- rpc
- wallet
- scoring
- miner
- blockchain.config.name
- bind.address
- public.ip
- genesis
- transaction.outdated
- play.vm
- hello.phrase
- details.inmemory.storage.limit
- solc.path
Describes how your node peers other nodes.
-
peer.discovery.enabled = [true/false]
enables the possibility of being discovered by new peers. -
peer.discovery.ip.list = []
is a list of the peer to start the discovering. These peers must have thediscovery.enabled
option set to true. These are the list of some of RSK bootstrap nodes:
Network | ip.list |
---|---|
TestNet | "bootstrap02.testnet.rsk.co:50505","bootstrap03.testnet.rsk.co:50505","bootstrap04.testnet.rsk.co:50505","bootstrap05.testnet.rsk.co:50505" |
MainNet | "bootstrap01.rsk.co:5050","bootstrap02.rsk.co:5050","bootstrap03.rsk.co:5050","bootstrap04.rsk.co:5050","bootstrap05.rsk.co:5050","bootstrap06.rsk.co:5050","bootstrap07.rsk.co:5050","bootstrap08.rsk.co:5050","bootstrap09.rsk.co:5050","bootstrap10.rsk.co:5050","bootstrap11.rsk.co:5050","bootstrap12.rsk.co:5050","bootstrap13.rsk.co:5050","bootstrap14.rsk.co:5050","bootstrap15.rsk.co:5050","bootstrap16.rsk.co:5050" |
-
peer.active = []
is used to connect to specific nodes. It can be empty. -
peer.trusted = []
is a list of peers whose incoming connections are always accepted from. It can be empty. -
peer.port
is the port used to listen to incoming connections. Default port by each RSK network:
Network | peer.port |
---|---|
Regtest | 30305 |
TestNet | 50505 |
MainNet | 5050 |
-
peer.connection.timeout = number (seconds)
defines in seconds the timeout for trying to connect to a peer. Suggested value:2
. -
channel.read.timeout = number (seconds)
specifies how much time you will wait for a message to come before closing the channel. Suggested value:30
.
-
peer.privateKey = hash
is used to derive thenodeId
. This is a unique identification for the node and must be set. To get aprivateKey
and anodeId
go here.
-
peer.nodeId = hash
is used to identify the node. It isn't required. To get aprivateKey
and anodeId
go here. -
peer.networkId = int
is the number of the network to connect to. It's important to mantain these numbers. It identifies the network you are going to connect to. For a regtest private network, you should use always the same (not necessary 34567). RSK networks Id:
Network | peer.networkId |
---|---|
Regtest | 34567 |
TestNet | 779 |
MainNet | 775 |
-
peer.maxActivePeers = int
is the max number of active peers that your node will maintain. Suggested value:30
. -
peer.p2p.eip8 = bool
forces peer to send handshake message in format defined by EIP-8.
Describes where the blockchain database is saved.
-
database.dir = path
is the place to save physical storage files. -
database.reset = [true/false]
resets de database when application starts if it is set to true.
Enabling de vm.structured
will log all the calls to the VM in the local database, this means, all the contract executions (opcodes).
When testing, using this module is the only way to see Exceptions.
-
trace = [true/false]
enables thevm.structured
. -
dir = foldername
the directory where calls are saved. -
compressed = [true/false]
compress data when enabled.initStorageLimit = int
the storage limit.
An example:
vm.structured {
trace = false
dir = vmtrace
compressed = true
initStorageLimit = 10000
}
Options related to syncing the blockchain:
-
sync.enabled = [true/false]
enables the blockchain synchronization. Should be set totrue
to keep the node updated. -
sync.max.hashes.ask = int
determines the max amount of blocks to sync in a same batch. The synchronization is done in batches of blocks. Suggested value:10000
. -
sync.peer.count = int
minimum peers count used in syncing. Sync may use more peers than this value but always trying to get at least this number from discovery. However, it will continue syncing if it's not reached. -
sync.timeoutWaitingPeers = int (seconds)
timeout to start to wait for syncing requests. -
sync.timeoutWaitingRequests = int (seconds)
expiration time in minutes for peer status. -
sync.maxSkeletonChunks = int
maximum amount of chunks included in a skeleton message. -
sync.shunkSize = int
amount of blocks contained in a chunk, must be192
or adivisor of 192
.
An example:
sync {
enabled = true
max.hashes.ask = 10000
peer.count = 10
expectedPeers = 5
timeoutWaitingPeers = 1
timeoutWaitingRequest = 30
expirationTimePeerStatus = 10
maxSkeletonChunks = 20
chunkSize = 192
}
Describes the configuration for the RPC protocol.
-
rpc.port = port
is the port where RPC calls are sent to. By default RSK uses4444
. -
rpc.cors = domain
restricts the RPC calls from other domains. Default value islocalhost
. -
rpc.modules
lists of different RPC modules. If a module is not in the list and enabled, its RPC calls are discard. Examples:
modules = [
{ name: "eth", version: "1.0", enabled: "true" },
{ name: "net", version: "1.0", enabled: "true" },
{ name: "rpc", version: "1.0", enabled: "true" },
{ name: "web3", version: "1.0", enabled: "true" },
{ name: "evm", version: "1.0", enabled: "true" },
{ name: "sco", version: "1.0", enabled: "true" },
{ name: "txpool", version: "1.0", enabled: "true" },
{ name: "personal", version: "1.0", enabled: "true" }
]
It is possible to enable/disable particular methods in a module.
{
name: "evm",
version: "1.0",
enabled: "true",
methods: {
enabled: ["evm_snapshot", "evm_revert"],
disabled: [ "evm_reset", "evm_increaseTime"]
}
}
RSK has implemented an RPC miner module. To use it, you have to include:
{ name: "mnr", version: "1.0", enabled: "true" }
You can store your accounts on the node to use them to sign transactions. However, it is not secure to use a wallet in a public node.
wallet {
enabled = true
accounts = [
{
"publicKey" : "<PUBLIC_KEY>"
"privateKey" : "<PRIVATE_KEY>"
}
]
}
Scoring is the way the node 'punishes' other nodes when bad responses are sent. Punishment can be done by node id or address.
-
scoring.nodes.number = int
number of nodes to keep scoring. -
scoring.nodes.duration
andscoring.addresses.duration
initial punishment duration (in minutes). Default is10
. -
scoring.nodes.increment
andscoring.addresses.increment
punishment duration increment (in percentage). Default is10
. -
scoring.nodes.maximum
maximum punishment duration (in minutes). Default is0
. -
scoring.addresses.maximum
maximum punishment duration (in minutes). Default is1 week
.
An example:
scoring {
nodes {
number: 100
duration: 12
increment: 10
maximum: 0
}
addresses {
duration: 12
increment: 10
maximum: 6000
}
}
For more information about configuring RSK node to mine go here.
It is a string that describe the name of the configuration. We use:
Network | blockchain.config.name |
---|---|
Regtest | regtest |
TestNet | testnet |
MainNet | mainnet |
It is the last resort for public IP when it cannot be obtained by other ways.
Wildcard value: 0.0.0.0
.
It is the node's public IP. If it's not configured, default is http://checkip.amazonaws.com
.
It is the path to the genesis file (in resources/genesis). The folder resources/genesis contains several versions of genesis configuration according to the network the peer will run on.
Network | genesis |
---|---|
Regtest | rsk-dev.json |
TestNet | bamboo-testnet.json |
MainNet | rsk-mainnet.json |
It defines when a transaction is outdated:
-
transaction.outdated.threshold = int
is the number of blocks that should pass before pending transaction is removed. Suggested value:10
. -
transaction.outdated.timeout = int
is the number of seconds that should pass before pending transaction is removed. Suggested value:100
(10 blocks * 10 seconds per block).
It is a boolean that invokes vm program on message received, if the vm is not invoked the balance transfer occurs anyway. Suggested value: true
.
It is a string that will be included in the hello message of the peer.
Specifies when exactly to switch managing storage of the account on autonomous db. Suggested value: 1
.
If the inmemory storage of the contract exceded the limit, just deltas are saved.
It is the path to the Solidity compiler. It's set because you may want to use the node to compile your smart contracts.
If you don't have Solidity installed, you can use /bin/false
as value.