我正在使用 Fabric 运行一个 Python 脚本,它远程发送一个 bash 脚本并执行。 该脚本必须自动在多个远程服务器上运行(无需用户干预)。
但是当我安装这两个包时,命令行中的 GUI 界面提示有点复杂。这会导致 bash 脚本“挂起”,等待用户输入以继续。
- mysql-server(提示用户输入 root 密码)
- postfix(提示一些配置设置)
有没有在命令行中没有 GUI 界面提示的情况下配置过程的替代方法?
最佳答案
在http://www.muhuk.com/2010/05/how-to-install-mysql-with-fabric/它描述了安装 mysql-server 的解决方案,基本上你需要做的是:
# password prompt
while True:
mysql_password = getpass('Please enter MySQL root password: ')
mysql_password_confirmation = getpass('Please confirm your password: ')
if mysql_password == mysql_password_confirmation:
break
else:
print "Passwords don't match"
# set the value in debconf
with settings(hide('warnings', 'running', 'stdout', 'stderr'),
warn_only=True):
if not run('dpkg-query --show mysql-server'):
sudo('echo "mysql-server-5.1 mysql-server/root_password password '
'%s" | debconf-set-selections' % mysql_password)
sudo('echo "mysql-server-5.1 mysql-server/root_password_again '
'password %s" | debconf-set-selections' % mysql_password)
关于python - 自动远程安装 mysql-server 和 postfix,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8170691/