In this document, we could offer detailed description of all available configuration options in all configuration namespaces

Main configuration options

af_packet

NameTypeDefault valueDescription
mirror_afpacketboolfalseEnable capture from mirror port using AF_PACKET capture engine
interfacesstring_list[ ]Interfaces list for traffic capture
af_packet_extract_tunnel_trafficboolfalseEnables for af_packet code which strips external level for GRE tunnels
mirror_af_packet_samplingbooltrueEnables sampling for mirror mode offloaded on kernel / driver level
mirror_af_external_packet_samplingboolfalseEnables external sampling for mirror mode when router or switch does sampling
mirror_af_packet_socket_statsbooltrueEnables capture socket performance statistics
mirror_af_packet_disable_multithreadingbooltrueDisables multi thread processing and handles all traffic using single thread
mirror_af_packet_fanout_modestring“cpu”Fanout mode. Algorithm to spread load over threads
mirror_af_packet_sampling_ratepositive_integer_with_zero100Sampling rate for AF_PACKET
mirror_external_af_packet_sampling_ratepositive_integer_with_zero100External sampling rate for AF_PACKET
mirror_af_packet_workers_number_overrideboolfalseEnables logic to explicitly override number of worker processes
mirror_af_packet_workers_numberpositive_integer_with_zero1Specifies how many worker processes we need for each interface
afpacket_strict_cpu_affinityboolfalseEnables strict CPU affinity and binds traffic capture threads to fixed logical CPUs
af_packet_read_packet_length_from_ip_headerboolfalseBy default, FastNetMon reads packet length from the wire. But it can use information from IP header when you enable this option

api

NameTypeDefault valueDescription
enable_apibooltrueEnable internal FastNetMon API. It’s mandatory for fcli and public web API
api_hoststring“127.0.0.1”Internal API host for listening
api_portnumeric_ipv4_port50052Internal API port for listening

app_packet_sr

NameTypeDefault valueDescription
app_packet_srboolfalseEnable App Packet SR capture for Nokia SR UDP Shim encoding
app_packet_sr_local_addressesstring_list[ ]App Packet SR collector addresses to bind on in format: protocol://host:port as protocol you can use udp only
app_packet_sr_tunnel_trafficboolfalseEnables code which strips external level for GRE tunnels for App Packet SR
app_packet_sr_read_packet_length_from_ip_headerboolfalseBy default, FastNetMon reads packet length from the wire. But it can use information from IP header when you enable this option

ban_management

NameTypeDefault valueDescription
enable_banboolfalseCompletely enable or disable all ban actions
enable_ban_hostgroupboolfalseCompletely enable or disable all ban for total traffic per hostgroup
enable_ban_remote_outgoingboolfalseEnable blocking for remote hosts in outgoing direction
enable_ban_remote_incomingboolfalseEnable blocking for remote hosts in incoming direction
do_not_ban_incomingboolfalseCompletely disables ban for incoming traffic
do_not_ban_outgoingboolfalseCompletely disables ban for outgoing traffic
per_direction_hostgroup_thresholdsbooltrueChanges hostgroup thresholds to be per direction. Default becomes incoming
flexible_thresholdsboolfalseEnables flexible thresholds logic
flexible_thresholds_disable_multi_alertsboolfalseEnables compatibility mode for flexible threshold which triggers attack only using single threshold and only in single direction
keep_flow_spec_announces_during_restartboolfalseSaves list of flow spec announces on shutdown and restores it on startup
keep_blocked_hosts_during_restartboolfalseSaves list of blocked hosts on shutdown and restores it on startup
keep_blocked_hostgroups_during_restartboolfalseSaves list of blocked hostgroups on shutdown and restores it on startup
enable_ban_ipv6boolfalseCompletely enable or disable all ban actions for IPv6 traffic
unban_enabledbooltrueWe will try to unban blocked IPs after this time expires
ban_status_updatesboolfalseFastNetMon will report active attacks every X seconds
ban_status_delaypositive_integer_with_zero20How often FastNetMon will update external systems about active attacks
ban_timepositive_integer_with_zero771How long we should keep an IP in blocked state. Zero value is prohibited here.
unban_only_if_attack_finishedbooltrueCheck if the attack is still active, before triggering an unblock callback with this option. If the attack is still active, check each run of the unblock watchdog
gobgp_flow_spec_announcesboolfalseAnnounce flow spec rules to block only malicious traffic. Use only if you have BGP Flowspec capable routers
gobgp_flow_spec_v6_announcesboolfalseAnnounce flow spec IPv6 rules to block only malicious traffic. Use only if you have BGP Flowspec capable routers
flow_spec_unban_enabledbooltrueWe will try to withdraw flow spec rule when blocking time expires
flow_spec_per_hostgroup_managementboolfalseEnables logic which enables flow spec mitigations only when they explicitly enabled for hostgroup
flow_spec_ban_timepositive_integer_with_zero1900How long we should flow spec keep rule in announces. Zero value is prohibited here.
collect_attack_pcap_dumpsboolfalseThis option enables pcap collection for attack’s traffic dump. Works only for mirror and sFlow modes
collect_simple_attack_dumpsbooltrueCollect simple attack dumps which include information from attack’s sample. Works for all capture engines
ban_details_records_countpositive_integer_with_zero25How many packets will be collected from attack’s traffic. Please decrease this value if you are using sampled capture protocols
threshold_specific_ban_detailsboolfalseIn this mode FastNetMon will collect only traffic relevant to direction and type of threshold
do_not_cap_ban_details_records_countboolfalseDisables logic which automatically reduces ban_details_records_count when it exceeds 100 for sFlow and Netflow
unban_total_hostgroup_enabledbooltrueWe will try to unban blocked hostgroup after specified amount of time
ban_time_total_hostgrouppositive_integer_with_zero675How long we should keep hostgroup in blocked state. Zero value is prohibited here.
bucket_traffic_collection_timeoutpositive_integer_with_zero60How long we should wait for bucket to collect traffic after threshold was crossed

