您现在的位置是: Home> 学无止境> Linux> Linux
Linux下实现跨服务器数据同步
张伟江2019-07-19 18:00【Linux】7015人已围观
简介scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且scp传输是加密的。
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,从而打开压缩功能)启用压缩。通过指明 -C 参数来开启压缩模式。 |
-p | 保留原文件的修改时间,访问时间和访问权限。 |
-q | 不显示传输进度条。 |
-r | 递归复制整个目录。 |
-v | 详细方式显示输出。scp和ssh(1)会显示出整个过程的调试信息。这些信息用于调试连接,验证和配置问题。 |
-c | cipher 以cipher将数据传输进行加密,这个选项将直接传递给ssh。加密方式 选择在传输过程中用来加密的加密方式 这个选项会被直接传递到 ssh(1)。 |
-F | ssh_config 指定一个替代的ssh配置文件,此参数直接传递给ssh。 ssh 配置 给 ssh 指定一个用来替代默认配置的配置文件。这个选项会被直接传递到 ssh(1) |
-i | identity_file 从指定文件中读取传输时使用的密钥文件,此参数直接传递给ssh。 |
-l | limit 限定用户所能使用的带宽,以Kbit/s为单位。限速 限制命令使用的带宽,默认单位是 Kbit/s。 |
-o | ssh_option 如果习惯于使用ssh_config(5)中的参数传递方式, |
-P | port 注意是大写的P, port是指定数据传输用到的端口号。端口 指定需要的连接的远程主机的端口。注意,这个选项使用的是一个大写的“P”,因为小写的“-p”已经用来保留目标文件的时间和模式相关信息。(LCTT 译注:ssh 命令中使用小写的“-p”来指定目标端口。) |
-S | program 指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。 |
【1、安装 expect】
yum install expect
【2、复制以下脚本并执行】
#!/bin/bash
# sync跨服务器数据同步
# author ctocode-zwj <982215226@qq.com>
function ctocodeLinuxSync()
{
echo "|----------------------------------------------------------"
echo "|========== sync ---- $1 --- start =========="
echo "|----------------------------------------------------------"
echo ""
echo "== 1.1、if dir "
echo "== 1.2、delete remote ECS nginx vhosts "
echo "== 1.3、delete remote ECS program "
echo ""
ssh -t root@"$1" "
[[ -d /alidata/www/phplog ]] || mkdir /alidata/www/phplog;
[[ -d /alidata/www/ctocode_website ]] || mkdir /alidata/www/ctocode_website;
[[ -d /alidata/www/ctocode_website_log ]] || mkdir /alidata/www/ctocode_website_log;
[[ -d /alidata/www/ctocode_website_log_cms ]] || mkdir /alidata/www/ctocode_website_log_cms;
[[ -d /alidata/www/ctocode_website_log_shop ]] || mkdir /alidata/www/ctocode_website_log_shop;
[[ -d /alidata/www/ctocode_website_nginx_vhosts ]] || mkdir /alidata/www/ctocode_website_nginx_vhosts;
rm -r /alidata/www/ctocode_website_nginx_vhosts/*;
rm -r /alidata/www/ctocode_website/*;
"
echo ""
echo "== 2.1、copy local nginx vhosts to remote ECS "
echo ""
scp -r /alidata/www/ctocode_website_nginx_vhosts/* root@"$1":/alidata/www/ctocode_website_nginx_vhosts/
echo ""
echo "== 2.2、copy local program to remote ECS "
scp -rq /alidata/www/ctocode_website/* root@"$1":/alidata/www/ctocode_website/
echo ""
echo "== 3.1、restart remote ECS nginx "
echo "== 3.2、setting dir/file right "
ssh -t root@"$1" "
chmod -R 777 /alidata/www/ctocode_website/data;
chmod -R 777 /alidata/www/ctocode_website/ctocode-php-frame/function;
chmod -R 777 /alidata/www/ctocode_website/domain_cms/data;
chmod -R 777 /alidata/www/ctocode_website/domain_shop/data;
/etc/init.d/nginx restart;
"
echo ""
echo "|----------------------------------------------------------"
echo "|========== sync ---- $1 --- success =========="
echo "|----------------------------------------------------------"
echo ""
}
echo "|----------------------------------------"
echo "|"
echo "|========== ctocode-linux-sync =========="
echo "|"
echo "|----------------------------------------"
# 本机内网ip
localIp="*.*.*.*"
# 远程内网ip数组密码
remoteIpPwd="****"
# 远程内网ip数组
remoteIpArr[0]=*.*.*.*
remoteIpArr[1]=*.*.*.*
#for 循环遍历 -- 同步
for remoteIp in ${remoteIpArr[@]};
do
# expect 免密登录
/bin/expect <<-EOF
set timeout 30
spawn scp -r /root/.ssh/id_rsa.pub root@$remoteIp:/root/${localIp}_id_rsa.pub
# 监听询问,这句意思是交互获取是否返回password:
# send就是将密码zjk123发送过去
expect {
"*yes/no" { send "yes\r";exp_continue }
"password:" { send "$remoteIpPwd\r" }
}
# 将本机公钥追加到远程主机的authorized文件中
spawn ssh -t root@$remoteIp echo > /root/.ssh/authorized_keys
spawn ssh -t root@$remoteIp cat /root/${localIp}_id_rsa.pub >> /root/.ssh/authorized_keys
expect {
"*yes/no" { send "yes\r";exp_continue }
"*password:" { send "$remoteIpPwd\r" }
}
# interact代表执行完留在远程控制台,不加这句执行完后返回本地控制台
# interact
# expect eof
EOF
# -- 数据同步
ctocodeLinuxSync $remoteIp $localIp
done
echo "|----------------------------------------"
echo "|"
echo "|========== ctocode-linux-sync =========="
echo "|"
echo "|----------------------------------------"
rsync 数据同步
参考链接:http://man.linuxde.net/rsync
检查linux 是否有安装rsync
1、指令# rpm -qa rsync
出现rsync 包名就是安装了
2、指令# rsync
出现帮助信息说明已经安装
time rsync -aCvq repository root@mas2:/usr/nci/;
两台服务器传文件,用rsync传输增量时报错
rsync -ravzut -e ‘ssh -p 8004’ –progress /alidata1/70-sc-project/1031/ root@**:/alidata1/70-sc-project/1031/
错误如下:
bash: rsync: command not found
rsync: connection unexpectedly closed (0 bytes received so far) [sender]
rsync error: remote command not found (code 127) at io.c(600) [sender=3.0.6]
发现是文件接收端没有安装rsync命令,需要现在接收端安装执行 yum install rsync -y 命令即可
- END -
Next:Linux下gitlab的安装与使用
文章评论 共有 1 条评论
发表评论 取消回复
点击排行
本栏推荐
标签云
猜你喜欢
打赏本站
- 如果你觉得本站很棒,可以通过扫码支付打赏哦!
- 微信扫码:你说多少就多少~
- 支付宝扫码:你说多少就多少~
写得非常好