Linux系统中的ps进程查看命令使用实例集锦

   linux 中ps命令是Process Status的缩写。ps命令可以列出系统中当前运行的进程,所列出的进程是执行ps命令这个时刻正在运行的进程。

  如果要动态显示进程信息,需要使用top命令。

  通过ps命令,可以确定哪些进程正在运行和运行状态、进程是否结束、进程是否僵死,哪些进程占用过多资源等。

  要杀死进程,使用kill命令,例:kill 12345 (12345为进程的pid)

  linux进程有5种状态

  1.运行(正在运行或在运行队列中等待)

  2.中断(休眠中,受阻,或等待某个条件的形成或接受到信号)

  3.不可中断(收到信号不唤醒和不可运行,进程必须等待直到有中断发生)

  4.僵死(进程已终止,但进程描述符存在,直到父进程调用wait4()系统调用后释放)

  5.停止(进程受到SIGSTOP,SIGSTP,SIGTIN,SIGTOU信号后停止运行)

  ps 5种进程状态的标识码如下:

  R 运行 runnable(on run queue)

  S 中断 sleeping

  D 不可中断 uninterruptible sleep (usually IO)

  Z 僵死 a defunct("zombie") process

  T 停止 traced or stopped

  命令参数

  a 显示所有进程

  -a 显示同一终端下的所有程序

  -A 显示所有进程

  c 显示进程的真实名称

  -N 反向选择

  -e 等于“-A”

  e 显示环境变量

  f 显示程序间的关系

  -H 显示树状结构

  r 显示当前终端的进程

  T 显示当前终端的所有程序

  u 指定用户的所有进程

  -au 显示较详细的资讯

  -aux 显示所有包含其他使用者的进程

  -C<命令> 列出指定命令的状况

  –lines<行数> 每页显示的行数

  –width<字符数> 每页显示的字符数

  –help 显示帮助信息

  –version 显示版本显示

  输出列的含义

  F 代表这个程序的旗标 (flag), 4 代表使用者为 super user

  S 代表这个程序的状态 (STAT),关于各 STAT 的意义将在内文介绍

  UID 程序被该 UID 所拥有

  PID 进程的ID

  PPID 则是其上级父程序的ID

  C CPU 使用的资源百分比

  PRI 这个是 Priority (优先执行序) 的缩写,详细后面介绍

  NI 这个是 Nice 值,在下一小节我们会持续介绍

  ADDR 这个是 kernel function,指出该程序在内存的那个部分。如果是个 running的程序,一般就是 “-“

  SZ 使用掉的内存大小

  WCHAN 目前这个程序是否正在运作当中,若为 - 表示正在运作

  TTY 登入者的终端机位置

  TIME 使用掉的 CPU 时间。

  CMD 所下达的指令

  例子:

  1.显示所有进程信息

  代码如下:

  fdipzone@ubuntu:~$ ps -A

  PID TTY TIME CMD

  1 ? 00:00:01 init

  2 ? 00:00:00 kthreadd

  3 ? 00:00:00 ksoftirqd/0

  4 ? 00:00:00 kworker/0:0

  5 ? 00:00:00 kworker/u:0

  6 ? 00:00:00 migration/0

  7 ? 00:00:00 migration/1

  8 ? 00:00:00 kworker/1:0

  9 ? 00:00:00 ksoftirqd/1

  10 ? 00:00:00 kworker/0:1

  ...省略部分结果

  2.显示指定用户进程

  代码如下:

  fdipzone@ubuntu:~$ ps -u fdipzone

  PID TTY TIME CMD

  1502 ? 00:00:00 gnome-keyring-d

  1521 ? 00:00:00 gnome-session

  1551 ? 00:00:00 ibus-daemon

  1555 ? 00:00:00 ssh-agent

  1558 ? 00:00:00 dbus-launch

  1559 ? 00:00:00 ibus-gconf

  1561 ? 00:00:00 python

  1563 ? 00:00:00 dbus-daemon

  1564 ? 00:00:00 ibus-x11

  1569 ? 00:00:00 gconfd-2

  ...省略部分结果

  3.显示所有进程,并显示命令行

  代码如下:

  fdipzone@ubuntu:~$ ps -ef

  UID PID PPID C STIME TTY TIME CMD

  root 1 0 0 22:53 ? 00:00:01 /sbin/init

  root 2 0 0 22:53 ? 00:00:00 [kthreadd]

  root 3 2 0 22:53 ? 00:00:00 [ksoftirqd/0]

  root 4 2 0 22:53 ? 00:00:00 [kworker/0:0]

  root 5 2 0 22:53 ? 00:00:00 [kworker/u:0]

  root 6 2 0 22:53 ? 00:00:00 [migration/0]

  root 7 2 0 22:53 ? 00:00:00 [migration/1]

  root 8 2 0 22:53 ? 00:00:00 [kworker/1:0]

  root 9 2 0 22:53 ? 00:00:00 [ksoftirqd/1]

  root 10 2 0 22:53 ? 00:00:00 [kworker/0:1]

  ...省略部分结果

  4.与grep命令组合使用,查找指定的进程

  代码如下:

  fdipzone@ubuntu:~$ ps -ef | grep apache

  root 2032 1 0 22:56 ? 00:00:01 /usr/sbin/apache2 -k start

  www-data 2318 2032 0 22:58 ? 00:00:00 /usr/sbin/apache2 -k start

  www-data 2319 2032 0 22:58 ? 00:00:00 /usr/sbin/apache2 -k start

  www-data 2320 2032 0 22:58 ? 00:00:00 /usr/sbin/apache2 -k start

  www-data 2321 2032 0 22:58 ? 00:00:00 /usr/sbin/apache2 -k start

  www-data 2322 2032 0 22:58 ? 00:00:00 /usr/sbin/apache2 -k start

  www-data 2323 2032 0 22:58 ? 00:00:00 /usr/sbin/apache2 -k start

  ...省略部分结果

  5.显示当前登入用户的bash相关的进程

  代码如下:

  fdipzone@ubuntu:~$ ps -l

  F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD

  0 S 1000 1805 1798 0 80 0 - 7011 wait pts/0 00:00:00 bash

  0 R 1000 2561 1805 0 80 0 - 3377 - pts/0 00:00:00 ps

  6.列出所有用户启动的进程

  代码如下:

  [fdipzone@ubuntu:~$ ps aux

  USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND

  root 1 0.1 0.2 24136 2188 ? Ss 22:53 0:01 /sbin/init

  root 2 0.0 0.0 0 0 ? S 22:53 0:00 [kthreadd]

  root 3 0.0 0.0 0 0 ? S 22:53 0:00 [ksoftirqd/0]

  root 5 0.0 0.0 0 0 ? S 22:53 0:00 [kworker/u:0]

  root 6 0.0 0.0 0 0 ? S 22:53 0:00 [migration/0]

  root 7 0.0 0.0 0 0 ? S 22:53 0:00 [migration/1]

  root 8 0.0 0.0 0 0 ? S 22:53 0:00 [kworker/1:0]

  root 9 0.0 0.0 0 0 ? S 22:53 0:00 [ksoftirqd/1]

  root 10 0.0 0.0 0 0 ? S 22:53 0:00 [kworker/0:1]

  root 11 0.0 0.0 0 0 ? S< 22:53 0:00 [cpuset]

  root 12 0.0 0.0 0 0 ? S< 22:53 0:00 [khelper]

  ...省略部分结果

  另外:

  a:显示其他用户启动的进程

  x:查看系统中属于自己的进程

  u:启动这个进程的用户和启动时间

时间: 2024-11-02 14:29:22

Linux系统中的ps进程查看命令使用实例集锦的相关文章

详解Linux系统中的守护进程

守护进程daemon,是生存期较长的一种进程.它们常常在系统自举时启动,仅在系统关闭时才终止.因为它们没有控制终端,所以说它们是在后台运行的.UNIX系统有很多守护进程,它们执行日常事务活动. 1.系统自举 自举(bootstrapping)一词来自于人都是靠自身的"自举"机构站立起来的这一思想.计算机必须具备自举能力将自己所有的元件激活,以便能完成加载操作系统这一目的,然后再由操作系统承担起那些单靠自举代码无法完成的更复杂的任务. 自举只有两个功能:加电自检和磁盘引导. 加电自检:当

Linux系统中下载文件的wget命令行工具

简介 Linux系统中的wget是一个下载文件的命令行工具. 对于Linux用户是必不可少的工具,对于经常要下载一些软件或从远程服务器恢复备份到本地服务器,这个命令尤为重要.wget支持HTTP,HTTPS和FTP协议,可以使用HTTP代理. 自动下载 wget支持自动下载,即wget可以在用户退出系统的之后在后台执行.这意味这你可以登录系统,启动一个wget下载任务,然后退出系统,wget将在后台执行直到任务完成,这是个牛气冲天的功能. 完全重建 wget 可以跟踪HTML页面上的链接依次下载

linux系统中Nginx守护进程(自动启动nginx)

最近VPS的Nginx不知道为啥,会无缘无故关掉.可能是负载过高被母鸡Kill了.但是为了保持网站在线,写了个守护进程:  代码如下 复制代码 aa=`pgrep -f nginx | wc -l` if [ "$aa" = 0 ] then /usr/local/nginx/sbin/nginx /usr/local/php/sbin/php-fpm start else echo "the program is running" fi 把以上脚本写成一个.sh文

linux系统中使用adduser与useradd命令批量添加用户

adduser - 添加用户账号,与useradd是同一命令.需要root权限才能执行(有root权限). 在使用adduser命令时,它会添加这个名,并创建和用户名名称相同的组名,并把这个用户名添加到自己的组里去,并在/home目录想创建和用户名同名的目录,并拷贝/etc/skel目录下的内容到/home/用户名/的目录下,并提示输入密码,并提示填写相关这个用户名的信息. 在使用命令useradd时,它会添加这个用户名,并创建和用户名相同的组名,但它并不在/home目录下创建基于用户名的目录,

Linux系统中使用cmp和comm命令来比较两个文件

  cmp cmp 命令:比较任意两个类型的文件,且吧结果输出到标准输出,默认文件相同不输出,不同的文件输出差异 必要参数 -c 显示不同的信息 -l 列出所有的不同信息 -s 错误信息不提示 选择参数 -i<字符数> 指定字符数目 -v 显示版本信息 --help 显示帮助信息 [函数的返回值] 0 :文件时同样的 1 :文件是不同的 >1:发生错误 例: 代码如下: [root@localhost www]# cmp test1.rb test.rb #比较二个文件的不同 test1

在Linux系统中安装和使用apt-file命令

  刚才安装Spynner模块,使用的是easy_install spynner安装,各种文件缺失啊,无意中发现apt-file命令,从此再也不用担心编译软件缺少某个文件而不知所措了. 1.首先得安装apt-file命令 代码如下: apt-get install apt-file 2.接着更新apt-file的缓存 代码如下: apt-file update 3.现在你可以使用apt-file搜索缺失的文件了,比如编译过程中提示缺少 代码如下: root@test:~# apt-file se

linux系统中清理大文件的命令

查找大文件 find /dir -size +100M -exec ls -lh {} ; 如果要清空一些文本文件类的东西,可以使用 echo "" > /www/xxx.log 如果想直接删除大于50M的文件,使用命令 find /var/mail/ -size +50M -exec rm {} ; 如果想排序文件夹和文件,可以使用 du -s * | sort -nr | head

Linux系统中10个最危险的命令详解

我们大多数的朋友都是一辈子都用的windows系统,基本用鼠标就可以完成所有的操作,但是在Linux系统中那么基本上就是键盘+命令操作电脑的,Linux命令行佷有用.很高效,也很有趣,但有时候也很危险,尤其是在你不确定你自己在正在做什么时候.这篇文章并不打算引来你对Linux或linux 命令行的愤怒,只是想让你意识到在你运行某些命令时应该三思而后行.(译注:当然,以下命令通常都是在root权限下才能将愚蠢发挥到无可救药;在普通用户身份下,破坏的只是自己的一亩三分地.) 1. rm -rf 命令

Linux系统中10个最危险的命令

  我们大多数的朋友都是一辈子都用的windows系统,基本用鼠标就可以完成所有的操作,但是在Linux系统中那么基本上就是键盘+命令操作电脑的,Linux命令行佷有用.很高效,也很有趣,但有时候也很危险,尤其是在你不确定你自己在正在做什么时候.这篇文章并不打算引来你对Linux或linux 命令行的愤怒,只是想让你意识到在你运行某些命令时应该三思而后行.(译注:当然,以下命令通常都是在root权限下才能将愚蠢发挥到无可救药;在普通用户身份下,破坏的只是自己的一亩三分地.) 1. rm -rf