新服务器上线优化调整

1. 写入到系统配置

重新登录终端生效配置,只对使用二进制启动的进程生效,对于使用systemd管理的进程不生效,已经运行的进程不生效。

csharp 复制代码
cat >> /etc/security/limits.conf << EOF
# 限制用户能打开的进程数
* soft nproc 1000000
* hard nproc 1000000
# 限制用户能打开的文件描述符数量
* soft nofile 1000000
* hard nofile 1000000
# 允许进程锁定物理内存(禁止交换到 Swap,降低延迟),这里是不限制
* soft memlock unlimited
* hard memlock unlimited
EOF
复制代码
[root@localhost ~]# ulimit -n
1000000
[root@localhost ~]# ulimit -u
1000000
[root@localhost ~]# ulimit -m
unlimited

启动新进程查看效果:

复制代码
[root@localhost ~]# python3 -m http.server 8888  &
[1] 5321
[root@localhost ~]# cat /proc/5321/limits
Limit                     Soft Limit           Hard Limit           Units
Max cpu time              unlimited            unlimited            seconds
Max file size             unlimited            unlimited            bytes
Max data size             unlimited            unlimited            bytes
Max stack size            8388608              unlimited            bytes
Max core file size        unlimited            unlimited            bytes
Max resident set          unlimited            unlimited            bytes
Max processes             1000000              1000000              processes			# 打开进程数
Max open files            1000000              1000000              files						# 打开文件数
Max locked memory         unlimited            unlimited            bytes					# 最大锁定内存
Max address space         unlimited            unlimited            bytes
Max file locks            unlimited            unlimited            locks
Max pending signals       6790                 6790                 signals
Max msgqueue size         819200               819200               bytes
Max nice priority         0                    0
Max realtime priority     0                    0
Max realtime timeout      unlimited            unlimited            us

2. 写入到systemd配置文件

对使用systemd管理的服务生效,同样已运行的进程不生效。

csharp 复制代码
cat >> /etc/systemd/system.conf << EOF
# 限制用户能打开的文件描述符数量
DefaultLimitNOFILE=1000000
# 限制用户能打开的进程数
DefaultLimitNPROC=1000000
# 允许进程锁定物理内存(禁止交换到 Swap,降低延迟),这里是不限制
DefaultLimitMEMLOCK=infinity
EOF
systemctl daemon-reexec

查看是否生效:

复制代码
[root@localhost ~]# systemctl show --no-pager \
  -p DefaultLimitNOFILE \
  -p DefaultLimitNPROC \
  -p DefaultLimitMEMLOCK
DefaultLimitNOFILE=1000000
DefaultLimitNPROC=1000000
DefaultLimitMEMLOCK=infinity

启动新的service服务查看效果:

复制代码
dnf -y install httpd && systemctl start httpd
[root@localhost ~]# pidof httpd
8672 8671 8670 8669 8668
[root@localhost ~]# cat /proc/5321/limits
Limit                     Soft Limit           Hard Limit           Units
Max cpu time              unlimited            unlimited            seconds
Max file size             unlimited            unlimited            bytes
Max data size             unlimited            unlimited            bytes
Max stack size            8388608              unlimited            bytes
Max core file size        unlimited            unlimited            bytes
Max resident set          unlimited            unlimited            bytes
Max processes             1000000              1000000              processes   # 最大进程
Max open files            1000000              1000000              files				# 最大文件
Max locked memory         unlimited            unlimited            bytes			# 锁定内存限制
Max address space         unlimited            unlimited            bytes
Max file locks            unlimited            unlimited            locks
Max pending signals       6790                 6790                 signals
Max msgqueue size         819200               819200               bytes
Max nice priority         0                    0
Max realtime priority     0                    0
Max realtime timeout      unlimited            unlimited            us

3. 修改当前运行进程的限制

复制代码
[root@localhost ~]# pidof httpd
4133 4132 4131 4130 4129
[root@localhost ~]# cat /proc/4133/limits | grep -E 'Max processes|Max open files|Max locked memory'
Max processes             6790                 6790                 processes			# 当前最大进程
Max open files            1024                 524288               files					# 当前文件
Max locked memory         8388608              8388608              bytes			# 当前限制内存
[root@localhost ~]# prlimit --pid=4133 \
--nofile=1000000:1000000 \
--nproc=1000000:1000000 \
--memlock=unlimited:unlimited
[root@localhost ~]# cat /proc/4133/limits | grep -E 'Max processes|Max open files|Max locked memory'
Max processes             1000000              1000000              processes			# 修改后
Max open files            1000000              1000000              files						# 修改后
Max locked memory         unlimited            unlimited            bytes					# 修改后

补充:

prlimit:查看或修改运行中进程的系统资源限制(如文件句柄、进程数、锁内存等),支持在线热调整且不中断业务

基本用法:

查看限制:prlimit -p

修改限制:prlimit --pid -- 资源 = 软限:硬限

通用参数:

-p, --pid → 指定进程 PID

-h, --help → 显示帮助

-V, --version → 显示版本

资源限制参数(核心):

-n, --nofile → 最大打开文件数(高并发关键)

-u, --nproc → 最大用户进程 / 线程数

-l, --memlock → 最大锁定物理内存(不换 swap)

其他常用参数:

-c, --core → 核心转储文件大小

-d, --data → 进程数据段大小

-e, --nice → 最大 nice 优先级

-f, --fsize → 文件最大可写大小

-i, --sigpending → 最大挂起信号数

-m, --rss → 常驻内存集

-q, --msgqueue → POSIX 消息队列大小

-r, --rtprio → 实时调度优先级

-s, --stack → 最大栈大小

-t, --cpu → CPU 时间限制

-v, --as → 虚拟内存大小

-x, --locks → 文件锁数量

-y, --rttime → 实时调度 CPU 时间

相关推荐
心满意足的大脸猫4 分钟前
Win11 开启 SSH 服务器与密钥登录配置记录
服务器·microsoft·ssh
Cat_Rocky6 分钟前
Jenkins通过kubernetes连接K8s集群
运维·kubernetes·jenkins
Plastic garden6 分钟前
Docker(2)数据挂载
运维·docker·容器
Plastic garden6 分钟前
Docker(4) Compose
运维·docker·容器
utf8mb4安全女神13 分钟前
磁盘管理(交换分区)(MGR分区)(GPT分区)
linux·运维·服务器
不会就选b15 分钟前
linux之vim
linux·运维·vim
humors22121 分钟前
聊聊密码为啥会“白设”
大数据·运维·服务器·网络·网络安全
2301_7779983429 分钟前
进程控制:进程创建、进程终止、进程等待、进程程序替换
linux·服务器
xiaobobo333037 分钟前
Ubuntu 26.04下编译s5pv210芯片的linux内核源码,无法进入menuconfig界面
linux·运维·ubuntu
kongba00737 分钟前
双轨终端监视系统部署手册tmux + ttyd 实时 SSH 操作可视化方案
运维·ssh