bgp

NameTypeDefault valueDescription
gobgpboolfalseEnable BGP daemon integration
gobgp_api_hoststring“localhost”IP address or host to connect to GoBGP
gobgp_api_portnumeric_ipv4_port50051Port to connect to GoBGP
gobgp_bgp_listen_portnumeric_ipv4_port179BGP listen port
gobgp_router_idstring“”Router ID to override default configuration
gobgp_next_hopnumeric_ipv4_host“0.0.0.0”Next hop value for BGP unicast host and subnet IPv4 announces
gobgp_next_hop_host_ipv4numeric_ipv4_host“0.0.0.0”Next hop value for BGP unicast IPv4 host announces
gobgp_next_hop_subnet_ipv4numeric_ipv4_host“0.0.0.0”Next hop value for BGP unicast IPv4 subnet announces
gobgp_next_hop_remote_hostnumeric_ipv4_host“0.0.0.0”Next hop value for BGP unicast remote host IPv4 announces
gobgp_do_not_manage_daemonboolfalseDisables automatic start / restart operations for BGP daemon
gobgp_announce_hostbooltrueAnnounce /32 host itself with BGP
gobgp_announce_whole_subnetboolfalseAnnounce origin subnet of IP address
gobgp_announce_whole_subnet_force_custom_prefix_lengthboolfalseEnables override for subnet announce
gobgp_announce_whole_subnet_custom_prefix_lengthpositive_integer_with_zero24Prefix length to override default one
gobgp_announce_whole_subnet_force_custom_ipv6_prefix_lengthboolfalseEnables override for IPv6 subnet announce
gobgp_announce_whole_subnet_custom_ipv6_prefix_lengthpositive_integer_with_zero48IPv6 prefix length to override default one
gobgp_announce_remote_hostboolfalseAnnounce remote /32 host itself with BGP
gobgp_community_hoststring“65001:668”BGP community for outgoing host announces. Here you can add community string for the host announce. Usage ASN:Community. ASN and community should be from 1 to 65535).
gobgp_communities_host_ipv4string_list[ ]BGP communities for outgoing host announces. Here you can add communities strings for the host announces. Usage ASN:Community. ASN and community should be from 1 to 65535).
gobgp_communities_host_ipv6string_list[ ]BGP communities for outgoing host announces. Here you can add communities strings for the host announces. Usage ASN:Community. ASN and community should be from 1 to 65535).
gobgp_community_subnetstring“65001:667”BGP community for outgoing subnet announces. Here you can add community string for the prefix subnet announce. Usage ASN:Community. ASN and community should be from 1 to 65535).
gobgp_communities_subnet_ipv4string_list[ ]BGP communities for outgoing subnet announces. Here you can add communities strings for the prefix subnet announce. Usage ASN:Community. ASN and community should be from 1 to 65535).
gobgp_communities_subnet_ipv6string_list[ ]BGP communities for outgoing subnet announces. Here you can add communities strings for the prefix subnet announce. Usage ASN:Community. ASN and community should be from 1 to 65535).
gobgp_community_remote_hoststring“65001:669”BGP community for outgoing remote host announces. Here you can add community string for the host announce. Usage ASN:Community. ASN and community should be from 1 to 65535).
gobgp_ipv6boolfalseEnable BGP actions for IPv6 traffic
gobgp_next_hop_ipv6string“100::1”Next hop value for BGP unicast IPv6 announces
gobgp_announce_host_ipv6booltrueAnnounce /128 host itself with BGP
gobgp_announce_whole_subnet_ipv6boolfalseIPv6 prefix subnet, that will be announced
gobgp_community_host_ipv6string“65001:668”BGP community for outgoing host announces for IPv6 protocol. Here you can add community string for the host announce. Usage ASN:Community. ASN and community should be from 1 to 65535).
gobgp_community_subnet_ipv6string“65001:667”BGP community for outgoing subnet announces for IPv6 protocol. Here you can add community string for the prefix subnet announce. Usage ASN:Community. ASN and community should be from 1 to 65535).
gobgp_flow_spec_default_actionstring“discard”Default action for flow spec rules. You could specify accept, discard or rate-limit here
gobgp_flow_spec_next_hop_ipv4string_list[ ]List of IPv4 next hops
gobgp_flow_spec_next_hop_ipv6string_list[ ]List of IPv6 next hops
gobgp_flow_spec_v6_default_actionstring“discard”Default action for flow spec rules. You could specify accept, discard or rate-limit here
gobgp_flow_spec_v6_rate_limit_valuepositive_integer_with_zero1024For rate-limit action you could specify rate
gobgp_flow_spec_rate_limit_valuepositive_integer_with_zero1024For rate-limit action you could specify rate
flow_spec_tcp_options_use_match_bitboolfalseEnables force match bit in outgoing BGP Flow Spec announces about TCP flags
flow_spec_fragmentation_options_use_match_bitboolfalseEnables force match bit in outgoing BGP Flow Spec announces about fragmentation
flow_spec_do_not_process_length_fieldboolfalseDisables processing for length field completely. Use it if your device produces incorrect information about packet’s length
flow_spec_do_not_process_tcp_flags_fieldboolfalseDisables processing for TCP flags field completely. You may need it if your router does not support all TCP flags in flow spec rules
flow_spec_do_not_process_ip_fragmentation_flags_fieldboolfalseDisables processing for IP fragmentation field completely. You may need it if your router does not support all IP fragmentations flags in flow spec rules
flow_spec_ignore_do_not_fragment_flagboolfalseDisables processing for do not fragment field completely. It’s useful on Arista and Extreme
flow_spec_do_not_process_source_address_fieldboolfalseDisables processing for source address field completely. Use it if you experience attacks from big number of IP addresses
flow_spec_execute_validationbooltrueWith this option we check that source and destination addresses in flow spec rule specified from fcli or web API belongs to our ranges
do_not_withdraw_unicast_announces_on_restartboolfalseDisables automatic withdrawal of BGP Unicast announces
do_not_withdraw_flow_spec_announces_on_restartboolfalseDisables automatic withdrawal of BGP Flow Spec announces
gobgp_announce_hostgroup_networksboolfalseEnable BGP announces for any network from specific hostgroup when per hostgroup aka total thresholds in use
gobgp_announce_hostgroup_networks_ipv4boolfalseEnable BGP announces for all IPv4 networks from specific hostgroup when per hostgroup aka total thresholds in use
gobgp_announce_hostgroup_networks_ipv6boolfalseEnable BGP announces for all IPv6 networks from specific hostgroup when per hostgroup aka total thresholds in use
gobgp_next_hop_hostgroup_networks_ipv4string“0.0.0.0”Next hop for IPv4 per hostgroup network announces
gobgp_next_hop_hostgroup_networks_ipv6string“100::1”Next hop for IPv6 per hostgroup network announces
gobgp_communities_hostgroup_networks_ipv4string_list[ ]BGP communities for IPv4 hostgroup network announces. Here you can add communities strings for the host announces. Usage ASN:Community. ASN and community should be from 1 to 65535).
gobgp_communities_hostgroup_networks_ipv6string_list[ ]BGP communities for IPv6 hostgroup network announces. Here you can add communities strings for the host announces. Usage ASN:Community. ASN and community should be from 1 to 65535).

