删除文件时,lsyncd不尊重ssh用户

时间:2017-02-15 14:36:02

标签: ssh rsync lsyncd

我们已设置lsyncd以在两台主机之间同步数据。 ssh连接配置为使用具有匹配的id_rsa标识文件的用户tomcat。由于某种原因,遥控器上的追加/创建工作正常,但删除不起作用。当rsync尝试删除文件时,root用户用于连接目标主机而不是tomcat用户(用于create / append)。

在日志( /var/log/lsyncd/lsyncd.log )中,我们看到:

Wed Feb 15 13:48:24 2017 Normal: Rsyncing list
/test.txt
Wed Feb 15 13:48:26 2017 Normal: Finished (list): 0
Wed Feb 15 13:48:34 2017 Normal: Deleting list
/myfolder//test.txt
Received disconnect from 10.29.146.78: 2: Too many authentication failures for root
Wed Feb 15 13:48:41 2017 Normal: Retrying (list): 255

我们使用以下配置( /etc/lsyncd.conf ):

settings{
  pidfile        = "/var/run/lsyncd.pid",
  statusFile     = "/var/tmp/lsyncd.status",
  logfile        = "/var/log/lsyncd/lsyncd.log",
  statusInterval = 60,
  logfacility    = "user",
  logident       = "lsyncd",
  inotifyMode    = "CloseWrite",
  maxProcesses   = 10,
}

sync {
  default.rsyncssh,
  source = "/myfolder/",
  delete = true,
  host = "remote-host",
  targetdir = "/myfolder/",
  excludeFrom = "/etc/lsyncd/lsyncd.exclude",
  delay = 5,
  rsync = {
    binary = "/usr/bin/rsync",
    archive = true,
    owner = true,
    compress = true,
    _extra = { "--bwlimit=50000", "--delete-after" },
    rsh = "/usr/bin/ssh -l tomcat -i /usr/share/tomcat6/.ssh/id_rsa",
  }
}

作为一种解决方法,我们可以使用 /root/.ssh/config 文件:

Host remote-host
    Hostname remote-host
    User tomcat
    IdentityFile /usr/share/tomcat6/.ssh/id_rsa

当然我们宁愿不必使用它,因为它应该与lsyncd.conf配置一起使用。

我们正在使用 lsyncd版本2.1.4

2 个答案:

答案 0 :(得分:0)

使用rsyncssh时,必须要小心。

" ssh {}"配置参数有自己的"二进制","端口"," _extra"。有关完整的设置列表,请参阅documentation

这有点令人困惑,因为" rsync {}"还需要配置。是的,这两个部分都需要完成。

" ssh" section用于删除和移动事件。 " rsync" section用于文件传输。

可以通过使用rsync而不是rsyncssh来避免混淆。但是,当文件移动时,您将失去rsyncssh提供的带宽效率。

答案 1 :(得分:0)

GitHub上的以下问题帮助我解决了同一问题: https://github.com/axkibe/lsyncd/issues/369

我所做的非常简单,我只是将default.rsyncssh文件中的default.rsync替换为lysync.conf.lua