
具体查看进程pid可以使用ps -ef|grep 进程名字
下面是ps和kill的简单介绍
Linux中的ps命令是Process Status的缩写。ps命令用来列出系统中当前运行的那些进程。ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要动态的显示进程信息,就可以使用top命令。
要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而 ps 命令就是最基本同时也是非常强大的进程查看命令。使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等。总之大部分信息都是可以通过执行该命令得到的。
ps 为我们提供了进程的一次性的查看,它所提供的查看结果并不动态连续的;如果想对进程时间监控,应该用 top 工具。
kill 命令用于杀死进程。
linux上进程有5种状态:
1. 运行(正在运行或在运行队列中等待)
2. 中断(休眠中, 受阻, 在等待某个条件的形成或接受到信号)
3. 不可中断(收到信号不唤醒和不可运行, 进程必须等待直到有中断发生)
4. 僵死(进程已终止, 但进程描述符存在, 直到父进程调用wait4()系统调用后释放)
5. 停止(进程收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信号后停止运行运行)
ps工具标识进程的5种状态码:
D 不可中断 uninterruptible sleep (usually IO)
R 运行 runnable (on run queue)
S 中断 sleeping
T 停止 traced or stopped
Z 僵死 a defunct (”zombie”) process
1.命令格式:
ps[参数]
2.命令功能:
用来显示当前进程的状态
3.命令参数:
a 显示所有进程
-a 显示同一终端下的所有程序
-A 显示所有进程
c 显示进程的真实名称
-N 反向选择
-e 等于“-A”
e 显示环境变量
f 显示程序间的关系
-H 显示树状结构
r 显示当前终端的进程
T 显示当前终端的所有程序
u 指定用户的所有进程
-au 显示较详细的资讯
-aux 显示所有包含其他使用者的行程
-C 列出指定命令的状况
--lines 每页显示的行数
--width 每页显示的字符数
--help 显示帮助信息
--version 显示版本显示
Linux中的kill命令用来终止指定的进程(terminate a process)的运行,是Linux下进程管理的常用命令。通常,终止一个前台进程可以使用Ctrl+C键,但是,对于一个后台进程就须用kill命令来终止,我们就需要先使用ps/pidof/pstree/top等工具获取进程PID,然后使用kill命令来杀掉该进程。kill命令是通过向进程发送指定的信号来结束相应进程的。在默认情况下,采用编号为15的TERM信号。TERM信号将终止所有不能捕获该信号的进程。对于那些可以捕获该信号的进程就要用编号为9的kill信号,强行“杀掉”该进程。
1.命令格式:
kill[参数][进程号]
2.命令功能:
发送指定的信号到相应进程。不指定型号将发送SIGTERM(15)终止指定进程。如果任无法终止该程序可用“-KILL” 参数,其发送的信号为SIGKILL(9) ,将强制结束进程,使用ps命令或者jobs 命令可以查看进程号。root用户将影响用户的进程,非root用户只能影响自己的进程。
3.命令参数:
-l 信号,若果不加信号的编号参数,则使用“-l”参数会列出全部的信号名称
-a 当处理当前进程时,不限制命令名和进程号的对应关系
-p 指定kill 命令只打印相关进程的进程号,而不发送任何信号
-s 指定发送信号
-u 指定用户
注意:
1、kill命令可以带信号号码选项,也可以不带。如果没有信号号码,kill命令就会发出终止信号(15),这个信号可以被进程捕获,使得进程在退出之前可以清理并释放资源。也可以用kill向进程发送特定的信号。例如:
kill -2 123
它的效果等同于在前台运行PID为123的进程时按下Ctrl+C键。但是,普通用户只能使用不带signal参数的kill命令或最多使用-9信号。
2、kill可以带有进程ID号作为参数。当用kill向这些进程发送信号时,必须是这些进程的主人。如果试图撤销一个没有权限撤销的进程或撤销一个不存在的进程,就会得到一个错误信息。
3、可以向多个进程发信号或终止它们。
4、当kill成功地发送了信号后,shell会在屏幕上显示出进程的终止信息。有时这个信息不会马上显示,只有当按下Enter键使shell的命令提示符再次出现时,才会显示出来。
5、应注意,信号使进程强行终止,这常会带来一些副作用,如数据丢失或者终端无法恢复到正常状态。发送信号时必须小心,只有在万不得已时,才用kill信号(9),因为进程不能首先捕获它。要撤销所有的后台作业,可以输入kill 0。因为有些在后台运行的命令会启动多个进程,跟踪并找到所有要杀掉的进程的PID是件很麻烦的事。这时,使用kill 0来终止所有由当前shell启动的进程,是个有效的方法。
下面是我之前的一些笔记,没来及整理,希望帮到你!所有指令均在我电脑测试通过,根据你自己的实验环境,你可能需要做一些修改!# 挂载(mount)光盘镜像文件、移动硬盘、U盘以及Windows网络共享和UNIX NFS网络共享。
>挂接命令(mount)
命令格式:
mount [-t vfstype] [-o options] device dir
其中:
1.-t vfstype指定`文件系统`的类型,通常不必指定。mount会自动选择正确的类型。常用类型有:
```c
光盘或光盘镜像:iso9660
DOS fat16文件系统:msdos
Windows 9x fat32文件系统:vfat
Windows NT ntfs文件系统:ntfs
Mount Windows文件网络共享:smbfs
UNIX(LINUX)文件网络共享:nfs
```
2.-o options主要用来描述设备或档案的挂接方式。常用的参数有:
```c
loop:用来把一个文件当成硬盘分区挂接上系统
ro:采用只读方式挂接设备
rw:采用读写方式挂接设备
iocharset:指定访问文件系统所用字符集
```
3.device要挂接(mount)的设备。
4.dir设备在系统上的挂接点(mount point)。
挂接光盘镜像文件
在Windows下许多人都习惯把软件和资料做成光盘镜像文件通过虚拟光驱来使用。linux系统下制作和使用光盘镜像比Windows系统更方便,不必借用任何第三方软件包。
1、从光盘制作光盘镜像文件。将光盘放入光驱,执行下面的命令。
`#cp /dev/cdrom /home/sunky/mydisk.iso或`
`#dd if=/dev/cdrom f=/home/sunky/mydisk.iso`
注:执行上面的任何一条命令都可将当前光驱里的光盘`制作`成光盘镜像文件/home/sunky/mydisk.iso
2、将文件和目录`制作`成光盘镜像文件,执行下面的命令。
`mkisofs -r -J -V mydisk -o /home/sunky/mydisk.iso /home/sunky/ mydir`
注:这条命令将/home/sunky/mydir目录下所有的目录和文件制作成光盘镜像文件/home/sunky/mydisk.iso,光盘卷标为:mydisk
3、光盘镜像文件的挂接(mount)
注:建立一个目录用来作挂接点(mount point)
`#mkdir /mnt/vcdrom`
注:使用/mnt/vcdrom就可以访问盘镜像文件mydisk.iso里的所有文件了。
挂接移动硬盘
`#mount -o loop -t iso9660 /home/sunky/mydisk.iso /mnt/vcdrom`
sudo mount -o loop -t iso9660 /home/lking/system/elementaryos.iso /mnt/iso
卸载:`sudo umount -t iso9660 /mnt/iso`
对linux系统而言,`USB接口`的移动硬盘是当作SCSI设备对待的。插入移动硬盘之前,应先用fdisk–l或more /proc/partitions`查看系统的硬盘和硬盘分区情况`。
[root at pldyrouter /]# `fdisk -l`
在这里可以清楚地看到系统有一块SCSI硬盘/dev/sda和它的四个磁盘分区/dev/sda1 -- /dev/sda4, /dev/sda5是分区/dev/sda4的逻辑分区。接好移动硬盘后,再用fdisk–l或more /proc/partitions查看系统的硬盘和硬盘分区情况
[root at pldyrouter /]# fdisk -l
大家应该可以发现多了一个`SCSI`硬盘/dev/sdc和它的两个磁盘分区`/dev/sdc1`?、/dev/sdc2,其中/dev/sdc5是/dev/sdc2分区的逻辑分区。我们可以使用下面的命令挂接/dev/sdc1和/dev/sdc5。
注:建立目录用来作挂接点(mount point)
`#mkdir -p /mnt/usbhd1`
`#mkdir -p /mnt/usbhd2`
注:对ntfs格式的磁盘分区应使用-t ntfs参数,对`fat32格式的磁盘分区应使用-t vfat参数`。
`#mount -t ntfs /dev/sdc1 /mnt/usbhd1`
`#mount -t vfat /dev/sdc5 /mnt/usbhd2`
若汉字文件名显示为乱码或不显示,可以使用下面的命令格式。
`#mount -t ntfs -o iocharset=cp936 /dev/sdc1 /mnt/usbhd1`
`#mount -t vfat -o iocharset=cp936 /dev/sdc5 /mnt/usbhd2`
linux系统下使用fdisk分区命令和mkfs文件系统创建命令可以将移动硬盘的分区制作成linux系统所特有的ext2、ext3格式。这样,在linux下使用就更方便了。使用下面的命令直接挂接即可。
#mount /dev/sdc1 /mnt/usbhd1
# 挂接U盘
和USB接口的移动硬盘一样对linux系统而言U盘也是当作SCSI设备对待的。使用方法和移动硬盘完全一样。插入U盘之前,应先用fdisk–l或more /proc/partitions查看系统的硬盘和硬盘分区情况。
[root at pldyrouter root]# `fdisk -l`
插入U盘后,再用fdisk–l或more /proc/partitions查看系统的硬盘和硬盘分区情况。
[root at pldyrouter root]# `fdisk -l`
系统多了一个SCSI硬盘`/dev/sdd`和一个磁盘分区`/dev/sdd1`,/dev/sdd1就是我们要挂接的U盘。
注:建立一个目录用来作挂接点(mount point)
`#mkdir -p /mnt/usb`
`#mount -t vfat /dev/sdd1 /mnt/usb`
卸载:`umount -t vfat /dev/sdb4 `
注:现在可以通过/mnt/usb来访问U盘了,若汉字文件名显示为乱码或不显示,可以使用下面的命令。
`#mount -t vfat -o iocharset=cp936 /dev/sdd1 /mnt/usb`
挂接Windows文件共享
Windows网络共享的核心是SMB/CIFS,在linux下要挂接(mount)windows的磁盘共享,就必须安装和使用samba软件包。现在流行的linux发行版绝大多数已经包含了samba软件包,如果安装linux系统时未安装samba请首先安装samba。当然也可以到
当windows系统共享设置好以后,就可以在linux客户端挂接(mount)了,具体 *** 作如下:
注:建立一个目录用来作挂接点(mount point)
`# mkdir–p /mnt/samba`
`# mount -t smbfs -o username=administrator,password=pldy123 //10.140.133.23/c$ /mnt/samba`
注:administrator和pldy123是ip地址为10.140.133.23 windows计算机的一个用户名和密码,c$是这台计算机的一个磁盘共享
如此就可以在linux系统上通过/mnt/samba来访问windows系统磁盘上的文件了。以上 *** 作在redhat asserver3、redflag server 4.1、suse server 9以及windows NT 4.0、windows 2000、windows xp、windows 2003环境下测试通过。
挂接UNIX系统NFS文件共享
类似于windows的网络共享,UNIX(Linux)系统也有自己的网络共享,那就是NFS(网络文件系统),下面我们就以SUN Solaris2.8和REDHAT as server 3为例简单介绍一下在linux下如何mount nfs网络共享。
在linux客户端挂接(mount)NFS磁盘共享之前,必须先配置好NFS服务端。
1、Solaris系统NFS服务端配置方法如下:
(1)修改/etc/dfs/dfstab,增加共享目录
share -F nfs -o rw /export/home/sunky
(2)启动nfs服务
`# /etc/init.d/nfs.server start`
(3)NFS服务启动以后,也可以使用下面的命令增加新的共享
`share /export/home/sunky1`
`share /export/home/sunky2`
注:/export/home/sunky和/export/home/sunky1是准备共享的目录
2、linux系统NFS服务端配置方法如下:
(1)修改/etc/exports,增加共享目录
/export/home/sunky 10.140.133.23(rw)
/export/home/sunky1 *(rw)
/export/home/sunky2 linux-client(rw)
注:/export/home/目录下的sunky、sunky1、sunky2是准备共享的目录,10.140.133.23、*、linux- client是被允许挂接此共享linux客户机的IP地址或主机名。如果要使用主机名linux-client必须在服务端主机/etc/hosts文件里增加linux-client主机ip定义。格式如下:10.140.133.23 linux-client
(2)启动与停止NFS服务
/etc/rc.d/init.d/portmap start (在REDHAT中PORTMAP是默认启动的)
/etc/rc.d/init.d/nfs start启动NFS服务
/etc/rc.d/init.d/nfs stop停止NFS服务
注:若修改/etc/export文件增加新的共享,应先停止NFS服务,再启动NFS服务方能使新增加的共享起作用。使用命令exportfs -rv也可以达到同样的效果。
3、linux客户端挂接(mount)其他linux系统或UNIX系统的NFS共享
`mkdir–p /mnt/nfs`
注:建立一个目录用来作挂接点(mount point)
`#mount -t nfs -o rw 10.140.133.9:/export/home/sunky /mnt/nfs`
注:这里我们假设10.140.133.9是NFS服务端的主机IP地址,当然这里也可以使用主机名,但必须在本机/etc/hosts文件里增加服务端ip定义。/export/home/sunky为服务端共享的目录。
如此就可以在linux客户端通过/mnt/nfs来访问其它linux系统或UNIX系统以NFS方式共享出来的文件了。以上 *** 作在redhat as server 3、redflag server4.1、suse server 9以及Solaris 7、Solaris 8、Solaris 9 for x86&sparc环境下测试通过。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)