Я пытаюсь сделать резервную копию устройства Linkproof с помощью ожидаемого сценария, и у меня возникли некоторые проблемы. Это мой первый ожидаемый сценарий, и я достиг своих пределов;)
#!/usr/bin/expect
spawn ssh @IPADDRESS
expect "username:"
# Send the username, and then wait for a password prompt.
send "@username\r"
expect "password:"
# Send the password, and then wait for a shell prompt.
send "@password\r"
expect "#"
# Send the prebuilt command, and then wait for another shell prompt.
send "system config immediate\r"
#Send space to pass the pause
expect -re "^ *--More--\[^\n\r]*"
send ""
expect -re "^ *--More--\[^\n\r]*"
send ""
expect -re "^ *--More--\[^\n\r]*"
send ""
# Capture the results of the command into a variable. This can be displayed, or written to disk.
sleep 10
expect -re .*
set results $expect_out(buffer)
# Copy buffer in a file
set config [open linkproof.txt w]
puts $config $results
close $config
# Exit the session.
expect "#"
send "logout\r"
expect eof
Содержимое выходного файла:
Невозможно установить подлинность хоста "@IP (XXX.XXX.XXX.XXX)".
Отпечаток ключа RSA: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX.
Вы уверены, что хотите продолжить подключение (да / нет)? @ Имя пользователя
Пожалуйста, введите «да» или «нет»: @ пароль
Пожалуйста, введите «да» или «нет»: конфигурация системы незамедлительно
Пожалуйста, введите «да» или «нет»:
Как видите, результат команды отсутствует в файле. Не могли бы вы помочь мне понять почему?
Спасибо за вашу помощь.
Ромуальд