• linux windows杀进程


    LINUX 杀杀杀:

    改进1:

    把ps的查询结果通过管道给grep查找包含特定字符串的进程。管道符“|”用来隔开两个命令,管道符左边命令的输出会作为管道符右边命令的输入。

    $ ps -ef | grep firefox 
    
    1827     1  4 11:38 ?        00:27:33 /usr/lib/firefox-3.6.18/firefox-bin smx      
    12029 1824 0 21:54 pts/0 00:00:00 grep --color=auto firefox $kill -s 9 1827

    改进2——使用pgrep:

    一看到pgrep首先会想到什么?没错,grep!pgrep的p表明了这个命令是专门用于进程查询的grep。

    $ pgrep firefox 1827
    
    $kill -s 9 1827

    改进3——使用pidof:

    看到pidof想到啥?没错pid of xx,字面翻译过来就是 xx的PID。

    $ pidof firefox-bin 1827
    
    $kill -s 9 1827

    说明:

    和pgrep相比稍显不足的是,pidof必须给出进程的全名。然后就是老生常谈:

    无论使用ps 然后慢慢查找进程PID 还是用grep查找包含相应字符串的进程,亦或者用pgrep直接查找包含相应字符串的进程PID,然后手动输入给kill杀掉,都稍显麻烦。有没有更方便的方法?有!

     

    改进4:

    $ps -ef | grep firefox | grep -v grep | cut -c 9-15 | xargs kill -s 9

    说明:

    “grep firefox”的输出结果是,所有含有关键字“firefox”的进程。

    “grep -v grep”是在列出的进程中去除含有关键字“grep”的进程。

    “cut -c 9-15”是截取输入行的第9个字符到第15个字符,而这正好是进程号PID。

    “xargs kill -s 9”中的xargs命令是用来把前面命令的输出结果(PID)作为“kill -s 9”命令的参数,并执行该命令。“kill -s 9”会强行杀掉指定进程。

    难道你不想抱怨点什么?没错太长了

    改进5:

    知道pgrep和pidof两个命令,干嘛还要打那么长一串!

    $ pgrep firefox | xargs kill -s 9

    改进6:

    $ ps -ef | grep firefox | awk '{print $2}' | xargs kill -9 kill: No such process

    有一个比较郁闷的地方,进程已经正确找到并且终止了,但是执行完却提示找不到进程。

    其中awk '{print $2}' 的作用就是打印(print)出第二列的内容。根据常规篇,可以知道ps输出的第二列正好是PID。就把进程相应的PID通过xargs传递给kill作参数,杀掉对应的进程。

    改进7:

    难道每次都要调用xargs把PID传递给kill?答案是否定的:

    $kill -s 9 `ps -aux | grep firefox | awk '{print $2}'`

    改进8:

    没错,命令依然有点长,换成pgrep。

    $kill -s 9 `pgrep firefox`

    改进9——pkill:

    看到pkill想到了什么?没错pgrep和kill!pkill=pgrep+kill。

    $pkill - firefox

    说明:"-9" 即发送的信号是9,pkill与kill在这点的差别是:pkill无须 “s”,终止信号等级直接跟在 “-“ 后面。之前我一直以为是 "-s 9",结果每次运行都无法终止进程。

    改进10——killall:

    killall和pkill是相似的,不过如果给出的进程名不完整,killall会报错。pkill或者pgrep只要给出进程名的一部分就可以终止进程。

    $killall -9 firefox

    ========================================================================================================================== 

    ==========================================================================================================================

    windows杀杀杀:

    1.进程cmd窗口:
    2.查看端口占用:
    netstat -aon | findstr "19000"
    结果:
     TCP    0.0.0.0:19000          0.0.0.0:0              LISTENING       2888
     TCP    [::]:19000             [::]:0                 LISTENING       2888
     TCP    [::1]:19000            [::1]:58746            TIME_WAIT       0
     TCP    [::1]:19000            [::1]:58833            TIME_WAIT       0
    可知是由进程号为 2888 的进程占用了 19000 的端口;

    3.根据进程号查看进程:
    tasklist | findstr "2888"
    结果:
    Apache.exe                    2888 Services                   0     21,780 K
    可知此进程是 Apache.exe

    4.杀死进程:
    可以通过任务管理器 杀进程;
    也可用代码:
    taskkill -pid 1688 -F
    结果:
    成功: 已终止 PID 为 2888 的进程。

  • 相关阅读:
    VC获取系统时间、程序运行时间
    数学题
    最小费用流
    最大流模板
    计划
    算法竞赛入门经典 训练指南 之 图论(完全版持续更新)
    uva 11324 The Largest Clique 强连通分量求缩点构造DAG
    hdu 4288 Coder 一个很水的版本 >_<
    hoj 2939 Coin Question
    成都网络赛 1002 Control 1005 Food
  • 原文地址:https://www.cnblogs.com/appledady/p/9323744.html
Copyright © 2020-2023  润新知