Envio de comandos por ssh sem troca de chaves a múltiplos servidores
Publicado por Djames Suhanko 06/06/2009
[ Hits: 8.674 ]
Homepage: http://phantomclone.com
Para enviar comando a vários servidores de um cluster ao mesmo tempo sem usar troca de chaves, existe um programa chamado cssh...
#!/usr/bin/env python #By: Djames Suhanko - Catho online #lista de servidores sincroniza =["server1.domain","server2.domain", "server3.domain"] import pexpect import sys from threading import Thread #usuario e senha podem ser colocados em um arquivo.ini ou estaticamente nesse arquivo #Testa a lista de parâmetros try: if sys.argv[3]: pass except: print "Uso: " + "script" + " <comando entre aspas> <usuario> <senha>" sys.exit() #essa função inicia o envio dos comandos passados como argumentos. def executor(comando,usuario,senha,servidor): a = 'ssh ' + usuario + '@' + servidor foo = pexpect.spawn(a) foo.expect('.*ssword:') foo.sendline(senha) foo.sendline('su') foo.expect('.*sword:') foo.sendline('senha_secreta') foo.sendline(comando + '&& exit') print "comando e saida para: " + servidor + "..........[OK]" foo.sendline('exit') foo.expect('.*osed.') foo.interact() #cria uma lista... tasks = [] #loop com thread da funcao executor for i in sincroniza: t = Thread(target=executor,args=(sys.argv[1],sys.argv[2],sys.argv[3],i)) t.start() tasks.append(t) #aguarda a finalização de todas as tarefas. for t in tasks: t.join()
Importar múltiplos hosts ZABBIX
Peer-to-peer nós para processamento em multipontos
Nenhum comentário foi encontrado.
tux-gpt - Assistente de IA para o Terminal
Instalação e configuração do Chrony
Programa IRPF - Guia de Instalação e Resolução de alguns Problemas
Como instalar no Linux Jogos da Steam só para Windows
Instalando o Team Viewer no Debian Trixie - problema no Policykit
O Que Fazer Após Instalar Ubuntu 25.04
Copiar Layout do Teclado para aplicar em outra Distribuição (4)
Alguém poderia me ajudar a escolher peças pra montar um desktop? (32)