进程和计划任务

1、进程概念

内核的功用:进程管理、文件系统、网络功能、内存管理、驱动程序、安全功能等;

进程是运行中的程序的一个副本,是被载入内存的一个指令集合;

进程ID(PID )号码被用来标记各个进程;

UID、GID 和SELinux 语境决定对文件系统的存取和访问权限,这些权限通常从执行进程的用户来继承并且存在生命周期;

task struct:Linux内核存储进程信息的数据结构格式;

task list:多个任务的的task struct组成的链表;

进程创建:init 是第一个进程,其后进程都由其父进程创建,表现为父子关系进程;

2、进程优先级

1)、系统优先级:数字越小,优先级越高

0-139(CentOS4,5)

0-98,99(CenOS6)

2)、实时优先级: 99-0值越大优先级越高

3)、Nice值:-20-19 分别对应系统优先级的100-139或99

4)、时间复杂度(Big O)-用时和规模的关系,主要有以下的模式:

O(1), O(logn), O(n)线性, O(n^2)抛物线, O(2^n)

3、进程状态

Linux内核:抢占式多任务

进程类型:

守护进程,daemon, 在系统引导过程中启动的进程,是和终端无关的进程

前台进程,跟终端相关,通过终端启动的进程

注意:两者可相互转化

进程状态:

运行态-running

就绪态-ready

睡眠态-sleeping

可中断-interruptable

不可中断-uninterruptable

停止态-stopped, 暂停于内存中,但不会被调度,除非手动启动

僵死态-zombie,结束进程,父进程结束前,子进程不关闭

4、系统管理工具

进程的分类:

CPU-Bound是CPU密集型,非交互

IO-Bound是IO密集型,交互

Linux系统状态的查看及管理工具:pstree,ps,pidof,pgrep,top,htop,glance,pmap,vmstat, dstat,kill,pkill,job,bg,fg,nohup

pstree 命令:

pstree – display a tree of processes

ps(process state)命令-静态查看:

ps – report a snapshot of the current processes

默认显示当前终端中的进程

[root@centos7 ~]# ps –e

[root@centos7 ~]# ps -A

上两者等价,查看所有终端所有进程

a 选项包括所有终端中用户启动的进程

[root@centos7 ~]# ps a

x 选项包括不链接终端的进程,即后台运行的守护进程

[root@centos7 ~]# ps x

u 选项显示进程所有者的信息

[root@centos7 ~]# ps u

[root@centos7 ~]# ps axu 查看所有终端的所有进程的详细信息

f 选项显示进程的父进程

o 属性…选项显示定制的信息:

user、pid 、%cpu 、%mem 、stat、tty、euser、ruser、nice、pri等等

其中euser是真正生效的用户,ruser是真正执行命令的用户

[root@centos7 ~]# ps axo user,pid,%cpu,%mem,stat,tty,nice

常用组合:-ef、-eFH

-e: 显示所有进程

-f: 显示完整格式程序信息

-F:显示更完整格式的进程信息

-H:以进程层级格式显示进程相关信息

常用组合:自定义要查看的字段

-eo pid,tid,class,rtprio,ni,pri,psr,pcpu,stat,comm

axo stat,euid,ruid,tty,tpgid,sess,pgrp,ppid,pid,pcpu,comm.

最灵活格式-搜索进程:

#ps 选项 | 其它命令

#ps axu | grep bash

按预定义的模式搜索进程:pgrep

pgrep [options] pattern

-u uid: effective user,生效者,搜索结果是进程pid

#pgrep -u wang

-U uid: real user,真正发起运行命令者,搜索结果是进程pid

#pgrep -U wang

-t: 与指定终端相关的进程

-l: 显示进程名

-a: 显示完整格式的进程名

-P: 显示指定进程的子进程,搜索结果是进程pid号

#pgrep -P 8708

按确切的程序名称搜索进程:/sbin/pidof

$pidof bash

Linux系统各进程的相关信息均保存在/proc/PID 目录下的各文件中

5、uptime命令

显示当前时间、系统已启动的时间、当前上线人数,系统平均负载(1 、5 、10 分钟的平均负载,一般不会超过1)

[root@centos7 ~]# uptime

 23:30:52 up  1:56,  4 users,  load average: 0.08, 0.03, 0.05

