Não é possível usar o rsnapshot para sincronizar arquivos não pertencentes, mas capaz de fazer isso com o comando rsync simples

3

Estou tentando usar o rsnapshot para sincronizar o arquivo remoto com meu próprio computador. No entanto, tenho alguns problemas quando preciso acessar arquivos que não são de propriedade do usuário que está executando o SSH na máquina remota.

Meu /etc/rsnapshot.conf é assim:

config_version  1.2
snapshot_root   /shared/.backup/
cmd_cp          /bin/cp
cmd_rm          /bin/rm
cmd_rsync       /usr/bin/rsync
cmd_ssh         /usr/bin/ssh
cmd_logger      /usr/bin/logger
cmd_du          /usr/bin/du

retain      hourly  6
retain      daily   7
retain      weekly  4
retain      monthly 3

verbose     2
loglevel    5
logfile     /shared/.backup/rsnapshot.log

ssh_args    -i ~/.ssh/id_rsa -p 62222

# BACKUP DEFINITIONS
backup  [email protected]:/          dev.local.root/     exclude_file=/shared/.backup/exclude.root,+rsync_long_args=--rsync-path='sudo rsync',rsync_short_args=-zalhHx

Depois de executar rsnapshot hourly , vejo este erro:

bash: sudo rsync: command not found
rsync: connection unexpectedly closed (0 bytes received so far) [Receiver]
rsync error: remote command not found (code 127) at io.c(226) [Receiver=3.1.0]
----------------------------------------------------------------------------
rsnapshot encountered an error! The program was invoked with these options:
/usr/bin/rsnapshot hourly
----------------------------------------------------------------------------
ERROR: /usr/bin/rsync returned 127 while processing [email protected]:/

Se eu verificar meu arquivo rsnapshot.log , posso ver que rsnapshot tentou este comando:

/usr/bin/rsync -zalhHx --delete --numeric-ids --relative --delete-excluded --exclude-from=/shared/.backup/exclude.root --rsync-path='sudo rsync' --rsh=/usr/bin/ssh -i ~/.ssh/id_rsa -p 62222 [email protected]:/ /shared/.backup/hourly.0/dev.local.root/

Se eu tentar executar o mesmo comando no terminal, recebo este erro:

Unexpected remote arg: [email protected]:/
rsync error: syntax or usage error (code 1) at main.c(1348) [sender=3.1.0]

No entanto, se eu colocar aspas em torno de --rsh part, tudo funcionará bem:

/usr/bin/rsync -zalhHx --delete --numeric-ids --relative --delete-excluded --exclude-from=/shared/.backup/exclude.root --rsync-path='sudo rsync' --rsh='/usr/bin/ssh -i ~/.ssh/id_rsa -p 62222' [email protected]:/ /shared/.backup/hourly.0/dev.local.root/

Alguns fatos

  • Na máquina remota, há uma linha username ALL=(ALL) NOPASSWD:ALL no arquivo sudoers.
  • Eu normalmente posso SSH para a máquina remota com minha chave SSH.
  • Eu posso invocar os comandos sudo no servidor sem precisar de uma senha.
  • Não consigo usar o SSH como root na máquina remota devido a PermitRootLogin on e AllowUsers username in sshd_config
  • Se eu tentar ssh [email protected] -p 62222 -i ~/.ssh/id_rsa which rsync , a saída será /usr/bin/rsync
  • Se eu tentar ssh [email protected] -p 62222 -i ~/.ssh/id_rsa echo $PATH , a saída será /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games

Então ... Minha pergunta é simples: como eu construo corretamente este comando rsync em rsnapshot ?
Obrigado pela ajuda!

    
por errata 10.11.2014 / 13:29

1 resposta

1

Eu tive exatamente o mesmo erro Eu fui forçado a especificar um script manual

--rsync-path='sudo rsync' > --rsync-path='/usr/local/bin/rsync'

com / usr / local / bin / rsync no remoto

#! /bin/sh
exec /usr/bin/sudo /usr/bin/rsync "$@" 
    
por 14.12.2015 / 16:12