This is a reference of IP networking parameters that are configurable as described in our linux tweaking article -here-.

/proc/sys/net/ipv4/* Variables:

ip_forward - BOOLEAN
 0 - disabled (default)
 not 0 - enabled

Forward Packets between interfaces.

This variable is special, its change resets all configuration
 parameters to their default state (RFC1122 for hosts, RFC1812
 for routers)

ip_default_ttl - INTEGER
 default 64

ip_no_pmtu_disc - BOOLEAN
 Disable Path MTU Discovery.
 default FALSE

IP Fragmentation:

ipfrag_high_thresh - INTEGER
 Maximum memory used to reassemble IP fragments. When 
 ipfrag_high_thresh bytes of memory is allocated for this purpose,
 the fragment handler will toss packets until ipfrag_low_thresh
 is reached.
 
ipfrag_low_thresh - INTEGER
 See ipfrag_high_thresh

ipfrag_time - INTEGER
 Time in seconds to keep an IP fragment in memory.

INET peer storage:

inet_peer_threshold - INTEGER
 The approximate size of the storage.  Starting from this threshold 
 entries will be thrown aggressively.  This threshold also determines
 entries' time-to-live and time intervals between garbage collection
 passes.  More entries, less time-to-live, less GC interval.

inet_peer_minttl - INTEGER
 Minimum time-to-live of entries.  Should be enough to cover fragment
 time-to-live on the reassembling side.  This minimum time-to-live  is
 guaranteed if the pool size is less than inet_peer_threshold.
 Measured in jiffies.

inet_peer_maxttl - INTEGER
 Maximum time-to-live of entries.  Unused entries will expire after
 this period of time if there is no memory pressure on the pool (i.e.
 when the number of entries in the pool is very small).
 Measured in jiffies.

inet_peer_gc_mintime - INTEGER
 Minimum interval between garbage collection passes.  This interval is
 in effect under high memory pressure on the pool.
 Measured in jiffies.

inet_peer_gc_maxtime - INTEGER
 Minimum interval between garbage collection passes.  This interval is
 in effect under low (or absent) memory pressure on the pool.
 Measured in jiffies.

TCP variables:

tcp_syn_retries - INTEGER
 Number of times initial SYNs for an active TCP connection attempt
 will be retransmitted. Should not be higher than 255. Default value
 is 5, which corresponds to ~180seconds.

tcp_synack_retries - INTEGER
 Number of times SYNACKs for a passive TCP connection attempt will
 be retransmitted. Should not be higher than 255. Default value
 is 5, which corresponds to ~180seconds.

tcp_keepalive_time - INTEGER
 How often TCP sends out keepalive messages when keepalive is enabled.
 Default: 2hours.

tcp_keepalive_probes - INTEGER
 How many keepalive probes TCP sends out, until it decides that the
 connection is broken. Default value: 9.

tcp_keepalive_interval - INTEGER
 How frequently the probes are send out. Multiplied by
 tcp_keepalive_probes it is time to kill not responding connection,
 after probes started. Default value: 75sec i.e. connection
 will be aborted after ~11 minutes of retries.

tcp_retries1 - INTEGER
 How many times to retry before deciding that something is wrong
 and it is necessary to report this suspection to network layer.
 Minimal RFC value is 3, it is default, which corresponds
 to ~3sec-8min depending on RTO.

tcp_retries2 - INTEGER
 How may times to retry before killing alive TCP connection.
 RFC1122 says that the limit should be longer than 100 sec.
 It is too small number. Default value 15 corresponds to ~13-30min
 depending on RTO.

tcp_orphan_retries - INTEGER
 How may times to retry before killing TCP connection, closed
 by our side. Default value 7 corresponds to ~50sec-16min
 depending on RTO. If you machine is loaded WEB server,
 you should think about lowering this value, such sockets
 may consume significant resources. Cf. tcp_max_orphans.

tcp_fin_timeout - INTEGER
 Time to hold socket in state FIN-WAIT-2, if it was closed
 by our side. Peer can be broken and never close its side,
 or even died unexpectedly. Default value is 60sec.
 Usual value used in 2.2 was 180 seconds, you may restore
 it, but remember that if your machine is even underloaded WEB server,
 you risk to overflow memory with kilotons of dead sockets,
 FIN-WAIT-2 sockets are less dangerous than FIN-WAIT-1,
 because they eat maximum 1.5K of memory, but they tend
 to live longer. Cf. tcp_max_orphans.

tcp_max_tw_buckets - INTEGER
 Maximal number of timewait sockets held by system simultaneously.
 If this number is exceeded time-wait socket is immediately destroyed
 and warning is printed. This limit exists only to prevent
 simple DoS attacks, you _must_ not lower the limit artificially,
 but rather increase it (probably, after increasing installed memory),
 if network conditions require more than default value.

tcp_tw_recycle - BOOLEAN
 Enable fast recycling TIME-WAIT sockets. Default value is 1.
 It should not be changed without advice/request of technical
 experts.

tcp_max_orphans - INTEGER
 Maximal number of TCP sockets not attached to any user file handle,
 held by system. If this number is exceeded orphaned connections are
 reset immediately and warning is printed. This limit exists
 only to prevent simple DoS attacks, you _must_ not rely on this
 or lower the limit artificially, but rather increase it
 (probably, after increasing installed memory),
 if network conditions require more than default value,
 and tune network services to linger and kill such states
 more aggressively. Let me to remind again: each orphan eats
 up to ~64K of unswappable memory.

tcp_abort_on_overflow - BOOLEAN
 If listening service is too slow to accept new connections,
 reset them. Default state is FALSE. It means that if overflow
 occurred due to a burst, connection will recover. Enable this
 option _only_ if you are really sure that listening daemon
 cannot be tuned to accept connections faster. Enabling this
 option can harm clients of your server.

tcp_syncookies - BOOLEAN
 Only valid when the kernel was compiled with CONFIG_SYNCOOKIES
 Send out syncookies when the syn backlog queue of a socket 
 overflows. This is to prevent against the common 'syn flood attack'
 Default: FALSE

Note, that syncookies is fallback facility.
 It MUST NOT be used to help highly loaded servers to stand
 against legal connection rate. If you see synflood warnings
 in your logs, but investigation shows that they occur
 because of overload with legal connections, you should tune
 another parameters until this warning disappear.
 See: tcp_max_syn_backlog, tcp_synack_retries, tcp_abort_on_overflow.

syncookies seriously violate TCP protocol, do not allow
 to use TCP extensions, can result in serious degradation
 of some services (f.e. SMTP relaying), visible not by you,
 but your clients and relays, contacting you. While you see
 synflood warnings in logs not being really flooded, your server
 is seriously misconfigured.

tcp_stdurg - BOOLEAN
 Use the Host requirements interpretation of the TCP urg pointer field.
 Most hosts use the older BSD interpretation, so if you turn this on
 Linux might not communicate correctly with them. 
 Default: FALSE 
 
tcp_max_syn_backlog - INTEGER
 Maximal number of remembered connection requests, which are
 still did not receive an acknowledgement from connecting client.
 Default value is 1024 for systems with more than 128Mb of memory,
 and 128 for low memory machines. If server suffers of overload,
 try to increase this number. Warning! If you make it greater
 than 1024, it would be better to change TCP_SYNQ_HSIZE in
 include/net/tcp.h to keep TCP_SYNQ_HSIZE*16<=tcp_max_syn_backlog
 and to recompile kernel.

tcp_window_scaling - BOOLEAN
 Enable window scaling as defined in RFC1323.

tcp_timestamps - BOOLEAN
 Enable timestamps as defined in RFC1323.

tcp_sack - BOOLEAN
 Enable select acknowledgments (SACKS).

tcp_fack - BOOLEAN
 Enable FACK congestion avoidance and fast restransmission.
 The value is not used, if tcp_sack is not enabled.

tcp_dsack - BOOLEAN
 Allows TCP to send "duplicate" SACKs.

tcp_ecn - BOOLEAN
 Enable Explicit Congestion Notification in TCP.

tcp_reordering - INTEGER
 Maximal reordering of packets in a TCP stream.
 Default: 3

tcp_retrans_collapse - BOOLEAN
 Bug-to-bug compatibility with some broken printers.
 On retransmit try to send bigger packets to work around bugs in
 certain TCP stacks.

tcp_wmem - vector of 3 INTEGERs: min, default, max
 min: Amount of memory reserved for send buffers for TCP socket.
 Each TCP socket has rights to use it due to fact of its birth.
 Default: 4K

default: Amount of memory allowed for send buffers for TCP socket
 by default. This value overrides net.core.wmem_default used
 by other protocols, it is usually lower than net.core.wmem_default.
 Default: 16K

max: Maximal amount of memory allowed for automatically selected
 send buffers for TCP socket. This value does not override
 net.core.wmem_max, "static" selection via SO_SNDBUF does not use this.
 Default: 128K

 

tcp_rmem - vector of 3 INTEGERs: min, default, max
 min: Minimal size of receive buffer used by TCP sockets.
 It is guaranteed to each TCP socket, even under moderate memory
 pressure.
 Default: 8K

default: default size of receive buffer used by TCP sockets.
 This value overrides net.core.rmem_default used by other protocols.
 Default: 87380 bytes. This value results in window of 65535 with
 default setting of tcp_adv_win_scale and tcp_app_win:0 and a bit
 less for default tcp_app_win. See below about these variables.

max: maximal size of receive buffer allowed for automatically
 selected receiver buffers for TCP socket. This value does not override
 net.core.rmem_max, "static" selection via SO_RCVBUF does not use this.
 Default: 87380*2 bytes.

tcp_mem - vector of 3 INTEGERs: min, pressure, max
 low: below this number of pages TCP is not bothered about its
 memory appetite.

pressure: when amount of memory allocated by TCP exceeds this number
 of pages, TCP moderates its memory consumption and enters memory
 pressure mode, which is exited when memory consumtion falls
 under "low".

high: number of pages allowed for queueing by all TCP sockets.

Defaults are calculated at boot time from amount of available
 memory.

tcp_app_win - INTEGER
 Reserve max(window/2^tcp_app_win, mss) of window for application
 buffer. Value 0 is special, it means that nothing is reserved.
 Default: 31

tcp_adv_win_scale - INTEGER
 Count buffering overhead as bytes/2^tcp_adv_win_scale
 (if tcp_adv_win_scale > 0) or bytes-bytes/2^(-tcp_adv_win_scale),
 if it is <= 0.
 Default: 2

tcp_rfc1337 - BOOLEAN
 If set, the TCP stack behaves conforming to RFC1337. If unset,
 we are not conforming to RFC, but prevent TCP TIME_WAIT
 asassination. 
 Default: 0

ip_local_port_range - 2 INTEGERS
 Defines the local port range that is used by TCP and UDP to
 choose the local port. The first number is the first, the 
 second the last local port number. Default value depends on
 amount of memory available on the system:
 > 128Mb 32768-61000
 < 128Mb 1024-4999 or even less.
 This number defines number of active connections, which this
 system can issue simultaneously to systems not supporting
 TCP extensions (timestamps). With tcp_tw_recycle enabled
 (i.e. by default) range 1024-4999 is enough to issue up to
 2000 connections per second to systems supporting timestamps.

ip_nonlocal_bind - BOOLEAN
 If set, allows processes to bind() to non-local IP adresses,
 which can be quite useful - but may break some applications.
 Default: 0

ip_dynaddr - BOOLEAN
 If set non-zero, enables support for dynamic addresses.
 If set to a non-zero value larger than 1, a kernel log
 message will be printed when dynamic address rewriting
 occurs.
 Default: 0

icmp_echo_ignore_all - BOOLEAN
icmp_echo_ignore_broadcasts - BOOLEAN
 If either is set to true, then the kernel will ignore either all
 ICMP ECHO requests sent to it or just those to broadcast/multicast
 addresses, respectively.

icmp_destunreach_rate - INTEGER
icmp_paramprob_rate - INTEGER
icmp_timeexceed_rate - INTEGER
icmp_echoreply_rate - INTEGER (not enabled per default)
 Limit the maximal rates for sending ICMP packets to specific targets.
 0 to disable any limiting, otherwise the maximal rate in jiffies(1)
 See the source for more information.

icmp_ignore_bogus_error_responses - BOOLEAN
 Some routers violate RFC 1122 by sending bogus responses to broadcast
 frames.  Such violations are normally logged via a kernel warning.
 If this is set to TRUE, the kernel will not give such warnings, which
 will avoid log file clutter.
 Default: FALSE

(1) Jiffie: internal timeunit for the kernel. On the i386 1/100s, on the
Alpha 1/1024s. See the HZ define in /usr/include/asm/param.h for the exact
value on your system.

igmp_max_memberships - INTEGER
 Change the maximum number of multicast groups we can subscribe to.
 Default: 20

conf/interface/*: 
conf/all/* is special and changes the settings for all interfaces.
 Change special settings per interface.

log_martians - BOOLEAN
 Log packets with impossible addresses to kernel log.

accept_redirects - BOOLEAN
 Accept ICMP redirect messages.
 default TRUE (host)
  FALSE (router)

forwarding - BOOLEAN
 Enable IP forwarding on this interface.

mc_forwarding - BOOLEAN
 Do multicast routing. The kernel needs to be compiled with CONFIG_MROUTE
 and a multicast routing daemon is required.

proxy_arp - BOOLEAN
 Do proxy arp.

shared_media - BOOLEAN
 Send(router) or accept(host) RFC1620 shared media redirects.
 Overrides ip_secure_redirects.
 default TRUE

secure_redirects - BOOLEAN
 Accept ICMP redirect messages only for gateways,
 listed in default gateway list.
 default TRUE

send_redirects - BOOLEAN
 Send redirects, if router. Default: TRUE

bootp_relay - BOOLEAN
 Accept packets with source address 0.b.c.d destined
 not to this host as local ones. It is supposed, that
 BOOTP relay daemon will catch and forward such packets.

default FALSE
 Not Implemented Yet.

accept_source_route - BOOLEAN
 Accept packets with SRR option.
 default TRUE (router)
  FALSE (host)

rp_filter - BOOLEAN
 1 - do source validation by reversed path, as specified in RFC1812
     Recommended option for single homed hosts and stub network
     routers. Could cause troubles for complicated (not loop free)
     networks running a slow unreliable protocol (sort of RIP),
     or using static routes.

0 - No source validation.

Default value is 0. Note that some distributions enable it
 in startip scripts.

Alexey Kuznetsov.
kuznet@ms2.inr.ac.ru

Updated by:
Andi Kleen
ak@muc.de

/proc/sys/net/ipv6/* Variables:

IPv6 has no global variables such as tcp_*.  tcp_* settings under ipv4/ also
apply to IPv6 [XXX?].

conf/default/*:
 Change the interface-specific default settings.

conf/all/*:
 Change all the interface-specific settings.

[XXX:  Other special features than forwarding?]

conf/all/forwarding - BOOLEAN
 Enable global IPv6 forwarding between all interfaces.

IPv4 and IPv6 work differently here; e.g. netfilter must be used 
 to control which interfaces may forward packets and which not.

This also sets all interfaces' Host/Router setting 
 'forwarding' to the specified value.  See below for details.

This referred to as global forwarding.

conf/interface/*:
 Change special settings per interface.

The functional behaviour for certain settings is different 
 depending on whether local forwarding is enabled or not.

accept_ra - BOOLEAN
 Accept Router Advertisements; autoconfigure using them.
 
 Functional default: enabled if local forwarding is disabled.
       disabled if local forwarding is enabled.

accept_redirects - BOOLEAN
 Accept Redirects.

Functional default: enabled if local forwarding is disabled.
       disabled if local forwarding is enabled.

autoconf - BOOLEAN
 Configure link-local addresses using L2 hardware addresses.

Default: TRUE

dad_transmits - INTEGER
 The amount of Duplicate Address Detection probes to send.
 Default: 1
 
forwarding - BOOLEAN
 Configure interface-specific Host/Router behaviour.

Note: It is recommended to have the same setting on all 
 interfaces; mixed router/host scenarios are rather uncommon.

FALSE:

By default, Host behaviour is assumed.  This means:

1. IsRouter flag is not set in Neighbour Advertisements.
 2. Router Solicitations are being sent when necessary.
 3. If accept_ra is TRUE (default), accept Router 
    Advertisements (and do autoconfiguration).
 4. If accept_redirects is TRUE (default), accept Redirects.

TRUE:

If local forwarding is enabled, Router behaviour is assumed. 
 This means exactly the reverse from the above:

1. IsRouter flag is set in Neighbour Advertisements.
 2. Router Solicitations are not sent.
 3. Router Advertisements are ignored.
 4. Redirects are ignored.

Default: FALSE if global forwarding is disabled (default),
   otherwise TRUE.

hop_limit - INTEGER
 Default Hop Limit to set.
 Default: 64

mtu - INTEGER
 Default Maximum Transfer Unit
 Default: 1280 (IPv6 required minimum)

router_solicitation_delay - INTEGER
 Number of seconds to wait after interface is brought up
 before sending Router Solicitations.
 Default: 1

router_solicitation_interval - INTEGER
 Number of seconds to wait between Router Solicitations.
 Default: 4

router_solicitations - INTEGER
 Number of Router Solicitations to send until assuming no 
 routers are present.
 Default: 3

IPv6 Update by:
Pekka Savola
pekkas@netcore.fi

$Id: ip-sysctl.txt,v 1.1.1.1 2002-08-19 13:34:26 blueflux Exp $

Linux TCP/IP parameters reference的更多相关文章

  1. The TCP/IP parameters for tweaking

    The TCP/IP parameters for tweaking a Linux-based machine for fast internet connections are located i ...

  2. [转]linux tcp/ip调优

    LINUX tcp/ip性能调优 On 2011年03月15日, in linux, tips, by netoearth 在TCP/IP协议中,TCP协议提供可靠的连接服务,采用三次握手建立一个连接 ...

  3. [转帖]Linux TCP/IP协议栈,数据发送接收流程,TCP协议特点

    Linux TCP/IP协议栈,数据发送接收流程,TCP协议特点 http://network.51cto.com/art/201909/603780.htm 可以毫不夸张的说现如今的互联网是基于TC ...

  4. linux tcp/ip编程和windows tcp/ip编程差别以及windows socket编程详解

    最近要涉及对接现有应用visual c++开发的tcp客户端,花时间了解了下windows下tcp开发和linux的差别,从开发的角度而言,最大的差别是头文件(早期为了推广尽可能兼容,后面越来越扩展, ...

  5. [转] Linux TCP/IP网络小课堂:net-tools与iproute2大比较

    PS:netstat选项是-planet,方便记忆 http://os.51cto.com/art/201409/450886.htm 如今许多系统管理员仍结合使用ifconfig.route.arp ...

  6. Linux TCP/IP 协议栈之 Socket 的实现分析(一)

    内核版本:2.6.37参考[作者:kendo的文章(基于内涵版本2.6.12)] 第一部份 Socket套接字的创建 socket 并不是 TCP/IP协议的一部份. 从广义上来讲,socket 是U ...

  7. Linux TCP/IP调优-Linux内核参数注释

    固定文件的内核参数 下列文件所在目录: /proc/sys/net/ipv4/ 名称 默认值 建议值 描述 tcpsyn_retries 5 1 对于一个新建连接,内核要发送多少个SYN连接请求才决定 ...

  8. Linux - TCP/IP网络协议基础

    1.0 Tcp / IP 背景介绍 上世纪70年代,随着计算机的发展,人们意识到如果想要发挥计算机的更大作用,就要讲世界各地的计算机连接起来. 但是简单的连接时不够的,因为计算机之间无法沟通.因此设计 ...

  9. linux tcp/ip 参数解析

    后面整理相关信息/* *     TCP option lengths */#define TCPOLEN_MSS            4 //只能出现在SYN段中#define TCPOLEN_W ...

