我有以下脚本可以在远程系统上进行更新。
from fabric.api import run
serverIp = "192.168.1.1"
serverPort = "8000"
filename = "MyFIle.tar.gz"
dirName = "MyDir"
def makeUpdate():
run("/bin/update.sh {0} {1} {2} {3}".format(serverIp, serverPort,
filename, dirName))
我列出了需要更新的数百个IP。我使用以下脚本来做到这一点。
import os
data = open("clients.txt").read().strip().split("\n")
for i in data:
if i:
print(i)
for i in data:
os.system("fab -H {0} -u root -I host_type".format(i))
配置ssh密钥后,一切正常,但是我必须将其部署到不配置ssh密钥的计算机上。在这种情况下,每次建立新的ssh连接时,它都会要求输入密码。所有设备的密码均相同。输入密码几百次不方便。
当我从命令行传递密码时,密码无效。
由于某种原因,我必须以 root 身份登录,因此sudo密码在这种情况下不起作用;是我认为正在发生的事情。
是否可以自动执行此操作或将密码传递给 fab 命令的参数?
提前谢谢。
答案 0 :(得分:2)
这是我如何解决您的问题:
import getpass # for getting the password from the user
import json # for outputting raw data
from fabric.api import execute, run, settings, task
@task
def make_update():
# keeping global scope clean
server_ip = "192.168.1.1"
server_port = "8000"
file_name = "MyFIle.tar.gz"
dir_name = "MyDir"
# return data so we can review it if we want
return run("/bin/update.sh {0} {1} {2} {3}".format(
server_ip, server_port, file_name, dir_name
))
@task
def make_update_all():
# generate host list from file
with open("clients.txt") as f:
hosts = f.read().splitlines()
# locally modify fabric environment
with settings(
user="root",
password=getpass.getpass(), # get the root password
parallel=True # do work in parallel to save time (False for debug)
):
results = execute(make_update, hosts=hosts)
print json.dumps(results, indent=4) # output results in a semi-legible way
然后我将像这样运行它:
fab make_update_all