sudo: incapaz de executar ./script.sh: esse arquivo ou diretório não existe

27

Estou perplexo. Eu tenho um script no meu /homediretório que é executável:

[user@server ~]$ ll
total 4
-rwx------ 1 user user 2608 Jul 15 18:23 qa.sh

No entanto, quando tento executá-lo, sudoele diz que não pode encontrá-lo:

[user@server ~]$ sudo ./qa.sh 
[sudo] password for user: 
sudo: unable to execute ./qa.sh: No such file or directory

Isso está em uma nova versão. Nenhuma alteração foi feita, o que causaria problemas. De fato, o objetivo do script é garantir que ele seja realmente construído de acordo com nossas políticas. Talvez não esteja e sudoesteja sendo quebrado durante a compilação?

Também devo observar que posso executar sudocom outros comandos em outros diretórios.

EDIT: O script (eu não o escrevi, por isso não /bin/bashme refiro, por favor;))

#! /bin/bash

. /root/.bash_profile

customer=$1

if [ -z "$customer" ]; then

        echo "Customer not provided. Exiting..."
        exit 1

fi

space ()
{
echo
echo '###########################################################################'
echo '###########################################################################'
echo '###########################################################################'
echo
}

g=/bin/egrep

$g ^Listen /etc/ssh/sshd_config
$g ^PermitR /etc/ssh/sshd_config
$g ^LogL /etc/ssh/sshd_config
$g ^PubkeyA /etc/ssh/sshd_config
$g ^HostbasedA /etc/ssh/sshd_config
$g ^IgnoreR /etc/ssh/sshd_config
$g ^PermitE /etc/ssh/sshd_config
$g ^ClientA /etc/ssh/sshd_config

space

$g 'snyder|rsch|bream|shud|mweb|dam|kng|cdu|dpr|aro|pvya' /etc/passwd ; echo ; echo ; $g 'snyder|rsch|bream|shud|mweb|dam|kng|cdu|dpr|aro|pvya' /etc/shadow

space

$g 'dsu|scan' /etc/passwd ; echo ; echo ; $g 'dsu|scan' /etc/shadow

space

$g ${customer}admin /etc/passwd

space

chage -l ${customer}admin

space

$g 'urs|cust|dsu' /etc/sudoers

space

$g dsu /etc/security/access.conf

space

$g account /etc/pam.d/login

space

/sbin/ifconfig -a | $g addr | $g -v inet6

space

echo "10.153.156.0|10.153.174.160|10.120.80.0|10.152.80.0|10.153.193.0|172.18.1.0|10.153.173.0"
echo
$g '10.153.156.0|10.153.174.160|10.120.80.0|10.152.80.0|10.153.193.0|172.18.1.0|10.153.173.0' /etc/sysconfig/network-scripts/route-eth1

space

cat /etc/sysconfig/network-scripts/route-eth2

space

netstat -rn | tail -1

space

cat /etc/sysconfig/iptables

space

cat /etc/hosts

space

##file /usr/local/groundwork ; echo ; echo ; /sbin/service gdma status

##space

cat /etc/resolv.conf

space

HOSTNAME=`echo $HOSTNAME | awk -F. '{ print $1 }'`

nslookup ${HOSTNAME}

echo
echo

nslookup ${HOSTNAME}-mgt

echo
echo

nslookup ${HOSTNAME}-bkp

space

/sbin/service rhnsd status ; echo ; echo ; /sbin/chkconfig --list rhnsd ; echo ; echo ; yum update --security

space

/sbin/service osad status ; echo ; echo ; /sbin/chkconfig --list osad

space

/sbin/service sshd status ; echo ; echo ; /sbin/chkconfig --list sshd

space

/sbin/service snmpd status ; echo ; echo ; /sbin/chkconfig --list snmpd ; echo ; echo ; echo ; cat /etc/snmp/snmpd.conf

space

df -h

space

cat /proc/cpuinfo | $g ^processor

space

free -g

space

if [ -f /etc/rsyslog.conf ]; then

        tail -3 /etc/rsyslog.conf

else

        echo "This system is not running rsyslog."

fi

rm -f $0
theillien
fonte
3
tente usar em sh qa.shvez de./qa.sh
Networker
@Networker Nenhuma mudança de comportamento ao usar este formato.
theillien

Respostas:

28

Isso geralmente acontece quando a #!linha shebang ( ) no seu script é interrompida.

O shebang é o que diz ao kernel que o arquivo precisa ser executado usando um intérprete. Quando executada sem sudo, a mensagem é um pouco mais significativa. Mas com sudovocê recebe a mensagem que recebeu.

Por exemplo:

$ cat test.sh
#!/bin/foo
echo bar

$ ./test.sh
bash: ./test.sh: /bin/foo: bad interpreter: No such file or directory

$ bash test.sh
bar

$ sudo ./test.sh
sudo: unable to execute ./test.sh: No such file or directory

$ sudo bash ./test.sh
bar

A bad interpretermensagem indica claramente que é o shebang que está com defeito.

Patrick
fonte
11
Esse foi o problema. Havia ^Mcaracteres ocultos e o intérprete estava lendo como parte da linha shebang. Eu passei dos2unixe consertei. Obrigado ~
theillien
11
Qual editor você está usando?
CTRL-ALT-DELOR
5
No meu caso, o final da linha foi definido incorretamente, para CR-LF para Windows, deve ser LF para Linux. Pode demorar um pouco antes de descobrir isso.
precisa saber é o seguinte
11

Eu apenas tive esse problema exato, acabou por ser um problema de codificação de arquivo de texto. Para corrigi-lo durante a execução do Xubuntu 14.04.3 LTS, instalei o dos2unix e converti a codificação do script e, em seguida, executei o script novamente usando o sudo e funcionou bem. Você pode encontrar um exemplo abaixo:

sudo apt-get install dos2unix -y
dos2unix test.sh
sudo chmod u+x test.sh && sudo ./test.sh
Tom B
fonte
Enquanto isso funciona, perceba que a interpretação dos caracteres de final de linha é modelada pelo shebang no arquivo. Portanto, isso pode resolver o problema, mas também pode alterar o shebang.
ErikE
Eu tive esse problema com o editor Atom no Windows. O final da linha padrão era CRLF. Mas se você for para Configurações> Pacotes> Seletor de final de linha, poderá alterar a linha padrão final para LF. Então, quando você WinSCP, o script bash no Linux, ele deve ser executado sem esse No such file or directoryerro enganoso .
snark