『Write by NIX CRAFT 』
本文章来自于http://www.cyberciti.biz/faq/linux-tcp-tuning linux
注:如需转载,请注明来源,谢谢!缓存
本文基于CENTOS 、DEBIAN/UBUNTU 编写 。服务器
我有两台位于不一样数据中心的服务器,都用来处理不少并行的大文件传输。可是处理大文件,网络性能很是差。而且涉及到一个大文件,会致使性能降级。我怎样经过调整Linux下面的 TCP 来解决这个问题?网络
默认,Linux的stack是没有为广域网之间的大文件高速传输而配置的,这样作是为了节约内存资源。为了使链接的系统服务之间能有更加高速的网络处理更多的网络包,你能够很容易的经过增长网络 buffer size 来调整 Linux 网络 stack 。app
默认的 Linux buffer size 的最大值是很是小的,tcp 的内存是基于系统的内存自动计算的,你能经过键入如下命令找到实际的值:socket
$ cat /proc/sys/net/ipv4/tcp_mem
默认的和最大的接收数据包内存大小:tcp
$ cat /proc/sys/net/core/rmem_default $ cat /proc/sys/net/core/rmem_max
默认的和最大的发送数据包内存的大小:性能
$ cat /proc/sys/net/core/wmem_default $ cat /proc/sys/net/core/wmem_max
最大的内存 buffers 的选项:spa
$ cat /proc/sys/net/core/optmem_max
为全部的协议队列设置操做系统层面的最大的发送 buffer size (wmem) 和 接收 buffer size (rmem)为 12 MB。换句话说,设置内存数量,分配给每个为了传送文件而打开或者是建立的 tcp socket 。操作系统
警告!在大多数的 Linux 中
rmem_max
和wmem_max
被分配的值为 128 k,在一个低延迟的网络环境中,或者是 apps 好比 DNS、Web Server,这或许是足够的。尽管如此,若是延迟太大,默认的值可能就过小了,因此请记录如下在你的服务器上用来提升内存使用方法的设置。
# echo 'net.core.wmem_max=12582912' >> /etc/sysctl.conf # echo 'net.core.rmem_max=12582912' >> /etc/sysctl.conf
你还须要设置 minimum size, initial size, and maximum size in bytes:
# echo 'net.ipv4.tcp_rmem= 10240 87380 12582912' >> /etc/sysctl.conf # echo 'net.ipv4.tcp_wmem= 10240 87380 12582912' >> /etc/sysctl.conf
打开 window scaling ,这是一个用来扩展传输窗口的选项:
# echo 'net.ipv4.tcp_window_scaling = 1' >> /etc/sysctl.conf
确保定义在 RFC1323 中的 timestamps
打开:
# echo 'net.ipv4.tcp_timestamps = 1' >> /etc/sysctl.conf
确保 select acknowledgments:
# echo 'net.ipv4.tcp_sack = 1' >> /etc/sysctl.conf
这个 “select acknowledgments” 不知道该如何翻译,翻译为“选择确认?”
当链接关闭的时候,TCP 默认缓存了不少链接指标在 route cache 中,以致于在不久的未来,链接创建的时候,能够用这些值来设置初始化条件。一般,这提高了总体的性能,可是,有时候会引发性能降低, 若是设置的话,TCP 在关闭的时候不缓存这些指标。
# echo 'net.ipv4.tcp_no_metrics_save = 1' >> /etc/sysctl.conf
当 interface 接收到的数据包数量比内核处理速度的快的时候, 设置 input 队列最大的 packets 数量值。
# echo 'net.core.netdev_max_backlog = 5000' >> /etc/sysctl.conf
如今重载这些改变,使其生效:
# sysctl -p
使用 tcpdump 命令查看 经过 eth0 数据包流量的变化:
# tcpdump -ni eth0
请参考内核文档/networking/ip-sysctl.txt获取更加多的信息
请查看 sysctl
的 man
手册
注:如翻译有误的地方,欢迎指正,而且欢迎针对文章里面的内容探讨