近段时间工作需要做了些scp和rsync的异地安全备份,整理了一下,希望多大家有用。

scp的备份指南:

需求:用scp自动完成异地文件的定时copy

难点:如何让异地主机建立安全的信任关系

1、在A机器上用root运行ssh-keygen,将生成/root/.ssh/identity和/root/.ssh/identity.pub两个文件;

2、在A机器上运行scp /root/.ssh/identity.pub test@192.168.1.10:/upload/.ssh/authorized_keys(假设B机器的IP地址为192.168.1.10,B

机器上开了用户test,要上传到的目录是/upload,需输入密码)。目的是将本地的identity.pub放到远程机器上并改名为

authorized_keys,这样就建立了新任主机,以后就不需要每次ssh都需要输入密码了;

3、通过crontab建立脚本,例:30 02 * * 1-5 scp /home/data/* test@192.168.1.10:/upload。

(每天2:30am自动将/home/data下面的所有文件以test用户名传到远程主机192.168.1.10的/upload目录中);

认证原理:

如果你希望从A作为用户user1 SSH 到B 作为用户user2, 若要用RSA键对法认证且不需要密码,则B上的ssh

后台程序拿出~user2/.ssh/authorized_keys中的与A有关的RSA公钥来对A上的以user1身份运行的ssh客户程序进行挑战,前面我们已经把A上的identity.pub拷贝到B上作为authorized_keys了。则A保持私钥identity,而B上的sshd又拿出A的公钥来挑战,因此成功,你可以加很多行到authorized_keys以允许其它服务器的公钥可以加进来。

scp特点:

使用ssl加密,安全性高。

rsync的备份指南:

需求:用rsync完成异地文件的同步

难点:如何建立异地信任关系

1、在A主机上(rsync服务器)上编译安装rsync,需要版本在2.4.3以上(http://rsync.samba.org),在/etc目录下建立rsyncd.conf文件,内容如下:

uid = nobody

gid = nobody

use chroot = no # 不使用chroot

max connections = 4 # 最大连接数为4

log file = /var/log/rsyncd.log

pid file = /var/run/rsyncd.pid

lock file = /var/run/rsync.lock # 日志记录文件

[test] # 这里是认证的模块名,在客户端需要指定

path = /home/test # 需要同步的目录

comment = test folder

uid = root

ignore errors # 可以忽略一些无关的IO错误

read only = yes # 只读

list = no # 不允许列文件

auth users = rsynctest # 认证的用户名,如果没有这行,则表明是匿名

secrets file = /etc/test.scrt # 认证用户密码文件

2、在/etc下建立test.scrt文件,输入:

用户名:密码

例:rsynctest:testrsync

将文件属性修改为600(千万注意)

3、启动rsync服务:rsync --daemon (rsync运行在tcp 873端口,可以通过netstat

-an|grep LISTEN察看)。

4、在B主机上(rsync客户机)上建立/etc/test文件,内容为A主机的密码,例:

testsync

5、用crontab建立脚本,例:0 21 * * 1-5 rsync -vzrtp --progress --delete

--password-file=/etc/test rsynctest@192.168.1.10::test

/home/rsynctest

rsync中的参数:v是verbose,z是压缩,r是recursive,tp都是保持文件原有属性如属主、时间

的参数。--progress是指显示出详细的进度情况,--delete是指如果服务器端删除了这一文件,那么客户端也相应把文件删除,保持真正的一致。--password-file=/etc/test来指定密码文件,这样就可以在脚本中使

用而无需交互式地输入验证密码了,这里需要注意的是这份密码文件权限属性要设得只有属主可读(600)。

rsynctest@192.168.1.10中,rsynctest是指定密码文件中的用户名,192.168.1.10是A主机的IP地址::test是指模块名[test],也就是在/etc/rsyncd.conf中自定义的名称。最后的/home/rsynctest是备份到本地的目录名。

(也可以用-e ssh的参数建立起加密的连接,然后和scp中信任主机的办法一样如法炮制)

(在上面实例中的rsynctest并不是真实的用户,可以根据自己需要文本定义,这也是使用rsync的一大好处)

rsync的特点:

特性如下:

1、可以镜像保存整个目录树和文件系统。

2、可以很容易做到保持原来文件的权限、时间、软硬链接等等。

3、无须特殊权限即可安装。

4、优化的流程,文件传输效率高。

5、可以使用rcp、ssh等方式来传输文件,当然也可以通过直接的socket连接。

6、支持匿名传输。

rsync的功能还很强大,深入的眼就可以到官方网站上了解。

linux中scp -r命令,Linux 下scp和rsync的使用(转)相关推荐

  1. linux中清理缓存命令,linux清理缓存的命令

    查看缓存的命令 free -m 清理缓存的命令 echo 1 > /proc/sys/vm/drop_caches echo 2 > /proc/sys/vm/drop_caches ec ...

  2. linux中C编译命令,linux下命令行下编译c程式

    linux下命令行下编译c程式 2008-02-23 05:41:36来源:互联网 阅读 () C 是任何版本的UNIX上的系统语言. C 在过去的二十年中有了很大的发展. 在80年代末期美国国家标准 ...

  3. linux中往sed命令,Linux中Sed命令怎么用?

    Linux中Sed命令怎么用? 发布时间:2020-05-26 17:14:39 来源:亿速云 阅读:245 作者:鸽子 Sed介绍:sed是文本处理工具,读取文本内容,根据指定的条件进行处理如删除. ...

  4. 在linux中的sort命令,linux中sort命令

    功能说明:将文本文件内容加以排序,sort可针对文本文件的内容,以行为单位来排序. 参 数: -b 忽略每行前面开始出的空格字符. -c 检查文件是否已经按照顺序排序. -d 排序时,处理英文字母.数 ...

  5. linux 中的 ln 命令,Linux中ln命令的用法以及分析

    在ubuntu用也有类似于windows中快捷方式这种类型的东西,即链接.这里一般使用ln命令来执行得到,ln命令用法简单,但是与windows不同,这里有硬链接和软链接两种类型的链接.在介绍两种链接 ...

  6. linux 中重启 关机命令,Linux关机命令和重启命令说明

    在Linux中,常用的关机命令shutdown.halt.poweroff.init:重启命令有:reboot.本文将主要为大家带来一些常用的关机命令以及各种关机命令之间的区别和具体用法. 关机命令: ...

  7. linux中剪切文件命令,Linux文件处理常用命令操作技巧

    我是Linux初学者,做个笔记,以下是Linux几个常用文件处理命令: 命令提示符 [root@localhost~]# 其中: root                          表示当前登 ...

  8. linux中的ul命令,linux lin命令

    ln是linux中又一个非常重要命令,它的功能是为某一个文件在另外一个位置建立一个同不的链接,这个命令最常用的参数是-s,具体用法是:ln –s 源文件 目标文件. 当我们需要在不同的目录,用到相同的 ...

  9. linux中scp -r命令,linux:scp从入门到刚入门

    Objective-C 关联 在项目开发中,经常会使用到关联,就是将两个实例对象绑定,使得其中一个实例对象成为另一个实例对象的一部分.关联特性在mac os 10.6 及ios 3.1以上才可以使用. ...

最新文章

  1. access update语句执行_MySQL 中 update 修改数据与原数据相同会再次执行吗?
  2. “中台不就是微服务吗?有啥区别?”
  3. 一次线上JVM调优实践,FullGC40次/天到10天一次的优化过程
  4. Oracle数据库的一些常用命令
  5. 设置LD_LIBRARY_PATH不起作用解决
  6. Spark精华问答 | Spark和Hadoop的架构区别解读
  7. Linux系统编程23:基础IO之了解硬盘物理和逻辑结构及明白inode的本质和掌握软硬链接及其区别
  8. freerdp 解压安装_Linux下安装FreeRDP,连接windows远程桌面的好软件 | 学步园
  9. 波士顿动力十年对比刷屏,网友:以后该不会变成终结者吧?
  10. matlab 求二值图像图形的面积和重心
  11. 数据库事务4种隔离级别及7种传播行为(三)
  12. Wpe工作原理和教程-以传奇为列
  13. Unity实现简单卡牌游戏框架
  14. 安卓手机上最好的3个小说阅读器
  15. html中颜色打字机效果,基于Css3和JQuery实现打字机效果
  16. web数据可视化(ECharts版)
  17. 正则表达式在JS中的应用,判断邮箱是否合法
  18. Matplotlib绘制箱线图
  19. wim文件怎么安装系统 wim文件安装系统教程
  20. 【苹果群发】苹果推iMessage接口筛选应用程序利用密钥箱生成CSR文书

热门文章

  1. [智能家居]DIY下雨感应器 接入HomeAssistant实现下雨语音提醒
  2. 2021-2027全球与中国嵌入式调制解调器市场现状及未来发展趋势
  3. iOS开发系列–打造自己的“美图秀秀”
  4. Java 17 新特性:密封类
  5. lol3.10日服务器维护,英雄联盟3月10日更新维护时间 LOL10.5版本维护结束时间
  6. DFXCGBFCBFDBSRFHDSG
  7. 在html中金色怎么写,HTML5 3款设计精美的暗金色文本输入框
  8. 雅思培训心得(2)口语考试应对策略(8-8更新)
  9. MIUI13和MIUI12的录音存储位置
  10. 数学金字塔C语言原函数,课内资源 - 基于C语言实现的金字塔问题(Pyramid Problem)...