如何使用Tasklist/Taskkill命令
2007-08-15 15:26
一. Tasklist命令用来显示运行在本地或远程计算机上的所有进程,带有多个执行参数。
使用格式 Tasklist [/S system [/U username [/P [password]]]] [/M [module] | /SVC | /V] [/FI filter] [/FO format] [/NH]
参数含义 /S system 指定连接到的远程系统。
/U [domain\]user 指定使用哪个用户执行这个命令。
/P [password] 为指定的用户指定密码。
/M [module] 列出调用指定的DLL模块的所有进程。如果没有指定模块名,显示每个进程加载的所有模块。
/SVC 显示每个进程中的服务。
/V 显示详细信息。
/FI filter 显示一系列符合筛选器指定的进程。
/FO format 指定输出格式,有效值:TABLE、LIST、CSV。
/NH 指定输出中不显示栏目标题。只对TABLE和CSV格式有效。
应用实例:
1.查看本机进程 在“命令提示符”中输入Tasklist命令即可显示本机的所有进程(图1)。本机的显示结果由5部分组成:图像名(进程名)、PID、会话名、会话#和内存使用。
2.查看远程系统的进程 在命令提示符下输入“Tasklist /s 218.22.123.26 /u jtdd /p 12345678”(不包括引号)即可查看到IP地址为218.22.123.26的远程系统的进程(图2)。其中/s参数后的“218.22.123.26”指要查看的远程系统的IP地址,/u后的“jtdd”指Tasklist命令使用的用户账号,它必须是远程系统上的一个合法账号,/p后的“12345678”指jtdd账号的密码。 注意:使用Tasklist命令查看远程系统的进程时,需要远程机器的RPC服务的支持,否则,该命令不能正常使用。
3.查看系统进程提供的服务 Tasklist命令不但可以查看系统进程,而且还可以查看每个进程提供的服务。如查看本机进程SVCHOST.EXE提供的服务,在命令提示符下输入“Tasklist /svc”命令即可(图3)。你会惊奇地发现,有4个SVCHOST.EXE进程,而总共有二十几项服务使用这个进程。 对于远程系统来说,查看系统服务也很简单,使用“Tasklist /s 218.22.123.26 /u jtdd /p 12345678 /svc”命令,就可以查看IP地址为218.22.123.26的远程系统进程所提供的服务。
4.查看调用DLL模块文件的进程列表 要查看本地系统中哪些进程调用了shell32.dll模块文件,只需在命令提示符下输入“Tasklist /m shell32.dll”即可显示这些进程的列表。
5.使用筛选器查找指定的进程 在命令提示符下输入“TASKLIST /FI "USERNAME ne NT AUTHORITY\SYSTEM" /FI "STATUS eq running”,就可以列出系统中正在运行的非SYSTEM状态的所有进程。其中“/FI”为筛选器参数,“ne”和“eq”为关系运算符“不相等”和“相等”。
谈到“Tasklist”命令,我们就不得不提到它的孪生兄弟“Taskkill”命令,顾名思义,它是用来关掉进程的。 要关掉本机的notepad.exe进程,有两种方法: 1.先使用Tasklist查找它的PID,假设系统显示本机notepad.exe进程的PID值为1132,然后运行“Taskkill /pid 1132”命令即可。其中“/pid”参数后面是要终止进程的PID值。 2.直接运行“Taskkill /IM notepad.exe”命令,其中“/IM”参数后面为进程的图像名
二. 使用“Tasklist”命令查看本机进程 在命令提示符窗口中输入:tasklist,就显示本机的所有进程。显示结果由五部分组成:图像名(进程名)、PID、会话名、会话#、内存使用。 查看远程系统的进程 在命令提示符下输入:tasklist /s IP /u username /p password 其中/s参数后的 IP 指要查看的远程系统的IP地址,/u后的 username 指 tasklist 命令使用的用户帐号,它是远程系统上的一个合法帐号,/p后的“password”指username帐号的密码。通过上面的命令,我们就可以查看到远程系统的进程了。 提示:使用tasklist命令查看远程系统的进程时,需要远程机器的RPC 服务器
的支持,否则,该命令就不能正常使用。 查看系统进程提供的服务 tasklist命令不但可以查看系统进程,而且还可以查看每个进程提供的服务。 如查看本机的进程“SVCHOST.EXE”提供的服务,在命令提示符下输入:tasklist /svc,发现有四个“SVCHOST.EXE”进程,有二十几项服务使用这个进程;对于远程系统来说,查看系统服务使用 tasklist /s IP /u username /p password /svc就可以查看IP地址为“IP”的远程系统进程所提供的服务。
查看调用DLL模块文件的进程列表 在命令提示符下输入: tasklist /m shell32.dll可以查看本地系统中哪些进程调用了shell32.dll DLL模块文件,这时系统将显示调用进程列表。 使用筛选器查找指定的进程 在命令提示符下输入:TASKLIST /FI "USERNAME ne NT AUTHORITY\SYSTEM" /FI "STATUS eq running",这样就列出了系统中正在运行的非“SYSTEM“状态的所有进程,其中“/FI“为筛选器参数,” ne“和”eq“为关系运算符”不相等“和”相等“。
taskkill命令,顾名思义,它是用来杀死进程的。如要杀死本机的“notepad.exe”进程,首先使用Tasklist查找它的PID,系统显示“notepad.exe”进程的PID值为“1132“,然后输入taskkill /pid 1132或者输入 taskkill /IM notepad.exe即可,其中“ /pid ”后面跟要终止进程的PID值,“/IM”后面为进程的图像名。 字串8
如果用上面的方法仍然结束不了,那么就试试下面的这个杀手锏吧!用ntsd命令 ntsd -c q -p PID 把最后那个PID,改成你要终止的进程的ID。如果你不知道进程的ID,可以通过以下方法查看:任务管理器-—>进程选项卡-—>查看-—>选择列-—>勾上"PID(进程标识符)",同样也可以使用tasklist查看。更多的使用方法可以在命令提示符状态下输入ntsd /?查看。 使用ntsd命令除了不能杀掉System、SMSS.EXE 和 CSRSS.EXE进程外,其他的都可以结束掉。前两个进程是纯内核态的,最后那个是Win32子系统,ntsd本身需要它。ntsd从WIN 2K开始就是系统自带的用户态调试工具,被调试器附着(attach)的进程会随调试器一起退出,所以可以用来在命令行下终止进程。使用ntsd自动就获得了debug权限,从而能杀掉大部分的进程。ntsd会新开一个调试窗口,本来在纯命令行下无法控制,但如果只是简单的命令(退出(q)),用-c参数从命令行传递就行了。
ntsd命令使用说明
2007-11-20 17:40:04
些不良程序和流氓软件也热忠于占据进程这块宝地。当遇到这种进程时,你就想通过任务管理器结束它们,但有时间你会遇到用任务管理器关不了的进程,这里告诉你一个简单、方便而有效的方法:
选择“开始”——“运行”,输入“cmd”打开DOS窗口,输入:
ntsd -c q -p PID
说明:PID,在这里改成你需要终止进程的ID号。
ntsd从2000开始就是系统自带的用户态调试工具。被调试器附着(attach)的进程会随调试器一起退出,所以可以用来在命令行下终止进程。使用ntsd自动就获得了debug权限,从而能杀掉大部分的进程。ntsd会新开一个调试窗口,本来在纯命令行下无法控制,但如果只是简单的命
令,比如退出(q),用-c参数从命令行传递就行了。
使用ntsd这个命令,可以结束系统大部分进程,只有System、SMSS.EXE和CSRSS.EXE不能杀,前两个是纯内核态的,最后那个是Win32
子系统,ntsd本身需要它。
进程的ID号如何获得?
打开任务管理器,在菜单栏,选择“查看”—“选择列”,在打开的选择项窗口中将“PID(进程标识符)”项选择钩上,这样任务管理器的进程中就会多出PID一项了。
没有菜单栏和标签栏了怎么办?
你有没有遇到过任务管理器窗口只有一个内容框架,没有菜单栏和标签栏的情况。
这只是系统为我们提供的另一种简洁显示方式,在任务管理器的灰色空白处双击操作所致,请在灰色空白处再次双击,就立刻恢复正常。
|