linux作业管理

作业管理

kill

kill命令:
    向进程发送控制信号,以实现对进程管理
    显示当前系统可用信号:kill -l
    常用信号:man 7 signal
        1) SIGHUP: 无须关闭进程而让其重读配置文件
        2) SIGINT: 中止正在运行的进程;相当于Ctrl+c
        9) SIGKILL: 杀死正在运行的进程
        15) SIGTERM:终止正在运行的进程
        18) SIGCONT:  相当于使用 bg PID 将其激活。
        19) SIGSTOP: ctrl+z
    指定信号的方法:
        (1) 信号的数字标识;1, 2, 9
        (2) 信号完整名称;SIGHUP
        (3) 信号的简写名称;HUP

kill
按PID:kill [-SIGNAL] pid…
对指定进程操作发送信号

killall
按名称:killall[-SIGNAL] comm…
对一类进程进行操作发送信号
killall -9 ping 杀死所有的ping进程

pkill
按模式:pkill[options] pattern
-SIGNAL
-u uid: effective user,生效者
-U uid: real user,真正发起运行命令者
-t terminal: 与指定终端相关的进程
-l: 显示进程名
-a: 显示完整格式的进程名
-P pid: 显示父进程为此处指定的进程的进程列表

    可以针对进程的属性关闭一类程序

信号也是可以捕捉的,但是15号信号是不能捕捉的。脚本编程可以使用

kill名称是杀死,实际上是用户通过它像指定进程发送信号(进程间通信的一种方式)。
只是发送信号


Linux的作业控制
前台作业:通过终端启动,且启动后一直占据终端;
后台作业:可通过终端启动,但启动后即转入后台运行(释放终端)
如何让作业运行于后台?
(1) 运行中的作业:Ctrl+z
(2) 尚未启动的作业:# COMMAND &

例:
使用ping命令,ping一个地址,屏幕就会被ping命令占用,不能做任何事。
是用ctrl+z键可以将ping命令送到后台执行,使用该方式送到后台后,ping会停止运行处于stopped状态,使用kill名 kill -18 PID(ping) 可以将ping唤醒 。但是ping的命令输出结果还是会输出到标准输出上。
屏幕上会有ping的结果,但是不影响执行命令,可以输入命令并执行,但是屏幕上输出结果看着比较乱。
使用ctrl+c不能关闭ping了。

[root@yangyouwei ~]# jobs
[1]+  Stopped                 ping 127.0.0.1
[root@yangyouwei ~]# kill -18 38885 
当然也可以使用kill 将其关闭
也可以使用jobs查看其作业号,使用fg JOB_NUM 将其调到前台来。在使用ctrl+c终止

相当于 kill -19 PID
    [root@yangyouwei ~]#ping 127.0.0.1 ##开启一个ping进程
    [root@yangyouwei ~]# pgrep ping  查询ping的PID
    38975
    [root@yangyouwei ~]# kill -19 38975     ##发送19信号使其调入后台处于停止状态。(stopped)
    [3]+  Stopped                 ping 127.0.0.2
    [root@yangyouwei ~]# 

放入后台后又可能是休眠有可能是继续运行。ping使用&放入后台后是可以继续运行,但是例如vim放入后台就是stopped(因为vim是交互式命令)

nohup

此类后台作业虽然被送往后台运行,但其依然与终端相关;退出终端,将关闭后台作业。如果希望送往后台后,剥离与终端的关系:
# nohup COMMAND &  

nohup ping 127.0.0.1 &
送到后台后,关闭终端,ping进程也不会关闭。init进程接管。但是使用jobs看不到了

查看所有作业:

# jobs

作业控制:

# fg [[%]JOB_NUM]:把指定的后台作业调回前台;
    front ground 

# bg [[%]JOB_NUM]:让送往后台的作业在后台继续运行;
    back ground

将后台的进程(stopped状态)激活,使其在后台继续运行。
相当于kill -18 PID

    [root@yangyouwei ~]# jobs
    [1]+  Stopped                 ping 127.0.0.1
    [root@yangyouwei ~]# bg 1
    [root@yangyouwei ~]# jobs
    [1]+  running                 ping 127.0.0.1


# kill [%JOB_NUM]:终止指定的作业;

fg、bg、kill使用时。kill要针对jobs操作,必须使用%号, 否者操作的是对应号码的PID 进程
kill %job_NUM

并行运行

vi f4.sh ###通过脚本调用,同时执行123脚本

    F1.sh&
    F2.sh&
    F3.sh&

注:如果将将三个脚本的代码放入一个脚本中,执行顺序是执行完f1段代码再执行f2段代码…

((f1.sh&);(f2.sh&);(f3.sh&)) ##每个命令或脚本开启一个shell后执行。

{ f1.sh& f2.sh& f3.sh& }  ##在当前shell下同时运行三个命令或脚本

进程优先级

进程优先级调整:
    静态优先级:100-139
    进程默认启动时的nice值为0,优先级为12
    只有根用户才能降低nice值(提高优先性)

nice命令:
    nice [OPTION] [COMMAND [ARG]...] 
    使用-n 因为优先级有正数和负数,使用-n更容易看清楚

renice命令:  ##修改已经运行的进程的优先级

    renice [-n] priority pid...
    使用-n 因为优先级有正数和负数,使用-n更容易看清楚

查看:
    ps axo pid,comm,ni

注:普通用户只能把进程的优先级调低。

原创文章,作者:yyw,如若转载,请注明出处:http://www.178linux.com/44964

(0)
yywyyw
上一篇 2016-09-09
下一篇 2016-09-09

相关推荐

  • Linux软件包管理之rpm和yum的使用

    rpm命令的使用 什么是RPM? rpm:RPM Package Manager (原Redhat Package Manager) Linux 软件包管理工具 特定的程序由应用程序组成;     GPL:源码     glibs:标准的C库 常见Linux发行版的软件包管理器:…

    Linux干货 2016-08-25
  • 第四周博客作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 2、编辑/etc/group文件,添加组hadoop。 3、手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号;其家目录为/home/hadoop。 4、复制/etc/sk…

    Linux干货 2017-02-07
  • 多实例

    多实例

    Linux干货 2018-01-29
  • yum使用和源码编译进程

    yum 是通过分析RPM的标头数据,根据各软件的依赖关系制作出有依赖关系时的解决方案,然后自动处理软件的依赖性问题,以解决软件安装或升级的问题。  yum使用方法: yum [options] [command] [packages …] install package .. 通过yum安装软件包 update package .. 更新软件包 u…

    Linux干货 2016-08-24
  • N22-第五周博客作业

    1、显示当前系统上root、fedora或user1用户的默认shell; [root@bogon ~]# grep -E  "^(root|fedora|user1)" /etc/passwd  | cut -d: -f1,7r…

    Linux干货 2016-09-26
  • 磁盘配额的操作步骤

    磁盘配额 操作步骤: 1、创建一个10G的分区 /dev/sdd1并将其格式化,挂载 2、如果是新硬盘便不存在同步问题。旧硬盘得使用命令partx  -a /dev/sdd1 3、临时创建挂载文件夹 /mnt/home    4、将/home/*  mv  到 /mnt/home 中,再将/dev/…

    Linux干货 2016-09-01