From 0ff4bf9600880956fa0e273280338bb5fa633fa6 Mon Sep 17 00:00:00 2001 From: Conor Schaefer Date: Wed, 4 Oct 2023 10:46:08 -0700 Subject: [PATCH] chore: update cometbft config template As of CometBFT v0.37.x, fastsync has been deprecated in favor of blocksync, but v0.38.x will disregard both options. We can't yet update the value since we're on v0.37.x still, but I'm still pulling in the config file changes to comments and explanations created by diffing a newly generated CometBFT config against our TOML template. Refs #3144. Refs #2263. --- crates/bin/pd/src/testnet/config.rs | 11 ++-- ...ate.toml => cometbft_config_template.toml} | 60 +++++++++++-------- 2 files changed, 40 insertions(+), 31 deletions(-) rename testnets/{tm_config_template.toml => cometbft_config_template.toml} (90%) diff --git a/crates/bin/pd/src/testnet/config.rs b/crates/bin/pd/src/testnet/config.rs index cabc12dbdd..cbedcee93f 100644 --- a/crates/bin/pd/src/testnet/config.rs +++ b/crates/bin/pd/src/testnet/config.rs @@ -37,17 +37,17 @@ impl TestnetTendermintConfig { tm_rpc_bind: Option, tm_p2p_bind: Option, ) -> anyhow::Result { - tracing::debug!("List of TM peers: {:?}", peers); + tracing::debug!("List of CometBFT peers: {:?}", peers); let moniker: Moniker = Moniker::from_str(node_name)?; let mut tm_config = TendermintConfig::parse_toml(include_str!( - "../../../../../testnets/tm_config_template.toml" + "../../../../../testnets/cometbft_config_template.toml" )) - .context("Failed to parse the TOML config template for Tendermint")?; + .context("Failed to parse the TOML config template for CometBFT")?; tm_config.moniker = moniker; tm_config.p2p.seeds = peers; tracing::debug!("External address looks like: {:?}", external_address); tm_config.p2p.external_address = external_address; - // The Tendermint config wants URLs, not SocketAddrs, so we'll prepend protocol. + // The CometBFT config wants URLs, not SocketAddrs, so we'll prepend protocol. if let Some(rpc) = tm_rpc_bind { tm_config.rpc.laddr = parse_tm_address(None, &Url::parse(format!("tcp://{}", rpc).as_str())?)?; @@ -56,9 +56,6 @@ impl TestnetTendermintConfig { tm_config.p2p.laddr = parse_tm_address(None, &Url::parse(format!("tcp://{}", p2p).as_str())?)?; } - // We don't use pprof_laddr, and tendermint-rs incorrectly prepends "tcp://" to it, - // which emits an error on service start, so let's remove it entirely. - tm_config.rpc.pprof_laddr = None; Ok(Self(tm_config)) } diff --git a/testnets/tm_config_template.toml b/testnets/cometbft_config_template.toml similarity index 90% rename from testnets/tm_config_template.toml rename to testnets/cometbft_config_template.toml index 74e87b00be..13d1bb8d1d 100644 --- a/testnets/tm_config_template.toml +++ b/testnets/cometbft_config_template.toml @@ -3,7 +3,7 @@ # NOTE: Any path below can be absolute (e.g. "/var/myawesomeapp/data") or # relative to the home directory (e.g. "data"). The home directory is -# "$HOME/.tendermint" by default, but could be changed via $TMHOME env variable +# "$HOME/.cometbft" by default, but could be changed via $CMTHOME env variable # or --home cmd flag. ####################################################################### @@ -11,16 +11,20 @@ ####################################################################### # TCP or UNIX socket address of the ABCI application, -# or the name of an ABCI application compiled in with the Tendermint binary +# or the name of an ABCI application compiled in with the CometBFT binary proxy_app = "tcp://127.0.0.1:26658" # A custom human readable name for this node moniker = "" -# If this node is many blocks behind the tip of the chain, FastSync +# If this node is many blocks behind the tip of the chain, BlockSync # allows them to catchup quickly by downloading blocks in parallel # and verifying their commits +# +# Deprecated: this key will be removed and BlockSync will be enabled +# unconditionally in the next major release. fast_sync = true +block_sync = true # Database backend: goleveldb | cleveldb | boltdb | rocksdb | badgerdb # * goleveldb (github.com/syndtr/goleveldb - most popular implementation) @@ -63,7 +67,7 @@ priv_validator_key_file = "config/priv_validator_key.json" # Path to the JSON file containing the last sign state of a validator priv_validator_state_file = "data/priv_validator_state.json" -# TCP or UNIX socket address for Tendermint to listen on for +# TCP or UNIX socket address for CometBFT to listen on for # connections from an external PrivValidator process priv_validator_laddr = "" @@ -96,16 +100,10 @@ laddr = "tcp://0.0.0.0:26657" cors_allowed_origins = [] # A list of methods the client is allowed to use with cross-domain requests -cors_allowed_methods = ["HEAD", "GET", "POST"] +cors_allowed_methods = ["HEAD", "GET", "POST", ] # A list of non simple headers the client is allowed to use with cross-domain requests -cors_allowed_headers = [ - "Origin", - "Accept", - "Content-Type", - "X-Requested-With", - "X-Server-Time", -] +cors_allowed_headers = ["Origin", "Accept", "Content-Type", "X-Requested-With", "X-Server-Time", ] # TCP or UNIX socket address for the gRPC server to listen on # NOTE: This server only supports /broadcast_tx_commit @@ -116,7 +114,7 @@ grpc_laddr = "" # If you want to accept a larger number than the default, make sure # you increase your OS limits. # 0 - unlimited. -# Should be < ulimit -Sn - MaxNumInboundPeers - MaxNumOutboundPeers - N of wal, db and other open files +# Should be < {ulimit -Sn} - {MaxNumInboundPeers} - {MaxNumOutboundPeers} - {N of wal, db and other open files} # 1024 - 40 - 10 - 50 = 924 = ~900 grpc_max_open_connections = 900 @@ -128,7 +126,7 @@ unsafe = false # If you want to accept a larger number than the default, make sure # you increase your OS limits. # 0 - unlimited. -# Should be < ulimit -Sn - MaxNumInboundPeers - MaxNumOutboundPeers - N of wal, db and other open files +# Should be < {ulimit -Sn} - {MaxNumInboundPeers} - {MaxNumOutboundPeers} - {N of wal, db and other open files} # 1024 - 40 - 10 - 50 = 924 = ~900 max_open_connections = 900 @@ -166,7 +164,7 @@ experimental_websocket_write_buffer_size = 200 # # Enabling this experimental parameter will cause the WebSocket connection to # be closed instead if it cannot read fast enough, allowing for greater -# predictability in subscription behaviour. +# predictability in subscription behavior. experimental_close_on_slow_client = false # How long to wait for a tx to be committed during /broadcast_tx_commit. @@ -182,22 +180,22 @@ max_body_bytes = 1000000 max_header_bytes = 1048576 # The path to a file containing certificate that is used to create the HTTPS server. -# Might be either absolute path or path related to Tendermint's config directory. +# Might be either absolute path or path related to CometBFT's config directory. # If the certificate is signed by a certificate authority, # the certFile should be the concatenation of the server's certificate, any intermediates, # and the CA's certificate. -# NOTE: both tls_cert_file and tls_key_file must be present for Tendermint to create HTTPS server. +# NOTE: both tls_cert_file and tls_key_file must be present for CometBFT to create HTTPS server. # Otherwise, HTTP server is run. tls_cert_file = "" # The path to a file containing matching private key that is used to create the HTTPS server. -# Might be either absolute path or path related to Tendermint's config directory. -# NOTE: both tls-cert-file and tls-key-file must be present for Tendermint to create HTTPS server. +# Might be either absolute path or path related to CometBFT's config directory. +# NOTE: both tls-cert-file and tls-key-file must be present for CometBFT to create HTTPS server. # Otherwise, HTTP server is run. tls_key_file = "" # pprof listen address (https://golang.org/pkg/net/http/pprof) -pprof_laddr = "127.0.0.1:6060" +pprof_laddr = "" ####################################################### ### P2P Configuration Options ### @@ -282,7 +280,7 @@ dial_timeout = "3s" # Mempool version to use: # 1) "v0" - (default) FIFO mempool. -# 2) "v1" - prioritized mempool. +# 2) "v1" - prioritized mempool (deprecated; will be removed in the next release). version = "v0" recheck = true @@ -306,7 +304,7 @@ cache_size = 10000 keep-invalid-txs-in-cache = false # Maximum size of a single transaction. -# NOTE: the max size of a tx transmitted over the network is max_tx_bytes. +# NOTE: the max size of a tx transmitted over the network is {max_tx_bytes}. max_tx_bytes = 1048576 # Maximum size of a batch of transactions to send to a peer @@ -377,6 +375,19 @@ chunk_fetchers = "4" # 2) "v2" - complete redesign of v0, optimized for testability & readability version = "v0" +####################################################### +### Block Sync Configuration Options ### +####################################################### +[blocksync] + +# Block Sync version to use: +# +# In v0.37, v1 and v2 of the block sync protocols were deprecated. +# Please use v0 instead. +# +# 1) "v0" - the default block sync implementation +version = "v0" + ####################################################### ### Consensus Configuration Options ### ####################################################### @@ -399,11 +410,11 @@ timeout_precommit_delta = "500ms" # How long we wait after committing a block, before starting on the new # height (this gives us a chance to receive some more precommits, even # though we already have +2/3). -timeout_commit = "5s" +timeout_commit = "1s" # How many blocks to look back to check existence of the node's consensus votes before joining consensus # When non-zero, the node will panic upon restart -# if the same consensus key was used to sign double_sign_check_height last blocks. +# if the same consensus key was used to sign {double_sign_check_height} last blocks. # So, validators should stop the state machine, wait for some blocks, and then restart the state machine to avoid panic. double_sign_check_height = 0 @@ -421,6 +432,7 @@ peer_query_maj23_sleep_duration = "2s" ####################################################### ### Storage Configuration Options ### ####################################################### +[storage] # Set to true to discard ABCI responses from the state store, which can save a # considerable amount of disk space. Set to false to ensure ABCI responses are