Skip to content

banbot has a wide range of configuration options. By default, these are configured through the yaml configuration file.

Data Directory

Every time you start backtesting or real trading, you need to pass in the -datadir parameter, which is the data directory. You can also configure the environment variable BanDataDir and ignore the -datadir parameter.

You can store several yaml configuration files in the data directory. When backtesting, a backtest subdirectory will be automatically created in the data directory to store the backtest results.

Yaml Configuration File

banbot can receive several configuration file paths from command line parameters. If the following configuration files have the same configuration as the previous ones, the previous ones will be overwritten.

You can divide the configuration files into multiple parts and pass them in one by one for easy maintenance.

Default Configuration File

banbot will try to read two configuration files from the data directory by default: config.yml and config.local.yml.

You can create these two configuration files directly. You don't need to pass them in when starting banbot, and they will be read automatically.

config.yml is recommended to store relatively complete default configurations that do not need to be modified frequently. It is recommended to store local related configurations in config.local.yml, such as exchange api/secret, api_server and other configurations.

Complete Yaml configuration

yaml
name: local  # Bot name, used to distinguish different bots in message notifications
env: prod  # Running environment, prod represents production network, test represents test network (Binance testnet), dry_run represents simulation
leverage: 2  # Leverage ratio, only valid in the futures market
limit_vol_secs: 5  # The expiration time for the order book price based on trading volume, in seconds, default is 10
put_limit_secs: 120  # Limit order submission time to the exchange within which it is expected to be filled, in seconds, default is 120
market_type: spot  # Market type: spot for spot trading, linear for USDT-margined contracts, inverse for coin-margined contracts, option for options contracts
contract_type: swap  # swap for perpetual contracts, future for expiring contracts
odbook_ttl: 1000  # Order book expiration time, in milliseconds, default is 500
concur_num: 2  # Concurrent number of symbol candle downloads, default is 2 symbols
order_type: market  # Order type: market for market orders, limit for limit orders
stop_enter_bars: 20  # Cancel the limit entry order if it is not filled within this many candles, default is 0 (disabled)
prefire: 0  # Whether to trigger 10% ahead of the bar’s completion time
margin_add_rate: 0.66  # For futures contracts, add margin when the loss reaches this ratio of the initial margin to avoid liquidation, default is 0.66
stake_amount: 15  # Default amount per order, lower priority than stake_pct
stake_pct: 50  # Percentage of account to use for each order, based on the nominal value
max_stake_amt: 5000  # Max order amount of 5k, valid only if stake_pct is specified
charge_on_bomb: false # Automatically recharge to continue backtesting when backtesting liquidation occurs
take_over_strat: ma:demo # The strategy for taking over user orders during real trading, empty by default
open_vol_rate: 1  # Maximum allowed open order quantity / average candle volume ratio when not specifying order quantity, default is 1
min_open_rate: 0.5  # Minimum open order ratio, allows order if balance / per order amount exceeds this ratio when balance is insufficient, default is 0.5 (50%)
max_simul_open: 0 # Maximum number of simultaneously open orders on one candlestick
bt_net_cost: 15  # Order delay in backtest, can be used to simulate slippage, in seconds, default is 15
relay_sim_unfinish: false  # When trading a new symbol (backtesting/live trading), whether to trading from the open order relay at the beginning time
order_bar_max: 500  # Find the maximum number of bars for forward simulation from the open orders at the start time.
wallet_amounts:  # Wallet balance, used for backtesting
  USDT: 10000
stake_currency: [USDT, TUSD]  # Limit trading pairs to those priced in these currencies
fatal_stop:  # Global stop loss, forbids order placement when total loss reaches these limits
  '1440': 0.1  # 10% loss in a day
  '180': 0.2  # 20% loss in 3 hours
  '30': 0.3  # 30% loss in half an hour
