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 16:20
下一篇 2016-09-09 16:23

相关推荐

  • 获取linux命令帮助的方法

    1.help command 适用于内建命令。 2.command -hlep 适用于外部命令。 3.info command 适用于外部命令。 4.man command 适用外部命令和内建命令。     man帮助命令分章节             centos7:man 1…

    Linux干货 2017-08-19
  • 马哥教育网络班21期+第3周课程练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 //使用who命令列出列出当明显登录的所有用户,使用cut命令取出用户名,使用sort命令去重即可// [root@localhost ~]# who | cut -d' ' -f1…

    Linux干货 2016-08-08
  • week2

    一、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 常用工具cp mv rm cat tac head tail more less stat cp   cp SRC…DEST A. 如果SRC是文件: a. 如果目标不存在:新建DEST,并将SRC中的内容填充至DEST中。 b. 如果目标存在: (1). 如…

    Linux干货 2016-11-06
  • 第十四周作业

    系统的INPUT和OUTPUT默认策略为DROP; [root@CentOS7 ~]# iptables -P INPUT DROP [root@CentOS7 ~]# iptables -P OUTPUT DROP 1、限制本地主机的web服务器在周一不允许访问;新请求的速率不能超过100个每秒;web服务器包含了admin字符串的页面不允许访问;web服…

    Linux干货 2017-08-13
  • Linux文件系统

    文件是什么?存储空间内存储的有边界的一段流式数据,对数据可以做到按名存取。众多文件是如何有效的组织起来?1.  平面化把众多文件放在一起。当想查找某个文件时,需要遍历所有文件,当文件数目足够多的时候,查找一个文件将会非常慢,效率极低。2.  层级结构化根据后续查找文件的筛选条件进行分类,逐层放置,通常要查找一个文件,只需要从最高层级开始,…

    2017-09-05
  • 搭建缓存功能的WEB服务集群

    搭建缓存功能的WEB服务集群 实验简介 本文主要介绍双主模型的nginx proxy高可用集群的搭建方式。实验环境: 使用nfs服务器提供页面数据共享 使用单独的mariadb服务器提供关系型数据库 使用两台httpd服务器处理动态的php和静态页面资源 使用两台nginx服务器处理图片资源 使用两台varnish服务器作缓存处理 使用两台nginx作代理 …

    Linux干货 2017-07-15