随机推荐

  1. 数据结构练习 02-线性结构2. Reversing Linked List (25)

    Given a constant K and a singly linked list L, you are supposed to reverse the links of every K elem ...

  2. 分享关于学习new BufferedWriter()方法时常遇到的一个无厘头的问题

    今天在学习IO的过程中,关于处理流BufferedWriter的使用时,遇到了一个很犯二但是又会让初学者经常没有避免的问题,百度后才发现有人和我一样二,这还是对java基础掌握得不牢固的原因啊. 首先 ...

  3. JVM 学习笔记

    1.   JAVA类分为三类: 1.1   系统类  (用系统类加载器加载bootstrap ClassLoader) 1.2   扩展类  (用扩展类加载器加载Ext ClassLoader) 1. ...

  4. sap中用函数增加断点(break point)

    如果在增强程序中,每次调试都要去程序里面设置断点很麻烦,为了解决这个问题,可以用下面的两个方法: 1: if sy-uname eq 'XXXX'      "XXX 为账号名字 break ...

  5. Google面试题之100层仍两个棋子

    一道Google面试题,题目如下:"有一个100层高的大厦,你手中有两个相同的玻璃围棋子.从这个大厦的某一层扔下围棋子就会碎,用你手中的这两个玻璃围棋子,找出一个最优的策略,来得知那个临界层 ...

  6. iOS设备下添加button的按下效果

    在触屏上, button的按下效果用:active触发, 但是我发现iOS设备上:active效果并没有生效. :active pseudo-class doesn't work in mobile ...

  7. [译]GotW #2: Temporary Objects

        不必要的和(或)临时的变量经常是罪魁祸首,它让你在程序性能方面的努力功亏一篑.如何才能识别出它们然后避免它们呢? Problem JG Question: 1. 什么是临时变量? Guru Q ...

  8. bzoj3131

    这是一道很好也很烦的综合题…… 首先我们肯定要先把f(i)处理出来这是毫无疑问的 我们要求出数位乘积为now的个数,首先是空间上的问题 直接肯定会爆空间,不难发现 乘积的质因数只有2,3,5,7,并且 ...

  9. SQL Server 2008 R2 制作数据库结构和数据脚本

    数据库中包含众多表和数据,有时候需要创建脚本将表结构和数据一起导出 具体方法如下: 1.右键选择数据库,选择“任务”--->“生成脚本” 2.根据需求,选择制作脚本的对象,一般情况选择“表” 3 ...

  10. WordPress Lazy SEO插件lazyseo.php脚本任意文件上传漏洞

    漏洞名称: WordPress Lazy SEO插件lazyseo.php脚本任意文件上传漏洞 CNNVD编号: CNNVD-201309-446 发布时间: 2013-09-26 更新时间: 201 ...