使用rsync + ssh +公钥作为与ssh密钥所有者不同的用户同步本地和远程目录

目标是通过ssh同步本地和远程文件夹。

我目前的用户是user1 ,我有一个无密码的访问设置通过SSH到服务器server1 。 我想通过rsync实用程序将本地文件夹与server1上的文件夹同步。 通常我会跑:

rsync -rtvz /path/to/local/folder server1:/path/to/remote/folder 

ssh访问按预期工作, rsync能够通过ssh连接,但是它返回“Permission denied”错误,因为在server1上 ,文件夹/path/to/remote/folderuser2user2拥有。 文件夹的文件权限不允许其他人修改。 user1server1上的sudoer,所以sudo su - user2ssh会话期间工作。 如何改变rsync切换到用户ssh ed到服务器?

user1添加到组user2不是一个选项,因为服务器上的所有用户/组pipe理都是自动完成的,并且每隔X分钟从中央回购站复制,而我没有访问该回执。

与更改目标文件夹的权限/所有权相同:定期自动更新所有权限。

我想到的可能的解决scheme是将本地文件夹与服务器上user1拥有的临时中间远程文件夹同步,然后将两个远程文件夹同步为user2的脚本。

search一个更短,更漂亮的解决scheme并没有取得任何成功。

我没有尝试过,但如何使用rsync的“ – rsync-path”选项?

 rsync -rtvz --rsync-path='sudo -u user2 rsync' /path/to/local/folder server1:/path/to/remote/folder 

要解决权限问题,您需要通过以user2远程登录的SSH会话运行rsync:

 rsync avz -e 'ssh -i privatekeyfile' /path/to/local/folder/ user2@server1:/path/to/local/folder 

以下答案解释了如何设置SSH密钥。

  • 蚂蚁,从远程机器下载文件集

user1设置无密码访问权限以访问user2 @ server1 ,然后执行:

 rsync -rtvz /path/to/local/folder user2@server1:/path/to/remote/folder