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 "$@"
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
username ALL=(ALL) NOPASSWD:ALL
no arquivo sudoers. sudo
no servidor sem precisar de uma senha. PermitRootLogin on
e AllowUsers username
in sshd_config
ssh [email protected] -p 62222 -i ~/.ssh/id_rsa which rsync
, a saída será /usr/bin/rsync
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!
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 "$@"
Tags ssh permissions rsync rsnapshot