天天看點

9.8_Linux程序管理和計劃任務

程序管理篇

程序概念

核心的功用:程序管理、檔案系統、網絡功能、記憶體管理、驅動程式、安全功能等

Process: 運作中的程式的一個副本,是被載入記憶體的一個指令集合

    程序ID(Process ID,PID)号碼被用來标記各個程序

    UID、GID、和SELinux語境決定對檔案系統的存取和通路權限,

    通常從執行程序的使用者來繼承

    存在生命周期

task struct:Linux核心存儲程序資訊的資料結構格式

task list:多個任務的的task struct組成的連結清單

程序建立:

    init:第一個程序

        父子關系

    程序:都由其父程序建立,CoW

        fork(), clone()

程序優先級

    系統優先級:數字越小,優先級越高

        0-139(CentOS4,5)

            各有140個運作隊列和過期隊列

        0-98,99(CentOS6)

    實時優先級:99-0:值最大優先級最高

    nice值:-20到19,對應系統優先級100-139或99

Big O:時間複雜度,用時和規模的關系

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

程序相關概念

程序記憶體:

    Page Frame: 頁框,用存儲頁面資料,存儲Page 4k

    LRU:Least Recently Used 近期最少使用算法,釋放記憶體

    實體位址空間和線性位址空間

    MMU:Memory Management Unit負責轉換線性和實體位址

IPC: Inter Process Communication

    同一主機上

        signal

        shm: shared memory

        semophore信号量,一種計數器

    不同主機上:

        rpc: remote procedure call

        socket: IP和端口号

程序狀态

Linux核心:搶占式多任務

程序類型:

    守護程序: daemon,在系統引導過程中啟動的程序,和終端無關程序

    前台程序:跟終端相關,通過終端啟動的程序

    注意:兩者可互相轉化

程序狀态:

    運作态:running

    就緒态:ready

    睡眠态:

        可中斷:interrup table

        不可中斷:uninterruptable

    停止态:stopped,暫停于記憶體中,但不會被排程,除非手動啟動

    僵死态:zombie,結束程序,父程序結束前,子程序不關閉

系統管理工具

程序的分類:

    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

    -p 顯示程序編号

示例:

以樹狀可以很清晰看見程序跟程序之間的關系

9.8_Linux程式管理和計劃任務

連程序編号一起顯示

9.8_Linux程式管理和計劃任務

ps指令: process state 顯示程序狀态

    ps-report a snapshot of the current processes

    Linux系統各程序的相關資訊均儲存在/proc/PID目錄下的各檔案中

列舉程序ps

适用ps來檢視程序資訊

    ps [OPTION]...

支援三種選項:

    UNIX選項如-A -e

    BSD選項如a

    GUN選項如--help

預設顯示目前終端中的程序

    a 選項包括所有終端中的程序

    x 選項包括不連結終端的程序

    u 選項顯示程序所有者的資訊

    f 選項顯示程序的父程序

    o 屬性… 選項顯示定制的資訊:

       pid、comm、%cpu、%mem、state、tty、euser(EffectiveUser)、ruser(RealUser)

示例1:ps的常用選項使用

VSZ:許諾使用記憶體

RSS:實際使用記憶體

9.8_Linux程式管理和計劃任務

示例2:指定檢視相關的程序資訊

假設wan使用者在修改密碼,此時passwd會用到SUID的權限

9.8_Linux程式管理和計劃任務

此時用root賬号檢視賬号可以看見,此處可以看euser是root,ruser是wan,此處展現了SUID的作用了

9.8_Linux程式管理和計劃任務

假如隻通過ps直接檢視該程序的時候,隻會顯示euser的使用者,但是該進去實際使用者是wan

9.8_Linux程式管理和計劃任務

程序管理工具

VSZ: Virtual memory SiZe,虛拟記憶體集,線性記憶體,許諾使用記憶體,

RSS: ReSidentSize, 常駐記憶體集,實際使用記憶體

STAT:程序狀态

    R:running 正在運作

    S: interrup table sleeping

    D: uninterrup table sleeping

    T: stopped

    Z: zombie

    +: 前台程序

    l: 多線程程序

    N:低優先級程序

    <: 高優先級程序

    s: session leader,會話(子程序)發起者

常用組合:-ef

    -e: 顯示所有程序

    -f: 顯示完整格式程式資訊

常用組合:-eFH

    -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

程序優先級分類

ni: nice 值,普通優先級,值越低優先級越高

pri: priority 優先級,程序優先級,數值越大優先級越高