[root@centos7 ~]# lscpu

系统平均负载指在特定时间间隔内运行队列中的平均进程数

如果每个CPU内核的当前活动进程数不大于3 的话,那么系统的性能良好;如果每个CPU 内核的任务数大于5,那么这台机器的性能有严重问题

如果linux 主机是1个双核CPU的话,当Load Average为6的时候说明机器已经被充分使用了

6、top命令-实时观察进程的状态

#top

首部信息显示-可用如下按键子命令控制:

uptime信息:l

tasks及cpu信息:t

cpu 分别显示:1

memory信息:m

退出命令:q

修改刷新时间间隔:s

终止指定进程:k

保存文件:W

选项

-d #: 指定刷新时间间隔,默认为3秒

-b: 以批次方式显示

-n #:显示多少批次

7、htop 命令

需从Fedora-EPEL源安装,配置yum源路径:

http://10.1.0.1/fedora-epel/7/x86_64

http://10.1.0.1/fedora-epel/6/x86_64

选项如下(进入命令后可以使用F#实现相应控制目的):

-d #:指定延迟时间

-u UserName:仅显示指定用户的进程

-s COLUME:以指定字段进行排序

按键子命令

8、内存工具

1)、vmstat命令-查看内存信息

[root@localhost ~]# vmstat 理解以下各种参数变量的含义

procs ———–memory———- —swap– —–io—- –system– —–cpu—–

 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st

 1  0      0 440004  27592 211584    0    0    23     1   28   28  0  0 98  1  0

[root@localhost ~]# vmstat 2 5

两秒执行一次,执行五次,用于实现动态观察

[root@localhost ~]# pidof vim

3910 查看进程vim的进程编号

2)、pmap 命令-查看指定进程对应的内存映射信息

pmap [options] pid […]

-x: 显示详细格式的信息

#pmap PID

# cat /proc/PID/maps

[root@localhost ~]# pmap 3910

[root@localhost ~]# cat /proc/3910/maps

9、glances 命令

需从Fedora-EPEL源安装,配置yum源路径:

http://10.1.0.1/fedora-epel/7/x86_64

http://10.1.0.1/fedora-epel/6/x86_64

服务模式:

#glances -s -B IPADDR

IPADDR指明监听的本机哪个地址

客户端模式-实现远程服务器监控:

#glances -c IPADDR

IPADDR要连入的服务器端地址

10、dstat 命令-系统资源统计

dstat [-afv] [options..] [delay [count]]

-c: 显示cpu 相关信息

-C #,#,…,total

-d: 显示disk 相关信息

-D sda,sdb,…,total

-g:显示page 相关统计数据

-m: 显示memory 相关统计数据

-n: 显示network 相关统计数据

-p: 显示process 相关统计数据

-r: 显示io 请求相关的统计数据

-s: 显示swapped 相关的统计数据

–tcp

–udp

–unix

–raw

–socket

–ipc

–top-cpu:显示最占用CPU 的进程

–top-io:显示最占用io 的进程

–top-mem:显示最占用内存的进程

–top-latency: 显示延迟最大的进程

11、kill 命令

向进程发送控制信号,以实现对进程管理,显示当前系统可用信号#kill -l

常用信号,可用#man 7 signal查看:

1)  SIGHUP无须关闭进程而让其重读配置文件

#yum install httpd

# systemctl status httpd

#systemctl restart httpd

#links 10.1.252.250

#cd /var/www/html

#echo welcome to www.magedu.com > index.html

#links 10.1.252.250

#cd /var/www

#mkdir magesite

#mv html/index.html magesite

#links 10.1.252.250

#vim /etc/httpd/conf/httpd.conf 修改网页的存放路径为/var/www/html为/var/www/magesite

#kill -1 PID

#kill –SIGHUP PID

此外httpd进程的主进程号,不关闭进程而让httpd进程重读配置文件

或者用此方式重新加载配置文件#systemctl reload httpd

#links 10.1.252.250

2) SIGINT中止正在运行的进程,相当于Ctrl+c

9) SIGKILL杀死正在运行的进程,比SIGINT和SIGTERM更近强硬

15) SIGTERM终止正在运行的进程

