入手內核的前篇之進程和計劃任務

概念的介紹
 
內核的功用:進程管理、文件系統、網絡功能、內存管理、驅動程序、 安全功能等。
進程,在linux系統中,觸發一個事件時,系統都會將它定義成一個進程,而且給進程一個ID咱們稱之爲PID,也就是進程號,這個進程建立與之能使用的權限和功能也和建立者有關。
在CentOS 7之前的第一個進程是init
[root@magedu6 ~]# pstree               #以進程樹的形式顯示當前進程
init─┬─NetworkManager─┬─dhclient
     │                └─{NetworkManager}
     ├─abrtd
     ├─acpid
     ├─atd
     ├─auditd───{auditd}
     ├─automount───4*[{automount}]
....

而在CentOS 7上第一個進程是systemdlinux

systemd─┬─NetworkManager─┬─2*[dhclient]
        │                └─2*[{NetworkManager}]
        ├─auditd───{auditd}
        ├─automount───4*[{automount}]
        ├─crond
        ├─dbus-daemon───{dbus-daemon}
        ├─login───bash
        ├─master─┬─pickup
        │        └─qmgr
...

Process:  運行中的程序的一個 副本,是被 載入內存的一個指令集合
進程ID (Process ID ,PID )號碼被用來標記各個進程
UID 、GID 、和SELinux 語境決定對文件系統的存取和 訪問權限,
一般 從執行進程的 用戶來繼承
存在生命週期
task struct :Linux 內核存儲進程信息的數據結構格式
task list :多個任務的的task struct 組成的鏈表

進程:都由其父進程建立,CoW #CoW寫時複製技術
fork(), clone()ios

過程這樣的算法

一、系統先以fork的方式複製一個與服進程相同的進程,這個進程與服進程惟一的差異就是PID不一樣,可是這個進程還會多一個PPID的參數,PPID就是父進程的程序識別PID。shell

二、而後新產生的進程開始加載實際要運行的程序進行執行。#只有進行寫入操做的時候纔會這樣。數據庫

進程間通訊vim

  1.主機上的進程通訊能夠經過signal(信號指令)、shm(共享內存空間)、semerphor(旗語)windows

  2.兩個主機間的通訊經過rpc(遠程過程調用)、socket(套接字)centos

進程優先級:
  系統優先級: 數字越小,優先級越高
    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 負責轉換線性和物理地址
TLB:Translation Lookaside Buffer 翻譯 後備 緩衝器, 用於保存虛擬地址和物理地址映射關係的緩存 #你實際使用多少,但給你多少
IPC: Inter Process Communication
同一主機: signal: 發信號
shm: shared memory 共享內存 #兩個進程要通訊,他們會建立個共享內存來通訊
semaphore: 信號量,一種計數器 #當你使用一個程序調用一個進程,你會給個標記表示你在使用,這樣其餘進程沒法再次調度。
不一樣主機:rpc: remote procedure call #遠程過程調用 當你程序使用的時候須要使用B程序調用下,調用完後返回A進程
socket: IP #unix套接字文件實現

進程狀態安全

    linux內核:搶佔式多任務 #在之前操做系統中是協做式多任務,意思是一個任務獲得了CPU時間,除非它本身放棄使用CPU,不然將徹底霸佔CPU,而搶佔式多任務系統的控制權在操做系統這,操做系統會輪詢的問每一個任務是否須要CPU的使用權,而過一段時間後會收回CPU使用權,將它放在最後,在去詢問下一個任務,這樣的好處是不會形成任務鎖死

進程類型:
守護進程: daemon, 在系統引導過程當中啓動的進程, 和 終端無關進程
前臺進程:跟終端相關,經過終端啓動的進程
#二者可相互轉換
 
進程狀態:
運行態:running
就緒態:ready #等待CPU時間片 調用
睡眠態:
可中斷:interruptable
不可中斷:uninterruptable #好比IO操做文件,沒有讀取完你不能中斷
中止態:stopped, 暫停於內存,但不會被調度,除非手動啓動 #當你用VI編輯的時候就是這個狀態
僵死態:zombie,結束進程,父進程結束前,子進程不關閉
  一些命令的使用。  
