У меня есть клиент, я запускаю exec_commands против использования Paramiko.
Есть ли способ зарегистрировать stderr
, stdout
, stdin
в регистраторе с помощью регистрации питонов?Я попытался использовать функцию ниже, но безуспешно.
def client_exe(hostname, command, username, password):
logger = getLogger("EXEC", "log.log")
#paramiko.util.log_to_file("log.log", level="DEBUG")
ssh_client = paramiko.SSHClient()
ssh_client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh_client.connect(hostname=hostname, username=username, password=password)
stdin, stdout, stderr = ssh_client.exec_command(command, get_pty=True)
logger.info(
"Remote Machine: {} \n\tCommand: {} \n\tSTDIN: {} \n\tSTDOUT: {} \n\tErrors: {}".format(
hostname, command,
stdin.readlines(),
stdout.readlines(),
stderr.readlines()))
Приведенный выше скрипт вызывает ошибку ввода-вывода о том, что файл не открыт для чтения.
Ниже приведена моя getLogger
функция:
def getLogger(name, logname):
logger = logging.getLogger(name)
fmt = logging.Formatter("%(asctime)s %(levelname)s: %(message)s", datefmt='%m/%d/%Y %I:%M:%S %p')
fileHandler = logging.FileHandler(logname, mode="a")
fileHandler.setFormatter(fmt)
streamHandler = logging.StreamHandler()
streamHandler.setFormatter(fmt)
logger.setLevel(logging.DEBUG)
logger.addHandler(fileHandler)
logger.addHandler(streamHandler)
return logger
Приблизительновывод попытки использовать выше:
File "/home/<MYPATH>/distro.py", line 89, in <module>
client_exe("192.168.xxx.xxx", "ls -la")
File "/home/<MYPATH>/distro.py", line 52, in client_exe
logger.info("Remote Machine: {} \n\tCommand: {} \n\tSTDIN: {} \n\tSTDOUT: {} \n\tErrors: {}".format(hostname, command, stdin.readlines(), stdout.readlines(), stderr.readlines()))
File "/home/<MYPATH>/venv/lib/python3.7/site-packages/paramiko/file.py", line 349, in readlines
line = self.readline()
File "/home/<MYPATH>/venv/lib/python3.7/site-packages/paramiko/file.py", line 257, in readline
raise IOError("File not open for reading")
OSError: File not open for reading
Process finished with exit code 1
Текущий обходной путь:
print(file=logger.debug("{}\n{}\n{}".format(stdin.readlines(), stdout.readlines(), stderr.readlines())