psr: processor CPU編号

rtprio: 實時優先級

9.8_Linux程式管理和計劃任務

CentOS 6優先級關系對應表,越左邊的優先級越高,越右邊的優先級越低

9.8_Linux程式管理和計劃任務

CentOS 4和5優先級關系對應表,越左邊的優先級越高,越右邊的優先級越低

9.8_Linux程式管理和計劃任務

搜尋程序

最靈活:ps 選項 |  其它指令

按預定義的模式:pgrep

    pgrep [options] pattern

        -u uid: effective user,生效者

        -U uid: real user,真正發起運作指令者

        -t terminal: 與指定終端相關的程序

        -l: 顯示程序名

        -a: 顯示完整格式的程序名

        -P pid: 顯示指定程序的子程序

示例:搜尋指定程序

9.8_Linux程式管理和計劃任務

按确切的程式名稱:/sbin/pidof

    pidof bash

示例:搜尋指定程序的pid

9.8_Linux程式管理和計劃任務

uptime指令

顯示目前時間,系統已啟動的時間、目前上線人數,系統平均負載

系統平均負載:(1、5、10分鐘的平均負載,一般不會超過1)

    指在特定時間間隔内運作隊列中的平均程序數。

如果每個CPU核心的目前活動程序數不大于3的話,那麼系統的性能良好。如果每個CPU核心的任務數大于5,那麼這台機器的性能有嚴重問題。

如果linux主機是1個雙核CPU的話,當Load Average 為6的時候說明機器已經被充分使用了。

9.8_Linux程式管理和計劃任務

top指令:

選項:

    -d #: 指定重新整理時間間隔,預設為3秒

    -b: 以批次方式

    -n #: 顯示多少批次

有許多内置指令:

排序:

    P:以占據的CPU百分比,%CPU

    M:占據記憶體百分比,%MEM

    T:累積占據CPU時長,TIME+

首部資訊顯示:

    uptime資訊:l指令

    tasks及cpu資訊:t指令

    cpu分别顯示:1 (數字)

    memory資訊:m指令

退出指令:q

修改重新整理時間間隔:s

終止指定程序:k

儲存檔案:W

欄位資訊簡介

us:使用者空間

sy:核心空間

ni:調整nice時間

id:空閑

wa:等待IO時間

hi:硬中斷

si:軟中斷(模式切換)

st:虛拟機偷走的時間

PID (Process Id):任務的程序ID

PPID (Parent Process Pid):父任務的程序ID

RUSER (Real User Name):任務的所有者真實名稱

UID (User Id):任務所有者ID

USER (User Name):任務所有者名稱

GROUP (Group Name):任務所有者群組名

TTY (Controlling Tty):終端

PR (Priority):優先級

%CPU (CPU usage):CPU使用率

%MEM (Memory usage (RES)):記憶體使用率

S (Process Status):程序狀态

TIME+ (CPU Time, hundredths):CPU時間,精确到秒

9.8_Linux程式管理和計劃任務

htop指令:需從Fedora-EPEL源安裝

    -d #: 指定延遲時間;

    -u UserName: 僅顯示指定使用者的程序;

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

子指令:

    s: 跟蹤標明程序的系統調用;

    l: 顯示標明程序打開的檔案清單;

    a:将標明的程序綁定至某指定CPU核心;

    t: 顯示程序樹

9.8_Linux程式管理和計劃任務

F1-F10選項

F3直接搜尋程序

9.8_Linux程式管理和計劃任務

F9發送kill指令,預設級别是15

9.8_Linux程式管理和計劃任務

vmstat指令:檢視虛拟記憶體資訊

    vmstat [options] [delay [count]]

        -s 記憶體資訊彙總

procs:

    r:等待運作的程序的個數,和核心數有關

    b:處于不可中斷睡眠态的程序個數(被阻塞的隊列的長度)

memory:

    swpd: 交換記憶體的使用總量

    free:空閑實體記憶體總量

    buffer:用于buffer的記憶體總量

    cache:用于cache的記憶體總量

swap:

    si:從磁盤交換進記憶體的資料速率(kb/s)

    so:從記憶體交換至磁盤的資料速率(kb/s)

io:

    bi:從塊裝置讀入資料到系統的速率(kb/s)

    bo: 儲存資料至塊裝置的速率

system:

    in: interrupts, 中斷速率,包括時鐘

    cs: context switch, 程序切換速率