fatal_stop_hours: 8  # Prohibits order placement for this many hours when global stop loss is triggered; default is 8
timerange: "20230701-20230808"  # candle data range used for backtesting
run_timeframes: [5m]  # All allowed timeframes for the bot. The strategy will choose the most suitable minimum timeframe; this setting is lower priority than run_policy
run_policy:  # The strategy to run, multiple strategies can run simultaneously or a strategy can be run with different parameters
  - name: Demo  # Strategy name
    run_timeframes: [5m]  # Timeframes supported by this strategy, overrides the root run_timeframes when provided
    filters:  # All filters from pairlists can be used
    - name: OffsetFilter  # Offset limit filter, typically used last
      offset: 10  # Start from the 10th item
      limit: 30  # Take up to 30 items
    max_pair: 999  # Maximum number of symbols allowed for this strategy
    max_open: 10  # Maximum number of open orders for this strategy
    max_simul_open: 0  # Maximum number of orders opened simultaneously on a candlestick
    order_bar_max: 0  # Overrides the global default order_bar_max when non-zero
    stake_rate: 1 # The stake amount rate for this strategy
    dirt: any  # any/long/short
    pairs: [BTC/USDT:USDT]
    params: {atr: 15}
    pair_params:
      BTC/USDT:USDT: {atr:14}
    strat_perf:  # Same as root-level strat_perf configuration
      enable: false
strat_perf:
  enable: false  # Whether to enable strategy symbol performance tracking, automatically reduces order size for symbols with significant losses
  min_od_num: 5  # Minimum of 5 orders, default is 5; performance will not be calculated if fewer than 5
  max_od_num: 30  # Maximum number of orders in a job, minimum is 8, default is 30
  min_job_num: 10  # Minimum number of symbols, default is 10, minimum is 7
  mid_weight: 0.2  # Weight for orders in the middle performance range
  bad_weight: 0.1  # Weight for orders in the poor performance range
pairs:  # Given trading pairs, if not empty, pairlists will be ignored
- SOL/USDT:USDT
- UNFI/USDT:USDT
- SFP/USDT:USDT
pairmgr:
  cron: '25 1 0 */2 * *' # Second Minute Hour Day Month Weekday
  offset: 0  # Ignore the first n symbols in the list
  limit: 999  # Keep a maximum of n symbols in the list
  force_filters: false  # apply pairlists to static pairs force; default: false
  pos_on_rotation: hold  # hold/close the position when rotating the symbol list, default: hold
pairlists:  # Filters for trading pairs, applied sequentially in top-down order
  - name: VolumePairList  # Sort all pairs by trading volume in descending order
    limit: 100  # Take the top 100 pairs
    limit_rate: 1 # Cut limit by the rate
    min_value: 100000  # Minimum trading volume value
    refresh_secs: 7200  # Cache duration
    back_timeframe: 1d  # Timeframe for calculating trading volume, default is 1 day
    back_period: 1  # Multiplier for the trading volume period, back_timeframe * back_period gives the time range
  - name: PriceFilter  # Price filter
    max_unit_value: 100  # Max allowed unit price change value (based on quote currency, usually USDT)
    precision: 0.0015  # Filter pairs based on price precision, default requires price changes to be at least 0.1%
    min: 0.001  # Minimum price
    max: 100000  # Maximum price
  - name: RateOfChangeFilter  # Volatility filter
    back_days: 5  # Number of days to review for candle data
    min: 0.03  # Minimum price change ratio
    max: 10  # Maximum price change ratio
    refresh_period: 1440  # Cache duration, in seconds
  - name: SpreadFilter  # Liquidity filter
    max_ratio: 0.005  # Formula: 1 - bid/ask, max price spread ratio allowed
  - name: CorrelationFilter  # Correlation filter
    min: -1  # Filter symbols based on correlation to the market average; default is 0 (disabled)
    max: 1  # Filter symbols based on correlation to the market average; default is 0 (disabled)
    timeframe: 5m  # Timeframe for calculating correlation
    back_num: 70  # Lookback length for correlation data
    sort: asc  # asc/desc/""
    top_n: 50  # Return only the top n symbols with the lowest correlation; default is 0 (no limit)
  - name: VolatilityFilter  # Volatility filter, formula: std(log(c/c1)) * sqrt(back_days)
    back_days: 10  # Number of days to review for candle data
    max: 1  # Maximum volatility score, higher values allow more volatile symbols on the daily level
    min: 0.05  # Minimum volatility score, lower values allow symbols with less volatility on the daily level
    refresh_period: 1440  # Cache duration
  - name: AgeFilter  # Filter symbols based on listing days
    min: 5
  - name: OffsetFilter  # Offset limit filter, typically used last
    reverse: false  # reverse array
    offset: 10  # Start from the 10th item
    rate: 0.5  # 50% of array
    limit: 30  # Take up to 30 items
  - name: ShuffleFilter  # Random shuffle
    seed: 42  # Random seed, optional