18) SIGCONT使在后台的作业在后台继续运行

19) SIGSTOP把前提作业送往后台休眠

按PID:kill [-SIGNAL] pid …

按名称:killall [-SIGNAL] comm…

按模式:pkill [options] pattern

-SIGNAL

-u uid:effective user,生效者

-U uid:real user,真正发起运行命令者

-t terminal: 与指定终端相关的进程

12、作业管理

Linux 的作业控制

前台作业:通过终端启动,且启动后一直占据终端

后台作业:可通过终端启动,但启动后即转入后台运行(释放终端)

如何让作业运行于后台?

(1) 运行中的作业:Ctrl+z

(2) 尚未启动的作业:# COMMAND &

后台作业虽然被送往后台运行,但其依然与终端相关,退出终端,将关闭后台作业

如果希望送往后台后,剥离与终端的关系,可用以下命令实现:

# nohup COMMAND &

#screen;COMMAND

查看后台所有作业:

# jobs

作业控制:

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

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

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

13、并行运行

同时运行多个进程,提高效率

#vi all.sh

此脚本中分行写入f1.sh& f2.sh& f3.sh&,然后运行脚本all.sh可以实现并行运行

#(f1.sh&);(f2.sh&);(f3.sh&)

#{ f1.sh& f2.sh& f3.sh& }

而#f1.sh;f2.sh;f3.sh 是顺序执行

14、进程优先级

进程优先级调整:

静态优先级100-139

进程默认启动时的nice 值为0,优先级为120

只有根用户才能降低nice 值(提高优先性)

nice 命令-启动命令时指定优先级:

nice [OPTION] [COMMAND [ARG]…]

#nice -n -5 ping 127.0.0.1

renice 命令-启动命令后更改优先级:

renice [-n] priority pid…

#ping 127.0.0.1

#pidof ping

#renice -n -5 PID

查看进程的nice和pri优先级:

#ps axo pid,comm,nice,pri

15、任务计划

未来的某时间点执行一次任务:at

系统自行选择空闲时间去执行此处指定的任务:batch

周期性运行某任务:cron

1)、at任务-交互式执行方式下按Ctrl+d结束at任务建立

at [option] TIME

常用选项:

-V: 显示版本信息

-l: 列出指定队列中等待运行的作业,相当于atq

-d: 删除指定的作业,相当于atrm

[root@localhost ~]# at -l

2  2016-09-08 16:56 a root

[root@localhost ~]# at -d 2

-c: 查看具体作业任务

[root@localhost ~]# at -l

3  2016-09-08 16:59 a root

[root@localhost ~]# at -c 3

-f /path/from/somefile:从指定的文件中读取任务

[root@localhost ~]# at -f /root/at.txt 11:30

-m: 当任务被完成之后,将给用户发送邮件,即使没有标准输出

注意:作业执行命令的结果中的标准输出和错误以邮件通知给相关用户,为了避免产生过多的垃圾邮件,所以在作业执行命令中避免有标准输出和错误

TIME:定义出什么时候执行at 这项任务的时间

HH:MM [YYYY-mm-dd]

noon, midnight, teatime(4pm),tomorrow

now+#{minutes,hours,days,OR weeks}

at时间格式:

HH:MM 02:00

在今日的 HH:MM 进行,若该时刻已过,则明天此时执行任务

HH:MM YYYY-MM-DD 04:00 2016-09-20

规定在某年某月的某一天的特殊时刻进行该项任务

HH:MM[am|pm] [Month] [Date]

04pm March 17

17:20 tomorrow

HH:MM[am|pm]+number[minutes|hours|days|weeks]

在某个时间点再加几个时间后才进行该项任务

now + 5 minutes

04pm + 3 days

执行方式:

交互式/输入重定向/at -f 文件

其中输入重定向# at 11:30 < at.txt,其中at.txt是命令文件

    ‘at -f 文件’的执行方式# at -f /root/at.txt 11:30

依赖与atd 服务, 需要启动才能实现at任务

at队列存放在/var/spool/at目录中

[root@localhost at]# at -l

4  2016-09-08 17:05 a root

[root@localhost ~]# cd /var/spool/at

[root@localhost at]# ls

a000040176afa1  spool

[root@localhost at]# cat a000040176afa1

