0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

总结一些常见网络相关的内核参数

阿铭linux 2018-01-16 16:14 次阅读

谈到内核大家会觉得很神秘,关于内核参数的调整更是觉得云里雾里的。其实,并没有大家想象的那么难,平时对它们的调整也是很少用到。

也许你有经历,想了解一些内核参数的作用,然后去网上搜了很多文档,结果发现大多都一样,而且没有人能够说的很详细。下面是我总结的几个跟网络相关的参数,希望对你有所帮助。当然,我也不保证理解的一定到位,如果你有更好的理解,请留言回复!
总结一些常见网络相关的内核参数

1net.ipv4.tcp_max_tw_buckets

对于tcp连接,服务端和客户端通信完后状态变为timewait,假如某台服务器非常忙,连接数特别多的话,那么这个timewait数量就会越来越大。毕竟它也是会占用一定的资源,所以应该有一个最大值,当超过这个值,系统就会删除最早的连接,这样始终保持在一个数量级。

这个数值就是由net.ipv4.tcp_max_tw_buckets这个参数来决定的。CentOS7系统,你可以使用sysctl -a |grep tw_buckets来查看它的值,默认为32768,你可以适当把它调低,比如调整到8000,毕竟这个状态的连接太多也是会消耗资源的。

但你不要把它调到几十、几百这样,因为这种状态的tcp连接也是有用的,如果同样的客户端再次和服务端通信,就不用再次建立新的连接了,用这个旧的通道,省时省力。

2net.ipv4.tcp_tw_recycle=1

该参数的作用是快速回收timewait状态的连接。上面虽然提到系统会自动删除掉timewait状态的连接,但如果把这样的连接重新利用起来岂不是更好。所以该参数设置为1就可以让timewait状态的连接快速回收,它需要和下面的参数配合一起使用。

3net.ipv4.tcp_tw_reuse=1

该参数设置为1,将timewait状态的连接重新用于新的TCP连接,要结合上面的参数一起使用。

4net.ipv4.tcp_syncookies=1

tcp三次握手中,客户端向服务端发起syn请求,服务端收到后,也会向客户端发起syn请求同时连带ack确认,假如客户端发送请求后直接断开和服务端的连接,不接收服务端发起的这个请求,服务端会重试多次。

这个重试的过程会持续一段时间,当这种状态的连接数量非常大时,服务器会消耗很大的资源,从而造成瘫痪,正常的连接进不来,这种恶意的半连接行为其实叫做syn flood攻击。

设置为1,是开启SYN Cookies,开启后可以避免发生上述的syn flood攻击。开启该参数后,服务端接收客户端的ack后,再向客户端发送ack+syn之前会要求client在短时间内回应一个序号,如果客户端不能提供序号或者提供的序号不对则认为该客户端不合法,于是不会发ack+syn给客户端,更涉及不到重试。

5net.ipv4.tcp_max_syn_backlog

该参数定义系统能接受的最大半连接状态的tcp连接数。客户端向服务端发送了syn包,服务端收到后,会记录一下,该参数决定最多能记录几个这样的连接。我的CentOS7系统,默认是256,当有syn flood攻击时,这个数值太小则很容易导致服务器瘫痪,实际上此时服务器并没有消耗太多资源(cpu、内存等),所以可以适当调大它,比如调整到30000。

6net.ipv4.tcp_syn_retries

该参数适用于客户端,它定义发起syn的最大重试次数,默认为5,建议改为2。

7 net.ipv4.tcp_synack_retries

该参数适用于服务端,它定义发起syn+ack的最大重试次数,默认为5,建议改为2,可以适当预防syn flood攻击。

8net.ipv4.ip_local_port_range

该参数定义端口范围,系统默认保留端口为1024及以下,以上部分为自定义端口。这个参数适用于客户端,当客户端和服务端建立连接时,比如说访问服务端的80端口,客户端随机开启了一个端口和服务端发起连接,这个参数定义随机端口的范围。默认为3276861000,建议调整为102561000。

9net.ipv4.tcp_fin_timeout

tcp连接的状态中,客户端上有一个是FIN-WAIT-2状态,它是状态变迁为timewait前一个状态。该参数定义不属于任何进程的该连接状态的超时时间,默认值为60,建议调整为6。

10net.ipv4.tcp_keepalive_time

tcp连接状态里,有一个是keepalived状态,只有在这个状态下,客户端和服务端才能通信。正常情况下,当通信完毕,客户端或服务端会告诉对方要关闭连接,此时状态就会变为timewait,如果客户端没有告诉服务端,并且服务端也没有告诉客户端关闭的话(例如,客户端那边断网了),此时需要该参数来判定。