cpu:

    us: Time spent running non-kernel code

    sy: Time spent running kernel code

    id: Time spent idle. Linux 2.5.41前,包括IO-wait time.

    wa: Time spent waiting for IO. 2.5.41前,包括in idle.

    st: Time stolen from a virtual machine. 2.6.11前, unknown.

示例1:vmstat 2 5 兩秒一次,顯示5次

9.8_Linux程式管理和計劃任務

示例2:檢視記憶體彙總資訊

9.8_Linux程式管理和計劃任務

示例3:dd if=/dev/sda of=/dev/null 測試硬碟讀資料,并且監控

9.8_Linux程式管理和計劃任務

可以看見io bi暴增,假如系統的io值過高,這個時候就需要檢視是系統哪個程序占用大量的io了

9.8_Linux程式管理和計劃任務

示例4:dd if=/dev/zero of=f1       測試硬碟寫資料,并且監控

9.8_Linux程式管理和計劃任務

可以看見io bo暴增,假如系統的io值過高,這個時候就需要檢視是系統哪個程序占用大量的io了

9.8_Linux程式管理和計劃任務

注意:示例3和示例4都是測試磁盤吞吐量

如果io比較大,可以看看是哪個程式産生那麼大的io,磁盤io太大的話會帶來系統的負載偏大

pmap指令:程序對應的記憶體映射

pmap [options]  pid [...]

    -x: 顯示詳細格式的資訊;

示例:pmap 1

9.8_Linux程式管理和計劃任務

另外一種實作:

cat /proc/PID/maps

9.8_Linux程式管理和計劃任務

glances指令:glances - A cross-platform curses-based monitoring tool (EPEL源安裝)

glances [-bdehmnrsvyz1] [-B bind] [-c server] [-C conffile] [-p port] [-P password] [--password] [-t refresh] [-f file] [-o output]

常用選項:

    -b: 以Byte為機關顯示網卡資料速率

    -d: 關閉磁盤I/O子產品

    -f /path/to/somefile: 設定輸入檔案位置

    -o {HTML|CSV}:輸出格式

    -m: 禁用mount子產品

    -n: 禁用網絡子產品

    -t #: 延遲時間間隔

    -1:每個CPU的相關資料單獨顯示

内建指令:

    a Sort processes automatically

    l Show/hide logs

    c Sort processes by CPU%

    b Bytes or bits for network I/O

    m Sort processes by MEM%

    w Delete warning logs

    p Sort processes by name

    x Delete warning and critical logs

    i Sort processes by I/O rate

    1 Global CPU or per-CPU stats

    d Show/hide disk I/O stats

    h Show/hide this help screen

    f Show/hide file system stats

    t View network I/O as combination

    n Show/hide network stats

    u View cumulative network I/O

    s Show/hide sensors stats

    q Quit (Esc and Ctrl-C also work)

    y Show/hide hddtempstats

C/S模式下運作glances指令

服務模式:

    glances -s -B IPADDR

    IPADDR: 指明監聽的本機哪個位址

用戶端模式:

    glances -c IPADDR

    IPADDR:要連入的伺服器端位址

示例1:通過glances觀察網絡流量

9.8_Linux程式管理和計劃任務

此刻向10.1.156.68的主機發送大量的ping包

9.8_Linux程式管理和計劃任務

可以看見eth0的接口的流量飙升

9.8_Linux程式管理和計劃任務

示例2:通過c/s模式監控網絡流量

首先服務端開啟glances服務

9.8_Linux程式管理和計劃任務

從客服端開啟監控服務

9.8_Linux程式管理和計劃任務

已經連結上了

9.8_Linux程式管理和計劃任務

這個時候從一個端口向服務端發送大流量包,然後再觀察流量,可以看見網絡流量有明顯的變化

9.8_Linux程式管理和計劃任務

dstat指令:系統資源統計

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

    -c: 顯示cpu相關資訊

        -C #,#,...,total

    -d: 顯示disk相關資訊

        -D total,sda,sdb,...

    -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: 顯示延遲最大的程序

示例:用dstat監控網絡流量

當網絡端口接收到流量的時候,net的監控端的流量會發生明顯的變化

9.8_Linux程式管理和計劃任務

kill指令:

向程序發送控制信号,以實作對程序管理

顯示目前系統可用信号:kill -l

常用信号:man 7 signal

    1) SIGHUP: 無須關閉程序而讓其重讀配置檔案

    2) SIGINT: 中止正在運作的程序;相當于Ctrl+c

    9) SIGKILL: 殺死正在運作的程序

    15) SIGTERM:終止正在運作的程序

    18) SIGCONT:繼續運作

    19) SIGSTOP:背景休眠

