Linux scp 後臺執行傳輸檔案

haoge0205發表於2018-09-10

Linux scp 設定nohup後臺執行

1.正常執行scp命令

從oradb30機器複製一個資料夾到oradb31機器:
scp -r /u01/media/Disk1/ 192.168.1.31:/u01/media/

[root@oradb30 ~]# scp -r /u01/media/Disk1/ 192.168.1.31:/u01/media/reverse mapping checking getaddrinfo for bogon failed - POSSIBLE BREAK-IN ATTEMPT!
root@192.168.1.31's password: 
...
filegroup2.jar                                                                                                                                              100%   84KB  83.8KB/s   00:00    
filegroup9.jar                                                                                                                                              100%   16KB  16.1KB/s   00:00

2.輸入ctrl + z 暫停任務

輸入ctrl + z 暫停

[1]+  Stopped                 scp -r /u01/media/Disk1/ 192.168.1.31:/u01/media/[root@oradb30 ~]#

此時檢視jobs:

[root@oradb30 ~]# jobs[1]+  Stopped                 scp -r /u01/media/Disk1/ 192.168.1.31:/u01/media/[root@oradb30 ~]#

3.bg將其放入後臺

bg將該任務號放入後臺:

[root@oradb30 media]# bg %1[1]+ scp -r Disk1/ 192.168.1.31:/u01/media/ &

檢視任務已經在後臺執行:

[root@oradb30 media]# jobs[1]+  Running                 scp -r Disk1/ 192.168.1.31:/u01/media/ &

4.disown -h 將這個作業忽略HUP訊號

使用disown -h 將這個作業忽略HUP訊號:

[root@oradb30 media]# disown -h %1[root@oradb30 media]# jobs[1]+  Running                 scp -r Disk1/ 192.168.1.31:/u01/media/ &

檢視任務執行狀態和父程式號:

[root@oradb30 media]# ps -ef|grep scproot     12704 12638  0 05:19 pts/0    00:00:01 scp -r Disk1  192.168.1.31 /u01/media/
root     12705 12704  8 05:19 pts/0    00:00:17 /usr/bin/ssh -x -oForwardAgent no -oPermitLocalCommand no -oClearAllForwardings yes 192.168.1.31 scp -r -t /u01/media/
root     12823 12638  0 05:22 pts/0    00:00:00 grep scp

5.測試會話中斷,任務繼續執行不受影響

斷開該會話測試任務是否可以繼續後臺執行:

[root@oradb30 media]# exitlogout
Last login: Thu Jan  5 05:19:50 2017 from 192.168.1.198[root@oradb30 ~]# [root@oradb30 ~]# [root@oradb30 ~]# [root@oradb30 ~]# ps -ef|grep scproot     12704     1  0 05:19 ?        00:00:02 scp -r Disk1  192.168.1.31 /u01/media/
root     12705 12704  8 05:19 ?        00:00:17 /usr/bin/ssh -x -oForwardAgent no -oPermitLocalCommand no -oClearAllForwardings yes 192.168.1.31 scp -r -t /u01/media/
root     12854 12829  0 05:22 pts/2    00:00:00 grep scp

發現scp任務繼續執行,沒有因為會話斷開而中斷,父程式號變為1。

如果有其他任務需要使用nohup後臺執行,但執行時卻忘記了使用nohup,也可以參照此方法進行設定。

如果配置好ssh無密碼登陸,也可以直接 nohup scp .. & 執行。


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28939273/viewspace-2213871/,如需轉載,請註明出處,否則將追究法律責任。

相關文章