在bash中,如何为后台进程命令输入密码?

时间:2013-07-31 03:42:00

标签: linux bash nohup

我正在尝试从dreamhost到另一台主机进行rsync备份,这是我想要使用的命令:

nohup rsync -e“/ usr / bin / ssh”--bwlimit = 2000 -av username@server.dreamhost.com:remote_directory local_directory&

我希望这个过程能够在后台继续运行,即使我断开连接也是如此。问题是,我不知道如何在后台进程时输入密码。我该怎么做?

2 个答案:

答案 0 :(得分:8)

通常这可以通过完全不需要密码来完成。相反,请考虑将SSH配置为使用公钥。有几种在线资源(例如this one from dreamhost)可以帮助您实现这一目标。

答案 1 :(得分:5)

我会用一把钥匙。如果您需要使用密码保护密钥,或者因任何原因无法使用密钥,请使用expect来传递密码:

rsync_auto.sh:

#/bin/bash

expect <<<EOF
spawn nohup rsync -e "/usr/bin/ssh" --bwlimit=2000 -av username@server.dreamhost.com:remote_directory
expect "password:"
send "your_password\r"
expect eof
EOF

!!!确保除了您之外没有人可以访问该文件!!!:

chmod 500 rsync_auto.sh

更精细的方法可能是将密码存储在密钥环应用程序中,例如gnome-keyring,而不是将它们存储在普通文件中。如果你有兴趣,我发现了article