linux/centos rsync安装配置教程

   一、服务器端配置:

  # yum -y install xinetd

  # vi /etc/xinetd.d/rsync

  将如下代码

  service rsync

  {

  disable = yes

  socket_type = stream

  wait = no

  user = root

  server = /usr/bin/rsync

  server_args = –daemon

  log_on_failure += USERID

  }

  中的 disable = yes 改成 disable = no

  然后启动 xinetd

  # /etc/init.d/xinetd start 或 service xinetd restart

  注意:如果服务器上装有防火墙记得要打开端口,默认端口是873

  # telnet 127.0.0.1 873

  Trying 127.0.0.1...

  telnet: connect to address 127.0.0.1: Connection refused

  # iptables -A INPUT -s 192.168.0.0/255.255.255.0 -p tcp -m tcp --dport 873 -j ACCEPT

  # iptables -A INPUT -p tcp -m tcp --dport 873 -j DROP

  # vi /etc/rsyncd.conf (这个文件如果不存在自己创建)

  #Global Settings

  uid = root #以什么身份运行rsync

  gid = root

  use chroot = no #不使用chroot

  max connections = 20 #最大连接数

  secrets file = /etc/rsyncd.secrets #密码文件位置,认证文件设置,设置用户名和密码

  log file = /var/log/rsyncd.log #指定rsync的日志文件,而不将日志发送给syslog

  pid file = /var/run/rsyncd.pid #指定rsync的pid文件

  lock file = /var/run/rsync.lock #指定支持max connections参数的锁文件,默认值是/var/run/rsyncd.lock

  comment = hello world

  #motd file = /etc/rsyncd.motd #欢迎信息文件名称和存放位置(此文件没有,可以自行添加)

  [backup] # 这里是认证的模块名,在client端需要指定

  path = /titan24/www/repos # 需要做镜像的目录

  auth users = rsync # 授权帐号。认证的用户名,如果没有这行,则表明是匿名,多个用户用,分隔

  read only = no # yes只读 值为NO意思为可读可写模式,数据恢复用NO

  hosts allow = 192.168.3.128 #允许访问的服务器IP

  hosts deny = * #黑名单

  list = true # 允许列文件

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

  #exclude = cache/111/ cache/222/ #忽略的目录

  # vi /etc/rsyncd.secrets (设置访问(认证)的用户名密码)

  rsync:111111 #用户名:密碼

  给文件正确的权限

  # chown root:root /etc/rsyncd.secrets

  # chmod 600 /etc/rsyncd.secrets #(必须是600)

  二、client 端进行同步

  客户端默认好像已经装了rsync,没有的话装下:

  # yum -y install rsync

  执行异步同步操作:

  /usr/bin/rsync -avz --progress rsync@192.168.3.191::backup /www

  # crontab -e #(可以定时每三分钟同步一次文件)

  */3 * * * * rsync -avz --progress rsync@192.168.3.191::backup /www

  下面这个命令完整一点:

  #vi /etc/rsyncd.pas

  加入密码

  rsyncofpass

  注意,客户端的密码文件只需要密码,而不需要用户名!

  更改文件权限:

  #chmod 0600 /etc/rsyncd.pas

  #rsync -vzrtopgu --progress --delete --password-file=/etc/rsyncd.pas rsync_user@192.168.0.2::rsync_module_name1 /www/

  这个命令行中-vzrtopg里的v是verbose,

  z是压缩传输,

  r是recursive,

  topg都是保持文件原有属性如属主、时间的参数。

  u是只同步已经更新的文件,避免没有更新的文件被重复更新一次,不过要注意两者机器的时钟的同步。

  –progress是指显示出详细的进度情况,

  –delete是指如果服务器端删除了这一文件,那么客户端也相应把文件删除,保持真正的一致。

  后 面的rsync_user@192.168.0.2::rsync_module_name1中,之后的rsync_module_name1是模块名, 也就是在/etc/rsyncd.conf中自定义的名称,rsync_user是指定模块中指定的可以同步的用户名。

  最后的/www是备份到本地的目录名。

  在这里面,还可以用-e ssh的参数建立起加密的连接。

  可以用–password-file=/password/path/file来指定密码文件,这样就可以在脚本中使用而无需交互式地输入验证密码了,这里需要注意的是这份密码文件权限属性要设得只有属主可读。

  #/usr/local/rsync/bin/rsync -vzrtopg –progress –delete rsync_user@192.168.0.2::rsync_module_name1/tmp/

  Password:

  或者你也可以制定password文件

  由于需要系统crontab执行,所以这里采用读入密码文件的方式,

  这个时候就成功了。

  请继续浏览下一页:同步命令说明

  ---------------------------------同步命令说明:---------------------------------

  1 显示目录内容

  命令

  ——

  a) rsync

  b) rsync -r

  c) rsync jack@192.168.0.1::

  d) rsync ssh_user@192.168.0.1:

  命令说明

  ———

  a) 显示目录内容(第一层)

  b) 递归显示目录内容

  c) 显示远程主机目录内容

  *注1:端口模式, 基于rsync用户的身份验证

  *注2:rsync server上的目录必须具有xx7的权限.

  d) 查看远程主机目录内容

  *注1:remote shell模式, 通过ssh连接的基于系统本地用户的身份验证

  *注2:这里只使用了一个冒号(:),同时用户名是远程主机的ssh 用户,密码也是ssh用户对应的密码。

  *注3:使用””,则列出文件夹本身的信息。若要列出文件夹内容,应使用”/”。

  参数说明

  ———

  -r 对目录进行递归操作

  2 本地目录之间同步

  命令

  ——

  a) rsync -av –progress / *** 注意(/) ***

  b) rsync -av –progress

  c) rsync -avu –progress –delete /

  d) rsync -av –progress –temp-dir=/tmp /

  命令说明

  ———

  a) 同步src-dir目录下所有文件到dst-dir目录下

  b) 同步src-dir目录下所有文件到dst-dir/src-dir目录下

  c) 对src-dir目录内容向dst-dir目录下进行差异更新,有增加/更新则添加替换,有减少则对其删减

  d) 比a)多了–temp-dir=/tmp,即指定/tmp为临时交换区,这样可以避免因目标目录空间不够引起的无法同步文件的错误。

  参数说明

  ———

  -a 相当于 -rlptgoD 的集合

  -u 等同于 –update,在目标文件比源文件新的情况下不更新

  -v 显示同步的文件

  –progress 显示文件同步时的百分比进度、传输速率

  –delete 删除目标目录中多于源目录的文件

  3 异地主机之间同步

  命令

  ——

  a) rsync -avz –progress jack@192.168.0.1::/

  b) rsync -avz –progress jack@192.168.0.1::/ –password-file=/home/jack/rsync.jack

  c) rsync -avuz –progress –delete jack@192.168.0.1::/ –password-file=/home/jack/rsync.jack

  d) rsync -avz –progress jack@192.168.0.1::/

  命令说明

  ———

  a) 同步本地目录的内容到远程主机192.168.0.1的目录下,jack是rsync数据库用户(参见3. /etc/rsync.secrets)

  b) 通过自动读取用户密码而实现非交互登录文件同步

  c) 较b)多了-u和–delete

  d) 同步远程主机内容到本地目录

