Linux 内核调优部分参数说明

news/2024/12/21 20:26:01/
  • 表示尽量使用内存,减少使用磁盘 swap 交换分区,内存速度明显高于磁盘一个数量级。
vm.swappiness = 0
  • 内存分配策略,Redis 持久化存储需设置值为1。
vm.overcommit_memory = 1

0:表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1:表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2:表示内核允许分配超过所有物理内存和交换空间总和的内存

  • 接收套接字缓冲区大小的默认值(以字节为单位)。
net.core.rmem_default = 262144
  • 接收套接字缓冲区大小的最大值(以字节为单位)。
net.core.rmem_max = 16777216
  • 发送套接字缓冲区大小的默认值(以字节为单位)。
net.core.wmem_default = 262144
  • 发送套接字缓冲区大小的最大值(以字节为单位)。
net.core.wmem_max = 16777216
  • 用来限制监听(LISTEN)队列最大数据包的数量,超过这个数量就会导致链接超时或者触发重传机制。
net.core.somaxconn = 262144
  • 当网卡接收数据包的速度大于内核处理的速度时,会有一个队列保存这些数据包。这个参数表示该队列的最大值。
net.core.netdev_max_backlog = 262144
  • 表示系统中最多有多少 TCP 套接字不被关联到任何一个用户文件句柄上。如果超过这里设置的数字,连接就会复位并输出警告信息。这个限制仅仅是为了防止简单的 DoS 攻击。此值不能太小。
net.ipv4.tcp_max_orphans = 262144
  • 表示那些尚未收到客户端确认信息的连接(SYN 消息)队列的长度,默认为1024,加大队列长度为262144,可以容纳更多等待连接的网络连接数。
net.ipv4.tcp_max_syn_backlog = 262144
  • 表示系统同时保持 TIME_WAIT 套接字的最大数量。如果超过此数,TIME_WAIT套接字会被立刻清除并且打印警告信息。之所以要设定这个限制,纯粹为了抵御那些简单的 DoS 攻击,不过,过多的 TIME_WAIT 套接字也会消耗服务器资源,甚至死机。
net.ipv4.tcp_max_tw_buckets = 10000
  • 表示允许系统打开的端口范围。
net.ipv4.ip_local_port_range = 1024 65500
  • 表示允许重用 TIME_WAIT 状态的套接字用于新的 TCP 连接,默认为0,表示关闭。
net.ipv4.tcp_tw_reuse = 1
  • 当出现 SYN 等待队列溢出时,启用 cookies 来处理,可防范少量 SYN 攻击,默认为0,表示关闭。
net.ipv4.tcp_syncookies = 1
  • 表示系统允许SYN连接的重试次数。为了打开对端的连接,内核需要发送一个 SYN 并附带一个回应前面一个 SYN 的 ACK 包。也就是所谓三次握手中的第二次握手。这个设置决定了内核放弃连接之前发送 SYN+ACK 包的数量。
net.ipv4.tcp_synack_retries = 1
  • 表示在内核放弃建立连接之前发送 SYN 包的数量。
net.ipv4.tcp_syn_retries = 1
  • 减少处于 FIN-WAIT-2 连接状态的时间,使系统可以处理更多的连接。
net.ipv4.tcp_fin_timeout = 30
  • 这个参数表示当keepalive启用时,TCP 发送 keepalive 消息的频度。默认是2小时,若将其设置得小一些,可以更快地清理无效的连接。
net.ipv4.tcp_keepalive_time = 600
  • 探测消息未获得响应时,重发该消息的间隔时间(秒)。
net.ipv4.tcp_keepalive_intvl = 30
  • 在认定连接失效之前,发送多少个 TCP 的 keepalive 探测包。系统默认值是9。这个值乘以 tcp_keepalive_intvl 之后决定了,一个连接发送了 keepalive 探测包之后可以有多少时间没有回应。
