我正在尝试运行命令
rsync -rtv -e 'ssh -i /Users/yuanlinfeng/.ssh/id_rsa -o "UserKnownHostsFile=/dev/null" -o "StrictHostKeyChecking no" -o "ConnectTimeout=2"' /tmp/a username@ip:/home/ubuntu/a
代码是:
let login_settings = format!(r#"'ssh -i {} -o "UserKnownHostsFile=/dev/null" -o "StrictHostKeyChecking no" -o "ConnectTimeout=2"'"#, identity);
let mut cmd = Command::new("rsync");
cmd.env("SETTING", login_settings);
cmd.arg("-rtv").arg("-e").arg(login_settings);
if delete {
cmd.arg("--delete");
}
match exclude_files {
None => {}
Some(exclude_files) => {
for file in exclude_files.iter() {
cmd.arg("--exclude").arg(file);
}
}
}
let target = format!("{}@{}:{}", username, remote_ip, dest);
cmd.arg(source).arg(target);
let output = cmd.output()?;
if output.stdout.len() > 0 {
println!("stdout: {}", String::from_utf8_lossy(&output.stdout));
}
if output.stderr.len() > 0 {
println!("stderr: {}", String::from_utf8_lossy(&output.stderr));
}
错误:
stderr: rsync: Failed to exec ssh -i /Users/yuanlinfeng/.ssh/id_rsa -o "UserKnownHostsFile=/dev/null" -o "StrictHostKeyChecking no" -o "ConnectTimeout=2": No such file or directory (2)
rsync error: error in IPC code (code 14) at /BuildRoot/Library/Caches/com.apple.xbs/Sources/rsync/rsync-52/rsync/pipe.c(86) [sender=2.6.9]
rsync: connection unexpectedly closed (0 bytes received so far) [sender]
rsync error: error in rsync protocol data stream (code 12) at /BuildRoot/Library/Caches/com.apple.xbs/Sources/rsync/rsync-52/rsync/io.c(453) [sender=2.6.9]
看起来参数中的引号被删除了。我该如何解决?
我正在使用macOS High Sierra和Rust 1.22.1。
答案 0 :(得分:2)
'
参数周围的ssh ...
引号实际上并未传递给rsync
; shell使用它们将参数分隔为rsync
。
您的Rust代码尝试调用类似这样的内容:rsync -e "'ssh ...'" ...
。 rsync然后尝试将'ssh ...'
参数拆分为类似于shell(似乎它实际上并没有使用shell来扩展它)。这意味着它会将ssh ...
视为一个参数(要执行的文件名),但这样的文件不存在。
删除'
电话中的format!
引号,它可能会有效。
在Linux上,你可以通过strace -ff -e trace=execve -- ./target/...
运行你的例子,看看它是如何工作的。 macOS有dtruss
,但我无法帮助你:)