clickhouse_metrics

NameTypeDefault valueDescription
clickhouse_metricsboolfalseExport traffic speed metrics to ClickHouse
clickhouse_metrics_databasestring“fastnetmon”Database for ClickHouse traffic metrics
clickhouse_metrics_usernamestring“default”Username for ClickHouse metrics
clickhouse_metrics_passwordstring“”Password for ClickHouse metrics
clickhouse_metrics_hoststring“127.0.0.1”Server address for ClickHouse server to export metrics. IPv4, IPv6 address or hostname
clickhouse_metrics_portnumeric_ipv4_port9000ClickHouse server port
clickhouse_metrics_push_periodpositive_integer_with_zero1Delay for run ClickHouse push thread
clickhouse_metrics_export_top_hostsbooltrueEnables export of only top talker hosts for IPv4 and IPv6 into separate table

email_notification

NameTypeDefault valueDescription
email_notifications_enabledboolfalseEnable email notifications
email_notifications_disable_certificate_checksboolfalseDisables TLS certificate validation completely
email_notifications_hoststring“smtp.gmail.com”Hostname of SMTP server
email_notifications_portnumeric_ipv4_port587Port of SMTP server used for email notifications
email_notifications_tlsbooltrueEnable TLS for your SMTP server
email_notifications_authbooltrueEnable auth for your SMTP server
email_notifications_auth_methodstring“”Auth method for SMTP authorization. Used only when auth enabled
email_notifications_usernamestring“fastnetmon@yourdomain.com”Username for SMTP authorization
email_notifications_passwordstring“super-secret-password”Password for SMTP authorization
email_notifications_fromstring“fastnetmon@yourdomain.com”Email address for FROM field
email_notifications_recipientsstring_list[ ]Email notification recipients
email_notifications_hide_flow_spec_rulesboolfalseHide flow spec rules from email
email_notifications_add_simple_packet_dumpbooltrueAdd simple packet dump to email
email_subject_blackhole_blockstring“FastNetMon blocked host {{ ip }}”Subject template for email notification about blocked host
email_subject_blackhole_unblockstring“FastNetMon unblocked host {{ ip }}”Subject template for email notification about unblocked host
email_subject_partial_blockstring“FastNetMon partially blocked traffic for host {{ ip }}”Subject template for email notification about partially blocked host
email_subject_partial_unblockstring“FastNetMon partially unblocked traffic for host {{ ip }}”Subject template for email notification about partially unblocked host
slack_notifications_add_simple_packet_dumpbooltrueAdd simple packet dump to Slack alerts

filter_xdp

NameTypeDefault valueDescription
filter_xdpboolfalseEnable capability to generate and inject filtering rules for XDP
filter_xdp_modestring“skb”Sets XDP mode: skb, driver, hardware
interfaces_filter_xdpstring_list[ ]Interfaces list to load XDP microcode

graphite

NameTypeDefault valueDescription
graphiteboolfalseEnabled metrics export to Graphite
graphite_hostnumeric_ipv4_host“127.0.0.1”Graphite server address
graphite_portnumeric_ipv4_port2003Graphite server port
graphite_prefixstring“fastnetmon”Default prefix for Graphite metrics
graphite_push_periodpositive_integer_with_zero1Delay for run Graphite push thread

influxdb