比如客户端已经断网了,但服务端上本次连接的状态依然是keepalived,服务端为了确认客户端是否断网,就需要每隔一段时间去发一个探测包去确认一下看看对方是否在线。这个时间就由该参数决定。它的默认值为7200(单位为秒),建议设置为30。

11 net.ipv4.tcp_keepalive_intvl

该参数和上面的参数是一起的,服务端在规定时间内发起了探测,查看客户端是否在线,如果客户端并没有确认,此时服务端还不能认定为对方不在线,而是要尝试多次。该参数定义重新发送探测的时间,即第一次发现对方有问题后,过多久再次发起探测。

默认值为75秒(单位为秒),可以改为3。

12 net.ipv4.tcp_keepalive_probes

第10和第11个参数规定了何时发起探测和探测失败后再过多久再发起探测,但并没有定义一共探测几次才算结束。该参数定义发起探测的包的数量。默认为9,建议设置2。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 内核
    +关注

    关注

    3

    文章

    1309

    浏览量

    39833
  • 参数
    +关注

    关注

    11

    文章

    1396

    浏览量

    31408

原文标题:常见网络相关的内核参数调整

文章出处:【微信号:aming_linux,微信公众号:阿铭linux】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Linux一些常见问题——内核编译常见错误

    Linux一些常见问题——内核编译常见错误编译2.6.31内核后重启出现insmod: error inserting '/lib/dm-r
    发表于 02-20 15:22

    MSP430入门的一些常见问题

    讲了MSP430入门的一些常见问题,初学者很有帮助。
    发表于 11-07 22:55

    关于FPGA的一些典型问题总结

    关于FPGA的一些典型问题总结
    发表于 11-04 13:05

    PCB Layout的一些总结

    PCB设计中总结一些原则,希望高手能够指正勘误。、关于布局1.布局,字面上的解释,就是将电路元件合理的放置。那怎么样的放置是合理的,个简单的原则就是模块化划分清晰,也就是说有
    发表于 12-20 17:34

    总结关于linux学习什么的一些课程设置

    ven卢qq3354367110总结关于linux学习的一些课程第:了解Linux系统;区分各种版本的Linux系统,以便于拓展 Linux视野。1、Linux 简介;2、Lin
    发表于 07-29 15:07

    一些生活当中常见的经典电路

    一些生活当中很常见的经典电路,给大家分享分享
    发表于 05-16 13:54

    有关VBA的一些编程总结

    基本的资料,边学边做。以下是一些总结的问题,希望在网友后面用到作为一些参考。改变单元格字体的COLOR和单元格底色Workbooks(1).Sheets(“Sheet3”).Range(“1:65536”).Font.Color
    发表于 06-28 13:59

    常用的一些Linux内核配置选项有哪些?

    常用的一些Linux内核配置选项有哪些?引导模块支持子选项的配置方法有哪些?
    发表于 07-22 09:08

    求大佬分享伺服调试的一些应用总结

    求大佬分享伺服调试的一些应用总结
    发表于 11-15 06:25

    Linux内核中GNU C扩展的一些常用C语言语法分析

    13.1 总结前面12节的课程,主要针对 Linux 内核中 GNU C 扩展的一些常用 C 语言语法进行了分析。GNU C 的这些扩展语法,主要用来完善 C 语言标准和编译优化。而通过 C 标准
    发表于 12-14 06:29

    上位机通信协议相关一些知识点分享

    网络通信优先自己的工作有涉及到上位机,主要是串口RS-232,于是跟公司的嵌入式工程师请教并学习了上位机通信协议相关一些知识。1.串口现在串口是比较老的技术,常见的串口包括:VA.
    发表于 12-23 06:30

    Stm32关于GPIO的一些操作复习总结

    前言最近复习了下Stm32关于GPIO的一些操作,也对其相关函数做了下整理,以下的8条函数均在HAL库的 stm32l4xx_hal.c 中。内容 1. HAL_GPIO_Init
    发表于 01-12 08:10

    STM32中串口的一些常见问题有哪些?

    STM32中串口的一些常见问题有哪些?
    发表于 02-18 08:00

    关于stm32的一些简单的介绍

    #序言本文章是关于stm的一些简单的介绍,全部都是个人学习的一些经验总结,分享给想要自学stm32的朋友们用于入门。其中部分内容借鉴于《stm32中文参考手册》和《cortex-m3权威指南》,对于
    发表于 02-24 06:30

    TCP相关内核参数总结

    在Linux上做网络应用的性能优化时,一般都会对TCP相关内核参数进行调节,特别是和缓冲、队列有关的参数。很多文章会告诉你需要修改哪些
    的头像 发表于 11-10 15:17 278次阅读
    TCP<b class='flag-5'>相关</b>的<b class='flag-5'>内核</b><b class='flag-5'>参数</b><b class='flag-5'>总结</b>