linux进程和计划任务

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

进程管理:

    系统优先级:数字越小,优先级越高
    实时优先级: 99-0,值最大优先级最高
    nice值:-20 到19 ,对应系统优先级100-139或99

Linux 内核:抢占式多任务
          进程类型:
                     守护进程: daemon, 在系统引导过程中启动的进程,和终端无关进程
                     前台进程:跟终端相关,通过终端启动的进程
                     注意:两者可相互转化
          进程状态:
                  运行态:running
                  就绪态:ready
                  睡眠态:
                  可中断:interruptable
                 不可中断:uninterruptable
                 停止态:stopped, 暂停于内存,但不会被调度,除非手动启动
                 僵死态:zombie,结束进程,父进程结束前,子进程不关闭

进程和线程的区别:

      一个进程可以有多个线程,一个CPU只能运行一个进程,

      线程可以共享资源,包括网络资源,内存资源

进程管理工具:
          pstree  -p  :  查看进程树    -p   查看pid
          ps            :  查看终端信息
             默认显示当前终端中的进程
                • a 选项包括所有终端中的进程
                • x 选项包括不链接终端的进程
                • u 选项显示进程所有者的信息
                • f 选项显示进程的父进程
                • o 属性…  选项显示定制的信息
                        pid 、comm 、%cpu 、%mem 、state 、tty 、euser 、ruser
          pidof  command      : 查看运行命令的pid
          stat:进程状态 
               R            S         D           T          Z          L       N     < 
                     可中断休眠   停止             僵尸进程    多线程         高优先级
                            
        常用组合:-ef
                  -e:  显示所有进程
                  -f:  显示完整格式程序信息
       常用组合:-eFH
                  -F:  显示更完整格式的进程信息
                  -H:  以进程层级格式显示进程相关信息

nice命令:
       nice 10 pid
       renice -n 10 pid      调整进程优先级
uptime :  显示当前时间,和系统平均负载 

top命令:
       -d #   :指定刷新时间间隔,默认为3秒
       -b     :以批次方式 (就是一次显示一个页面)
       -n #   :显示多少批次(比如显示3次页面就退出的意思)
        排序:
P :以占据的CPU 百分比,%CPU
M :占据内存百分比,%MEM
T :累积占据CPU 时长,TIME+
       首部信息显示:
uptime 信息:      l 命令
tasks 及cpu 信息: t 命令
cpu 分别显示:     1 ( 数字)
memory 信息:      m 命令
退出命令:         q
修改刷新时间间隔: s
终止指定进程:     k
保存文件:         W    
top栏位信息简介;进程查看对比就方便记住了

htop 命令:需从Fedora-EPEL 源安装 yum -y install htop

vmstat: 虚拟内存信息

    vmstat 2 5   :  每2秒显示一次,显示五次结束

               iostat: 统计CPU 和设备IO 信息

                  iostat 2  5 : 

系统监测工具:

      glance: 

             服务器模式:
                    glances -s -B IPADDR
                                    IPADDR: 指明监听的本机哪个地址

             客户端模式:
                   glances -c IPADDR
                                  IPADDR: 要连入的服务器端地址

       dstat:, 代替vmstat,iostat;功能很强大
-c:  显示cpu 相关信息
-d:  显示disk 相关信息
-g :显示page 相关统计数据
-m:  显示memory 相关统计数据
-n:  显示network 相关统计数据
-p:  显示process 相关统计数据
-r:  显示io 请求相关的统计数据
-s:  显示swapped相关的统计数据

kill 命令:
向进程发送控制信号;以实现对进程管理,每个信号对应一个数字,信号名称以SIG开头(可省略)不区分大小写
       显示当前系统可用信号: kill –l,trap -l
常用信号:man 7 signal
1) SIGHUP:  无须关闭进程而让其重读配置文件
2) SIGINT:  中止正在运行的进程;相当于Ctrl+c
3) SIGQUIT: 相当于ctrl+\
9) SIGKILL:  强制杀死正在运行的进程
15) SIGTERM :终止正在运行的进程
18) SIGCONT :继续运行
19) SIGSTOP :后台休眠
指定信号的方法:
(1)  信号的数字标识:1, 2, 9
(2)  信号的简写名称:HUP

例如:kill -9 PID        kill -1  pid  

作业管理:
       Linux 的作业控制
