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 设置和内核缓冲区。

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

相关推荐
木辰風3 分钟前
如何在MySQL中搜索JSON数据,并去除引号
数据库·mysql·json
zzhongcy8 分钟前
分库分表详解,以及ShardingJDBC介绍
数据库·oracle
Deamon Tree13 分钟前
Redis的过期策略以及内存淘汰机制
java·数据库·redis·缓存
calwen40 分钟前
Windows 通过 SSH 跳板机安全连接内网开发服务器
服务器
晓py43 分钟前
SQL调优专题笔记:打造你的数据库性能优化思维体系
数据库·笔记·sql
人工智能训练1 小时前
在 Ubuntu 系统中利用 conda 创建虚拟环境安装 sglang 大模型引擎的完整步骤、版本查看方法、启动指令及验证方式
linux·运维·服务器·人工智能·ubuntu·conda·sglang
IvorySQL1 小时前
数据库内核的降维观测方法
数据库·postgresql
☆璇1 小时前
【Linux】网络层协议IP
linux·服务器·tcp/ip
R.lin1 小时前
红包实现方案
java·开发语言·网络·后端·架构
金仓拾光集1 小时前
__金仓数据库平替MongoDB全栈安全实战:从文档存储到多模一体化的演进之路__
数据库·安全·mongodb