`
bwhzhl
  • 浏览: 103181 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

优化Linux的内核参数来提高服务器并发处理能力

 
阅读更多

PS:在服务器硬件资源额定有限的情况下,最大的压榨服务器的性能,提高服务器的并发处理能力,是很多运维技术人员思考的问题。要提高Linux系统下的负载能力,可以使用nginx等原生并发处理能力就很强的web服务器,如果使用Apache的可以启用其Worker模式,来提高其并发处理能力。除此之外,在考虑节省成本的情况下,可以修改Linux的内核相关TCP参数,来最大的提高服务器性能。当然,最基础的提高负载问题,还是升级服务器硬件了,这是最根本的。

Linux系统下,TCP连接断开后,会以TIME_WAIT状态保留一定的时间,然后才会释放端口。当并发请求过多的时候,就会产生大量的 TIME_WAIT状态的连接,无法及时断开的话,会占用大量的端口资源和服务器资源。这个时候我们可以优化TCP的内核参数,来及时将 TIME_WAIT状态的端口清理掉。

本文介绍的方法只对拥有大量TIME_WAIT状态的连接导致系统资源消耗有效,如果不是这种情况下,效果可能不明显。可以使用netstat命令去查TIME_WAIT状态的连接状态,输入下面的组合命令,查看当前TCP连接的状态和对应的连接数量:
#netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}’
这个命令会输出类似下面的结果:
LAST_ACK 16
SYN_RECV 348
ESTABLISHED 70
FIN_WAIT1 229
FIN_WAIT2 30
CLOSING 33
TIME_WAIT 18098

我们只用关心TIME_WAIT的个数,在这里可以看到,有18000多个TIME_WAIT,这样就占用了18000多个端口。要知道端口的数量只有 65535个,占用一个少一个,会严重的影响到后继的新连接。这种情况下,我们就有必要调整下Linux的TCP内核参数,让系统更快的释放 TIME_WAIT连接。

用vim打开配置文件:#vim /etc/sysctl.conf

在这个文件中,加入下面的几行内容:
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_fin_timeout = 30

输入下面的命令,让内核参数生效:#sysctl -p

简单的说明上面的参数的含义:

net.ipv4.tcp_syncookies = 1
#表示开启SYN Cookies。当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭;
net.ipv4.tcp_tw_reuse = 1
#表示开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭;
net.ipv4.tcp_tw_recycle = 1
#表示开启TCP连接中TIME-WAIT sockets的快速回收,默认为0,表示关闭;
net.ipv4.tcp_fin_timeout
#修改系統默认的 TIMEOUT 时间。

在经过这样的调整之后,除了会进一步提升服务器的负载能力之外,还能够防御小流量程度的DoS、CC和SYN攻击。

此外,如果你的连接数本身就很多,我们可以再优化一下TCP的可使用端口范围,进一步提升服务器的并发能力。依然是往上面的参数文件中,加入下面这些配置:
net.ipv4.tcp_keepalive_time = 1200
net.ipv4.ip_local_port_range = 10000 65000
net.ipv4.tcp_max_syn_backlog = 8192
net.ipv4.tcp_max_tw_buckets = 5000

#这几个参数,建议只在流量非常大的服务器上开启,会有显著的效果。一般的流量小的服务器上,没有必要去设置这几个参数。

net.ipv4.tcp_keepalive_time = 1200
#表示当keepalive起用的时候,TCP发送keepalive消息的频度。缺省是2小时,改为20分钟。
net.ipv4.ip_local_port_range = 10000 65000
#表示用于向外连接的端口范围。缺省情况下很小:32768到61000,改为10000到65000。(注意:这里不要将最低值设的太低,否则可能会占用掉正常的端口!)
net.ipv4.tcp_max_syn_backlog = 8192
#表示SYN队列的长度,默认为1024,加大队列长度为8192,可以容纳更多等待连接的网络连接数。
net.ipv4.tcp_max_tw_buckets = 6000
#表示系统同时保持TIME_WAIT的最大数量,如果超过这个数字,TIME_WAIT将立刻被清除并打印警告信息。默 认为180000,改为6000。对于ApacheNginx 等服务器,上几行的参数可以很好地减少TIME_WAIT套接字数量,但是对于 Squid ,效果却不大。此项参数可以控制TIME_WAIT的最大数量,避免Squid服务器被大量的TIME_WAIT拖死。

内核其他TCP参数说明:
net.ipv4.tcp_max_syn_backlog = 65536
#记录的那些尚未收到客户端确认信息的连接请求的最大值。对于有128M内存的系统而言,缺省值是1024,小内存的系统则是128。
net.core.netdev_max_backlog = 32768
#每个网络接口接收数据包的速率比内核处理这些包的速率快时,允许送到队列的数据包的最大数目。
net.core.somaxconn = 32768
#web应用中listen函数的backlog默认会给我们内核参数的net.core.somaxconn限制到128,而nginx定义的NGX_LISTEN_BACKLOG默认为511,所以有必要调整这个值。

net.core.wmem_default = 8388608
net.core.rmem_default = 8388608
net.core.rmem_max = 16777216           #最大socket读buffer,可参考的优化值:873200
net.core.wmem_max = 16777216           #最大socket写buffer,可参考的优化值:873200
net.ipv4.tcp_timestsmps = 0
#时间戳可以避免序列号的卷绕。一个1Gbps的链路肯定会遇到以前用过的序列号。时间戳能够让内核接受这种“异常”的数据包。这里需要将其关掉。
net.ipv4.tcp_synack_retries = 2
#为了打开对端的连接,内核需要发送一个SYN并附带一个回应前面一个SYN的ACK。也就是所谓三次握手中的第二次握手。这个设置决定了内核放弃连接之前发送SYN+ACK包的数量。
net.ipv4.tcp_syn_retries = 2
#在内核放弃建立连接之前发送SYN包的数量。
#net.ipv4.tcp_tw_len = 1
net.ipv4.tcp_tw_reuse = 1
# 开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接。

net.ipv4.tcp_wmem = 8192 436600 873200
# TCP写buffer,可参考的优化值: 8192 436600 873200
net.ipv4.tcp_rmem  = 32768 436600 873200
# TCP读buffer,可参考的优化值: 32768 436600 873200
net.ipv4.tcp_mem = 94500000 91500000 92700000
# 同样有3个值,意思是:
net.ipv4.tcp_mem[0]:低于此值,TCP没有内存压力。
net.ipv4.tcp_mem[1]:在此值下,进入内存压力阶段。
net.ipv4.tcp_mem[2]:高于此值,TCP拒绝分配socket。
上述内存单位是页,而不是字节。可参考的优化值是:786432 1048576 1572864

net.ipv4.tcp_max_orphans = 3276800
#系统中最多有多少个TCP套接字不被关联到任何一个用户文件句柄上。
如果超过这个数字,连接将即刻被复位并打印出警告信息。
这个限制仅仅是为了防止简单的DoS攻击,不能过分依靠它或者人为地减小这个值,
更应该增加这个值(如果增加了内存之后)。
net.ipv4.tcp_fin_timeout = 30
#如果套接字由本端要求关闭,这个参数决定了它保持在FIN-WAIT-2状态的时间。对端可以出错并永远不关闭连接,甚至意外当机。缺省值是60秒。 2.2 内核的通常值是180秒,你可以按这个设置,但要记住的是,即使你的机器是一个轻载的WEB服务器,也有因为大量的死套接字而内存溢出的风险,FIN- WAIT-2的危险性比FIN-WAIT-1要小,因为它最多只能吃掉1.5K内存,但是它们的生存期长些。

经过这样的优化配置之后,你的服务器的TCP并发处理能力会显著提高。以上配置仅供参考,用于生产环境请根据自己的实际情况。

分享到:
评论

相关推荐

    教案之优化Linux的内核参数来提高服务器并发处理能力.pdf

    总结来说,优化Linux内核参数是提高服务器并发处理能力的有效手段,特别是针对TCP连接管理进行微调,可以有效地解决TIME_WAIT状态的连接占用资源的问题,并增强服务器的防御能力。同时,合理调整端口范围和连接队列...

    优化Linux的内核提高服务器并发能力

    1. Linux内核参数优化:Linux内核支持许多参数来控制TCP/IP协议栈的行为,这些参数包括与TCP连接处理、端口分配、套接字缓冲区大小等相关。通过修改这些参数,可以有效地调整Linux系统对网络请求的处理能力。这些...

    linux内核参数

    Linux内核参数调优是优化服务器性能的关键环节,特别是在硬件资源有限的情况下,通过调整内核参数可以有效地提高服务器的并发处理能力。对于Web服务器,如Nginx和Apache,它们的并发模型对于处理高负载至关重要。...

    牛客网Linux高并发服务器开发.zip

    综上所述,"牛客网Linux高并发服务器开发"的学习内容涵盖了从底层内核到上层应用的全面知识,旨在培养开发者构建高效、稳定、安全的服务器能力。通过深入学习和实践,可以提升在嵌入式Linux领域的专业技能。

    Linux优化-修改内核参数.rar

    2. **网络优化**:网络相关的参数如`net.core.somaxconn`决定了服务器可以同时处理的最大TCP连接数,这对于高并发的Web服务至关重要。`net.ipv4.tcp_fin_timeout`和`net.ipv4.tcp_keepalive_time`等参数可以优化连接...

    [试读]服务器并发处理能力+-+进程切换

    ### 服务器并发处理能力与进程切换 #### 一、服务器并发处理能力概述 服务器的并发处理能力是指服务器在同一时间内能够处理多个用户请求的能力。在现代互联网应用中,高并发访问是常态,特别是在大型网站和应用...

    linux 内核参数VM调优 之 参数调节和场景分析

    通过对Linux内核参数中虚拟内存管理部分的关键参数进行合理的调整和优化,可以显著提升系统的性能表现,尤其是在I/O密集型的应用场景下。根据不同场景的特点灵活调节这些参数,可以实现最佳的系统性能与稳定性平衡。

    解密Linux内核2.4 解密Linux内核2.4

    【解密Linux内核2.4】:Linux内核2.4版本的发布标志着Linux操作系统在技术上的巨大飞跃,尤其在系统性能、网络优化、硬件支持以及设备驱动方面都有显著提升。这一版本的内核旨在提供更强大的企业级功能,同时优化...

    linux高并发服务器带数据库操作

    Linux内核提供了强大的多任务处理和内存管理能力,支持多线程(threads)和进程(processes)模型,这使得服务器能够同时处理大量并发连接。 epoll是Linux下用于I/O多路复用的高效机制,通过它,服务器可以监控大量...

    深入分析Linux内核源码

    - **中断的后半部分处理机制**:为了提高性能,Linux内核将中断处理分为两部分,即硬中断处理和软中断处理,本节将详细介绍这一机制。 #### 第四章 进程描述 本章主要介绍Linux内核中进程管理的核心概念和技术细节...

    Linux内核优化是指通过调整内核的参数和设置,提高Linux系统的性能和效率

    通过对Linux内核进行优化,可以显著提高系统的稳定性、响应速度以及资源利用率,这对于高性能计算、大数据处理等场景尤其重要。 #### 四、sysctl.conf配置文件详解 `/etc/sysctl.conf` 和 `/etc/sysctl.d/` 是用于...

    linux内核完全注释

    1. 进程管理:Linux内核通过调度算法来管理多个并发执行的进程,确保公平和高效地分配CPU时间。它还包括进程间的通信(IPC)机制,如管道、信号量、消息队列等,以支持多进程协同工作。 2. 内存管理:内核负责动态...

    webserver(1)_linux高并发服务器_源码

    epoll是Linux内核提供的高效I/O事件通知机制,尤其适用于高并发的网络服务。与传统的select和poll相比,epoll具有更好的性能和可扩展性。epoll支持两种工作模式:水平触发(Level Triggered, LT)和边缘触发(Edge ...

    Linux之TCPIP内核参数优化1

    Linux中的TCP/IP内核参数优化对于提升网络性能和系统稳定性至关重要。本文主要关注的是与TCP/IP相关的内核参数,特别是那些影响数据传输效率和连接管理的设置。在Ubuntu 12.04 LTS Desktop (x64)系统中,这些参数...

    Linux并发服务器程序

    Linux并发服务器程序的设计与实现是基于Linux操作系统的网络编程能力。它通过使用Socket接口创建基于TCP协议的服务端程序,能够处理多个客户端的并发连接。本文将详细介绍Linux并发服务器程序的关键知识点,包括其...

    Linux高性能服务器编程电子版

    1. **多线程与并发处理**:Linux提供了多种机制来实现多线程和并发,如pthread库,以及进程间通信(IPC)如信号量、管道、共享内存等,用于提高服务器处理并发请求的能力。 2. **网络编程**:深入理解TCP/IP协议栈...

Global site tag (gtag.js) - Google Analytics