NameTypeDefault valueDescription
influxdb_kafkaboolfalseEnables traffic metrics export to Influxdb over Kafka
influxdb_kafka_brokersstring_list[ ]Kafka brokers for InfluxDB export
influxdb_kafka_topicstring“fastnetmon”Topic name for Kafka InfluxDB instance
influxdb_kafka_partitionerstring“consistent”Partitioner between available partitions
influxdbboolfalseEnabled traffic metrics export to Influxdb
influxdb_databasestring“fastnetmon”Database for InfluxDB data
influxdb_hoststring“127.0.0.1”InfluxDB server address (IPv4, IPv6 address or domain name)
influxdb_portnumeric_ipv4_port8086InfluxDB server port
influxdb_custom_tagsboolfalseAdds custom tag to InfluxDB export data
influxdb_tag_namestring“node”Custom tag name
influxdb_tag_valuestring“master”Custom tag value
influxdb_tags_tablestring_string_mapCustom tags in key / value format
influxdb_skip_host_countersboolfalseSkip export for host counters to reduce load on InfluxDB server
influxdb_push_host_ipv6_countersbooltrueEnable pushing per host IPv6 counters to InfluxDB
influxdb_push_host_ipv4_flexible_countersbooltrueEnables export of flexible per host IPv4 counters to InfluxDB
influxdb_push_host_ipv6_flexible_countersbooltrueEnables export of flexible per host IPv6 counters to InfluxDB
influxdb_userstring“fastnetmon”Username for InfluxDB
influxdb_passwordstring“fastnetmon”Password for InfluxDB
influxdb_authboolfalseEnable authorization for InfluxDB
influxdb_attack_notificationboolfalseEnables attack notifications in Grafana
influxdb_push_periodpositive_integer_with_zero1Delay for run InfluxDB push thread

logging

NameTypeDefault valueDescription
logging_levelstring“info”Configures logging level
logging_local_syslog_loggingboolfalseEnable this option if you want to send logs to local syslog facility
logging_remote_syslog_loggingboolfalseEnable this option if you want to send logs to a remote syslog server using UDP protocol
logging_remote_syslog_servernumeric_ipv4_host“10.10.10.10”This is the IPv4 address of your syslog server. You can specify the address you need
logging_remote_syslog_portnumeric_ipv4_port514Remote syslog server port

mikrotik

NameTypeDefault valueDescription
mikrotik_announce_hostboolfalseEnable Mikrotik integration
mikrotik_announce_host_blackholebooltrueEnable blackhole flag for per host Mikrotik announce
mikrotik_rest_api_urlsstring_list[ ]Mikrotik API URLs

mongo

NameTypeDefault valueDescription
mongo_store_attack_informationboolfalseEnables attacks export to MongoDB

netflow

NameTypeDefault valueDescription
netflowboolfalseEnable Netflow capture. We support Netflow v5, v9 and IPFIX (10)
netflow_count_packets_per_deviceboolfalseEnable logic to count number of packets from each router
netflow_multi_thread_processingboolfalseEnables multi thread processing for each Netflow port
netflow_threads_per_portpositive_integer_with_zero1Number of threads per Netflow port
netflow_multi_thread_modestring“”Mode used to distribute traffic between threads
netflow_portsnumeric_ipv4_port_list[ ]Netflow collector port. It’s possible to specify multiple ports here
netflow_hoststring“0.0.0.0”Netflow collector host. To bind on all interfaces for IPv4 and IPv6 use ::. To bind only on IPv4 use 0.0.0.0. To bind on localhost for IPv4 and IPv6 use ::1. To bind only on IPv4 use 127.0.0.1
netflow_socket_read_modestring“recvfrom”Switches logic used to read data from socket: recvfrom or recvmsg
netflow_rx_queue_overflow_monitoringboolfalseSwitches on logic to monitor drops on socket
netflow_ignore_sampling_rate_from_deviceboolfalseIgnores sampling rate announces from device. For Netflow v9 and IPFIX only
netflow_ignore_long_duration_flow_enableboolfalseFastNetMon will ignore flows which exceed duration specified in configuration
netflow_long_duration_flow_limitpositive_integer_with_zero1FastNetMon will ignore flows which exceed duration specified in this option
netflow_v5_per_router_sampling_ratestring_positive_integer_with_zero_mapCustom Netflow v5 sampling rate on router basis
netflow_v9_per_router_sampling_ratestring_positive_integer_with_zero_mapCustom Netflow v9 sampling rate on router basis
netflow_v9_read_sampling_rate_in_data_sectionboolfalseEnables logic which can retrieve sampling rate when it was passed in data section. Mikrotik uses this approach
netflow_v9_extract_tunnel_trafficboolfalseEnables logic for Netflow v9 code which strips external level for GRE tunnels. It works only when packet header information is present
ipfix_per_router_sampling_ratestring_positive_integer_with_zero_mapCustom IPFIX sampling rate on router basis
ipfix_extract_tunnel_trafficboolfalseEnables logic for IPFIX code which strips external level for GRE tunnels. It works only when packet header information is present
netflow_sampling_ratiopositive_integer_with_zero1Netflow 9 or IPFIX sampling rate used at agent side. Netflow v9 and IPFIX agents use different and very complex approaches for notifying about sample ratio. Here you could specify a sampling ratio for all this agents. For Netflow v5 we extract sampling ratio from packets directly and this option not used.
netflow_v5_custom_sampling_ratio_enableboolfalseThis option will override netflow v5 sampling rate from packets by specified value
netflow_v5_sampling_ratiopositive_integer_with_zero1It will be used when netflow_v5_custom_sampling_ratio_enable set to enable
netflow_templates_cachebooltrueCache Netflow v9 or IPFIX data templates on disk
netflow_sampling_cachebooltrueCache Netflow v9 and IPFIX sampling rates on disk
netflow_process_only_flows_with_dropped_packetsboolfalseWe will process only Netflow v9 or IPFIX with forwarding status set to dropped
netflow_mark_zero_next_hop_and_zero_output_as_droppedboolfalseWith this option all traffic with zero IPv4 and IPv6 addresses in next hop and zero output interface will be marked as dropped