指定信号的方法:

    (1) 信号的數字辨別;1, 2, 9

    (2) 信号完整名稱;SIGHUP

    (3) 信号的簡寫名稱;HUP

按PID:kill [-SIGNAL] pid…

按名稱:killall[-SIGNAL] comm…

按模式:pkill[options] pattern

    -SIGNAL

    -u uid: effective user,生效者

    -U uid: real user,真正發起運作指令者

    -t terminal: 與指定終端相關的程序

    -l: 顯示程序名

    -a: 顯示完整格式的程序名

    -P pid: 顯示父程序為此處指定的程序的程序清單

示例1:正常關閉掉程序

kill指令指定程序号殺掉程序,預設的級别是15

9.8_Linux程式管理和計劃任務

此時此程序已經被殺掉

9.8_Linux程式管理和計劃任務

示例2:強制殺掉某程序(程序可以使用pkill -9 -t pts/1 等直接殺掉哦)

現在要殺掉此程序

9.8_Linux程式管理和計劃任務

檢視此程序的pid号碼

9.8_Linux程式管理和計劃任務

正常的15信号會發現是殺不死此程序

9.8_Linux程式管理和計劃任務

發送強制信号9殺死程序,發現此程序已經被殺死

9.8_Linux程式管理和計劃任務

示例3:殺死所有的指定程序

9.8_Linux程式管理和計劃任務

示例4:殺死指定比對的程序

9.8_Linux程式管理和計劃任務

Linux作業管理篇

Linux的作業控制

    前台作業:通過終端啟動,且啟動後一直占據終端;

    背景作業:可通過終端啟動,但啟動後即轉入背景運作(釋放終端)

如何讓作業運作于背景?

    (1) 運作中的作業:Ctrl+z

    (2) 尚未啟動的作業:COMMAND &

背景作業雖然被送往背景運作,但其依然與終端相關;退出終端,将關閉背景作業。如果希望送往背景後,剝離與終端的關系

    nohup COMMAND & screen;COMMAND (此處可以檢視Linux入門幫助篇screen的用法)

檢視所有作業:

    jobs

作業控制:

    fg[[%]JOB_NUM]:把指定的背景作業調回前台;

    bg[[%]JOB_NUM]:讓送往背景的作業在背景繼續運作;

    kill [%JOB_NUM]:終止指定的作業;

前台運作、背景運作、背景休眠關系圖

9.8_Linux程式管理和計劃任務

示例1:把前台程序轉到背景運作,并且把它關閉

在指令後面加上&符号,把程序轉到背景運作,下圖可以看見,開始會提示[1] 3193表示他的pid号和jobs的編号,

然後在中間輸入了ctrl+c的信号,但是程式并沒有停止下來

如果上面的jobs号被刷掉的話,此時可以快速輸入jobs指令,會顯示jobs 1正在運作,然後再執行fg加指定jobs編号把指令調回來前台執行,然後按ctrl+c終止掉指令

9.8_Linux程式管理和計劃任務

示例2:把程式調到背景休眠狀态,然後再把程式調回去背景運作

9.8_Linux程式管理和計劃任務

如果向程式繼續在調背景執行,則輸入bg加jobs num

9.8_Linux程式管理和計劃任務

示例3:通過kill指令對背景指令程序操作

kill第18級指令,喚醒背景的休眠的做工,讓其繼續在背景運作

9.8_Linux程式管理和計劃任務

kill第19号指令,讓程式進入背景休眠狀态

9.8_Linux程式管理和計劃任務

并行同時運作多個程序,提高效率

正常來說,同時執行幾個指令,他們應該是按照順序執行,一個完成後再執行另外以一個

同時運作多個程式的方法:

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

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

示例:同時運作多個程式

9.8_Linux程式管理和計劃任務
9.8_Linux程式管理和計劃任務

程序優先級調整:

    靜态優先級:100-139

    程序預設啟動時的nice值為0,優先級為120

    隻有根使用者才能降低nice值(提高優先性)

    普通使用者能把自己運作的程式的優先級調低,但是不能調高

nice指令:隻能夠指定未開始執行的程式

    nice [OPTION] [COMMAND [ARG]...]

renice指令:對已經正在進行的程式重新配置設定其優先級

    renice [-n] priority pid...

檢視:

ps axo pid,comm,ni

示例1:調高某程式的優先級

ping程式的預設ni優先級隻有0

