#!/bin/sh
#
Host = ###############
Port = ####
email_id="##################"
email_sub="######"
#
if ping -q -c 5 $Host >/dev/null
then
result_host="Successful"
else
result_host="Not Successful"
fi
result_nc='nc -z $Host $Port; echo $?'
if [ $result_nc != 0 ];
then
result_port="Not Opened"
else
result_port="Opened"
fi
mesg="Ping to host was ${result_host}, Port $port is ${result_port}."
echo "$mesg"
#echo "$mesg" | mail -s "$email_sub" $email_id
quando uso para executar o script, recebo um erro Erro de sintaxe:Unexpected end of file.
Responder1
Eu tentei executar isso. Não recebi um erro de sintaxe. Na verdade, parece principalmente uma boa sintaxe.
Por favor, veja a saída abaixo:
$ ./a.sh
./a.sh: 3: ./a.sh: Host: not found
./a.sh: 4: ./a.sh: Port: not found
Usage: ping [-aAbBdDfhLnOqrRUvV] [-c count] [-i interval] [-I interface]
[-m mark] [-M pmtudisc_option] [-l preload] [-p pattern] [-Q tos]
[-s packetsize] [-S sndbuf] [-t ttl] [-T timestamp_option]
[-w deadline] [-W timeout] [hop1 ...] destination
./a.sh: 15: [: nc: unexpected operator
Ping to host was Not Successful, Port is Opened.
Acho que você deseja substituir as aspas nesta linha por crases:
result_nc='nc -z $Host $Port; echo $?'
então mude para:
result_nc=`nc -z $Host $Port; echo $?`
Há também um problema de lógica (não um problema de sintaxe) com essa linha porque ela atribui o resultado stdout do comando em result_nc. Como Gordon sugeriu, mude para:
if nc -z $Host $Port
then
...
E remova os espaços na tarefa:
Host = ###############
Port = ####
então isso se torna:
Host=###############
Port=####
porque as atribuições não funcionarão corretamente se houver espaços.
E confirahttp://www.shellcheck.net/