記錄一次 數據遷移的過程

新服務器  html

安裝對應軟件 linux

遷移項目策略sql

上傳文件夾 修改成別的文件夾  而後把這個文件夾打包 tar czvf userfiles3.tar userfiles3/安全

10G估計5分鐘左右bash

而後快速改回服務器

而後  進行scp傳輸app

先說下經常使用的狀況:ssh

兩臺機器IP分別爲:A.104.238.161.75,B.43.224.34.73。ide

在A服務器上操做,將B服務器上/home/lk/目錄下全部的文件所有複製到本地的/root目錄下,命令爲:scp -r root@43.224.34.73:/home/lk /root。測試

具體過程爲:

[root@XX ~]# scp -r root@43.224.34.73:/home/lk /root
root@43.224.34.73's password: 
k2.sql                                                     100%    0     0.0KB/s   00:00    
k.zip                                                      100%  176     0.2KB/s   00:00    
.bash_history                                              100%   32     0.0KB/s   00:00    
.bash_logout                                               100%   18     0.0KB/s   00:00    
.bashrc                                                    100%  231     0.2KB/s   00:00    
k3.sql                                                     100%    0     0.0KB/s   00:00    
.bash_profile                                              100%  193     0.2KB/s   00:00    
[root@XX ~]# ls

在A服務器上將/root/lk目錄下全部的文件傳輸到B的/home/lk/cpfile目錄下,命令爲:scp -r /root/lk root@43.224.34.73:/home/lk/cpfile。

具體過稱爲:

[root@XX lk]# scp -r /root/lk root@43.224.34.73:/home/lk/cpfile
root@43.224.34.73's password: 
k2.sql                                                     100%    0     0.0KB/s   00:00    
k3.sql                                                     100%    0     0.0KB/s   00:00    
.bash_profile                                              100%  193     0.2KB/s   00:00    
.bash_logout                                               100%   18     0.0KB/s   00:00    
.bash_history                                              100%   32     0.0KB/s   00:00    
k.zip                                                      100%  176     0.2KB/s   00:00    
.bashrc                                                    100%  231     0.2KB/s   00:00    
[root@XX lk]#

scp在誇機器複製的時候爲了提升數據的安全性,使用了ssh鏈接和加密方式,若是機器之間配置了ssh免密碼登陸,那在使用scp的時候密碼都不用輸入。

命令詳解:

scp是secure copy的簡寫,用於在Linux下進行遠程拷貝文件的命令,和它相似的命令有cp,不過cp只是在本機進行拷貝不能跨服務器,並且scp傳輸是加密的。可能會稍微影響一下速度。當你服務器硬盤變爲只讀 read only system時,用scp能夠幫你把文件移出來。另外,scp還很是不佔資源,不會提升多少系統負荷,在這一點上,rsync就遠遠不及它了。雖然 rsync比scp會快一點,但當小文件衆多的狀況下,rsync會致使硬盤I/O很是高,而scp基本不影響系統正常使用。

1.命令格式:

scp [參數] [原路徑] [目標路徑]

2.命令功能:

scp是 secure copy的縮寫, scp是linux系統下基於ssh登錄進行安全的遠程文件拷貝命令。linux的scp命令能夠在linux服務器之間複製文件和目錄。

3.命令參數:

-1  強制scp命令使用協議ssh1  

-2  強制scp命令使用協議ssh2  

-4  強制scp命令只使用IPv4尋址  

-6  強制scp命令只使用IPv6尋址  

-B  使用批處理模式(傳輸過程當中不詢問傳輸口令或短語)  

-C  容許壓縮。(將-C標誌傳遞給ssh,從而打開壓縮功能)  

-p 保留原文件的修改時間,訪問時間和訪問權限。  

-q  不顯示傳輸進度條。  

-r  遞歸複製整個目錄。  

-v 詳細方式顯示輸出。scp和ssh(1)會顯示出整個過程的調試信息。這些信息用於調試鏈接,驗證和配置問題。   

-c cipher  以cipher將數據傳輸進行加密,這個選項將直接傳遞給ssh。   

-F ssh_config  指定一個替代的ssh配置文件,此參數直接傳遞給ssh。  

-i identity_file  從指定文件中讀取傳輸時使用的密鑰文件,此參數直接傳遞給ssh。    

-l limit  限定用戶所能使用的帶寬,以Kbit/s爲單位。     

-o ssh_option  若是習慣於使用ssh_config(5)中的參數傳遞方式,   

-P port  注意是大寫的P, port是指定數據傳輸用到的端口號   

-S program  指定加密傳輸時所使用的程序。此程序必須可以理解ssh(1)的選項。

4.使用實例:

scp命令的實際應用概述:  

從本地服務器複製到遠程服務器: 

(1) 複製文件:  

命令格式:  

scp local_file remote_username@remote_ip:remote_folder  

或者  

scp local_file remote_username@remote_ip:remote_file  

或者  

scp local_file remote_ip:remote_folder  

或者  

scp local_file remote_ip:remote_file  

第1,2個指定了用戶名,命令執行後須要輸入用戶密碼,第1個僅指定了遠程的目錄,文件名字不變,第2個指定了文件名  

第3,4個沒有指定用戶名,命令執行後須要輸入用戶名和密碼,第3個僅指定了遠程的目錄,文件名字不變,第4個指定了文件名   

(2) 複製目錄:  

命令格式:  

scp -r local_folder remote_username@remote_ip:remote_folder  

或者  

scp -r local_folder remote_ip:remote_folder  

第1個指定了用戶名,命令執行後須要輸入用戶密碼;  

第2個沒有指定用戶名,命令執行後須要輸入用戶名和密碼;

 

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 scp
root     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]# exit
logout

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 scp
root     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 .. & 執行。

相關文章
相關標籤/搜索