时间: 2024-11-02 16:04:52

linux/centos rsync安装配置教程的相关文章

Linux下Redis安装配置教程_Redis

redis作为NoSQL数据库的一种应用,响应速度和命中率上还是比较高效的.项目中需要用集中式可横向扩展的缓存框架,做了一点调研,即便redis.memcached存在效率上的差异(具体比较参考http://timyang.net/data/mcdb-tt-redis/),但其实都能满足目前项目的需求:但是redis还是比较风骚的,支持链表和集合操作,支持正则表达式查找key,目前项目缓存的结果大多是链表,如果链表新增或者修改数据的话,redis就体现出了极大的优势(memcached只能重新加

linux下Golang安装配置教程

做为运维人员,使用python语言足矣,理论上是无需了解golang的.不过最近发现一个新潮的监控系统都是基于golang进行开发的,如小米公司的Open-Falcon(github项目页) .stack exchange 公司的Bosun (github项目页). 一.Go的三种安装方式 Go有多种安装方式,你可以选择自己喜欢的.这里我们介绍三种最常见的安装方式: Go源码安装:这是一种标准的软件安装方式.对于经常使用Unix类系统的用户,尤其对于开发者来说,从源码安装可以自己定制. Go标准

Linux下Docker安装配置教程_docker

在Linux上安装Docker,具体几个步骤: 环境:windows7 虚拟机:Oracle VMVirtualBox Linux: ubuntukylin-14.04.1-amd64.iso JDK:1.7 一.环境准备 step1:安装虚拟机 step2:修改宿主机BIOS配置,详细步骤见文章:http://www.jb51.net/article/96239.htm step3:在虚拟机上安装ubuntu系统.内存设置为4G,硬盘设置为100G,其余均按默认,一直点选下一步.直到系统安装成

linux中Virtualmin安装配置教程

进入后台 http://你的IP地址或者是主机名:10000/ 输入地址进入后是webmin的默认登录界面 帐号:root 密码:你的VPS的密码 进入后需要我们初始化Virtualmin Introduction 提示一下内容: This post-installation wizard allows you to configure Virtualmin optimally for your system. You can make selections depending on wheth

linux中Shadowsocks-Go Mu 安装配置教程

安装前配置 还是老样子,那就是各种支持库的安装.   Debian apt-get update apt-get install -y redis-server git CentOS yum install -y redis-server git 安装GO环境 Ubuntu/Debian – 安装配置Golang           安装教程:https://www.bxl.me/9531.html CentOS 6 – 安装配置Go语言                   安装教程:https

linux rsync安装 配置 实例详解_linux shell

Redhat中安装rsync 1.  首先在服务端和客户端都安装rsync,我的RHEL5默认已经安装好了.在安装RedHat5的时候,可以在软件定制中的"基本系统"-->"基本"的"可选的软件包"中看见:rsync-2.6.8是默认选择安装的 2.    也可以通过命令行检查是否安装: 或者:rpm –q rsync 3.  如果在开始安装RedHat的时候,使用默认选择的rysnc软件,但现在想用更高版本的rsync,可以卸载掉rysn

CentOS下安装配置Tomcat环境

  CentOS下安装配置Tomcat 演示环境 系统:Linux CentOS 6.3 32位 环境:无安装apache.php.mysql 账号:Root 一.下载相关安装包 注:可以先进入 #cd /usr/local/ /进里面后再下载(也可以根据自己情况而定) 1.下载jdk 2.下载Tomcat 二.安装JDK和Tomcat 注:可以先进入 #cd /usr/local/ /再执行下面的命令 1.编译安装Jdk #chmod 777 jdk-6u41-linux-i586-rpm.b

CentOS下安装配置Tomcat环境方法

CentOS下安装配置Tomcat 演示环境 系统:Linux CentOS 6.3 32位 环境:无安装apache.php.mysql 账号:Root 一.下载相关安装包 注:可以先进入  #cd /usr/local/         /进里面后再下载(也可以根据自己情况而定) 1.下载jdk 下载链接: #wget http://download.oracle.com/otn/java/jdk/6u41-b02/jdk-6u41-linux-i586-rpm.bin?AuthParam=

jpgraph安装配置教程详细介绍

在学习了之前两篇php jpgraph安装教程后,只要jpgraph类库通过了PHP安装环境的验证后,就可以正式安装jpgraph类库了,其实jpgraph类库的安装非常方便,只要将下载的jpgraph类库解压缩至已搭建的PHP环境下的相关目录下即可.jpgraph安装过程的关键在于PHP配置文件php.ini与jpgraph配置文件jpg-config.inc.php配置.下面我根据jpgraph类库的英文文档进行说明,希望对使用jpgraph类库的PHP开发者有所帮助. jpgraph类库安