sudo: неможливо виконати ./script.sh: такого файлу чи каталогу немає


27

Я тупаю. У моєму /homeкаталозі є сценарій, який виконується:

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

Однак, коли я намагаюся запустити його, sudoвін каже, що він не може його знайти:

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

Це на новому складі. Жодних змін, що спричинили б проблеми, не було. Насправді сенс сценарію полягає в тому, щоб він був фактично побудований відповідно до нашої політики. Можливо, можливо, це не так і sudoнасправді ламається під час збірки?

Я також повинен зазначити, що я можу працювати sudoз іншими командами в інших каталогах.

EDIT: Сценарій (я його не написав, тому не перекладайте /bin/bashмене, будь ласка;))

#! /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

3
спробуйте використовувати sh qa.shзамість./qa.sh
Networker

@Networker Немає змін у поведінці під час використання цього формату.
theillien

Відповіді:


28

Зазвичай це відбувається, коли #!рядок shebang ( ) у вашому сценарії порушено.

Шебанг - це те, що повідомляє ядро, що файл повинен бути виконаний за допомогою інтерпретатора. Якщо запустити без sudo, повідомлення має трохи більше значення. Але разом з sudoвами отримаєте повідомлення, яке ви отримали.

Наприклад:

$ 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

bad interpreterПовідомлення ясно вказує на те, що це кубло , який несправний.


11
Це було питання. Були приховані ^Mперсонажі, і перекладач читав це як частину рядка shebang. Я пробіг його через це, dos2unixі він це виправив. Спасибі ~
theillien

1
Який редактор ви використовуєте?
ctrl-alt-delor

5
У моєму випадку закінчення рядків було встановлено неправильно, CR-LF для Windows, LF для Linux. Може пройти деякий час, перш ніж дізнатися про це.
RolfBly

11

У мене була саме така проблема, виявилася проблема кодування текстових файлів. Для мене, щоб виправити це під час запуску Xubuntu 14.04.3 LTS, я встановив dos2unix і перетворив кодування сценарію, а потім запустив сценарій знову за допомогою sudo, і він працював чудово. Ви можете знайти приклад нижче:

sudo apt-get install dos2unix -y
dos2unix test.sh
sudo chmod u+x test.sh && sudo ./test.sh

Поки це працює, зрозумійте, що інтерпретація символів, що закінчуються рядками, формується шебангом у файлі. Так це може виправити проблему, але може змінити шебанг.
ЕрікЕ

У мене була ця проблема з редактором Atom у Windows. За замовчуванням закінчується рядок CRLF. Але якщо ви перейдете в Налаштування> Пакети> Вибір закінчення рядка, ви можете змінити рядок за замовчуванням, що закінчується, на LF. Тоді, коли ви WinSCP, скрипт bash в Linux, він повинен виконуватись без помилкової No such file or directoryпомилки.
snark
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.