linux管理进程和计划任务,Linux进程和计划任务管理
本章結構
#查看進程
#控制進程
#at一次性任務設置
#crontab周期性任務設置
程序和進程的關系
#程序
保存在硬盤、光盤等介質中的可執行代碼和數據
靜態保存的代碼
#進程
在cpu及內存中運行的程序代碼
動態執行的代碼
父、子進程:每個進程可以創建一個或多個進程
查看進程ps
#ps命令
查看靜態的進程統計信息
#PS命令—查看靜態的進程統計信息
ps命令是Linux系統中最為常用的進程查看工具,主要用于顯示高喊擋圈運行的各個進程完整信息的靜態快照
a:顯示當前終端下所有進程信息,包含其他用戶進程,與“x”選項結合時顯示系統中所有進程信息
u:使用以用戶為主的格式輸出進程信息
x:顯示當前用戶在所有終端下的進程信息
-e:顯示系統內的所有進程信息
-l:使用長格式顯示進程信息
-f:使用完整的格式顯示進程信息
USER:啟動該進程的用戶賬號名稱
PID:該進程在系統中的數字ID,在當前系統中是唯一的
TTY:標名該進程在那個==哪個終端上運行,“?”表示不需要終端
STAT:顯示了進程當前的狀態,如S(休眠)、R(運行)、Z(僵尸)、 START:啟動該進程的時間
TIME:該進程占用的時間
查看進程信息TOP
#top命令
查看動態的進程排名信息
(還有防止掉線的功能)
查看進程信息pgrep
#pgrep命令
根據特定條件查詢今晨PID信息
查看進程信息pstree
#pstree命令
以樹形結構列出進程信息
###yum -y install psmisc 安裝pstree命令
pstree -aup
-a:顯示完整信息
-u:列出對應用戶名
-p:列出對應PID號
進程的前后臺調度
#Cril+Z組合鍵
將當前進程掛起,即調入后臺并停止執行
#jobs命令
查看處于后臺的任務列表
#fg命令 (fg 1)
將后臺進程恢復到前臺運行,可指定任務序號
終止進程的運行
#Ctri+C組合鍵
終端正在執行的命令
#kill、killall命令
kill用于終止指定PID號的進程
killall用于終止指定名稱的所有進程
-9選項用于強制終止
終止進程的運行
#pkill命令
根據特定條件終止相應的進程
常用命令選項
-U:根據進程所屬的用戶名終止相應進程
-t:根據進程所在的終端終止相應進程
計劃任務管理
#at命令
一次性計劃任務
例如:在當天的21:30時自動關閉當前系統
計劃任務管理crontab
#crontab命令
按照預先設置的時間周期(分鐘、小時、天····)重復執行用戶指定的命令操作
屬于周期性計劃任務
主要設置文件
全局配置文件,位于文件:/etc/crontab
系統默認的設置,位于目錄:/etc/cron.*/
用戶定義的設置,位于文件:/var/spool/cron/用戶名
計劃任務管理crontab
#管理crontab計劃任務
編輯計劃任務:crontab -e 【-u 用戶名】
查看計劃任務:crontab - l 【-u 用戶名】
刪除計劃任務:crontab -r 【-u 用戶名】
crontab任務配置的格式
#時間數值的特殊表示方法
表示該范圍內的任意時間
,表示間隔的多個不連續時間點
表示一個連續的時間范圍
/ 指定間隔的時間頻率
舉例
0 17 * * 1-5 周一到周五每天17:00
30 8 * * 1,3,5 每周一、三、五的8點30分
0 8-18/2 * * * 8點到18點之間每2小時
0 * */3 * * 每三天
###常用的Crontab命令:
安裝crontab:yum install crontabs
查看定時任務列表:crontab -l
編輯定時任務:crontab –e【等同于: vim /var/spool/cron/root】
刪除定時任務:crontab –r
備份定時任務:crontab -l > $HOME/backMyCrontab
crontab服務操作說明:
service crond start //啟動服務
service crond stop //關閉服務
service crond restart //重啟服務
service crond reload //重新載入配置
service crond status//查看crontab服務狀態
實例:
每隔2分鐘輸出當前時間到文件
*/2 * * * * echo $(date) >> /test/date.log
在 12 月內, 每天的早上 6 點到 12 點,每隔 3 個小時 0 分鐘執行一次 /usr/bin/backup
0 6-12/3 * 12 * /usr/bin/backup
每天3-5,17-20每隔30分鐘同步一次互聯網時間,并且不輸出日志到crontab將結果輸出到log
echo “*/30 [3-5],[17-20] * * * /usr/bin/ntpstat time.windows.com >/dev/null 2>&1” >> /var/cron.log
每隔兩天的上午8點到11點的第3和第15分鐘執行command
3,15 8-11 */2 * * command
每個星期一的上午8點到11點的第3和第15分鐘執行command
3,15 8-11 * * 1 command
每周六、周日的1:10重啟smb
10 1 * * 6,0 /etc/init.d/smb restart
每周一至周五3點鐘,在目錄/home中,查找文件名為*.xxx的文件,并刪除4天前的文件。
00 03 * * 1-5 find /home “*.xxx” -mtime +4 -exec rm {} ;
每小時執行/etc/cron.hourly目錄內的腳本
01 * * * * root run-parts /etc/cron.hourly
Crontab使用小結:
1.環境變量問題,例如crontab不能識別Java的環境變量
crontab執行shell時,只能識別為數不多的環境變量,普通的環境變量是無法識別的,所以在編寫shell時,最好使用export重新聲明變量,確保腳本執行。
2.命令的執行最好用腳本
3.腳本權限加/bin/sh,規范路徑/server/scripts
4.時間變量用反斜線轉義,最好用腳本
5.定時任務添加注釋
6.>/dev/null 2>&1 ==>&>/dev/null,別隨意打印日志文件
7.定時任務里面的程序腳本盡量用全路徑
8.避免不必要的程序以及命令輸出
9.定時任務之前添加注釋
10.打包到文件目錄的上一級
知識拓展:
查看crontab的日志記錄:
linux
看 /var/log/cron.log這個文件就可以,可以用tail -f /var/log/cron.log觀察。
或者是 less /var/log/cron 輸入G(大寫),直接到末尾查看最新的日志信息。
mail任務
在 /var/spool/mail/root 文件中,有crontab執行日志的記錄,用tail -f /var/spool/mail/root 即可查看最近的crontab執行情況。
系統任務調度:系統周期性所要執行的工作,比如寫緩存數據到硬盤、日志清理等。在/etc目錄下有一個crontab文件,這個就是系統任務調度的配置文件。
/etc/crontab文件包括下面幾行:
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=""
HOME=/
第一行SHELL變量指定了系統要使用哪個shell,這里是bash,第二行PATH變量指定了系統執行命令的路徑,第三行MAILTO變量指定了crond的任務執行信息將通過電子郵件發送給root用戶,如果MAILTO變量的值為空,則表示不發送任務執行信息給用戶,第四行的HOME變量指定了在執行命令或者腳本時使用的主目錄。
用戶任務調度:用戶定期要執行的工作,比如用戶數據備份、定時郵件提醒等。用戶可以使用 crontab 工具來定制自己的計劃任務。所有用戶定義的crontab文件都被保存在/var/spool/cron目錄中。其文件名與用戶名一致,使用者權限文件如下:
/etc/cron.deny 該文件中所列用戶不允許使用crontab命令
/etc/cron.allow 該文件中所列用戶允許使用crontab命令
/var/spool/cron/ 所有用戶crontab文件存放的目錄,以用戶名命名
使用注意事項:
注意環境變量問題
有時我們創建了一個crontab,但是這個任務卻無法自動執行,而手動執行這個任務卻沒有問題,這種情況一般是由于在crontab文件中沒有配置環境變量引起的。
在 crontab文件中定義多個調度任務時,需要特別注意的一個問題就是環境變量的設置,因為我們手動執行某個任務時,是在當前shell環境下進行的,程 序當然能找到環境變量,而系統自動執行任務調度時,是不會加載任何環境變量的,因此,就需要在crontab文件中指定任務運行所需的所有環境變量,這 樣,系統執行任務調度時就沒有問題了。
不要假定cron知道所需要的特殊環境,它其實并不知道。所以你要保證在shelll腳本中提供所有必要的路徑和環境變量,除了一些自動設置的全局變量。所以注意如下3點:
1)腳本中涉及文件路徑時寫全局路徑;
2)腳本執行要用到java或其他環境變量時,通過source命令引入環境變量,如:
cat start_cbp.sh
#!/bin/sh
source /etc/profile
export RUN_CONF=/home/d139/conf/platform/cbp/cbp_jboss.conf
/usr/local/jboss-4.0.5/bin/run.sh -c mev &
3)當手動執行腳本OK,但是crontab死活不執行時。這時必須大膽懷疑是環境變量惹的禍,并可以嘗試在crontab中直接引入環境變量解決問題。如:
0 * * * * . /etc/profile;/bin/sh /var/www/java/audit_no_count/bin/restart_audit.sh
注意清理系統用戶的郵件日志(命令:rm -f /val/mail/root )
每條任務調度執行完畢,系統都會將任務輸出信息通過電子郵件的形式發送給當前系統用戶,這樣日積月累,日志信息會非常大,可能會影響系統的正常運行,因此,將每條任務進行重定向處理非常重要。
例如,可以在crontab文件中設置如下形式,忽略日志輸出:
0 */3 * * * /usr/local/apache2/apachectl restart >/dev/null 2>&1
“/dev/null 2>&1”表示先將標準輸出重定向到/dev/null,然后將標準錯誤重定向到標準輸出,由于標準輸出已經重定向到了/dev/null,因此標準錯誤也會重定向到/dev/null,這樣日志輸出問題就解決了。
系統級任務調度主要完成系統的一些維護操作,用戶級任務調度主要完成用戶自定義的一些任務,可以將用戶級任務調度放到系統級任務調度來完成(不建議這么 做),但是反過來卻不行,root用戶的任務調度操作可以通過“crontab –uroot –e”來設置,也可以將調度任務直接寫入/etc /crontab文件,需要注意的是,如果要定義一個定時重啟系統的任務,就必須將任務放到/etc/crontab文件,即使在root用戶下創建一個 定時重啟系統的任務也是無效的。
其他注意事項
新創建的cron job,不會馬上執行,至少要過2分鐘才執行。如果重啟cron則馬上執行。
當crontab突然失效時,可以嘗試/etc/init.d/crond restart解決問題。或者查看日志看某個job有沒有執行/報錯tail -f /var/log/cron。
千萬別亂運行crontab -r。它從Crontab目錄(/var/spool/cron)中刪除用戶的Crontab文件。刪除了該用戶的所有crontab都沒了。
在crontab中%是有特殊含義的,表示換行的意思。如果要用的話必須進行轉義%,如經常用的date ‘+%Y%m%d’在crontab里是不會執行的,應該換成date ‘+%Y%m%d’。
總結
以上是生活随笔為你收集整理的linux管理进程和计划任务,Linux进程和计划任务管理的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JSON对象转化为JSON字符串
- 下一篇: linux命令中的cp,Linux高级技