查看遷移失敗文件列表master/jobs/${JobName}/failed_tasks/${TaskName}/error.list,獲取失敗文件的相對路徑。
成都創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站建設(shè)、做網(wǎng)站、歙縣網(wǎng)絡(luò)推廣、微信平臺小程序開發(fā)、歙縣網(wǎng)絡(luò)營銷、歙縣企業(yè)策劃、歙縣品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供歙縣建站搭建服務(wù),24小時服務(wù)熱線:028-86922220,官方網(wǎng)址:www.cdcxhl.com
確認是否有這部分文件的權(quán)限訪問、文件是否被刪除、是否是軟鏈接文件、文件名是否存在亂碼等。
解決以上問題后,使用retry命令進行重試。
busybox是一個集成了許多常用Linux命令的工具箱,但它并不包含jobs命令。jobs命令通常用于查看當前shell中的作業(yè)列表和狀態(tài),對于busybox而言,可以使用其他命令來達到相同的效果。
例如,可以使用ps命令來查看當前進程的狀態(tài),包括正在運行的進程和已經(jīng)掛起的進程。使用以下命令可以查看所有進程的狀態(tài):
plaintext
Copy code
busybox ps -ef
另外,可以使用bg命令將一個已經(jīng)掛起的進程轉(zhuǎn)移到后臺運行,使用fg命令將一個掛起的進程轉(zhuǎn)移到前臺,并使用kill命令殺死一個進程。這些命令可以幫助管理進程和作業(yè)。
Linux進程調(diào)度
1.調(diào)度方式
Linux系統(tǒng)的調(diào)度方式基本上采用“ 搶占式優(yōu)先級 ”方式,當進程在用戶模式下運行時,不管它是否自愿,核心在一定條件下(如該進程的時間片用完或等待I/O)可以暫時中止其運行,而調(diào)度其他進程運行。一旦進程切換到內(nèi)核模式下運行時,就不受以上限制,而一直運行下去,僅在重新回到用戶模式之前才會發(fā)生進程調(diào)度。
Linux系統(tǒng)中的調(diào)度基本上繼承了UNIX系統(tǒng)的 以優(yōu)先級為基礎(chǔ) 的調(diào)度。也就是說,核心為系統(tǒng)中每個進程計算出一個優(yōu)先級,該優(yōu)先級反映了一個進程獲得CPU使用權(quán)的資格,即高優(yōu)先級的進程優(yōu)先得到運行。核心從進程就緒隊列中挑選一個優(yōu)先級最高的進程,為其分配一個CPU時間片,令其投入運行。在運行過程中,當前進程的優(yōu)先級隨時間遞減,這樣就實現(xiàn)了“負反饋”作用,即經(jīng)過一段時間之后,原來級別較低的進程就相對“提升”了級別,從而有機會得到運行。當所有進程的優(yōu)先級都變?yōu)?(最低)時,就重新計算一次所有進程的優(yōu)先級。
2.調(diào)度策略
Linux系統(tǒng)針對不同類別的進程提供了3種不同的調(diào)度策略,即SCHED_FIFO、SCHED_RR及SCHED_OTHER。其中,SCHED_FIFO適合于 短實時進程 ,它們對時間性要求比較強,而每次運行所需的時間比較短。一旦這種進程被調(diào)度且開始運行,就一直運行到自愿讓出CPU或被優(yōu)先級更高的進程搶占其執(zhí)行權(quán)為止。
SCHED_RR對應(yīng)“時間片輪轉(zhuǎn)法”,適合于每次運行需要 較長時間的實時進程 。一個運行進程分配一個時間片(200 ms),當時間片用完后,CPU被另外進程搶占,而該進程被送回相同優(yōu)先級隊列的末尾,核心動態(tài)調(diào)整用戶態(tài)進程的優(yōu)先級。這樣,一個進程從創(chuàng)建到完成任務(wù)后終止,需要經(jīng)歷多次反饋循環(huán)。當進程再次被調(diào)度運行時,它就從上次斷點處開始繼續(xù)執(zhí)行。
SCHED_OTHER是傳統(tǒng)的UNIX調(diào)度策略,適合于交互式的 分時進程 。這類進程的優(yōu)先級取決于兩個因素:一個是進程剩余時間配額,如果進程用完了配給的時間,則相應(yīng)優(yōu)先級降到0;另一個是進程的優(yōu)先數(shù)nice,這是從UNIX系統(tǒng)沿襲下來的方法,優(yōu)先數(shù)越小,其優(yōu)先級越高。nice的取值范圍是-20 19。用戶可以利用nice命令設(shè)定進程的nice值。但一般用戶只能設(shè)定正值,從而主動降低其優(yōu)先級;只有特權(quán)用戶才能把nice的值設(shè)置為負數(shù)。進程的優(yōu)先級就是以上二者之和。
后臺命令對應(yīng)后臺進程(又稱后臺作業(yè))。后臺進程的優(yōu)先級低于任何交互(前臺)進程的優(yōu)先級。所以,只有當系統(tǒng)中當前不存在可運行的交互進程時,才調(diào)度后臺進程運行。后臺進程往往按批處理方式調(diào)度運行。
3.調(diào)度時機
核心進行進程調(diào)度的時機有以下5種情況:
(1)當前進程調(diào)用系統(tǒng)調(diào)用nanosleep( )或者pause( ),使自己進入睡眠狀態(tài),主動讓出一段時間的CPU的使用權(quán)。
(2)進程終止,永久地放棄對CPU的使用。
(3)在時鐘中斷處理程序執(zhí)行過程中,發(fā)現(xiàn)當前進程連續(xù)運行的時間過長。
(4)當喚醒一個睡眠進程時,發(fā)現(xiàn)被喚醒的進程比當前進程更有資格運行。
(5)一個進程通過執(zhí)行系統(tǒng)調(diào)用來改變調(diào)度策略或者降低自身的優(yōu)先級(如nice命令),從而引起立即調(diào)度。
4.調(diào)度算法
進程調(diào)度的算法應(yīng)該比較簡單,以便減少頻繁調(diào)度時的系統(tǒng)開銷。Linux執(zhí)行進程調(diào)度時,首先查找所有在就緒隊列中的進程,從中選出優(yōu)先級最高且在內(nèi)存的一個進程。如果隊列中有實時進程,那么實時進程將優(yōu)先運行。如果最需要運行的進程不是當前進程,那么當前進程就被掛起,并且保存它的現(xiàn)場—— 所涉及的一切機器狀態(tài),包括程序計數(shù)器和CPU寄存器等,然后為選中的進程恢復(fù)運行現(xiàn)場。
(二)Linux常用調(diào)度命令
· nohup命令
nohup命令的功能是以忽略掛起和退出的方式執(zhí)行指定的命令。其命令格式是:
nohup command [arguments]
其中,command是所要執(zhí)行的命令,arguments是指定命令的參數(shù)。
nohup命令告訴系統(tǒng),command所代表的命令在執(zhí)行過程中不受任何結(jié)束運行的信號(hangup和quit)的影響。例如,
$ nohup find / -name exam.txt -printf1
find命令在后臺運行。在用戶注銷后,它會繼續(xù)運行:從根目錄開始,查找名字是exam.txt的文件,結(jié)果被定向到文件f1中。
如果用戶沒有對輸出進行重定向,則輸出被附加到當前目錄的nohup.out文件中。如果用戶在當前目錄中不具備寫權(quán)限,則輸出被定向到$HOME/nohup.out 中。
· at命令
at命令允許指定命令執(zhí)行的時間。at命令的常用形式是:
at time command
其中,time是指定命令command在將來執(zhí)行時的時間和日期。時間的指定方法有多種,用戶可以使用絕對時間,也可以用相對時間。該指定命令將以作業(yè)形式在后臺運行。例如:
$ at 15:00 Oct 20
回車后進入接收方式,接著鍵入以下命令:
mail -s "Happy Birthday!" liuzheny
按下D鍵,屏幕顯示:
job 862960800.a at Wed Oct 20 15:00:00 CST 1999
$
表明建立了一個作業(yè),其作業(yè)ID號是862960800.a,運行作業(yè)的時間是1999年10月20日下午3:00,給liuzheny發(fā)一條標題為“Happy Birthday!”(生日快樂)的空白郵件。
利用 at -l 可以列出當前at隊列中所有的作業(yè)。
利用 at -r 可以刪除指定的作業(yè)。這些作業(yè)以前由at或batch命令調(diào)度。例如,
at -r 862960797.a
將刪除作業(yè)ID號是862960797.a的作業(yè)。其一般使用形式是:
at -r job_id
注意,結(jié)尾是.a的作業(yè)ID號,表示這個作業(yè)是由at命令提交的;結(jié)尾是.b的作業(yè)ID號,表示這個作業(yè)是由batch命令提交的。
· batch命令
batch命令不帶任何參數(shù),它提交的作業(yè)的優(yōu)先級比at命令提交的作業(yè)的優(yōu)先級低。batch無法指定作業(yè)運行的時間。實際運行時間要看系統(tǒng)中已經(jīng)提交的作業(yè)數(shù)量。如果系統(tǒng)中優(yōu)先級較高的作業(yè)比較多,那么,batch提交的作業(yè)則需要等待;如果系統(tǒng)空閑,則運行batch提交的作業(yè)。例如,
$ batch
回車后進入接收方式,接著鍵入命令:
find / -name exam.txt -print
按下D。退出接收方式,屏幕顯示:
job 862961540.b at Thu Nov 18 14:30:00 CST 1999
表示find命令被batch作為一個作業(yè)提交給系統(tǒng),作業(yè)ID號是862961540.b。如果系統(tǒng)當前空閑,這個作業(yè)被立即執(zhí)行,其結(jié)果同樣作為郵件發(fā)送給用戶。
· jobs命令
jobs命令用來顯示當前shell下正在運行哪些作業(yè)(即后臺作業(yè))。例如:
$ jobs
[2] + Running tar tv3 *
[1] - Running find / -name README -print logfile
$
其中,第一列方括號中的數(shù)字表示作業(yè)序號,它是由當前運行的shell分配的,而不是由操作系統(tǒng)統(tǒng)一分配的。在當前shell環(huán)境下,第一個后臺作業(yè)的作業(yè)號為1,第二個作業(yè)的作業(yè)號為2,等等。
第二列中的“ ”號表示相應(yīng)作業(yè)的優(yōu)先級比“-”號對應(yīng)作業(yè)的優(yōu)先級高。
第三列表明作業(yè)狀態(tài),是否為運行、中斷、等待輸入或停止等。
最后列出的是創(chuàng)建當前這個作業(yè)所對應(yīng)的命令行。
利用 jobs -l 形式,可以在作業(yè)號后顯示出相應(yīng)進程的PID。如果想只顯示相應(yīng)進程的PID,不顯示其它信息,則使用 jobs -p 形式。
· fg命令
fg命令把指定的后臺作業(yè)移到前臺。其使用格式是:
fg [job…]
其中,參數(shù)job是一個或多個進程的PID,或者是命令名稱或者作業(yè)號(前面要帶有一個“%”號)。例如:
$ jobs
[2] + Running tar tv3 *
[1] - Running find / -name README -print logfile
$ fg %find
find / -name README -print logfile
注意,顯示的命令行末尾沒有“”符號。下面命令能產(chǎn)生同樣的效果:
$ fg %1
這樣,find命令對應(yīng)的進程就在前臺執(zhí)行。當后臺只有一個作業(yè)時,鍵入不帶參數(shù)的fg命令,就能使相應(yīng)進程移到前臺。當有兩個或更多的后臺作業(yè)時,鍵入不帶參數(shù)的fg,就把最后進入后臺的進程首先移到前臺。
· bg命令
bg命令可以把前臺進程換到后臺執(zhí)行。其使用格式是:
bg [job…]
其中,job是一個或多個進程的PID、命令名稱或者作業(yè)號,在參數(shù)前要帶“%”號。例如,在cc(C編譯命令)命令執(zhí)行過程中,按下Z鍵,使這個作業(yè)掛起。然后鍵入以下命令:
$ bg %cc
該掛起的作業(yè)在后臺重新開始執(zhí)行。
jobs命令是用來顯示后臺工作的,所謂后臺工作是指在某個命令執(zhí)行的過程中(命令沒有執(zhí)行完,就是一些費用時間的命令,不會一下執(zhí)行結(jié)束的), 按下鍵盤上的Ctrl+Z組合鍵暫停進程并將之丟入后臺;還有一種情況是直接將命令放入后臺執(zhí)行,那就是在命令的最末尾加上一個符號,比如這條命令:tar -zxv -f test.tar.gz -C /tmp /dev/null 。如果你之前沒有這兩種操作,jobs命令是不會顯示任何內(nèi)容的,因為jobs命令是job control,也就是所謂的作業(yè)控制,而不是查看后臺進程的命令(它所顯示的后臺工作,是指作業(yè)控制中的工作)。