Estoy usando Mac OS X 10.9.4, el siguiente es mi script para copiar archivos de la máquina local a un host diferente
#!/bin/bash
#!/usr/bin/expect
echo "I will fail if you give junk values!!"
echo " "
echo "Enter file name: "
read filePath
echo " "
echo "Where you want to copy?"
echo "Enter"
echo "1. if Host1"
echo "2. if Host2"
echo "3. if Host3"
read choice
echo " "
if [ $choice -eq "1" ]
then
spawn scp filePath uname@host1:/usr/tmp
expect "password"
send "MyPassword\r"
interact
elif [ $choice -eq "2" ]
then
spawn scp filePath uname@host2:/usr/tmp
expect "password"
send "MyPassword\r"
interact
elif [ $choice -eq "3" ]
then
spawn scp filePath uname@host3:/usr/tmp
expect "password"
send "MyPassword\r"
interact
else
echo "Wrong input"
fi
cuando ejecuto este script estoy recibiendo
./rcopy.sh: line 21: spawn: command not found
couldn't read file "password": no such file or directory
./rcopy.sh: line 23: send: command not found
./rcopy.sh: line 24: interact: command not found
bash
shell-script
expect
dev2d
fuente
fuente
Respuestas:
Su guión está intentando combinar dos intérpretes. Tienes ambos
#!/bin/bash
y#!/usr/bin/expect
. Eso no funcionará. Solo puedes usar uno de los dos. Desde elbash
principio, su script se ejecuta como un script bash.Sin embargo, dentro de su script, tiene
expect
comandos comospawn
ysend
. Dado que el script está siendo leído porbash
y no porexpect
, esto falla. Puede solucionar esto escribiendo diferentesexpect
guiones y llamándolos desde subash
guión o traduciéndolo todoexpect
.Sin embargo, la mejor manera, y una que evita la práctica horrible de tener sus contraseñas en texto plano en un archivo de texto simple, es configurar ssh sin contraseña. De esa manera,
scp
no necesitará una contraseña y no necesitaexpect
:Primero, cree una clave ssh pública en su máquina:
Se le pedirá una frase de contraseña que se le pedirá que ingrese la primera vez que ejecute cualquier comando ssh después de cada inicio de sesión. Esto significa que para múltiples comandos ssh o scp, solo tendrá que ingresarlo una vez. Deje la frase de contraseña vacía para un acceso completamente sin contraseña.
Una vez que haya generado su clave pública, cópiela en cada computadora de su red:
El
IPlistfile.txt
debe ser un archivo que contiene el nombre de un servidor o IP en cada línea. Por ejemplo:Como esta es la primera vez que hace esto, tendrá que ingresar manualmente la contraseña para cada IP, pero una vez que lo haya hecho, podrá copiar archivos a cualquiera de estas máquinas con un simple:
Elimina la expectativa de tu script. Ahora que tiene acceso sin contraseña, puede usar su script como:
fuente
Su código puede ser mucho más conciso:
Si configura las claves ssh como se sugiere, es aún mejor:
fuente
spawn
es unexpect
comando . No funcionará si su intérprete lo es/bin/bash
.fuente