`
steven-zhou
  • 浏览: 213286 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Linux Web Server 内核参数调整

阅读更多
基本系统调节
在对系统的 Apache、PHP 和 MySQL 组件进行调优之前,应该花一些时间确保底层Linux组
件的运行正常。还应该对正在运行的服务进行缩减,只运行需要的那些服务。这不但是一种
良好的安全实践,而且可以节省内存和CPU时间。

一些快速的内核调优措施
大多数Linux发布版都定义了适当的缓冲区和其他TCP参数。
可以修改这些参数来分配更多的内存,从而改进网络性能。设置内核参数的方法是通过
proc接口,也就是通过读写/proc中的值。幸运的是:sysctl可以读取/etc/sysctl.conf
中的值并根据需要填充/proc,这样就能够更轻松地管理这些参数。

清单2展示在互联网服务器上应用于Internet服务器的一些比较激进的网络设置。

清单2. 包含较为激进的网络设置的/etc/sysctl.conf

# Use TCP syncookies when needed
net.ipv4.tcp_syncookies = 1

# Enable TCP window scaling
net.ipv4.tcp_window_scaling: = 1

# Increase TCP max buffer size
net.core.rmem_max = 16777216
net.core.wmem_max = 16777216

# Increase Linux autotuning TCP buffer limits
net.ipv4.tcp_rmem = 4096 87380 16777216 
net.ipv4.tcp_wmem = 4096 65536 16777216

# Increase number of ports available
net.ipv4.ip_local_port_range = 1024 65000

将这些设置添加到/etc/sysctl.conf的现有内容中。

第一个设置启用TCP SYN cookie。
当从客户机发来新的TCP连接时,数据包设置了SYN位,服务器就为这个半开的连接创建一个
条目,并用一个SYN-ACK数据包进行响应。在正常操作中,远程客户机用一个ACK数据包进
行响应,这会使半开的连接转换为全开的。
有一种称为SYN泛滥(SYN flood)的网络攻击,它使ACK数据包无法返回,导致服务器用光内存空间,无法处理到来的连接。SYN cookie特性可以识别出这种情况,并使用一种优雅的方法
保留队列中的空间(细节参见 参考资料 一节)。
大多数系统都默认启用这个特性,但是确保配置这个特性更可靠。

启用TCP窗口伸缩使客户机能够以更高的速度下载数据。
TCP允许在未从远程端收到确认的情况下发送多个数据包,默认设置是最多64KB,在与延迟比
较大的远程客户机进行通信时这个设置可能不够。窗口伸缩会在头中启用更多的位,从而增加窗口大小。

后面四个配置项增加TCP发送和接收缓冲区。这使应用程序可以更快地丢掉它的数据,从而
为另一个请求服务。还可以强化远程客户机在服务器繁忙时发送数据的能力。

最后一个配置项增加可用的本地端口数量,这样就增加了可以同时服务的最大连接数量。

[b]在下一次引导系统时,或者下一次运行sysctl -p /etc/sysctl.conf时,这些设置就会生效。[/b]
分享到:
评论

相关推荐

    linux webserver例子

    Epoll是Linux内核提供的一种I/O多路复用技术,它提高了在高并发场景下的性能。 Epoll的核心优势在于其高效性,它允许程序同时监视多个文件描述符(如套接字),当就绪的文件描述符发生变化时,系统会通过epoll_wait...

    linux下的webserver-BOA及CGIC库的使用指南

    由于BOA的目标环境可能不是标准的Linux平台,因此需要对编译参数进行一定的调整,例如使用交叉编译工具链: ```bash cd boa-0.94.13/src CC=arm-linux-gcc CPP=arm-linux-gcc -E ./configure ``` 接着需要对源码...

    基于Linux的嵌入式WebServer的设计与实现.pdf

    【基于Linux的嵌入式WebServer的设计与实现】 在现代技术发展中,嵌入式系统扮演着越来越重要的角色,尤其在物联网(IoT)时代,它们是连接物理世界和数字世界的桥梁。嵌入式WebServer是一种将Web技术集成到嵌入式...

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

    这里的“webserver(1)_linux高并发服务器_源码”是一个针对该主题的实践项目,它采用Preactor模式并利用了Linux的epoll LT模型来处理大量并发连接。以下是对这些关键知识点的详细说明: **Linux高并发服务器:** 在...

    Linux中用内核KHTTPD实现Web服务加速

    例如,可以通过调整`clientport`和`serverport`来设置监听的端口,`documentroot`来设定Web文档根目录,以及`dynamic`来指定动态内容请求的特定字符串(如"cgi-bin")。 在实际部署中,有两种推荐的操作模式: 1. ...

    牛客webserver服务器项目一个月速通

    根据给定的文件信息,我们可以总结出一系列关于“牛客webserver服务器项目一个月速通”的重要知识点,主要围绕Linux系统编程的基础展开。 ### Linux开发环境搭建 - **环境准备**: - 安装Linux系统:可以选择通过...

    Linux内核升级、搭建HTTP服务器

    在Linux环境下,本次实训主要涉及三个关键知识点:Linux内核升级、HTTP服务器的...通过这些实践,学生不仅了解了Linux内核的工作原理,也掌握了构建网络服务的基本流程,为后续的系统管理和Web开发打下了坚实的基础。

    Linux Apache Web Server Administration-Sybex (2002).pdf

    17. 性能调优:涉及到系统性能的监控和调优,包括系统资源使用情况和内核参数的调整。 18. 使用脚本简化工作:自动化常规任务和管理脚本的编写可以大幅度提高系统管理效率。 19. Linux系统故障排除:涉及问题诊断...

    基于ARM9的嵌入式Linux系统的Web Server服务器计算机设计与科学专业.doc

    入式Linux系统与Web Server服务器概述 嵌入式系统是一种专用的计算机系统,它作为完整设备的一部分,通常具有特定的功能。这些系统广泛应用于各种领域,如汽车电子、医疗设备、消费电子、工业自动化等。其特点包括...

    linux virtual server 概述

    LVS的一个关键特性是其运行在Linux内核空间,这意味着调度开销极低,可以实现高吞吐量。此外,由于请求通常没有强相关性,服务器池中的节点可以并行处理请求,从而实现线性性能扩展。高速网络连接负载调度器、服务器...

    基于Linux和S3c2410的嵌入式WebServer的研究与实现

    ### 基于Linux和S3c2410的嵌入式WebServer的研究与实现 #### 一、概述 本文介绍了如何在基于嵌入式Linux操作系统和S3c2410 ARM处理器的嵌入式系统中实现Web Server(Boa网络服务器)。通过CGI(通用网关接口),...

    Linux内核模块编程

    - 函数原型:`socket(PF_NETLINK, SOCK_RAW, NETLINK_CUSTOM_HELLO_WEBSERVER);` - 参数说明: - `PF_NETLINK`:表示Netlink协议族。 - `SOCK_RAW`:表示原始套接字类型。 - `NETLINK_CUSTOM_HELLO_WEBSERVER`...

    基于嵌入式设备Web Server的设计与实现毕业论文.docx

    Linux C语言是指在Linux操作系统上使用的C语言,用于开发嵌入式系统和Web Server。在本文中,我们使用Linux C语言来实现Web Server的应用实例系统。 Arm开发板 Arm开发板是指基于Arm架构的嵌入式设备开发板,在...

    Linux环境下Epoll系统调用实现web服务器并发工作

    在`webserver.c`源代码中,我们可以看到具体的实现细节,包括结构体定义、套接字操作、Epoll接口的使用等。代码会演示如何初始化Epoll,监听套接字的注册,事件循环的运行,以及对就绪事件的处理逻辑。通过对这个...

    [Linux.Server.Hacks(第1版)].源代码.zip

    在深入讨论这些知识点之前,我们需要知道Linux是一个开源的操作系统,其内核由林纳斯·托瓦兹开发,现在由全球开发者社区共同维护。Linux服务器因其稳定性和灵活性,广泛应用于企业级网络环境,包括Web服务器、...

    Linux Virtual Server

    LVS 的核心思想是利用 Linux 内核的功能来实现一个虚拟的服务前端,这个前端能够接收来自客户端的请求,并根据一定的策略将这些请求分发到后端的一组真实服务器上进行处理。 #### 二、LVS 的组成部分与功能 LVS ...

    linux server服务器性能优化

    2. **系统调优**:调整系统参数,例如提高最大打开文件数限制,优化内存管理策略。 3. **进程调度**:合理设置进程优先级,确保关键服务优先执行。 4. **I/O优化**:如使用合适的RAID级别,调整块大小和缓存策略,...

Global site tag (gtag.js) - Google Analytics