ubuntu20.04 突破文件数限制

  1. 增加文件描述符的限制
    每个网络连接都占用一个文件描述符。增加文件描述符的数量,可以让系统处理更多的并发连接。

1.1 临时修改文件描述符限制

首先,查看当前的文件描述符限制:

bash 复制代码
ulimit -n

然后,将文件描述符限制增大,例如:

bash 复制代码
ulimit -n 100000

这种方法是临时的,仅对当前会话有效。如果你希望永久更改限制,需要修改系统配置文件。

1.2 永久修改文件描述符限制

打开 /etc/security/limits.conf 文件:

bash 复制代码
sudo nano /etc/security/limits.conf

在文件末尾添加以下内容:

plaintext 复制代码
* soft nofile 100000
* hard nofile 100000

保存并退出。

1.3 配置 PAM 支持

确保 PAM 配置文件允许文件描述符的增加。编辑 /etc/pam.d/common-session 文件:

bash 复制代码
sudo nano /etc/pam.d/common-session

在文件末尾添加以下行:

plaintext 复制代码
session required pam_limits.so

1.4 修改系统级别的文件描述符限制

编辑 /etc/sysctl.conf 文件:

bash 复制代码
sudo nano /etc/sysctl.conf

添加以下行:

plaintext 复制代码
fs.file-max = 200000

保存并关闭文件,然后应用更改:

bash 复制代码
sudo sysctl -p
  1. 调整端口范围
    操作系统为每个新的网络连接分配一个端口,默认情况下端口范围为 1024 到 65535。你可以扩大这个范围,以便系统能提供更多的可用端口。

2.1 修改端口范围

编辑 /etc/sysctl.conf 文件:

bash

sudo nano /etc/sysctl.conf

添加或修改以下行,扩大端口范围:

plaintext 复制代码
net.ipv4.ip_local_port_range = 1024 65535

保存并关闭文件,然后应用更改:

bash 复制代码
sudo sysctl -p
  1. 优化 TCP 设置
    为了支持更多的连接,调整一些内核参数来优化 TCP 设置。

3.1 增加最大 SYN 队列和最大连接数

编辑 /etc/sysctl.conf 文件:

bash 复制代码
sudo nano /etc/sysctl.conf

添加以下内容:

plaintext 复制代码
net.ipv4.tcp_max_syn_backlog = 8192
net.core.somaxconn = 8192

这会增加系统可以接受的 TCP 同步连接请求的最大数量,以及增加监听队列的大小。

3.2 增加 TCP 连接的最大数目

可以增加系统中 TCP 连接的最大数量,减少连接被丢弃的可能:

bash 复制代码
sudo sysctl -w net.ipv4.tcp_max_tw_buckets=1440000
sudo sysctl -w net.ipv4.tcp_fin_timeout=15

3.3 调整内核的网络缓冲区大小

为提高网络吞吐量,可以增大内核缓冲区大小:

bash 复制代码
sudo sysctl -w net.core.rmem_max=16777216
sudo sysctl -w net.core.wmem_max=16777216
sudo sysctl -w net.ipv4.tcp_rmem="4096 87380 16777216"
sudo sysctl -w net.ipv4.tcp_wmem="4096 65536 16777216"
  1. 检查设置是否生效
    设置完成后,可以检查系统的设置是否生效:
bash 复制代码
ulimit -n    # 查看文件描述符限制
sysctl net.ipv4.ip_local_port_range   # 查看端口范围
sysctl net.ipv4.tcp_max_syn_backlog   # 查看最大 SYN 队列大小
sysctl net.core.somaxconn            # 查看最大监听连接数
  1. 重启系统或网络服务
    为了确保所有设置生效,最好重启系统,或者至少重启网络服务:
bash 复制代码
sudo systemctl restart network

总结

通过以上步骤,你可以将 Ubuntu 20.04 系统配置为支持 10 万以上的连接。

主要的调整项包括增加文件描述符限制、修改端口范围、调整 TCP 设置和内核缓冲区。

设置完成后,系统应该能够承载大量的并发连接。

相关推荐
小蒜学长20 分钟前
springboot基于javaweb的小零食销售系统的设计与实现(代码+数据库+LW)
java·开发语言·数据库·spring boot·后端
云边有个稻草人39 分钟前
从内核调优到集群部署:基于Linux环境下KingbaseES数据库安装指南
linux·数据库·金仓数据库管理系统
EnCi Zheng1 小时前
JPA 连接 PostgreSQL 数据库完全指南
java·数据库·spring boot·后端·postgresql
Raymond运维1 小时前
MySQL包安装 -- RHEL系列(Yum资源库安装MySQL)
linux·数据库·mysql
夜月yeyue1 小时前
ART 加速器、流水线与指令预测的关系详解
linux·服务器·c语言·单片机·嵌入式硬件·性能优化·嵌入式高阶技巧
迎風吹頭髮1 小时前
UNIX下C语言编程与实践36-UNIX 时钟:系统时间、高分辨率时间与日历时间的转换与使用
服务器·c语言·unix
安卓开发者1 小时前
鸿蒙NEXT网络通信实战:使用HTTP协议进行网络请求
网络·http·harmonyos
为java加瓦2 小时前
IO多路复用的两种触发机制:ET和LT触发机制。以及IO操作是异步的还是同步的理解
java·服务器·网络
岑梓铭2 小时前
计算机网络第四章(8)——网络层《ICMB网际控制协议》
网络·计算机网络
他们叫我技术总监2 小时前
Oracle数据库常见问题实战:从连接错误到自动清理空闲会话
数据库·oracle