./和sh的区别~~~~

sh/bash/dash/ksh/zsh等Shell脚本
zwjiong
帖子: 17
注册时间: 2008-06-28 16:37

./和sh的区别~~~~

#1

帖子 zwjiong » 2008-11-26 21:43

写了一个最简单的shell程序~~~
#!/bin/bash

STR="Hello World"
echo $STR

:em06 但是在使用./运行的时候竟然说是 command not found
但是使用sh命令就可以~~~
然后看了下sh,其实是一个指向dash的软链接,不是指向bash的,晕掉了~~~望大侠帮我理理其中的关系
头像
xhy
帖子: 3916
注册时间: 2005-12-28 1:16
系统: Ubuntu 12.10 X64
来自: 火星

Re: ./和sh的区别~~~~

#2

帖子 xhy » 2008-11-26 21:49

ubuntu中默认不再是bash了 取而代之的是dash

./执行时,shell找/bin/bash当然找不到了

sh执行时,忽略掉#开头的行,直接使用sh作为解释器
目前负债150多万
zwjiong
帖子: 17
注册时间: 2008-06-28 16:37

Re: ./和sh的区别~~~~

#3

帖子 zwjiong » 2008-11-26 22:17

但是我在/bin 下面能够找到bash和dash阿~~
hgshlg
帖子: 222
注册时间: 2007-08-30 14:45

Re: ./和sh的区别~~~~

#4

帖子 hgshlg » 2008-11-26 23:34

运行权限?
头像
princelai
帖子: 920
注册时间: 2007-01-06 21:00
联系:

Re: ./和sh的区别~~~~

#5

帖子 princelai » 2008-11-27 0:18

sudo chmod a+x XXX
zwjiong
帖子: 17
注册时间: 2008-06-28 16:37

Re: ./和sh的区别~~~~

#6

帖子 zwjiong » 2008-11-27 9:03

直接使用./会提示权限不够~~~
但是如果使用sudo ./那就提示我之前所说的“command not found”
leeyee
帖子: 723
注册时间: 2006-04-11 9:01

Re: ./和sh的区别~~~~

#7

帖子 leeyee » 2008-11-27 9:46

脚本写完了一定要加上可执行权限才能执行的。

代码: 全选

chmod u+x xxx.sh
I would love to change the world, but they won't give me the source code.
http://hi.baidu.com/wienerlee
xyywll
帖子: 338
注册时间: 2008-05-24 1:24

Re: ./和sh的区别~~~~

#8

帖子 xyywll » 2008-11-27 10:02

zwjiong 写了:直接使用./会提示权限不够~~~
但是如果使用sudo ./那就提示我之前所说的“command not found”
sudo 的后,你的 PATH 环境变量用的是 root 的,so。。
如果努力的目的是为了超越他人,那么我们永远成功不了
大道是平的,我们该做的是让自己快乐,同时带给他人快乐
好好涵养自己的性格
才华是刀刃,辛苦是磨刀石
多食果蔬,健康长寿;少吃不吃鱼肉,珍爱它类生命,远离自身疾病
zwjiong
帖子: 17
注册时间: 2008-06-28 16:37

Re: ./和sh的区别~~~~

#9

帖子 zwjiong » 2008-11-27 10:12

xyywll 写了:
zwjiong 写了:直接使用./会提示权限不够~~~
但是如果使用sudo ./那就提示我之前所说的“command not found”
sudo 的后,你的 PATH 环境变量用的是 root 的,so。。
能不能解释的清楚点,小弟还是不大懂~~~
这个脚本我不是用root用户建立的(忘记用ls看了),所以用sudo之后其实以root用户执行,是不是就出现问题了~~~
leeyee
帖子: 723
注册时间: 2006-04-11 9:01

Re: ./和sh的区别~~~~

#10

帖子 leeyee » 2008-11-27 12:39

