Blame SOURCES/conntrackd.conf

eb5e09
eb5e09
# See also: http://conntrack-tools.netfilter.org/support.html
eb5e09
# 
eb5e09
# There are 3 different modes of running conntrackd: "alarm", "notrack" and "ftfw"
eb5e09
#
eb5e09
# The default package ships with a FTFW configuration, see /usr/share/doc/conntrackd*
eb5e09
# for example configurations for other modes.
eb5e09
eb5e09
eb5e09
#
eb5e09
# Synchronizer settings
eb5e09
#
eb5e09
Sync {
eb5e09
	Mode FTFW {
eb5e09
		#
eb5e09
		# Size of the resend queue (in objects). This is the maximum
eb5e09
		# number of objects that can be stored waiting to be confirmed
eb5e09
		# via acknoledgment. If you keep this value low, the daemon
eb5e09
		# will have less chances to recover state-changes under message
eb5e09
		# omission. On the other hand, if you keep this value high,
eb5e09
		# the daemon will consume more memory to store dead objects.
eb5e09
		# Default is 131072 objects.
eb5e09
		#
eb5e09
		# ResendQueueSize 131072
eb5e09
eb5e09
		#
eb5e09
		# This parameter allows you to set an initial fixed timeout
eb5e09
		# for the committed entries when this node goes from backup
eb5e09
		# to primary. This mechanism provides a way to purge entries
eb5e09
		# that were not recovered appropriately after the specified
eb5e09
		# fixed timeout. If you set a low value, TCP entries in
eb5e09
		# Established states with no traffic may hang. For example,
eb5e09
		# an SSH connection without KeepAlive enabled. If not set,
eb5e09
		# the daemon uses an approximate timeout value calculation
eb5e09
		# mechanism. By default, this option is not set.
eb5e09
		#
eb5e09
		# CommitTimeout 180
eb5e09
eb5e09
		#
eb5e09
		# If the firewall replica goes from primary to backup,
eb5e09
		# the conntrackd -t command is invoked in the script. 
eb5e09
		# This command schedules a flush of the table in N seconds.
eb5e09
		# This is useful to purge the connection tracking table of
eb5e09
		# zombie entries and avoid clashes with old entries if you
eb5e09
		# trigger several consecutive hand-overs. Default is 60 seconds.
eb5e09
		#
eb5e09
		# PurgeTimeout 60
eb5e09
eb5e09
		# Set the acknowledgement window size. If you decrease this
eb5e09
		# value, the number of acknowlegdments increases. More
eb5e09
		# acknowledgments means more overhead as conntrackd has to
eb5e09
		# handle more control messages. On the other hand, if you
eb5e09
		# increase this value, the resend queue gets more populated.
eb5e09
		# This results in more overhead in the queue releasing.
eb5e09
		# The following value is based on some practical experiments
eb5e09
		# measuring the cycles spent by the acknowledgment handling
eb5e09
		# with oprofile. If not set, default window size is 300.
eb5e09
		#
eb5e09
		# ACKWindowSize 300
eb5e09
eb5e09
		#
eb5e09
		# This clause allows you to disable the external cache. Thus,
eb5e09
		# the state entries are directly injected into the kernel
eb5e09
		# conntrack table. As a result, you save memory in user-space
eb5e09
		# but you consume slots in the kernel conntrack table for
eb5e09
		# backup state entries. Moreover, disabling the external cache
eb5e09
		# means more CPU consumption. You need a Linux kernel
eb5e09
		# >= 2.6.29 to use this feature. By default, this clause is
eb5e09
		# set off. If you are installing conntrackd for first time,
eb5e09
		# please read the user manual and I encourage you to consider
eb5e09
		# using the fail-over scripts instead of enabling this option!
eb5e09
		#
eb5e09
		# DisableExternalCache Off
eb5e09
	}
eb5e09
eb5e09
	#
eb5e09
	# Multicast IP and interface where messages are
eb5e09
	# broadcasted (dedicated link). IMPORTANT: Make sure
eb5e09
	# that iptables accepts traffic for destination
eb5e09
	# 225.0.0.50, eg:
eb5e09
	#
eb5e09
	#	iptables -I INPUT -d 225.0.0.50 -j ACCEPT
eb5e09
	#	iptables -I OUTPUT -d 225.0.0.50 -j ACCEPT
eb5e09
	#
eb5e09
	Multicast {
eb5e09
		# 
eb5e09
		# Multicast address: The address that you use as destination
eb5e09
		# in the synchronization messages. You do not have to add
eb5e09
		# this IP to any of your existing interfaces. If any doubt,
eb5e09
		# do not modify this value.
eb5e09
		#
eb5e09
		IPv4_address 225.0.0.50
eb5e09
eb5e09
		#
eb5e09
		# The multicast group that identifies the cluster. If any
eb5e09
		# doubt, do not modify this value.
eb5e09
		#
eb5e09
		Group 3780
eb5e09
eb5e09
		#
eb5e09
		# IP address of the interface that you are going to use to
eb5e09
		# send the synchronization messages. Remember that you must
eb5e09
		# use a dedicated link for the synchronization messages.
eb5e09
		#
eb5e09
		IPv4_interface 192.168.100.100
eb5e09
eb5e09
		#
eb5e09
		# The name of the interface that you are going to use to
eb5e09
		# send the synchronization messages.
eb5e09
		#
eb5e09
		Interface eth2
eb5e09
eb5e09
		# The multicast sender uses a buffer to enqueue the packets
eb5e09
		# that are going to be transmitted. The default size of this
eb5e09
		# socket buffer is available at /proc/sys/net/core/wmem_default.
eb5e09
		# This value determines the chances to have an overrun in the
eb5e09
		# sender queue. The overrun results packet loss, thus, losing
eb5e09
		# state information that would have to be retransmitted. If you
eb5e09
		# notice some packet loss, you may want to increase the size
eb5e09
		# of the sender buffer. The default size is usually around
eb5e09
		# ~100 KBytes which is fairly small for busy firewalls.
eb5e09
		#
eb5e09
		SndSocketBuffer 1249280
eb5e09
eb5e09
		# The multicast receiver uses a buffer to enqueue the packets
eb5e09
		# that the socket is pending to handle. The default size of this
eb5e09
		# socket buffer is available at /proc/sys/net/core/rmem_default.
eb5e09
		# This value determines the chances to have an overrun in the
eb5e09
		# receiver queue. The overrun results packet loss, thus, losing
eb5e09
		# state information that would have to be retransmitted. If you
eb5e09
		# notice some packet loss, you may want to increase the size of
eb5e09
		# the receiver buffer. The default size is usually around
eb5e09
		# ~100 KBytes which is fairly small for busy firewalls.
eb5e09
		#
eb5e09
		RcvSocketBuffer 1249280
eb5e09
eb5e09
		# 
eb5e09
		# Enable/Disable message checksumming. This is a good
eb5e09
		# property to achieve fault-tolerance. In case of doubt, do
eb5e09
		# not modify this value.
eb5e09
		#
eb5e09
		Checksum on
eb5e09
	}
eb5e09
	#
eb5e09
	# You can specify more than one dedicated link. Thus, if one dedicated
eb5e09
	# link fails, conntrackd can fail-over to another. Note that adding
eb5e09
	# more than one dedicated link does not mean that state-updates will
eb5e09
	# be sent to all of them. There is only one active dedicated link at
eb5e09
	# a given moment. The `Default' keyword indicates that this interface
eb5e09
	# will be selected as the initial dedicated link. You can have 
eb5e09
	# up to 4 redundant dedicated links. Note: Use different multicast 
eb5e09
	# groups for every redundant link.
eb5e09
	#
eb5e09
	# Multicast Default {
eb5e09
	#	IPv4_address 225.0.0.51
eb5e09
	#	Group 3781
eb5e09
	#	IPv4_interface 192.168.100.101
eb5e09
	#	Interface eth3
eb5e09
	#	# SndSocketBuffer 1249280
eb5e09
	#	# RcvSocketBuffer 1249280
eb5e09
	#	Checksum on
eb5e09
	# }
eb5e09
eb5e09
	#
eb5e09
	# You can use Unicast UDP instead of Multicast to propagate events.
eb5e09
	# Note that you cannot use unicast UDP and Multicast at the same
eb5e09
	# time, you can only select one.
eb5e09
	# 
eb5e09
	# UDP {
eb5e09
		# 
eb5e09
		# UDP address that this firewall uses to listen to events.
eb5e09
		#
eb5e09
		# IPv4_address 192.168.2.100
eb5e09
		#
eb5e09
		# or you may want to use an IPv6 address:
eb5e09
		#
eb5e09
		# IPv6_address fe80::215:58ff:fe28:5a27
eb5e09
eb5e09
		#
eb5e09
		# Destination UDP address that receives events, ie. the other
eb5e09
		# firewall's dedicated link address.
eb5e09
		#
eb5e09
		# IPv4_Destination_Address 192.168.2.101
eb5e09
		#
eb5e09
		# or you may want to use an IPv6 address:
eb5e09
		#
eb5e09
		# IPv6_Destination_Address fe80::2d0:59ff:fe2a:775c
eb5e09
eb5e09
		#
eb5e09
		# UDP port used
eb5e09
		#
eb5e09
		# Port 3780
eb5e09
eb5e09
		#
eb5e09
		# The name of the interface that you are going to use to
eb5e09
		# send the synchronization messages.
eb5e09
		#
eb5e09
		# Interface eth2
eb5e09
eb5e09
		# 
eb5e09
		# The sender socket buffer size
eb5e09
		#
eb5e09
		# SndSocketBuffer 1249280
eb5e09
eb5e09
		#
eb5e09
		# The receiver socket buffer size
eb5e09
		#
eb5e09
		# RcvSocketBuffer 1249280
eb5e09
eb5e09
		# 
eb5e09
		# Enable/Disable message checksumming. 
eb5e09
		#
eb5e09
		# Checksum on
eb5e09
	# }
eb5e09
eb5e09
	# 
eb5e09
	# Other unsorted options that are related to the synchronization.
eb5e09
	# 
eb5e09
	# Options {
eb5e09
		#
eb5e09
		# TCP state-entries have window tracking disabled by default,
eb5e09
		# you can enable it with this option. As said, default is off.
eb5e09
		# This feature requires a Linux kernel >= 2.6.36.
eb5e09
		#
eb5e09
		# TCPWindowTracking Off
eb5e09
	# }
eb5e09
}
eb5e09
eb5e09
#
eb5e09
# General settings
eb5e09
#
eb5e09
General {
eb5e09
	#
eb5e09
	# Set the nice value of the daemon, this value goes from -20
eb5e09
	# (most favorable scheduling) to 19 (least favorable). Using a
eb5e09
	# very low value reduces the chances to lose state-change events.
eb5e09
	# Default is 0 but this example file sets it to most favourable
eb5e09
	# scheduling as this is generally a good idea. See man nice(1) for
eb5e09
	# more information.
eb5e09
	#
eb5e09
	Nice -20
eb5e09
eb5e09
	#
eb5e09
	# Select a different scheduler for the daemon, you can select between
eb5e09
	# RR and FIFO and the process priority (minimum is 0, maximum is 99).
eb5e09
	# See man sched_setscheduler(2) for more information. Using a RT
eb5e09
	# scheduler reduces the chances to overrun the Netlink buffer.
eb5e09
	#
eb5e09
	# Scheduler {
eb5e09
	#	Type FIFO
eb5e09
	#	Priority 99
eb5e09
	# }
eb5e09
eb5e09
	#
eb5e09
	# Number of buckets in the cache hashtable. The bigger it is,
eb5e09
	# the closer it gets to O(1) at the cost of consuming more memory.
eb5e09
	# Read some documents about tuning hashtables for further reference.
eb5e09
	#
eb5e09
	HashSize 32768
eb5e09
eb5e09
	#
eb5e09
	# Maximum number of conntracks, it should be double of: 
eb5e09
	# $ cat /proc/sys/net/netfilter/nf_conntrack_max
eb5e09
	# since the daemon may keep some dead entries cached for possible
eb5e09
	# retransmission during state synchronization.
eb5e09
	#
eb5e09
	HashLimit 131072
eb5e09
eb5e09
	#
eb5e09
	# Logfile: on (/var/log/conntrackd.log), off, or a filename
eb5e09
	# Default: off
eb5e09
	#
eb5e09
	LogFile on
eb5e09
eb5e09
	#
eb5e09
	# Syslog: on, off or a facility name (daemon (default) or local0..7)
eb5e09
	# Default: off
eb5e09
	#
eb5e09
	#Syslog on
eb5e09
eb5e09
	#
eb5e09
	# Lockfile
eb5e09
	# 
eb5e09
	LockFile /var/lock/conntrack.lock
eb5e09
eb5e09
	#
eb5e09
	# Unix socket configuration
eb5e09
	#
eb5e09
	UNIX {
eb5e09
		Path /var/run/conntrackd.ctl
eb5e09
		Backlog 20
eb5e09
	}
eb5e09
eb5e09
	#
eb5e09
	# Netlink event socket buffer size. If you do not specify this clause,
eb5e09
	# the default buffer size value in /proc/net/core/rmem_default is
eb5e09
	# used. This default value is usually around 100 Kbytes which is
eb5e09
	# fairly small for busy firewalls. This leads to event message dropping
eb5e09
	# and high CPU consumption. This example configuration file sets the
eb5e09
	# size to 2 MBytes to avoid this sort of problems.
eb5e09
	#
eb5e09
	NetlinkBufferSize 2097152
eb5e09
eb5e09
	#
eb5e09
	# The daemon doubles the size of the netlink event socket buffer size
eb5e09
	# if it detects netlink event message dropping. This clause sets the
eb5e09
	# maximum buffer size growth that can be reached. This example file
eb5e09
	# sets the size to 8 MBytes.
eb5e09
	#
eb5e09
	NetlinkBufferSizeMaxGrowth 8388608
eb5e09
eb5e09
	#
eb5e09
	# If the daemon detects that Netlink is dropping state-change events,
eb5e09
	# it automatically schedules a resynchronization against the Kernel
eb5e09
	# after 30 seconds (default value). Resynchronizations are expensive
eb5e09
	# in terms of CPU consumption since the daemon has to get the full
eb5e09
	# kernel state-table and purge state-entries that do not exist anymore.
eb5e09
	# Be careful of setting a very small value here. You have the following
eb5e09
	# choices: On (enabled, use default 30 seconds value), Off (disabled)
eb5e09
	# or Value (in seconds, to set a specific amount of time). If not
eb5e09
	# specified, the daemon assumes that this option is enabled.
eb5e09
	#
eb5e09
	# NetlinkOverrunResync On
eb5e09
eb5e09
	#
eb5e09
	# If you want reliable event reporting over Netlink, set on this
eb5e09
	# option. If you set on this clause, it is a good idea to set off
eb5e09
	# NetlinkOverrunResync. This option is off by default and you need
eb5e09
	# a Linux kernel >= 2.6.31.
eb5e09
	#
eb5e09
	# NetlinkEventsReliable Off
eb5e09
eb5e09
	# 
eb5e09
	# By default, the daemon receives state updates following an
eb5e09
	# event-driven model. You can modify this behaviour by switching to
eb5e09
	# polling mode with the PollSecs clause. This clause tells conntrackd
eb5e09
	# to dump the states in the kernel every N seconds. With regards to
eb5e09
	# synchronization mode, the polling mode can only guarantee that
eb5e09
	# long-lifetime states are recovered. The main advantage of this method
eb5e09
	# is the reduction in the state replication at the cost of reducing the
eb5e09
	# chances of recovering connections.
eb5e09
	#
eb5e09
	# PollSecs 15
eb5e09
eb5e09
	#
eb5e09
	# The daemon prioritizes the handling of state-change events coming
eb5e09
	# from the core. With this clause, you can set the maximum number of
eb5e09
	# state-change events (those coming from kernel-space) that the daemon
eb5e09
	# will handle after which it will handle other events coming from the
eb5e09
	# network or userspace. A low value improves interactivity (in terms of
eb5e09
	# real-time behaviour) at the cost of extra CPU consumption.
eb5e09
	# Default (if not set) is 100.
eb5e09
	#
eb5e09
	# EventIterationLimit 100
eb5e09
eb5e09
	#
eb5e09
	# Event filtering: This clause allows you to filter certain traffic,
eb5e09
	# There are currently three filter-sets: Protocol, Address and
eb5e09
	# State. The filter is attached to an action that can be: Accept or
eb5e09
	# Ignore. Thus, you can define the event filtering policy of the
eb5e09
	# filter-sets in positive or negative logic depending on your needs.
eb5e09
	# You can select if conntrackd filters the event messages from 
eb5e09
	# user-space or kernel-space. The kernel-space event filtering
eb5e09
	# saves some CPU cycles by avoiding the copy of the event message
eb5e09
	# from kernel-space to user-space. The kernel-space event filtering
eb5e09
	# is prefered, however, you require a Linux kernel >= 2.6.29 to
eb5e09
	# filter from kernel-space. If you want to select kernel-space 
eb5e09
	# event filtering, use the keyword 'Kernelspace' instead of 
eb5e09
	# 'Userspace'.
eb5e09
	#
eb5e09
	Filter From Userspace {
eb5e09
		#
eb5e09
		# Accept only certain protocols: You may want to replicate
eb5e09
		# the state of flows depending on their layer 4 protocol.
eb5e09
		#
eb5e09
		Protocol Accept {
eb5e09
			TCP
eb5e09
			SCTP
eb5e09
			DCCP
eb5e09
			# UDP
eb5e09
			# ICMP # This requires a Linux kernel >= 2.6.31
eb5e09
			# IPv6-ICMP # This requires a Linux kernel >= 2.6.31
eb5e09
		}
eb5e09
eb5e09
		#
eb5e09
		# Ignore traffic for a certain set of IP's: Usually all the
eb5e09
		# IP assigned to the firewall since local traffic must be
eb5e09
		# ignored, only forwarded connections are worth to replicate.
eb5e09
		# Note that these values depends on the local IPs that are
eb5e09
		# assigned to the firewall.
eb5e09
		#
eb5e09
		Address Ignore {
eb5e09
			IPv4_address 127.0.0.1 # loopback
eb5e09
			IPv4_address 192.168.0.100 # virtual IP 1
eb5e09
			IPv4_address 192.168.1.100 # virtual IP 2
eb5e09
			IPv4_address 192.168.0.1
eb5e09
			IPv4_address 192.168.1.1
eb5e09
			IPv4_address 192.168.100.100 # dedicated link ip
eb5e09
			#
eb5e09
			# You can also specify networks in format IP/cidr.
eb5e09
			# IPv4_address 192.168.0.0/24
eb5e09
			#
eb5e09
			# You can also specify an IPv6 address
eb5e09
			# IPv6_address ::1
eb5e09
		}
eb5e09
eb5e09
		#
eb5e09
		# Uncomment this line below if you want to filter by flow state.
eb5e09
		# This option introduces a trade-off in the replication: it
eb5e09
		# reduces CPU consumption at the cost of having lazy backup 
eb5e09
		# firewall replicas. The existing TCP states are: SYN_SENT,
eb5e09
		# SYN_RECV, ESTABLISHED, FIN_WAIT, CLOSE_WAIT, LAST_ACK,
eb5e09
		# TIME_WAIT, CLOSED, LISTEN.
eb5e09
		#
eb5e09
		# State Accept {
eb5e09
		#	ESTABLISHED CLOSED TIME_WAIT CLOSE_WAIT for TCP
eb5e09
		# }
eb5e09
	}
eb5e09
}