9.8_Linux程式管理和計劃任務

nice -10 指定該指令優先級為10

9.8_Linux程式管理和計劃任務

ps axo指定檢視其優先級,可以看見優先級已經改變

9.8_Linux程式管理和計劃任務

如果需要改其優先級為負數的話,則輸入--

9.8_Linux程式管理和計劃任務

可以看見此時已經是負數的優先級

9.8_Linux程式管理和計劃任務

示例2:重新修改某程式優先級

9.8_Linux程式管理和計劃任務

任務計劃

Linux任務計劃、周期性任務執行

未來的某時間點執行一次任務:

    at

    batch:系統自行選擇空閑時間去執行此處指定的任務

周期性運作某任務:

    cron

at任務

包:at

at指令:at [option] TIME

    -V 顯示版本資訊:

    -l: 列出指定隊列中等待運作的作業;相當于atq

    -d: 删除指定的作業;相當于atrm

    -c: 檢視具體作業任務

    -f /path/from/somefile:從指定的檔案中讀取任務

    -m:當任務被完成之後,将給使用者發送郵件,即使沒有标準輸出

注意:作業執行指令的結果中的标準輸出和錯誤以郵件通知給相關使用者

TIME:定義出什麼時候進行at 這項任務的時間

     [YYYY-mm-dd]

    noon, midnight, teatime(4pm)

    tomorrow

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

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任務執行方式:

  1)互動式 2)輸入重定向 3)at –f 檔案

  依賴與atd服務,需要啟動才能實作at任務

  at隊列存放在/var/spool/at目錄中

  /etc/at.{allow,deny}控制使用者是否能執行at任務

    白名單:/etc/at.allow 預設不存在,隻有該檔案中的使用者才能執行at指令

    黑名單:/etc/at.deny 拒絕該檔案中使用者執行at指令,而沒有在at.deny 檔案中的使用者則可執行

    如果兩個檔案都不存在,隻有root 可以執行at 指令

示例1:建立一個計劃任務

在17:52分,執行指令echo hello world,但是我們并沒有看見有任務,原來是因為echo hello world是标準輸出,有标準輸出的計劃任務,都會以發郵件顯示,是以這一點需要注意。

9.8_Linux程式管理和計劃任務

示例2:添加白名單控制,指定某使用者才能執行at任務

可以看見,在白名單裡面添加了wan的使用者,此使用者可以執行at計劃任務,但是wan2使用者不在白名單裡面,是以執行at指令的時候就會提示權限不夠。

9.8_Linux程式管理和計劃任務

示例3:重定向腳本到at任務裡面

9.8_Linux程式管理和計劃任務

周期性任務計劃cron

相關的程式包:

cronie: 主程式包,提供crond守護程序及相關輔助工具

cronie-anacron:cronie的補充程式;用于監控cronie任務執行狀況;如cronie中的任務在過去該運作的時間點未能正常運作,則anacron會随後啟動一次此任務

crontabs:包含CentOS提供系統維護任務

計劃任務

確定crond守護處于運作狀态:

    CentOS 7:

        systemctl status crond

    CentOS 6:

        service crond     status

計劃周期性執行的任務送出給crond,到指定時間會自動運作

    系統cron任務:系統維護作業

        /etc/crontab

    使用者cron任務:

        crontab指令

日志:/var/log/cron

系統cron任務的/etc/crontab檔案格式

9.8_Linux程式管理和計劃任務

系統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分以centos身份運作echo指令;

10 21 * * * centos /bin/echo "Howdy!"

時間表示法:

(1) 特定值;

    給定時間點有效取值範圍内的值

(2) *

    給定時間點上有效取值範圍内的所有值

    表示“每...”

(3) 離散取值:

    #,#,#

(4) 連續取值:-

    #-#

(5) 在指定時間範圍上,定義步長:

    /# : #即為步長

    例如:每3小時echo指令;

    0 */3 * * * centos /bin/echo "howdy!"

一些特殊的時間表示格式

@reboot 表示每次重新開機以後執行    Run once after reboot.

@yearly 表示每年1月1日執行   0 0 1 1 *

@annually 同上   0 0 1 1 *

@monthly 每個月1号執行   0 0 1 * *

@weekly 每周日執行   0 0 * * 0

@daily 每天執行   0 0 * * *

@hourly 每小時執行   0 * * * *

示例1:新增系統計劃任務

9.8_Linux程式管理和計劃任務

示例2:讓系統計劃任務執行指定腳本