通过/etc/at.{allow,deny} 控制用户是否能执行at任务

先寻找/etc/at.allow 文件,文件中的使用者才能使用 at,没有在这个文件中的使用者则不能使用 at (即使没有写在at.deny当中);如果/etc/at.allow 不存在,就寻找 /etc/at.deny这个文件,写在at.deny中的使用者则不能使用at,而没有在at.deny文件中的使用者则可使用 at 命令;如果两个文件都不存在,只有 root用户可以使用at这个命令。

2)、周期性任务计划cron

相关的程序包:

cronie:主程序包,提供crond 守护进程及相关辅助工具

cronie-anacron:cronie的补充程序,用于监控cronie任务执行状况,如cronie中的任务在过去该运行的时间点未能正常运行,则anacron系统会在随后的启动时运行一次此任务; CentOS6.0以后版本取消anacron 服务,由crond 服务管理

crontabs:包含CentOS提供的系统维护任务

确保crond 守护处于运行状态:

CentOS7:systemctl status crond

CentOS6:service crond status

计划周期性执行的任务提交给crond,到指定时间会自动运行系统cron任务-系统维护作业

系统维护作业计划任务存放于/etc/crontab并且是按照一定的格式书写的

用户cron 任务可以使用crontab命令建立

周期性计划任务日志:/var/log/cron

系统cron任务:/etc/crontab

注释行以#开头

详情参见man 5 crontab

# Example of job definition:

# .—————- minute (0 – 59)

# | .————- hour (0 – 23)

# | | .———- day of month (1 – 31)

# | | | .——- month (1 – 12) OR jan,feb,mar,apr …

# | | | | .—- day of week (0 – 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat

# | | | | |

# * * * * * user-name command to be executed

例如:每天晚上9点10分运行touch命令;

10 21 * * * centos /bin/touch /root/aa.txt

时间表示法:

 (1)特定值:给定时间点有效取值范围内的值

 (2)*:给定时间点上有效取值范围内的所有值,表示“每…”

 (3)离散取值逗号隔开:#,#,#

 (4)连续取值:#-#

 (5)在指定时间范围上定义步长:/#,其中#即为步长

 例如:每3小时执行touch命令

0 */3 * * * centos /bin/touch /root/aa.txt

时间格式:

@reboot     Run once after reboot.

@yearly     0 0 1 1 *

@annually   0 0 1 1 *

@monthly    0 0 1 * *

@weekly     0 0 * * 0

@daily      0 0 * * *

@hourly     0 * * * *

* * * * * 的意思是每分钟执行作业任务

0 2 1,10,20 * 0,6的意思是每月的1/10/20号或者周六周日的凌晨两点执行作业任务

系统自定义的计划任务:

/etc/crontab

/etc/cron.d/ 配置文件

/etc/cron.hourly/ 其下为脚本文件

/etc/cron.daily/

/etc/cron.weekly/ 

/etc/cron.monthly/

16、anacron系统

运行计算机关机时cron没运行的任务,CentOS6以后版本取消anacron服务,由crond 服务管理

对偶尔要关机的服务器很有用

1)、配置文件/etc/anacrontab

其中的字段含义如下:

字段1:如果在这些日子里没有运行这些任务……

字段2:在重新引导后等待多少分钟后运行它

字段3:任务识别器,在日志文件中标识

字段4:要执行的任务

负责执行/etc/cron.daily、/etc/cron.weekly、/etc/cron.monthly中系统任务

其中/etc/cron.hourly/由/cron.d/0hourly执行

2)、管理临时文件

rhel6.0使用/etc/cron.daily/tmpwatch 定时清除临时文件

rhel7.0使用systemd-tmpfiles-setup 服务实现

