原文出处:
http://blog.itpub.net/205377/viewspace-1755848/
http://blog.csdn.net/shaochenshuo/article/details/51442610
有的时候我们需要SCP拷贝的文件很大,不能一直等着,那如何使SCP可以在后台运行呢?
下面介绍一个简单的方法:1、 运行SCP命令
[root@test dpdir]# nohup scp OUTDB_ERR??.dmp oracle@192.168.1.133:/oradir
2、 输入密码
nohup: appending output to nohup.out
oracle@ 192.168.1.133's password:
此时输完密码进程会挂起,还是在前台运行
3、 输入ctrl+z暂停程序
会出现如下提示:
[1]+ Stopped nohup scp OUTDB_ERR??.dmp oracle@192.168.1.133:/oradir
4、 执行bg使进程在后台继续运行
[root@test dpdir]# bg
[1]+ nohup scp OUTDB_ERR??.dmp oracle@192.168.1.133:/oradir &
[root@test dpdir]#
这样4步可以使SCP在后台运行,搞定

整个过程的输出日志大概下面这样,仅供参考。
====================================
linux 下后台执行scp
因为要传输一个大文件到另一台服务器上,因为传输速度不是很高,传输需要十几个小时,为了保证传输过程不会因为其他原因导致中断,准备把scp放到后台运行。说到后台执行 我们都知道 nohup command &,但是scp命令需要输入密码,所以无法直接使用nohup 。
方法1:
我们可以先配置两台服务器之间的互信,然后在执行
1)配置互信
ssh-keygen -t rsa
ssh-copy-id -i /root/.ssh/id_rsa.pub root@172.172.230.211
##配置成功后,可以在本服务器免密码登录172.172.230.211
2)后台执行scp
nohup scp -l 100000 test.tar root@172.172.230.211:/data &
##可以使用-l控制传输速度,传输过程中占用过大带宽,影响其他服务器。(100000/8/1024=12M)
方法2:使用bg命令转后台执行
1) 直接执行scp
scp -l 100 ibdata1 root@172.172.230.211:/data
2) 查看scp进程号
ps -a
PID TTY TIME CMD
30761 pts/4 00:12:45 mysql
31928 pts/5 00:00:00 scp
31930 pts/5 00:00:00 ssh
32006 pts/3 00:00:00 ps
3) 暂停进程
kill -stop procNumber
kill -stop 31928 >>命令输出如下:
- [root@shaofei-test-mysql-01 db_recover]# scp -l 100 ibdata1 root@172.172.230.211:/data
- root@172.172.230.211's password:
- ibdata1 0% 3024KB 12.6KB/s 39:22:36 ET
- <span style="color:#ff0000;">[1]+</span> Stopped scp -l 100 ibdata1 root@172.172.230.211:/data
4) 查看jobs
- jobs
- 1]+ Stopped scp -l 100 ibdata1 root@172.172.230.211:/data
4) 把scp转到后台执行
bg 1 >>命令输出如下:
- bg 1
- 1]+ scp -l 100 ibdata1 root@172.172.230.211:/data &
- bg 1
- -bash: bg: 1: no such job
##可以使用fg jobnum 把进程掉到前台来执行