我的配置文件中有以下设置:(/etc/rsnapshot.conf)
脚本/工具:http ://www.rsnapshot.org/
backup_script ssh [email protected] "sh /home/user/backup_mysql.sh" ./mysql
该示例显示以下内容:
backup_script ssh [email protected] "mysqldump -A > /var/db/dump/mysql.sql" unused2
我得到的错误:
ERROR: backup_script /usr/bin/ssh returned 255
我究竟做错了什么?
rsnapshot 配置文件以制表符分隔。确保
tabs
在 backup_scrip、ssh 命令和备份存储之间包含。如果这不起作用,请尝试运行rsnapshot configtest
以找出问题所在。答案已更新
将您的备份行转换为以下格式会更方便:
将中间部分放在 shell 脚本中,使其可执行并进行测试。除此之外,
ssh [email protected]
应该以非交互方式连接到没有密码的远程主机。该
rsnapshot.conf
示例实际上使用backup_exec
, 而不是backup_script
。但是,backup_script
仍然可以用于通过 ssh 运行任意命令并同步在临时目录中生成的任何文件。使用的任何命令都必须通过绝对路径引用。这对我有用,适用于我的一个 mysql 数据库:backup_script [tab] /usr/bin/ssh [email protected] "/usr/bin/mysqldump --single-transaction -u username dbname" > dbname.sql [tab] example.com/mysql/
一种可能的方法是转换
ssh [email protected] "sh /home/user/backup_mysql.sh"
为脚本(do_ssh.sh,此处)并调用该脚本。就像是,
我还建议您尝试在整个命令周围加上引号。
问题与ssh有关。从 ssh 手册页
您应该使用 ssh -v[vv] 从 ssh 获得详细的输出并查看它必须说的内容。
您是否设置了与远程主机的密钥身份验证,或者 ssh 命令是否希望您以交互方式输入密码?
如果您没有设置无密码身份验证,则 ssh 命令将无法进行身份验证,并因此返回错误(255 似乎是任何错误的默认返回值)。
我有一个类似的问题,通过确保脚本“路径”中没有选项卡来解决。
代替
尝试