net.ipv4.tcp_keepalive_probes = 3
  • 确定TCP栈应该如何反映内存使用,每个值的单位都是内存页(通常是4KB)。第一个值是内存使用的下限;第二个值是内存压力模式开始对缓冲区使用应用压力的上限;第三个值是内存使用的上限。在这个层次上可以将报文丢弃,从而减少对内存的使用。示例中第一个值为786432×4÷1024÷1024=3G,第二个值为1048576×4÷1024÷1024=4G,第三个值为1572864*4÷1024÷1024=6G。
net.ipv4.tcp_mem = 786432 1048576 1572864
  • 此参数限制并发未完成的异步请求数目,应该设置避免 I/O 子系统故障。
fs.aio-max-nr = 1048576
  • 该参数决定了系统中所允许的文件句柄最大数目,文件句柄设置代表 Linux 系统中可以打开的文件的数量。
fs.file-max = 6815744
  • 信号设置。
kernel.sem = 250 32000 100 128

第一列,表示每个信号集中的最大信号量数目。
第二列,表示系统范围内的最大信号量总数目。
第三列,表示每个信号发生时的最大系统操作数目。
第四列,表示系统范围内的最大信号集总数目。
(第一列)×(第四列)=(第二列)


http://www.ppmy.cn/news/47069.html

相关文章

「C/C++」C语言与C++的区别

目录 1. 语言起源2. 编程范式3. 內置类4. 函数重载5. 引用类型6. 模板7. 异常处理 1. 语言起源 C语言 最初是由Dennis Ritchie在1970年代开发的,它是一种可移植、高效、底层的编程语言,主要用于系统软件、嵌入式开发、操作系统等领域。 C语言 于1980年代…

我的创作纪念日:Unity CEO表示生成式AI将是Unity近期发展重点,发布神秘影片预告

PICK 未来的AI技术将会让人类迎来下一个生产力变革,这其中也包括生成型AI的突破性革新。各大公司也正在竞相推出AIGC工具,其中微软的Copilot、Adobe的Firefly、Github的chatGPT等引起了人们的关注。然而,游戏开发领域似乎还没有一款真正针对性…

nacos使用

【应用服务注册】 1,引入依赖 spring-cloud-starter-alibaba-nacos-discovery 2,配置服务地址 spring.cloud.nacos.discovery.server-addr:0.0.0.0:8848/ 3,启动类添加注解 EnableDiscoveryClient 4,统一接口返回结构 ResultData …

ubuntu(20.04)-shell脚本(2)echo-date-awk-sed-iptables-shell变量数组

1.echo 语法:echo [-ne][字符串]补充说明: 1、echo会将输入的字符串送往标准输出。 2、输出的字符串间以空白字符隔开,并在最后加上换行号。OPTIONS: -n 不要在最后自动换行 -e 若字符串中出现以下字符,则特别加以处理,而不会将它当成一般文…

【WebRTC技术专题】更进一步,核心组件RTP/RTCP数据传输协议 (3)

前言介绍 RTP/RTCP协议是流媒体通信的基石。 RTP协议定义流媒体数据在互联网上传输的数据包格式RTCP协议则负责可靠传输、流量控制和拥塞控制等服务质量保证。 在WebRTC项目中,RTP/RTCP模块作为传输模块的一部分 发送端采集到的媒体数据进行进行封包,…

C#FileInfo和File 类

C#中的FileInfo和File类都提供了许多方法和属性来操作文件,但它们的使用方法有所不同。下面是FileInfo和File类常用的方法举例说明: FileInfo类方法: CreateText:创建或打开一个文本文件,并返回一个StreamWriter对象…

MybatisPlus

目录 MybatisPlus入门案例步骤代码实现数据库及表MybatisPlus的Maven坐标配置数据库创建实体类User Mapper接口UserMapper 引导类测试类 简介使用MP做标准数据层开发标准CRUD新增删除修改根据id查询查询所有分页查询步骤1:调用方法传入参数获取返回值步骤2:设置分页拦截器 DQL编…

2023/4/18往日题目总结

搜索路径状态记录 1076. 迷宫问题 - AcWing题库 //以最简单的迷宫问题为例,如何记录走迷宫的路径,其实只需要记录一下状态即可 //也就是记录一下这个点是从哪个点来的,最后从终点开始输出即可(此时输出的是逆序) #in…