3개의 스크립트가 있는데 이것이 주요 스크립트입니다.
#!/usr/bin/expect -f
#!/bin/sh
set DATE [exec date +%F]
set IP "148.000.000.101"
set Username "user"
set Password "pass"
set Password_sql "sqlpass"
spawn ssh -p 22 mycomputer@localhost
expect "*?"
send "yes\r"
expect "password: "
send "passlocal\r"
expect "$ "
send "telnet $IP\r"
expect "Username:"
send "$Username\r"
expect "Password: "
send "$Password\r"
expect "*>"
send "show cdp neighbors detail\r"
log_file -noappend CDPdet.dat;
expect -ex "--More--" {send -- " "; exp_continue}
expect "*>"
log_file;
expect "*>"
send "exit\r"
expect "$ "
send -- "awk '/Device ID|IP address|Interface|Port ID/ { print }' CDPdet.dat >tabladetallada.dat\r"
expect "$ "
send -- "sed 's/--More--␣*//' tabladetallada.dat>tabladetallada2.dat \r"
expect "$ "
send -- "sed -i '$ s/.$//' Disptelnet.dat\r"
expect "$ "
send -- " echo \"\nIP address: $IP\" >>Disptelnet.dat\r"
expect "$ "
send -- "dos2unix Disptelnet.dat \r"
expect "$ "
send -- "dos2unix dispositivos.dat \r"
expect "$ "
send -- "awk '\r BEGIN {\r RS = \"\\n\\n\"\r FS = \"\\n\"\r OFS = \",\"\r print \"device_id,ip_address\"\r }\r {\r for(i=1; i<=NF; i++) {\r split(\$i, a, \":\");\r k\[a\[1\]\] = a\[2\]\r }\r print k\[\"Device ID\"\], k\[\"IP address\"\]\r\r }' dispositivos.dat>dispositivoss.csv \r"
expect "$ "
send -- "./telnetverison.sh \r"
expect "$ "
모든 것이 잘 진행되지만 ./telnetverison.sh가 실행되면 기본 스크립트는 "telnetverison.sh"가 완료될 때까지 기다리지 않습니다.
telnetverison.sh만 테스트했는데 잘 작동합니다. 코드는 다음과 같습니다.
#!/bin/bash
FILE1=dispositivoss.csv
set Username "user"
set Password "pass"
NUMERODISP="$(wc -l $FILE1 | awk '{print $1}')"
# echo "$NUMERODISP"
num=3
IP="$(awk -vnum="$num" 'NR == num { print $NF }' dispositivoss.csv)"
#echo "$IP"
for i in `seq 2 $NUMERODISP`;
do
IP="$(awk -vnum="$i" 'NR == num { print $NF }' dispositivoss.csv)"
expect -f conexionindividual.expect $IP $i
done
보시다시피, conexionindividual.expect에 대한 코드인 경우를 대비해 이 코드 내에 또 다른 스크립트가 중첩되어 있습니다.
#!/usr/bin/expect -f
set Username "user"
set Password "pass"
set IP [lindex $argv 0];
set i [lindex $argv 1];
spawn ssh -p 22 mycomputer@localhost
expect "*?"
send "yes\r"
expect "password: "
send "mypass\r"
expect "$ "
send "telnet $IP\r"
expect "Username:"
send "$Username\r"
expect "Password: "
send "$Password\r"
expect "*>"
send "show version\r"
log_file -noappend SN_$IP.dat;
expect -ex "--More--" {send -- " "; exp_continue}
expect "*>"
log_file;
메인 스크립트를 실행할 때 터미널이 검색하는 내용은 다음과 같습니다.
cesar@cesar-HP-Pavilion-15-NoteBook-PC:~$ awk '
...
> BEGIN { #this is the last awk in the "main" script
> RS = "\n\n"
./telnetverison.sh
> FS = "\n"
> OFS = ","
> print "device_id,ip_address"
> }
> {
> for(i=1; i<=NF; i++) {
> split($i, a, ":");
> k[a[1]] = a[2]
> }
> print k["Device ID"], k["IP address"]
>
> }' dispositivos.dat>dispositivoss.csv
cesar@cesar-HP-Pavilion-15-NoteBook-PC:~$ ./tecesar@cesar-HP-Pavilion-15-NoteBook-PC:~$ #here is the problem
도와주세요?
미리 감사드립니다.
업데이트: 해결되었습니다! 다음을 보낸 후 잠을 잤습니다.
expect "$ "
send -- "./telnetverison.sh \r"
sleep 400
expect "$ "
하지만 400초는 장치 수에 따라 충분하지 않습니다.
다른 아이디어가 있나요?
답변1
스크립트를 호출하기 전에 Expect의 시간 제한을 끄세요.
set timeout -1
send -- "./telnetverison.sh \r"
expect "$ "
Expect 스크립트를 호출하면 sleep
코드 냄새가 발생할 수 있습니다.