系統管理工具
進程的分類:
CPU-Bound :CPU 密集型,非交互 好比查找計算 排序,對CPU佔用率高的進程
IO-Bound :IO密集型,交互 。等待I/O時間長的進程 #dd之類的命令
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
Linux 系統各進程的相關信息均保存在/proc/PID 目錄下的各文件中。  
列舉進程ps
支持三種選項:
UNIX 選項 如 如-A -e

[root@localhost ~]# ps -A -e #-A和 -e 效果是同樣的。 PID TTY TIME CMD 1 ? 00:00:03 systemd 2 ? 00:00:00 kthreadd 3 ? 00:00:02 ksoftirqd/0 7 ? 00:00:00 migration/0 8 ? 00:00:00 rcu_bh
BSD 選項 如 如a

[root@localhost ~]# ps a PID TTY STAT TIME COMMAND 2180 tty1 Ss+ 0:00 -bash 6810 pts/0 Ss 0:00 -bash 7231 pts/0 R+ 0:00 ps a
GNU 選項 如 如--help
...
經常使用組合:-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,cmd
euid:有效用戶
      ruid:實際用戶執行命令的人
這三種選擇一種適合本身的就好。
 
top命令相似windows下的任務管理器
一些經常使用指令
選項 說明
-d 指定每兩次屏幕信息刷新之間的時間間隔
-i 不顯示限制或者僵死的進程信息
-c 顯示進程的整個命令路徑,而不是隻顯示命令名稱
-s 使top命令在安全模式下運行。此時top的交互式指令被取消,避免潛在危險
-b 分屏顯示輸出信息,結合「-n」選項能夠將屏幕信息輸出到文檔
-n top輸出信息更新的次數,完成後將退出top命令

 還有一些交互式命令      

top :有許多內置命令:
排序:
P :以佔據的CPU 百分比,%CPU
M :佔據內存百分比,%MEM
T :累積佔據CPU 時長,TIME+
 
首部信息顯示:
uptime 信息:l 命令
tasks 及cpu 信息:t 命令
cpu 分別顯示:1 ( 數字) #能夠顯示具體每一個CPU狀況
us :用戶空間
sy :內核空間
ni :調整nice 時間
id :空閒
wa :等待IO 時間
hi :硬中斷 #硬件資源操做
si :軟中斷(模式切換)進程切換
st :虛擬機偷走的時間
memory 信息:m 命令 #內存信息
退出命令:q
修改刷新時間間隔:s
終止指定進程:k
保存文件:W #存在家目錄下 .toprc
top輸出分爲統計信息區和進程信息區兩個部分,
1)統計信息區
  • 01:34:10:表示當前系統時間。
  • up 14:20:表示系統已經運行的時間
  • 2 users:當前登陸系統的用戶數
  • load average :表示系統平均負載,三個數值分別表示1分鐘 5分鐘 15分鐘到如今的系統平均負載值。

第二行和第三行分別是進程和CPU信息

  • Tasks:113 total:進程的總數。
  • 2 running:正在運行的進程。
  • 111 sleeping:處於休眠狀態的進程。
  • 0 stopped:中止的進程數。
  • 0 zombie:僵死的進程數。
  • %Cpu(s):0.0us:表示用戶進程佔用CPU的百分比。
  • 0.3 sy:系統進程佔用CPU的百分比。
  • 0.0 ni:用戶進程空間內改變過優先級的進程佔用CPU的百分比。
  • 99.7 id:空閒CPU佔用的百分比。
  • 0.0 wa:等待輸入、輸出的進程佔用CPU的百分比。

最後 兩行輸出的是內存信息

  • KiB Mem:483856 total:系統的物理內存大小。
  • 64972 free:目前空餘內存大小。
  • 115984 used:已經使用的物理內存大小。
  • 302900 buff/cache:用做內核緩衝區的內存大小。
  • KiB Swap:2097148 total:交換分區內存大小。
  • 2096352 free:空閒的交換分區大小。
  • 796 used:已經使用的交換分區大小。
  • 309652 avail Mem:緩存大小。

進程信息區