執行腳本的時候,如果是非root使用者,需要注意使用者執行腳本的權限

新增一個任務:工作日時間,每10分鐘執行一次磁盤空間檢查,一旦發現任何分區使用率高于80%,就執行wall警報

9.8_Linux程式管理和計劃任務
9.8_Linux程式管理和計劃任務

anacron系統

運作計算機關機時cron不運作的任務,CentOS6以後版本取消anacron服務,由crond服務管理。

假設計算機沒有一直開機

對筆記本電腦、桌上型電腦、工作站及其它不一直開機的系統很重要

對偶爾要關機的伺服器很有用

配置檔案:/etc/anacrontab

負責執行/etc/ cron.daily /etc/cron.weekly /etc/cron.monthly中系統任務。

    /etc/cron.hourly/由/cron.d/0hourly執行

   字段1:如果在這些日子裡沒有運作這些任務……

   字段2:在重新開機後等待這麼多分鐘後運作它

   字段3:任務識别器,在日志檔案中辨別

   字段4:要執行的任務

   當執行任務時,更新/var/spool/anacron/中檔案的時間戳

系統的計劃任務:

/etc/crontab

/etc/cron.d/   配置檔案

定義一些系統的配置檔案,例如0hourly,表示每小時執行run-parts對/etc/cron.hourly裡面的任務

9.8_Linux程式管理和計劃任務

/etc/cron.hourly/   每小時執行的腳本

9.8_Linux程式管理和計劃任務

/etc/cron.daily/   腳本

系統為什麼剛安裝完以後,一部分指令的幫助手冊沒有的原因。然後過一段時間會自動生成幫助手冊,原因就在這裡了,因為系統每天定義會自動執行mandb的指令(centos7)

9.8_Linux程式管理和計劃任務

/etc/cron.weekly/   每周腳本,預設為空

9.8_Linux程式管理和計劃任務

/etc/cron.monthly/   每月腳本,預設為空

9.8_Linux程式管理和計劃任務

管理臨時檔案

CentOS6使用/etc/cron.daily/tmpwatch定時清除臨時檔案

CentOS7使用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

    d /var/tmp 1777 root root 30d

指令:

    systemd-tmpfiles –clean|remove|create configfile

示例:系統自定義的定義清理臨時檔案的腳本,每10天清理/tmp目錄,沒30天清理/var/tmp目錄

9.8_Linux程式管理和計劃任務

使用者計劃任務cron:

crontab指令定義,每個使用者都有專用的cron任務檔案:/var/spool/cron/USERNAME

crontab指令:

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

    -l: 列出所有任務;

    -e: 編輯任務;

    -r: 移除所有任務;

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

    -u user: 僅root可運作,指定使用者管理cron任務

控制使用者執行計劃任務:(此處用法原理跟at的allow和deny是一樣的)

   /etc/cron.{allow,deny}

示例1:建立wan使用者的任務

建立任務1:每周2, 4, 7備份/var/log/messages檔案至/logs目錄中,檔案名形如“messages-yyyymmdd”

建立任務2:每兩小時取出目前系統/proc/meminfo檔案中以S或M開頭的資訊追加至/tmp/meminfo.txt檔案中

9.8_Linux程式管理和計劃任務

示例2:添加計劃任務的權限

當白名單存在的時候,僅允許白名單的使用者執行計劃任務,其他使用者不予執行。

假如白名單不存在的時候,僅有黑名單檔案,那麼,僅黑名單的使用者不能執行計劃任務,其他使用者都可以執行計劃任務。

9.8_Linux程式管理和計劃任務

示例3:删除計劃任務

9.8_Linux程式管理和計劃任務

示例4:編輯指定使用者的計劃任務

9.8_Linux程式管理和計劃任務

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

沒有被重定向的輸出會被郵寄給使用者

根使用者能夠修改其它使用者的作業

注意:運作結果的标準輸出和錯誤以郵件通知給相關使用者

    (1) COMMAND > /dev/null

    (2) COMMAND &> /dev/null

對于cron任務來講,%有特殊用途;如果在指令中要使用%,則需要轉義;不過,如果把%放置于單引号中,也可以不用轉義

思考:參考sleep指令~

(1) 如何在秒級别運作任務?

* * * * * for min in 0 1 2; do echo "hi"; sleep 20; done

(2) 如何實作每7分鐘運作一次任務?

sleep指令:

    sleep NUMBER[SUFFIX]...

        SUFFIX:

        s: 秒, 預設

        m: 分

        h: 小時

        d: 天

繼續閱讀