A. linux查看当前进程的nofile
您好,在Linux操作系统中,nofile是指当前进程打开的最大文件描述符数量。要查看当前进程的nofile,可以使用以下命令:
1. 使用命令“ulimit -n”可以查看当前用户的nofile限制。如果该值不够大,可以使用“ulimit -n <number>”来尘改增加nofile限制。
2. 使用命令“cat /proc/<pid>/limits”可以查看指定进程的nofile限制。其中,<pid>为要查看的进程的进程ID。
3. 使用命令“cat /proc/<pid>/status | grep Nofiles”可以查看指定进程打开的文件描述符数量。其中,<pid>为要查看的进程的进程ID。
4. 使用命令“lsof -p <pid> | wc -l”可以查看指定进程丛李打开的文件数量。其中,<pid>为要查看的进程的进程ID。
以上是查看当前进程派郑判的nofile的几种方法,可以根据实际情况选择合适的方法进行查看。
B. linux中查看系统当前所有进程的命令是
ps aux为查看系统当前所有进程命令。
工具/原料
VMware Linux 电脑
方法/步骤
1、打开VMware虚拟机,打开终端命令行,通过”su“命令切换到root用户下。
C. 如何统计Linux的进程数
统计有多少行用wc命令的-l参数,wc命令可以统计出多少字、行、字符数,它的-l参数表示仅仅统计出行数。这个命令一般是和管道符结合使用,比如想知道一个文件有多少行可以这样用:
cat /etc/passwd |wc -l
而查看Linux当前的所有进程用ps aux命令,结果中一行是一个进程,所以,统计Linux系统的进程总数的命令应该是:
ps aux | wc -l
D. linux中如何查看进程总数
方法一:
pstree -p 14686(PID),可获取到nginx的四个子进程(或 ps -ef |grep nginx)
方法二:ps -eL -o pid,%cpu,lwp|grep -i pid
E. 如何在Linux中查看所有正在运行的进程
可以使用top命令。
top命令提供了运行中系统的动态实时视图。在终端中输入top:
第一行:
10:01:23
当前系统时间
126
days,
14:29
系统已经运行了126天14小时29分钟(在这期间没有重启过)
2
users
当前有2个用户登录系统
load
average:
1.15,
1.42,
1.44
load
average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。
load
average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。
第二行:
Tasks
任务(进程),系统现在共有183个进程,其中处于运行中的有1个,182个在休眠(sleep),stoped状态的有0个,zombie状态(僵尸)的有0个。
第三行:cpu状态
6.7%
us
用户空间占用CPU的百分比。
0.4%
sy
内核空间占用CPU的百分比。
0.0%
ni
改变过优先级的进程占用CPU的百分比
92.9%
id
空闲CPU百分比
0.0%
wa
IO等待占用CPU的百分比
0.0%
hi
硬中断(Hardware
IRQ)占用CPU的百分比
0.0%
si
软中断(Software
Interrupts)占用CPU的百分比
在这里CPU的使用比率和windows概念不同,如果你不理解用户空间和内核空间,需要充充电了。
第四行:内存状态
8306544k
total
物理内存总量(8GB)
7775876k
used
使用中的内存总量(7.7GB)
530668k
free
空闲内存总量(530M)
79236k
buffers
缓存的内存量
(79M)
第五行:swap交换分区
2031608k
total
交换区总量(2GB)
2556k
used
使用的交换区总量(2.5M)
2029052k
free
空闲交换区总量(2GB)
4231276k
cached
缓冲的交换区总量(4GB)
F. 怎么能得到当前linux系统所能创建的最大进程数量
1、Linux 系统的最大进程数和最大文件打开数限制:
vi /etc/security/limits.conf
# 添加如下的行
* soft noproc 11000
* hard noproc 11000
* soft nofile 4100
* hard nofile 4100
2、说明:* 代表针对所有用户
noproc 是代表最大进程数
nofile 是代表最大文件打开数
# - "soft" for enforcing the soft limits
# - "hard" for enforcing hard limits
3、重新登录
ulimit -a查看配置结果
4、为立刻生效,可以执行
ulimit -n 10240
ulimit -n 10240
G. Linux最大线程数限制及当前线程数查询
查看系统允许的最大线程数:
Linux无法直接控制单个进程可拥有的线程数,但有参考公式max = VM/stack_size,默认stack为8k,可通过降低stack大小或增加虚拟内存来调大每个进程可拥有的最大线程数;
对于支持多线程的程序如Java,有可能会遇到一个进程无法创建更多线程的情形,其原因多种多样,而OS端可能由此参数造成.
查看系统允许的最大进程数:
ulimit -a 显示当前所有的资源限制
root用户下执行 ulimit -a 然后查看 max user processes 这个值通常是系统最大线程数的一半:/proc/sys/kernel/threads-max/2
普通用户下 ulimit -u 出现的max user processes的值 默认是 /etc/security/limits.d/20-nproc.conf(centos6 是90-nproc.conf) 文件中的
普通用户默认是1024
打开/etc/security/limits.conf (部分的系统是在/etc/security/limits.d/90-nproc.conf)
设置限制数量,第一列表示用户,* 表示所有用户
soft nproc :单个用户可用的最大进程数量(超过会警告);
hard nproc:单个用户可用的最大进程数量(超过会报错);
soft nofile :可打开的文件描述符的最大数(超过会警告);
hard nofile :可打开的文件描述符的最大数(超过会报错);
重启后生效
reboot
查询当前某程序的线程数
pstree -p 进程号 | wc -l
管道符号"|"左边命令的输出作为右边命令的输入
直接修改/etc/security/limits.conf 文件中的 * soft nproc 65535 值后,普通用户最大进程数无法达到65535 ,因为用户的max user processes的值,最后是受全局的kernel.pid_max的值限制。也就是说kernel.pid_max=1024 ,那么你用户的max user processes的值是127426 ,用户能打开的最大进程数还是1024。
永久修改系统最高进程数的方法
在/etc/sysctl.conf中添加kernel.pid_max = 65535
vim /etc/sysctl.conf
kernel.pid_max = 65535
或者:
echo "kernel.pid_max = 65535" >> /etc/sysctl.conf
然后重启机器。
临时修改的方法:
echo 65535 > /proc/sys/kernel/pid_max
所以以上都操作完成后,才算是正确修改了max user processes 的值