xyywll 写了:
zwjiong 写了:直接使用./会提示权限不够~~~
但是如果使用sudo ./那就提示我之前所说的“command not found”
sudo 的后,你的 PATH 环境变量用的是 root 的,so。。
跟环境变量没有关系的,./就是执行当前目录下的脚本么,只要脚本有执行权限,即使是sudo也是可以执行的。
之所以你sudo ./xxx会出现command not found是因为脚本没有权限,因此shell解释器没有解释./的意义,sudo就认为你输入的命令叫./xxx,而不是xxx。
而用sh xxx.sh可以执行是因为shell解释器把xxx.sh解释为sh命令的输入,这样当然是可以的。
I would love to change the world, but they won't give me the source code.
http://hi.baidu.com/wienerlee
zwjiong
帖子: 17
注册时间: 2008-06-28 16:37

Re: ./和sh的区别~~~~

#11

帖子 zwjiong » 2008-11-27 12:43

leeyee 写了:
xyywll 写了:
zwjiong 写了:直接使用./会提示权限不够~~~
但是如果使用sudo ./那就提示我之前所说的“command not found”
sudo 的后,你的 PATH 环境变量用的是 root 的,so。。
跟环境变量没有关系的,./就是执行当前目录下的脚本么,只要脚本有执行权限,即使是sudo也是可以执行的。
之所以你sudo ./xxx会出现command not found是因为脚本没有权限,因此shell解释器没有解释./的意义,sudo就认为你输入的命令叫./xxx,而不是xxx。
而用sh xxx.sh可以执行是因为shell解释器把xxx.sh解释为sh命令的输入,这样当然是可以的。
3Q~~解释的很明白,我刚刚也用chmod改了执行权限现在可以了~~~非常感谢啊~~
Dic4000
帖子: 104
注册时间: 2008-09-10 21:06

Re: ./和sh的区别~~~~

#12

帖子 Dic4000 » 2008-11-28 1:04

leeyee 写了:
xyywll 写了:
zwjiong 写了:直接使用./会提示权限不够~~~
但是如果使用sudo ./那就提示我之前所说的“command not found”
sudo 的后,你的 PATH 环境变量用的是 root 的,so。。
跟环境变量没有关系的,./就是执行当前目录下的脚本么,只要脚本有执行权限,即使是sudo也是可以执行的。
之所以你sudo ./xxx会出现command not found是因为脚本没有权限,因此shell解释器没有解释./的意义,sudo就认为你输入的命令叫./xxx,而不是xxx。
而用sh xxx.sh可以执行是因为shell解释器把xxx.sh解释为sh命令的输入,这样当然是可以的。
不错,学习了
xyywll
帖子: 338
注册时间: 2008-05-24 1:24

Re: ./和sh的区别~~~~

#13

帖子 xyywll » 2008-11-29 10:45

ls 三位朋友,我的感觉不是如此

你输入的任何命令都会被 shell 解析,除非用 quoting,不然 ./ 应该是被 shell 解析的,命令自然只是 ./ 后面的命令
比如脚本 haha.sh 用 strace 跟踪 sudo ./haha.sh 得到:
execve("/usr/bin/sudo", ["sudo", "haha.sh"], [/* 41 vars */]) = 0
显然,sudo 的参数是 haha.sh 而不是 ./haha.sh , ./ 被 shell 解析了
原因是什么,我还不知道,我弄完手头的事情,准备跟踪下执行过程

大家可以做做实验:
在 /bin 下面自己建立一个脚本,比如 haha.sh , 但不给 +x 权限,这样 sudo 的时候,一定会搜索到 /bin 目录,输入
sudo haha.sh
一样提示: sudo: haha.sh: command not found
所以我觉得是别的问题

我觉得真实的原因是:
1. 你给 shell 一个文本文件(类型是使用 文件头 探测到的),实际上就是给 shell 的一系列指令的集合,此时 haha.sh 不是一个可执行文件,而是一个文本文件,执行的实际是 当前shell名 haha.sh ,lz 的例子就是 bash haha.sh
但在执行前,先要检测有没有 +x ,因为没有,所以提示 Permission denied
如果 +x 了,执行的就是
bash haha.sh
2. sudo 的时候, sudo 后面的东西是被 shell 解析后作为 sudo 的参数,实际上是作为 execve 系统调用的实参来执行的,而 execve 能够启动的只能是一个 ELF a.out 等格式的可执行文件,所以用 sudo ./haha.sh , haha.sh 被作为一个可执行文件来传递给 execve ,显然它不是ELF a.tou (同样用文件头探测),execve 不了,所以说 command not found

