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、他のディレクトリで他のコマンドを使用して実行できることにも注意してください。

編集:スクリプト(私はそれを書いていないので/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 14

回答:


28

これは通常#!、スクリプトのシェバン()行が壊れているときに発生します。

シェバンは、インタープリターを使用してファイルを実行する必要があることをカーネルに伝えるものです。なし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キャラクターがいて、通訳はそれをシバンの一部として読んでいた。私はそれを実行し、dos2unixそれをすぐに修正しました。おかげで〜
theillien

1
どのエディターを使用していますか?
ctrl-alt-delor 14

5
私の場合、行末はWindowsではCR-LFに、LinuxではLFに設定する必要があります。あなたがそれを見つけるまでに時間がかかることがあります。
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

これは機能しますが、行末文字の解釈はファイルのシェバンによって形作られることを理解してください。これで問題を解決できますが、シバンを変更することもできます。
エリック

WindowsのAtomエディターでこの問題が発生しました。デフォルトの行末はCRLFでした。ただし、[設定]> [パッケージ]> [行末選択]に移動すると、デフォルトの行末をLFに変更できます。その後、bashスクリプトをWinSCPでLinuxに送信すると、誤解を招くようなNo such file or directoryエラーが発生することなく実行されます。
スナーク
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.