進程信息區顯示了每一個進程的運行狀態,咱們先來看一下每列輸出的含義。

  • PID:進程的ID。
  • USER:進程全部者的用戶名。
  • PR:進程優先級。
  • NI:nice值。負值表示高優先級,正值表示低優先級。
  • VIRT:進程使用的虛擬內存總量,單位KB. VIRT=SWAP+RES。
  • RES:進程使用的、未被患處的物理內存大小,單位KB。RES=CODE+DATA,其中,CODE爲執行代碼佔用的物理內存大小,DATA爲數據佔用的內存大小。
  • SHR:共享內存大小,單位KB。
  • S:進程狀態,D表示不可終端的睡眠狀態,R表示運行狀態,S表示睡眠狀態,T表示跟蹤/中止,Z表示僵死進程。
  • %CPU:上次更新到如今的CPU時間佔用百分比。
  • %MEM:進程佔用的物理內存百分比。
  • TIME+:進程總計使用的CPU時間,單位爲1/100秒。
  • COMMAND:正在運行進程的命令名或者命令路徑。
 
進程優先級調整:
靜態優先級:100-139
進程默認啓動時的nice 值爲0 ,優先級爲120
只有根用戶才能下降nice 值(提升優先性)
nice 命令:
nice [OPTION] [COMMAND [ARG]...]
nice -n 10 ping 127.0.0.1 #指定優先級運行
特殊用法:nice --6 d if=/dev/zero of=/dev/null
renice 命令: #能根據PID修改優先級
renice [-n] priority pid...
查看:
ps axo pid,comm,ni
 
搜索進程
最靈活:ps 選項 | 其它命令
按預約義的模式:pgrep
pgrep [options] pattern
-u uid: effective user ,生效者
-U uid: real user ,真正發起運行命令者
-t terminal: 與指定終端相關的進程
pgrep -lt pts/1
-l: 顯示進程名
-a: 顯示完整格式的進程名 #centos 7上纔有的選項
-P pid: 顯示指定進程的子進程
按確切的程序名稱:/sbin/pidof
pidof bash #查看進程編號,這個命令是軟連接,可是連接對象你不能用  
一個進程能夠擁有多個線程,但線程不能單獨存在。
一個進程裏多個線程之間的資源是共享的,線程消耗資源是不多的
 
uptime
顯示當前時間,系統已啓動的時間,也能顯示負載狀況。load Average 1 5 10分鐘內的負載
一個CPU內核當前活動進程數不大於3,表示正常,超過5系統性能就有問題。
 
#腳本里第一行不寫bash 執行的是命令,你用ps aux | grep f1.sh #會搜索不到
vmstat 命令:虛擬內存信息
vmstat [options] [delay [count]]
vmstat 2 5
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.
選項:
  -s: 顯示內存數據

[root@localhost ~]# vmstat 1 3 #一秒顯示依次,3次後結束 procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu----- r b swpd free buff cache si so bi bo in cs us sy id wa st 2 0 1340 90868 0 253020 0 0 5 4 40 53 0 0 100 0 0 0 0 1340 90852 0 253020 0 0 0 0 122 173 0 1 99 0 0 0 0 1340 90852 0 253020 0 0 0 0 121 164 0 0 100 0 0 [root@localhost ~]#
iostat: 統計CPU 和設備IO 信息
示例:iostat 1 10
pmap 命令:進程對應的內存映射
寫數字表示進程號,而後看內存映射信息
/proc/1/masp #地址
pmap [options] pid [...]
-x: 顯示詳細格式的信息
示例:pmap 1
另一種實現:
cat /proc/PID/maps
[root@localhost ~]# cat /proc/1/maps 
7fd420000000-7fd420029000 rw-p 00000000 00:00 0 
7fd420029000-7fd424000000 ---p 00000000 00:00 0 
7fd42778b000-7fd42778c000 ---p 00000000 00:00 0 
7fd42778c000-7fd427f8c000 rw-p 00000000 00:00 0 
7fd427f8c000-7fd427f8d000 ---p 00000000 00:00 0 
7fd427f8d000-7fd42878d000 rw-p 00000000 00:00 0 
7fd42878d000-7fd428791000 r-xp 00000000 fd:00 67235606                   /usr/lib64/libuuid.so.1.3.0
7fd428791000-7fd428990000 ---p 00004000 fd:00 67235606 