一些想法,没验证,大家可以自己先调试下
如果努力的目的是为了超越他人,那么我们永远成功不了
大道是平的,我们该做的是让自己快乐,同时带给他人快乐
好好涵养自己的性格
才华是刀刃,辛苦是磨刀石
多食果蔬,健康长寿;少吃不吃鱼肉,珍爱它类生命,远离自身疾病
leeyee
帖子: 723
注册时间: 2006-04-11 9:01

Re: ./和sh的区别~~~~

#14

帖子 leeyee » 2008-11-30 10:21

xyywll 写了:ls 三位朋友,我的感觉不是如此

你输入的任何命令都会被 shell 解析,除非用 quoting,不然 ./ 应该是被 shell 解析的,命令自然只是 ./ 后面的命令
比如脚本 haha.sh 用 strace 跟踪 sudo ./haha.sh 得到:
execve("/usr/bin/sudo", ["sudo", "haha.sh"], [/* 41 vars */]) = 0
显然,sudo 的参数是 haha.sh 而不是 ./haha.sh , ./ 被 shell 解析了
原因是什么,我还不知道,我弄完手头的事情,准备跟踪下执行过程

大家可以做做实验:
在 /bin 下面自己建立一个脚本,比如 haha.sh , 但不给 +x 权限,这样 sudo 的时候,一定会搜索到 /bin 目录,输入
sudo haha.sh
一样提示: sudo: haha.sh: command not found
所以我觉得是别的问题

我觉得真实的原因是:
1. 你给 shell 一个文本文件(类型是使用 文件头 探测到的),实际上就是给 shell 的一系列指令的集合,此时 haha.sh 不是一个可执行文件,而是一个文本文件,执行的实际是 当前shell名 haha.sh ,lz 的例子就是 bash haha.sh
但在执行前,先要检测有没有 +x ,因为没有,所以提示 Permission denied
如果 +x 了,执行的就是
bash haha.sh
2. sudo 的时候, sudo 后面的东西是被 shell 解析后作为 sudo 的参数,实际上是作为 execve 系统调用的实参来执行的,而 execve 能够启动的只能是一个 ELF a.out 等格式的可执行文件,所以用 sudo ./haha.sh , haha.sh 被作为一个可执行文件来传递给 execve ,显然它不是ELF a.tou (同样用文件头探测),execve 不了,所以说 command not found

一些想法,没验证,大家可以自己先调试下
其实你误会我的意思了。就拿你的例子来说吧,我已经说了sudo检查了haha.sh,但是发现它没有执行权限(也就是说不是可执行文件),所以它就不再进一步向下走了。“./”自然是已经被shell认出来了,否则它也不会去检查haha.sh是否可执行呀! :em02 只是它不再做进一步动作罢了。我说它没有被解释只是为了方便楼主理解。

你已经看到系统调用这一层,很赞!
I would love to change the world, but they won't give me the source code.
http://hi.baidu.com/wienerlee
lujinke
帖子: 81
注册时间: 2007-07-20 10:12

Re: ./和sh的区别~~~~

#15

帖子 lujinke » 2008-12-03 16:57

你用的什么版本的Ubuntu啊,我用7。10可以很好的运行没有你说的问题。
而且也不是想上面的人说的没有/bin/bash,而是/bin/bash ,/bin/dash
zwjiong 写了:写了一个最简单的shell程序~~~
#!/bin/bash

STR="Hello World"
echo $STR

:em06 但是在使用./运行的时候竟然说是 command not found
但是使用sh命令就可以~~~
然后看了下sh,其实是一个指向dash的软链接,不是指向bash的,晕掉了~~~望大侠帮我理理其中的关系
回复