network_management

NameTypeDefault valueDescription
networks_listcidr_networks_list[ ]Please specify all IPv4 and IPv6 networks which belong to you
networks_whitelistcidr_networks_list[ ]All ban actions will be disabled for your hosts in these networks. Use with attention!
networks_whitelist_remotecidr_networks_list[ ]We will skip traffic to/from these remote networks completely from processing
monitor_local_ip_addressesboolfalseAdd local IP addresses and aliases to networks_list

notify_script

NameTypeDefault valueDescription
notify_script_hostgroup_enabledboolfalseEnable script call in case of blocking for hostgroup total thresholds
notify_script_hostgroup_pathfile“/etc/fastnetmon/scripts/notify_about_attack.sh”Path to notify script for hostgroup level blocks
notify_script_enabledboolfalseEnable script call in case of blocking, unban and attack_details actions
notify_script_attack_status_updatesboolfalseEnables logic to report all active attacks and their performance to callback script every ban_status_delay seconds
notify_script_pathfile“/etc/fastnetmon/scripts/notify_about_attack.sh”Path to notify script. This script executed for ban, unban and attack detail collection
notify_script_formatstring“text”Specifies format used for notify script: text or JSON

prometheus

NameTypeDefault valueDescription
prometheusboolfalseEnable Prometheus metrics endpoint
prometheus_hostnumeric_ipv4_host“127.0.0.1”Prometheus metrics address
prometheus_portnumeric_ipv4_port9209Prometheus metrics port
prometheus_export_host_ipv4_countersboolfalseEnables logic to export IPv4 host counters via endpoint
prometheus_export_host_ipv6_countersboolfalseEnables logic to export IPv6 host counters via endpoint
prometheus_export_network_ipv4_countersbooltrueEnables logic to export IPv4 network counters via endpoint
prometheus_export_network_ipv6_countersbooltrueEnables logic to export IPv6 network counters via endpoint

redis

NameTypeDefault valueDescription
redis_enabledboolfalseEnables attack’s export to Redis
redis_hostnumeric_ipv4_host“127.0.0.1”Redis server host
redis_portnumeric_ipv4_port6379Redis server port
redis_prefixstring“fastnetmon”Prefix for all Redis keys

sflow

NameTypeDefault valueDescription
sflowboolfalseEnables sFlow capture engine. We support only sFlow v5
sflow_extract_tunnel_trafficboolfalseEnables for sFlow code which strips external level for GRE tunnels
sflow_count_packets_per_deviceboolfalseEnable logic to count number of sFlow packets from each device
sflow_portsnumeric_ipv4_port_list[ ]Ports list for sFlow collector. It’s possible to specify multiple ports here
sflow_hoststring“0.0.0.0”sFlow collector default host. Here you can specify the IP address of the listen interface. If default is used, all interfaces will be listen.
sflow_read_packet_length_from_ip_headerboolfalseSome vendors may lie about full packet length in sFlow packet. To avoid this issue we can switch to using IP packet length from parsed header
sflow_track_sampling_rateboolfalseEnables tracking for sFlow sampling rate for all exporting entities (devices, line cards)

slack_notification

NameTypeDefault valueDescription
slack_notifications_enabledboolfalseEnable Slack notifications
slack_notifications_urlstring“https://hooks.slack.com/services/TXXXXXXXX/BXXXXXXXXX/LXXXXXXXXX”Slack notification URL

system

NameTypeDefault valueDescription
cache_pathfile“/var/cache/fastnetmon”Path to folder used for cache
asn_lookupbooltrueEnable ASN mapping database to execute ASN lookup for IP. You could use it to lookup ASN for particular IP
country_lookupboolfalseEnable country lookup logic
force_asn_lookupboolfalseOverwrite ASN received from device by result of lookup by our ASN database
pid_pathfile“/var/run/fastnetmon.pid”Path to pid file for checking case if another copy of tool is running, it’s useful when you run multiple instances of tool
api_host_counters_max_hosts_in_responsepositive_integer_with_zero100Max number of hosts in show host_counters output
system_userstring“fastnetmon”Run FastNetMon daemon from particular system user
system_groupstring“fastnetmon”Run FastNetMon daemon from particular system group
drop_root_permissionsboolfalseTry to run from non-root user. Not supported for mirror capture
license_use_port_443booltrueUse port 443 instead for license server connections

telegram_notification

NameTypeDefault valueDescription
telegram_notifications_enabledboolfalseEnable Telegram notifications
telegram_notifications_bot_tokenstring“xxx:xxx”Telegram bot token
telegram_notifications_recipientsstring_list[ ]Telegram notification recipients, can be user ids or public chat ids
telegram_notifications_add_simple_packet_dumpbooltrueAdd simple packet dump to Telegram alert

tera_flow