[root@localhost ~]# pmap 1
1:   /usr/lib/systemd/systemd --switched-root --system --deserialize 21
00007fd420000000    164K rw---   [ anon ]
00007fd420029000  65372K -----   [ anon ]
00007fd42778b000      4K -----   [ anon ]
00007fd42778c000   8192K rw---   [ anon ]
00007fd427f8c000      4K -----   [ anon ]
00007fd427f8d000   8192K rw---   [ anon ]
00007fd42878d000     16K r-x-- libuuid.so.1.3.0
00007fd428791000   2044K ----- libuuid.so.1.3.0
View Code

dstat 命令:系統資源統計, 代替vmstat,iostat 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
kill 命令:
向進程發送控制信號,以實現對進程管理, 每一個信號對應一個數字,
信號名稱以SIG 開頭(可省略 ), 不 區分大小寫
顯示當前系統可用信號: kill –l,trap -l
經常使用信號:man 7 signal
1) SIGHUP: 無須關閉進程而讓其重讀配置文件
2) SIGINT: 停止正在運行的進程;至關於Ctrl+c
3) SIGQUIT: 至關於ctrl+\
9) SIGKILL: 強制殺死正在運行的進程 #不是什麼進程都能殺死好比bash
15) SIGTERM :終止正在運行的進程 #默認是15,有的進程這麼殺不死
18) SIGCONT :繼續運行
19) SIGSTOP :後臺休眠
#若是在後臺運行的程序,用它也能進行休眠
指定信號的方法:
(1) 信號的數字標識:1, 2, 9
(2) 信號完整名稱:SIGHUP (3) 信號的簡寫名稱:HUP
 
按PID :kill [-SIGNAL] pid …
kill –n SIGNAL pid;kill –s SIGNAL pid
按名稱:killall [-SIGNAL] comm…
按模式:pkill [options] pattern
-SIGNAL
-u uid: effective user ,生效者
pkill -9 -u wang
-U uid: real user ,真正發起運行命令者
-t terminal: 與指定終端相關的進程
-l: 顯示進程 名(pgrep 可用)
-a: 顯示完整格式的進程 名( (pgrep 可用)
-P pid: 顯示指定進程的子進程
 
 
Linux 的做業控制
前臺做業:經過終端啓動,且啓動後一直佔據終端;
後臺做業:可經過終端啓動,但啓動後即轉入後臺運行(釋放終端)
讓做業運行於後臺
(1) 運行中的做業: Ctrl+z
送到後臺並休眠
(2) 還沒有啓動的做業:# COMMAND &
後臺做業雖然被送日後臺運行,但其依然與終端相關;退出終端,將關閉
後臺做業。若是但願送日後臺後,剝離與終端的關係
 
nohup COMMAND & #screen;COMMAND
送到後臺運行不與終端有關
默認是有輸出的,能夠重定向到垃圾箱
nohup.out #結果這個文件下會有
screen #新開終端,跟sshd不要緊
-ls 查看會話
 
 
查看當前終端全部做業:
jobs #這個只能在當前終端看當前終端的後臺運行進程
後臺兩種狀態
運行:
休眠:stop
做業控制:
fg [[%]JOB_NUM] :把指定的後臺做業調回前臺
bg [[%]JOB_NUM] :讓送日後臺的做業在後臺繼續運行
kill [%JOB_NUM]: 終止指定的做業
kill %1 #結束編號做業,須要用jobs先查看
 
對於任務的加速完成
 
f1.sh;f2.sh;f3.sh #這是順序執行達不到效果
同時運行多個進程,提升效率
方法1 #必須放入後臺執行
vi all.sh
f1.sh&
f2.sh&
f3.sh&
方法2
(f1.sh&);(f2.sh&);(f3.sh&) #會開子進程
方法3
{ f1.sh& f2.sh& f3.sh& }
 
 
#at命令若是時間過了,會明天去執行
包:at
at 命令:at [option] TIME
經常使用選項:
-V 顯示版本信息:
-l: 列出指定隊列中等待運行的做業;至關於atq
-d: 刪除指定的做業;至關於atrm
-c: 查看具體做業任務
-f /path/from/somefile :從指定的文件中讀取任務
-m: 當任務 被完成以後,將給用戶發送郵件,即便沒有標準輸出
注意:做業執行命令的結果中的標準輸出和錯誤以郵件通知給相關用戶
TIME: 定義出何時進行 at 這項任務的時間
HH:MM [YYYY-mm-dd]
20:20 2016-10-10
noon, midnight, teatime (4pm) #英文單詞也能用
tomorrow #明天
now+#{minutes,hours,days, OR weeks}
at now+10minutes #10分鐘後自動執行
 
HH:MM 02:00 在今日的 HH:MM 進行,若該時刻已過,則明天此時執行任務
HH:MM YYYY-MM-DD 02: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
02pm + 3 days
 
執行方式:
1)交互式 )輸入重定向 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
/etc/at.deny
wang
mage
/etc/at.allow
#這個兩個用戶會由於寫入這個文件而不能執行。
#若是兩個文件都寫了該用戶。白名單權限更高。設置白名單後,一切以白名單爲主,若是這兩個文件都沒有,除了root所有拒絕
例:
[root@magedu6 ~]# cat /etc/rc.d/init.d/atd   #命令狀態確認 CentOS 6
#!/bin/sh
#
# atd Starts/stop the "at" daemon
#
# chkconfig:   345 95 5
# description: Runs commands scheduled by the "at" command at the time \
#    specified when "at" was run, and runs batch commands when the load \
#    average is low enough.
...省略
[root@magedu6 ~]# runlevel #確認是否啓動
3 5