exchange:  # Exchange configuration
  name: binance  # The exchange being used
  binance:
    account_prods:  # API key and secret for production network, required when env is set to prod
      user1: # Account name, can be any name, used when sending rpc messages
        api_key: xxx
        api_secret: bbb
        max_stake_amt: 1000  # Max allowed amount per order
        stake_rate: 1  # Order amount multiplier, relative to default
        leverage: 0  # Futures leverage, takes priority over the default
      user2: # Another account
        api_key: xxx
        api_secret: bbb
    account_tests:  # API key and secret for test network, required when env is set to test
      default:
        api_key: xxx
        api_secret: bbb
    options:  # Parameters for initializing the exchange via banexg, keys will be automatically converted from snake_case to CamelCase.
database:
  retention: all
  max_pool_size: 50
  auto_create: true  # Whether to automatically create the database if it does not exist
  url: postgresql://postgres:123@[127.0.0.1]:5432/ban
spider_addr: 127.0.0.1:6789  # Port and address monitored by the spider process
rpc_channels:  # RPC channels for sending message notifications
  wx_notify:  # Name of the RPC channel
    corp_id: ww0f12345678b7e
    agent_id: '1000005'
    corp_secret: b123456789_1Cx1234YB9K-MuVW1234
    touser: '@all'
    type: wework  # RPC type, supports: wework
    msg_types: [exception]  # Allowed message types to send
    accounts: []  # Allowed accounts, allows all if empty
    keywords: []  # Message filter keywords
    retry_num: 0
    retry_delay: 1000
    disable: true
webhook:  # Message types that can be sent via RPC
  entry:
    content: "{name} {action}\\nSymbol: {pair} {timeframe}\\nTag: {strategy}  {enter_tag}\\nPrice: {price:.5f}\\nCost: {value:.2f}"
  exit:
    content: "{name} {action}\\nSymbol: {pair} {timeframe}\\nTag: {strategy}  {exit_tag}\\nPrice: {price:.5f}\\nCost: {value:.2f}\\nProfit: {profit:.2f}"
  status:  # Bot status messages: start, stop, etc.
    content: '{name}: {status}'
  exception:
    content: '{name}: {status}'
api_server:  # For external control of the bot or access to dashboard via API
  enabled: true
  bind_ip: 0.0.0.0
  port: 8001
  jwt_secret_key: fn234njkcu89234nbf
  users:
    - user: ban
      pwd: 123
      acc_roles: {user1: admin}

Important details configuration

Configure single order amount

The minimum order amount depends on the exchange and currency pair, and is usually listed on the exchange support page.

When the robot starts, it will automatically load the exchange market information, which includes the order amount and other restrictions for all varieties. Banbot also limits the minimum single transaction amount to 10USD.

You can configure the single transaction amount through stake_pct or stake_amount. Note that for futures contracts, these two parameters refer to the nominal value, not the occupied margin.

If you need to use different transaction amounts for different accounts, you can configure the amount multiplier in exchange.[exg_name].account_prods.user1.stake_rate. The default is 1; changing it to <1 will reduce the order amount of this account. >1 will increase the order amount of this account

Similarly, you can also set different order amount multipliers for different strategies TradeStrat.StakeRate

Global stop loss

You can use fatal_stop to set the robot to stop trading for fatal_stop_hours hours when the robot's combined loss of all strategy tasks reaches a certain percentage within x minutes.