NameTypeDefault valueDescription
tera_flowboolfalseReceive information in Tera Flow format from the network
tera_flow_portsnumeric_ipv4_port_list[ ]Tera Flow collector port. It’s possible to specify multiple ports here
tera_flow_hoststring“0.0.0.0”Tera Flow collector host. To bind to all interfaces for all protocols: not possible yet. To bind to all interfaces for a specific protocol: :: or 0.0.0.0. To bind to localhost for a specific protocol: ::1 or 127.0.0.1.
tera_flow_local_addressesstring_list[ ]Tera Flow collector addresses to bind on in format: protocol://host:port as protocol you can use udp or tcp
tera_flow_tls_certificate_pathstring“”TLS certificate path for FastNetMon Flow server in TLS mode
tera_flow_tls_certificate_chainboolfalseYou need to set it when you specify path to certificate bundle with multiple certificates
tera_flow_tls_private_key_pathstring“”TLS private key path for FastNetMon Flow server in TLS mode

traffic_calculation_management

NameTypeDefault valueDescription
keep_traffic_counters_during_restartboolfalseKeep all speed counters during restarts
process_incoming_trafficbooltrueEnables or disables processing for incoming traffic
process_outgoing_trafficbooltrueEnables or disables processing for outgoing traffic
override_internal_traffic_as_incomingboolfalseEnables logic to process internal traffic as incoming
override_internal_traffic_as_outgoingboolfalseEnables logic to process internal traffic as outgoing
process_ipv6_trafficbooltrueEnables processing for IPv6 traffic
enable_connection_trackingbooltrueEnable traffic state tracking. If you interested in flow per second rates, please enable it. Be careful, it may increase CPU usage significantly
remote_host_trackingboolfalseCompletely enable or disable bandwidth calculation for remote hosts
connection_tracking_skip_portsboolfalseDisables port processing for connection tracking
enable_total_hostgroup_countersbooltrueEnable traffic counters for total per hostgroups traffic
enable_interface_countersbooltrueEnable interface counters for per interface traffic
enable_asn_countersbooltrueEnable ASN counters for per ASN traffic
build_total_hostgroups_from_per_host_hostgroupsboolfalseAllows using per-host hostgroups for building total hostgroups
dump_other_trafficboolfalseDump all traffic which belongs to other class to log. Only for debugging reasons. It significantly degrades performance
dump_internal_trafficboolfalseDump all traffic which belongs to internal class to log. Only for debugging reasons. It significantly degrades performance
dump_all_trafficboolfalseDump all traffic to log. Only for debugging reasons. It significantly degrades performance
dump_all_traffic_jsonboolfalseDump all traffic to log in JSON format. Only for debugging reasons. It significantly degrades performance
speed_calculation_delaypositive_integer_with_zero1This value control how often we run speed recalculation function. Please do not use this unless support suggested this to you
average_calculation_timepositive_integer_with_zero5We use average values for traffic speed to certain IP and calculates average over this time slice
flow_forwarderboolfalseFlow forwarder allows you to send traffic to remote FastNetMon
flow_forwarder_remote_addressesstring_list[ ]Flow forwarder allows you to send traffic to remote FastNetMon: protocol://host:port as protocol you can use udp or tcp
flow_forwarder_sampling_ratepositive_integer_with_zero512Sampling rate for mirrored traffic for Flow Forwarder export
ipv6_automatic_data_cleanupbooltrueEnables logic which removes old entries from IPv6 data counters
ipv6_automatic_data_cleanup_thresholdpositive_integer_with_zero300We will remove all entries which exceed this age in seconds
ipv6_automatic_data_cleanup_delaypositive_integer_with_zero300How often we will run cleanup logic
ipv4_automatic_data_cleanupbooltrueEnables logic which removes old entries from IPv4 data counters
ipv4_automatic_data_cleanup_thresholdpositive_integer_with_zero300We will remove all entries which exceed this age in seconds
ipv4_automatic_data_cleanup_delaypositive_integer_with_zero300How often we will run cleanup logic
ipv4_remote_automatic_data_cleanupbooltrueEnables logic which removes old entries from IPv4 remote data counters
ipv4_remote_automatic_data_cleanup_thresholdpositive_integer_with_zero300We will remove all remove IPv4 entries which exceed this age in seconds
ipv4_remote_automatic_data_cleanup_delaypositive_integer_with_zero300How often we will run cleanup logic for remote IPv4 records
traffic_bufferboolfalseEnables or disables traffic buffer which keeps some amount of previously processed packets
traffic_buffer_sizepositive_integer_with_zero100000Specifies number of elements in traffic_buffer for 1 second of average calculation time
traffic_buffer_port_mirrorboolfalseEnables or disables traffic buffer for port mirror modes. Do not enable unless sampling is enabled
generate_attack_traffic_samplesboolfalseEnables logic to populate statistical reports about attacks traffic. Only for vendor integrations
generate_attack_traffic_samples_delaypositive_integer_with_zero60How often we’re going to produce traffic reports about active attacks
generate_max_talkers_reportboolfalseEnables logic to track max talkers and store them into MongoDB Only for vendor integrations
generate_max_talkers_report_delaypositive_integer_with_zero300How often we’re going to produce reports about max talkers
generate_hostgroup_traffic_samplesboolfalseEnables logic to populate statistical reports about hostgroup traffic. Only for vendor integrations
generate_hostgroup_traffic_samples_delaypositive_integer_with_zero60How often we’re going to produce traffic reports for hostgroup traffic

traffic_db

NameTypeDefault valueDescription
traffic_dbboolfalseEnable traffic export to persistent traffic database
traffic_db_hoststring“127.0.0.1”Traffic DB server address as IPv4, IPv6 or hostname
traffic_db_portnumeric_ipv4_port8100Traffic DB server port
traffic_db_sampling_ratepositive_integer_with_zero512Sampling rate for mirrored traffic for traffic_db export