[root@magedu6 ~]# service atd status   #查看當前狀態
atd (pid  1913) 正在運行...

[root@magedu6 ~]# chkconfig --list atd
atd             0:關閉  1:關閉  2:關閉  3:啓用  4:啓用  5:啓用  6:關閉

[root@localhost ~]# cat /lib/systemd/system/atd.service  #CentOS 7上的狀態確認
[Unit]
Description=Job spooling tools
After=syslog.target systemd-user-sessions.service

[Service]
EnvironmentFile=/etc/sysconfig/atd
ExecStart=/usr/sbin/atd -f $OPTS
...
 
[root@localhost ~]# systemctl is-enabled atd   #確認開機是否啓動
enabled

[root@localhost ~]# systemctl status atd.service  #  #確認是否啓動,.service能夠省略
● atd.service - Job spooling tools
   Loaded: loaded (/usr/lib/systemd/system/atd.service; enabled; vendor preset: enabled)
   Active: inactive (dead)


[root@localhost ~]# at 09:28    #默認交互模式,echo這類終端打印 命令沒打印的緣由是他以郵件方式發送給root。只要標準輸出命令都要輸出到/dev/null避免太多垃圾郵件
at> echo at is starting
at> <EOT>
job 3 at Wed May 10 09:28:00 2017

[root@localhost ~]# at -l     #能夠看到沒執行的計劃任務,至關於atq命令
2       Wed May 10 09:24:00 2017 a root
3       Wed May 10 09:28:00 2017 a root

at命令關機也不會丟  由於會放在 /var/spool/at/... 文件裏

[root@localhost ~]# getent passwd daemon   #系統用戶,查看狀況
daemon:x:2:2:daemon:/sbin:/sbin/nologin
View Code
at -d 4 #刪除4這個計劃任務
atrm 5 #刪除計劃任務5
at -c 7 #查看具體狀況,就是看/var/spool/at這個文件
at -f atjob #直接調用文件 和sed -f 裏的效果差很少。
at -m 14:34
touch 1.log  
週期性任務計劃:cron
相關 的程序包:
cronie: 主程序包,提供crond 守護進程及相關輔助工具
cronie-anacron :cronie 的補充 程序,用於 監控cronie任務執行 情況,如cronie 中的任務在過去該運行的時間點未能正常運行,則anacron 會隨後啓動一次此任務。
crontabs :包含CentOS 提供系統維護任務
 
chkconfig --list crond #查看啓動沒有
service crond status #查看啓動沒有
systemctl status crond #7上查看啓動沒有
/usr/sbin/crond #真正的程序在這
/var/spool/cron #你作的計劃任務會在這
 
確保crond 守護處於運行狀態:
CentOS 7:
systemctl status crond
CentOS 6:
service crond status
計劃週期性執行的任務提交給crond ,到指定時間會自動運行
系統cron 任務:系統維護做業
/etc/crontab
用戶cron 任務:
crontab 命令
日誌:/var/log/cron
 