配置文件:

 /etc/tmpfiles.d/*.conf

 /run/tmpfiles.d/*.conf

 /usr/lib/tmpfiles/*.conf

例如在配置文件/usr/lib/tmpfiles.d/tmp.conf中有如下内容

d /tmp 1777 root root 10d 意思是10天以上的文件将被清理

d /var/tmp 1777 root root 30d

3)、用户cron-用户计划任务

用户可用crontab命令定义,每个用户都有专用的cron任务文件:/var/spool/cron/USERNAME

crontab命令-其它用户使用此命令继承的是root用户的权限:

#man 5 crontab

[root@localhost ~]# ll `which crontab`

-rwsr-xr-x. 1 root root 51784 Nov 10  2015 /usr/bin/crontab

crontab [-u user] [-l | -r | -e] [-i]

-l: 列出所有任务

-e: 编辑任务

-r: 移除所有任务

-i:同-r一同使用,以交互式模式移除指定任务

[root@centos7 cron]# crontab -ir

crontab: really delete root's crontab? Y

-u user: 仅root 可运行,用于管理指定用户的cron任务

[root@centos7 cron]# crontab -l -u wang

0 12 * * * touch /home/wang/fi

[root@centos7 cron]# crontab -r -u wang

[root@centos7 cron]# crontab -e -u wang

控制用户执行计划任务:/etc/cron.{allow,deny}

周期性计划任务日志:/var/log/cron

at和crontab的区别:

一次性作业使用at

重复性作业使用crontab

Create      at TIME          crontab -e

List        at -l            crontab -l

Details     at -c jobnum     N/A

Remove      at -d jobnum     crontab -r

Edit        N/A              crontab -e

[root@centos7 cron]# crontab -r

没有被重定向的输出会被邮寄给用户

根用户能够修改其它用户的作业

注意:运行结果的标准输出和错误以邮件通知给相关用户,避免过多垃圾邮件可用如下格式

(1) COMMAND > /dev/null

(2) COMMAND &> /dev/null

对于cron 任务来讲,%有特殊用途,如果在命令中要使用%,则需要转义;不过,如果把%放置于单引号中,也可以不用转义

思考:

(1) 如何在秒级别运行任务?

* * * * * for min in 0 1 2; do echo "hi"; sleep 20;done 每隔20秒执行echo命令

1 12 * * sleep 20;touch /root/fi 每天的12点1分20秒执行touch命令

(2)如何实现每7分钟运行一次任务?

sleep命令:

#sleep NUMBER[SUFFIX]…

SUFFIX:

s: 秒, 默认情况

m:

h: 小时

d:

而usleep命令,默认微秒

 

 

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

(0)
1861276386318612763863
上一篇 2016-09-13
下一篇 2016-09-13

相关推荐

  • LVM2 ( Blog4 )

    LV基本应用,扩展及缩减实现

    Linux干货 2017-11-27
  • LNMMP架构实现Web动静分离

    前言 前面的文章中说过LAMP架构包括:Linux操作系统,Apache网站服务器,MySQL数据库,Perl、PHP或者Python编程语言,而今天要说的LNMMP 和LAMP类似,只是作为Web服务器的不再是Apache而是高性能的Nginx,同时引进Memcached加速缓存效率,用于加快访问速度。 Memcached是一款开源、高性能、分布…

    Linux干货 2015-06-15
  • shell脚本编程和位置变量

    编程基础 程序:指令+数据    程序编程风格:       过程式:以指令为中心,数据服务于指令       对象式:以数据为中心,指令服务于数据    shell:提供了编程能…

    Linux干货 2016-08-16
  • Linux 计划任务快速理解入门

    计划任务简单来说是一个我们规定的时间去执行我们需要的脚本、命令及需要Linux做的事情。 以前写过一个脚本,由于当时没有学过计划任务,所以写起来特别痛苦,该脚本的需求是每天晚上11:00 备份/etc目录 当时特别小白,于是这么写的: VimrebootScript ‘ #!/bin/bash whiletrue;do If [ -d/app/e…

    Linux干货 2017-05-15
  • Vim

    vim编辑器         vim,可谓文本编辑界的大哥,功能强大无比,是进阶版的vi, vim 不但可以用不同颜色显示文字内容,还能够进行诸如 shell script, C program等程序编辑功能。 vim是一种模式化的编辑器  (vim自带教程,命令行中输…

    Linux干货 2016-08-09
  • if case语句练习

     1、 写一个脚本/root/bin/createuser.sh,实现如下功能:使用一个用户名做为参数,如果指定参数的用户存在,就显示其存在,否则添加之;显示添加的用户的id号等信息 [root@localhost bin]# cat createuser.sh #!/bin/bash # Date…

    Linux干货 2016-08-15