vyos

NameTypeDefault valueDescription
vyos_announce_hostboolfalseEnable VyOS integration
vyos_announce_host_blackholebooltrueEnable blackhole flag for per host VyOS announce
vyos_api_urlsstring_list[ ]VyOS API URL

web_api

NameTypeDefault valueDescription
web_api_hoststring“127.0.0.1”Web API host for listening
web_api_portnumeric_ipv4_port10007Web API port for listening
web_api_loginstring“admin”Login for web API
web_api_passwordstring“”Password for web API
web_api_sslboolfalseWeb API host for listening for ssl API
web_api_trace_queriesboolfalseTrace all queries
web_api_ssl_portnumeric_ipv4_port10443Web API port for listening
web_api_ssl_hoststring“127.0.0.1”Web API host for listening
web_api_ssl_certificate_pathstring“”Certificate for SSL API
web_api_ssl_private_key_pathstring“”Private key for SSL API

web_callback

NameTypeDefault valueDescription
web_callback_enabledboolfalseFastNetMon could call external script with http or https protocol and pass attack’s details in JSON format
web_callback_urlstring“http://127.0.0.1:8080/attack/notify”We could call this script in case of blackhole ban and unban and for partial (flow spec) block action and pass details with JSON inside POST query

xdp

NameTypeDefault valueDescription
mirror_xdpboolfalseEnable capture from mirror port using AF_XDP capture engine
xdp_read_packet_length_from_ip_headerboolfalseBy default, FastNetMon reads packet length from the wire. But it can use information from IP header when you enable this option
force_native_mode_xdpboolfalseRequires native XDP support from driver
zero_copy_xdpboolfalseEnable zero copy mode for XDP. Requires native support from driver (force_native_mode_xdp)
poll_mode_xdpboolfalseUse poll system call to process incoming packets
xdp_set_promiscboolfalseSet promisc flag on interface automatically
xdp_extract_tunnel_trafficboolfalseEnables code which strips external level for GRE tunnels
interfaces_xdpstring_list[ ]Interfaces list for traffic capture using XDP
microcode_xdp_pathstring“/etc/fastnetmon/xdp_kernel.o”You can specify custom path to microcode

Hostgroups configuration

default