時間表示法:
(1) 特定值
給定時間點有效取值範圍內的值
(2) *
給定時間點上有效取值範圍內的全部值
表示「每...」
(3) 離散取值
#,#,#
4) 連續取值
#-#
(5) 在指定時間範圍上,定義步長
/#: # 即爲步長
 
@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 * * * *
示例:每3 小時echo 和wall 命令
0 */3 * * * centos /bin/echo 「howdy」;/usr/bin/wall
「welcome to Magedu!
 
系統cron 任務:/etc/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 分運行echo 命令
10 21 * * * centos /bin/echo "Howdy!"
#寫計劃任務的時候必須寫明確路徑讓文件知道在哪找,由於不必定用一個shell。
例:
30 2 1-10,20-25 root /bin/touch /app/cron.log #寫普通用戶也行,但普通用戶不必定有資格
* #*表明每分鐘
cp -a /etc/ /paa/etcbak-`date +%F`/ #複製一個文件,由於有%因此不會成功
* * * * * root cron.sh #寫入腳本調用就好,最後兩個*是或,其餘三個是而且。若是想實現而且,就腳本里寫。
@reboot root touch /app/reboot.log #重啓後執行
 
/var/spool/cron/ #用命令建立的才放到這裏,文件裏寫入不存在
 
系統的計劃任務:
/etc/crontab #能夠修改文件達成,給管理員用的
/etc/cron.d/ 配置文件 #和上面那個路徑差很少
/etc/cron.hourly/ 腳本
#run-parts /etc/cron.hourly #去運行這個目錄下全部腳本
/etc/cron.daily/ 腳本
/etc/cron.weekly/ 腳本
/etc/cron.monthly/ 腳本
 
anacron
運行計算機關機時cron 不運行的任務,CentOS6 之後版本
取消anacron 服務,由crond 服務管理
對筆記本電腦、臺式機、工做站、偶爾要關機的服務器及其
它不一直開機的系統很重要對頗有用
配置文件:/etc/anacrontab ,負責執行/etc/ cron.daily /etc/cron.weekly /etc/cron.monthly 中系統任務。
• 字段1 :若是在這些日子裏沒有運行這些任務……
• 字段2 :在從新引導後等待這麼多分鐘後運行它
• 字段3 :任務識別器,在日誌文件中標識
• 字段4 :要執行的任務
由/etc/cron.hourly/0anacron 執行
當執行任務時,更新/var/spool/anacron/cron.daily 文件的時間戳
 
/usr/bin/on_ac_power #把電源拔了試試
 
whatis rm #查看數據庫裏這個命令的
 
#/etc/cron.daily
logrotate #用來發現日誌文件是否過大,過大會分割建立個文件,保證文件不會太大
mandb #更新數據庫 7上
mlocate
 
#ls /etc/cron.daily/ #腳本目錄
#cat /etc/cron.daily/tmpwatch #這個文件會自動清除一些臨時文件
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
 
#有特殊權限
用戶cron:
crontab 命令定義,每一個用戶都有專用的cron 任務文件:/var/spool/cron/USERNAME
crontab 命令:
crontab [-u user] [-l | -r | -e] [-i]
-l: 列出全部任務 #默認只看本身的加-u才能看別人的
-e: 編輯任務;
#會建立個臨時文件,不用寫用戶了
cd /var/spool/cron/ #文件放在這
-r: 移除當前用戶全部任務
-i :同-r 一同使用,以交互式模式移除指定任務
-u user: 僅root 可運行,指定用戶管理cron 任務
控制用戶執行計劃任務 :
/etc/cron.{allow,deny} #和at裏的道理同樣。 #默認也是沒有allow,若是已經有了計劃任務,仍是會執行,由於改的是命令如今的權限了。
 
#用這個命令修改後,會刪除舊文件,生成新文件。
export EDITOR=vim #使不少程序默認使用vim
vipw 至關於/etc/passwd #有語法檢查功能
/var/log/cron #計劃任務的日誌。若是誤刪除在這找。
 
一次性做業使用 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 任務來說,% 有特殊用途;若是在命令中要使用%,則須要轉義,將%
相關文章
相關標籤/搜索