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

(0)
sheweishewei
上一篇 2017-03-22
下一篇 2017-03-24

相关推荐

  • httpd及https

    1、建立httpd服务,要求: (1) 提供两个基于名称的虚拟主机:     www1.stuX.com,页面文件目录为/web/vhosts/www1;错误日志为/var/log/httpd/www1/error_log,访问日志为/var/log/httpd/www1/access_log;   &nbs…

    2017-06-05
  • 马哥教育网络班22期+第二周课程练习

    Linux上文件可管理类命令,其常用的使用方法和相关示例 目录管理类命令 目录管理类命令包含:mkdir,rmdir mkdir 使用说明及格式 移除空目录 rmdir [OPTION]… DIRECTORY…   常见选项及说明 -p –parents 创建时如果父目录不存在,一并创建 -v –ve…

    Linux干货 2016-08-24
  •   在服务器托管的过程中出现故障是不能完全避免的问题,可能是服务器硬盘出现硬件故障或者是防火墙遭到攻击。那么服务器托管出现故障怎么办?

      在服务器托管的过程中出现故障是不能完全避免的问题,可能是服务器硬盘出现硬件故障或者是防火墙遭到攻击。那么服务器托管出现故障怎么办?   服务器硬盘出现硬件故障时,大家应注意以下几点:   1、硬盘出现异声,此时磁头已不正常寻址,为防止打伤盘体,需立即断电不可拆解硬盘,需交有超净间的专业公司拆开检查。   2、BIOS不认盘,找不到硬盘,先请计算机工程师仔…

    Linux干货 2016-04-05
  • M20 – 1- 第三周(1):课堂练习与作业

    课堂练习: 1、创建用户gentoo,附加组为bin和root,默认shell为/bin/csh,注释信息为"Gentoo Distribution" [root@localhost ~]# useradd -G bin,root -s /bin/csh -c&nbsp…

    Linux干货 2016-08-08
  • 初涉Linux基本要点概括(1)

    计算机,这里通常指可以储存程序的计算机,根据冯诺依曼体系,计算机组成部件包括控制单元(Control Unit)、算术逻辑单元(Arithmetic Logic Unit)、内存(Memory)、输入设备(Input)、输出设备(Output)。计算机通过输入的数据和指令,可以完成各种复杂的运算任务,小到文字处理、游戏、影音、大到卫星定位,火箭发射,人工智能…

    Linux干货 2016-09-26
  • Bash 的配置文件

    有时候,在定义了别名 alilas cls=clear  , 或者定义了 umask=033 等等,在logout 用户后再登录,会失效,因为这些本地变量,仅对当前shell生效。而要保留配置,使其永久生效,就需要将这些定义的写入配置文件中保存。下面介绍下bash的配置文件:  Bash的配置文件可以分为: profile类: /etc/…

    Linux干货 2015-04-04