NameTypeDefault valueDescription
namestring“global”Name of host group
parent_namestring“”Parent host group name
descriptionstring“This is default group for all hosts”Human-friendly name for this group
calculation_methodstring“per_host”Traffic calculation method for host group: total or per_host (or empty value)
networkscidr_networks_list[ ]List of networks which belong to this group
enable_banboolfalseEnable ban actions for hosts in this group
ban_for_ppsboolfalseShould we block host in this group if it exceeds packet per second threshold?
ban_for_bandwidthboolfalseShould we block host in this group if it exceeds bandwidth threshold?
ban_for_flowsboolfalseShould we block host in this group if it exceeds flows threshold?
threshold_ppspositive_integer_with_zero100000Packet per second traffic to/from this host should exceed this value
threshold_mbpspositive_integer_with_zero1000Bandwidth to/from this host should exceed this value
threshold_flowspositive_integer_with_zero3500Flow per second speed to/from this host should exceed this value
ban_for_tcp_bandwidthboolfalseBlock hosts in group for TCP bandwidth threshold?
ban_for_udp_bandwidthboolfalseBlock hosts in group for UDP bandwidth threshold?
ban_for_icmp_bandwidthboolfalseBlock hosts in group for ICMP bandwidth threshold?
ban_for_tcp_ppsboolfalseShould we block host in this group if it exceeds packet per second threshold for TCP?
ban_for_udp_ppsboolfalseShould we block host in this group if it exceeds packet per second threshold for UDP?
ban_for_icmp_ppsboolfalseShould we block host in this group if it exceeds packet per second threshold for ICMP?
threshold_tcp_mbpspositive_integer_with_zero1000TCP bandwidth to/from this host should exceed this value
threshold_udp_mbpspositive_integer_with_zero1000UDP bandwidth to/from this host should exceed this value
threshold_icmp_mbpspositive_integer_with_zero1000ICMP bandwidth to/from this host should exceed this value
threshold_tcp_ppspositive_integer_with_zero100000TCP packet per second traffic to/from this host should exceed this value
threshold_udp_ppspositive_integer_with_zero100000UDP packet per second traffic to/from this host should exceed this value
threshold_icmp_ppspositive_integer_with_zero100000ICMP packet per second traffic to/from this host should exceed this value
ban_for_tcp_syn_ppsboolfalseBlock hosts in group for TCP SYN packets per second threshold
threshold_tcp_syn_ppspositive_integer_with_zero1000TCP SYN pps to/from this host should exceed this value
ban_for_tcp_syn_bandwidthboolfalseBlock hosts in group for TCP SYN packets per second threshold
threshold_tcp_syn_mbpspositive_integer_with_zero1000TCP SYN bandwidth to/from this host should exceed this value
ban_for_ip_fragments_ppsboolfalseBlock hosts in group for fragmented IP packets per second threshold
threshold_ip_fragments_ppspositive_integer_with_zero1000Fragmented IP pps to/from this host should exceed this value
ban_for_ip_fragments_bandwidthboolfalseBlock hosts in group for fragmented IP packets per second threshold
threshold_ip_fragments_mbpspositive_integer_with_zero1000fragmented IP bandwidth to/from this host should exceed this value
enable_ban_incomingboolfalseEnable ban actions for this group for incoming traffic
enable_ban_outgoingboolfalseEnable ban actions for this group for incooutgoingming traffic
enable_bgp_flow_specboolfalseEnable BGP Flow Spec for this hostgroup
ban_for_pps_outgoingboolfalseShould we block host in this group if it exceeds packet per second threshold?
ban_for_bandwidth_outgoingboolfalseShould we block host in this group if it exceeds bandwidth threshold?
ban_for_flows_outgoingboolfalseShould we block host in this group if it exceeds flows threshold?
threshold_pps_outgoingpositive_integer_with_zero100000Packet per second traffic to/from this host should exceed this value
threshold_mbps_outgoingpositive_integer_with_zero1000Bandwidth to/from this host should exceed this value
threshold_flows_outgoingpositive_integer_with_zero3500Flow per second speed to/from this host should exceed this value
ban_for_tcp_bandwidth_outgoingboolfalseBlock hosts in group for TCP bandwidth threshold?
ban_for_udp_bandwidth_outgoingboolfalseBlock hosts in group for UDP bandwidth threshold?
ban_for_icmp_bandwidth_outgoingboolfalseBlock hosts in group for ICMP bandwidth threshold?
ban_for_tcp_pps_outgoingboolfalseShould we block host in this group if it exceeds packet per second threshold for TCP?
ban_for_udp_pps_outgoingboolfalseShould we block host in this group if it exceeds packet per second threshold for UDP?
ban_for_icmp_pps_outgoingboolfalseShould we block host in this group if it exceeds packet per second threshold for ICMP?
threshold_tcp_mbps_outgoingpositive_integer_with_zero1000TCP bandwidth to/from this host should exceed this value
threshold_udp_mbps_outgoingpositive_integer_with_zero1000UDP bandwidth to/from this host should exceed this value
threshold_icmp_mbps_outgoingpositive_integer_with_zero1000ICMP bandwidth to/from this host should exceed this value
threshold_tcp_pps_outgoingpositive_integer_with_zero100000TCP packet per second traffic to/from this host should exceed this value
threshold_udp_pps_outgoingpositive_integer_with_zero100000UDP packet per second traffic to/from this host should exceed this value
threshold_icmp_pps_outgoingpositive_integer_with_zero100000ICMP packet per second traffic to/from this host should exceed this value
ban_for_tcp_syn_pps_outgoingboolfalseBlock hosts in group for TCP SYN packets per second threshold
threshold_tcp_syn_pps_outgoingpositive_integer_with_zero1000TCP SYN pps to/from this host should exceed this value
ban_for_tcp_syn_bandwidth_outgoingboolfalseBlock hosts in group for TCP SYN packets per second threshold
threshold_tcp_syn_mbps_outgoingpositive_integer_with_zero1000TCP SYN bandwidth to/from this host should exceed this value
ban_for_ip_fragments_pps_outgoingboolfalseBlock hosts in group for fragmented IP packets per second threshold
threshold_ip_fragments_pps_outgoingpositive_integer_with_zero1000Fragmented IP pps to/from this host should exceed this value
ban_for_ip_fragments_bandwidth_outgoingboolfalseBlock hosts in group for fragmented IP packets per second threshold
threshold_ip_fragments_mbps_outgoingpositive_integer_with_zero1000fragmented IP bandwidth to/from this host should exceed this value
flexible_thresholdsflexible_thresholds“{}”Flexible thresholds

BGP configuration

default

NameTypeDefault valueDescription
namestring“connection_main_router”System name for this connection
descriptionstring“Connection to main Router at NOC”Human-friendly name for this connection
local_asnpositive_integer_with_zero123456Local ASN number
local_addressnumeric_ipv4_or_ipv6_host“10.11.22.33”Local address for BGP connection
remote_asnpositive_integer_with_zero9002Remote autonomous system number
remote_addressnumeric_ipv4_or_ipv6_host“10.11.22.1”Remote IP address of BGP peer
multihopbooltrueEnable BGP multihop option
md5_authboolfalseEnable md5 auth for BGP session
md5_auth_passwordstring“”md5 password for BGP session
ipv4_unicastbooltrueEnable IPv4 unicast for this peering connection
ipv6_unicastboolfalseEnable IPv6 unicast for this peering connection
ipv4_flowspecboolfalseEnable IPv4 Flow Spec / RFC 5575 for this peering connection
ipv6_flowspecboolfalseEnable IPv6 Flow Spec / RFC 5575 for this peering connection
activeboolfalseYou could enable or disable this peer with this option

Traffic rules configuration

default

NameTypeDefault valueDescription
namestring“”Name for this rule
activeboolfalseYou could enable or disable rule using this flag
descriptionstring“”Human-friendly name for this rule
source_portsstring_list[ ]Source ports
destination_portsstring_list[ ]Destination ports
packet_lengthsstring_list[ ]Packet lengths
protocolsstring_list[ ]Protocols list
fragmentation_flagsstring_list[ ]Fragmentation flags list
tcp_flagsstring_list[ ]TCP flags list

User settings

default

NameTypeDefault valueDescription
namestring“admin”Name of user
passwordstring“secure”User password
full_namestring“John Doe”Full user name
emailstring“admin@company-name.net”Email of user
rolestring“admin”Role name of user

Role settings

default

NameTypeDefault valueDescription
namestring“admin”Role name
descriptionstring“Full Administrator Role”Description
permissionsstring_list[ ]List of permissions allocated for role

24/7 Tech Support

support@fastnetmon.com

Email Us

sales@fastnetmon.com