前台作业:通过终端启动,且启动后一直占据终端;
后台作业:可通过终端启动,但启动后即转入后台运行(释放终端)
  如何让作业运行于后台?
(1)  运行中的作业: Ctrl+z     (此操作会使进程休眠)
(2)  尚未启动的作业:# COMMAND &  (此操作后台运行)
  后台作业虽然被送往后台运行,但其依然与终端相关;退出终端,将关闭
后台作业。如果希望送往后台后,剥离与终端的关系
              # nohup COMMAND & #screen;COMMAND
  查看所有作业:
              # jobs
  作业控制:  后台作业都会有一个编号,直接指定编号也行
          # fg [[%]JOB_NUM] :把指定的后台作业调回前台
          # bg [[%]JOB_NUM] :让送往后台的作业在后台继续运行
          # kill [%JOB_NUM] :终止指定的作业
并行运行:
      方法1      (写三个脚本,放到一个脚本运行,每个脚本后用&)
         vi all.sh
             f1.sh&
             f2.sh&
             f3.sh&
    方法2
        (f1.sh&);(f2.sh&);(f3.sh&)
    方法3

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

任务计划:

    Linux 任务计划、周期性任务执行
•  未来的某时间点执行一次任务
             at
             batch :系统 自行选择空闲时间去执行此处指定的任务
•  周期性运行某任务
             cron

at: 依赖软件包,考试时候类似的包都会挖坑,需要手动启动服务,否则做完不生效
    rpm -q at    :查询软件包名称
    rpm -ql at   : 查询安装包路径        
       service atd status   :查看当前服务是否启动    start和stop,临时启动
       chkconfig  –list atd :查看是否开机启动的
       chkconfif –level 5 atd on/off   :在模式5设置开机启动或者关闭 –help 查看帮助
    centos7 :
       systemctl   is-enabled atd  :查看atd下次启动是否自动启动
       systenctl   enabled   atd   :  下次启动自动启动
       systenctl   disable   atd   :  下次启动不自动启动

at time   :命令格式,后面跟时间,ctrl+d  结束      
     at -l  :  查看计划任务
     at -d  #: 删除指定的计划任务编号
     at -c #:  查看任务计划内容, 目录在 /var/spool/at/  
     at -f *.text  time:   把多个任务计划写到文件调用
     at -m  : 当任务 被完成之后,将给用户发送邮件,即使没有标准输出
     计划任务结果以邮件形式发送,建议使用重定向解决 >/dev/null
     同时间的计划任务支持并行运行。

at.deny 和at.allow       /et/at.deny     默认/etc/at.allow 不存在
      at.deny 黑名单,要生效的前提,at.allow不存在,白名单的优先级最高
      at.allow 白名单,只有白名单的用户才可能执行at,默认不存在,如果存在,at.deny失效,优先级高
如果都不存在,只有root可以执行at
      如果 两个文件都不存在有 ,只有 root 行 可以执行 at  命令

周期性任务计划:
     cron :  和at一样,需要先查询清楚路径和是否启动服务,或者开机启动
     rpm -qa cron* :  可以用通配符搜索;
     确保crond 守护处于运行状态:
          CentOS 7:
                systemctl status crond
          CentOS 6:
                service crond status
  计划周期性执行的任务提交给crond ,到指定时间会自动运行
  系统cron 任务:系统维护作业
            /etc/crontab
  用户cron 任务:
                crontab 命令
         日志:/var/log/cron
   周期性计划对符号敏感,比如%,所以建议调用脚本,否则需要加单引号;

   vim /etc/crontab 
   时间表示法:
• (1)  特定值
给定时间点有效取值范围内的值
• (2)  *
给定时间点上有效取值范围内的所有值
表示 “每…”
• (3)  离散取值
#,#,#
• (4)  连续取值
#-#
• (5)  在指定时间范围上, 定义步长
/#: #即为步长
  示例:每3小时echo 命令
0 */3 * * * centos /bin/echo “howdy!”
一般来说,几月几号和周几一般不同时出现,如果都出现,表示或者的关系,都会执行

   @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 * * * *
  
   系统的计划任务:
/etc/crontab
/etc/cron.d/ 配置文件
/etc/cron.hourly/  脚本
/etc/cron.daily/   脚本
/etc/cron.weekly/  脚本
/etc/cron.monthly/ 脚本

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