shell脚本执行权限(shell脚本执行权限不够)
linux shell脚本执行命令详解
在Linux下,如果你需要执行shell脚本,那么应该使用那个命令呢?下面由我为大家整理了linux shell脚本执行命令的相关知识,希望对大家有帮助!
linux shell脚本执行
linux shell脚本执行方法一: 切换到shell脚本所在的目录(此时,称为工作目录)执行shell脚本:
cd /data/shell
http://111.pc699.com/003/hello.sh
http://111.pc699.com/003/的意思是说在当前的工作目录下执行hello.sh。如果不加上http://111.pc699.com/003/,bash可能会响应找到不到hello.sh的错误信息。因为目前的工作目录(/data/shell)可能不在执行程序默认的搜索路径之列,也就是说,不在环境变量PASH的内容之中。查看PATH的内容可用 echo $PASH 命令。现在的/data/shell就不在环境变量PASH中的,所以必须加上http://111.pc699.com/003/才可执行。
linux shell脚本执行方法二: 以绝对路径的方式去执行bash shell脚本:
/data/shell/hello.sh
linux shell脚本执行方法三: 直接使用bash 或sh 来执行bash shell脚本:
cd /data/shell
bash hello.sh
或
cd /data/shell
sh hello.sh
注意,若是以方法三的方式来执行,那么,可以不必事先设定shell的执行权限,甚至都不用写shell文件中的第一行(指定bash路径)。因为方法三是将hello.sh作为参数传给sh(bash)命令来执行的。这时不是hello.sh自己来执行,而是被人家调用执行,所以不要执行权限。那么不用指定bash路径自然也好理解了啊。
linux shell脚本执行方法四: 在当前的shell环境中执行bash shell脚本:
cd /data/shell
. hello.sh
或
cd /data/shell
source hello.sh
前三种方法执行shell脚本时都是在当前shell(称为父shell)开启一个子shell环境,此shell脚本就在这个子shell环境中执行。shell脚本执行完后子shell环境随即关闭,然后又回到父shell中。而方法四则是在当前shell中执行的。
如何运行shell脚本
编写好的shell脚本(如:test),可以采取两种方式进行运行:\x0d\x0a一、 $ sh test\x0d\x0a一般不采用这种调用方式,尤其不采用“shtest”的调用方式,因为这种方式将禁止shell读取标准输入。\x0d\x0a也可以采用 $ ksh test\x0d\x0a这种方式要求shell具有“可读”的访问权限。\x0d\x0a二、直接运行可执行的shell脚本之前,首先应使用下列chmod命令,把shell脚本文件设置为可执行的文件。\x0d\x0achmod 755 test(除文件属主可写之外,每个用户均具有读和可执行的访问权限)\x0d\x0achmod +rx test(同上)\x0d\x0achmod u+rx test(只有文件属主具有读和执行的访问权限)\x0d\x0a按照上述要求设置shell脚本文件的访问权限后,可采用下列方式,直接运行shell脚本了。\x0d\x0a1、test(如果命令检索路径包含当前目录)\x0d\x0a2、http://111.pc699.com/003/test(如果命令减缩路径不包含当前目录)\x0d\x0a*说明: sh test 方式调用一个shell叫蹦可能会禁止某些shell特定的扩展功能,因而可能引起脚本无法正确执行。
允许运行Power shell脚本
出于安全考虑,默认的 Windows PowerShell 策略不允许执行脚本
名称
Set-ExecutionPolicy
语法
Set-ExecutionPolicy [-ExecutionPolicy] {Unrestricted | RemoteSigned | AllSigned | Restricted | Default | Bypass |Undefined} [[-Scope] {Process | CurrentUser | LocalMachine | UserPolicy | MachinePolicy}] [CommonParameters]
Get-ExecutionPolicy表示获得当前环境执行powershell脚本的权限,这种权限有4个值
Restricted,默认设置,不允许运行任何脚本
AllSigned, 仅运行受信任脚本
RemoteSigned运行本地脚本,不管这些脚本是否受信任;
Unrestricted,允许运行所有脚本,甚至是不受信任的;
一般状况下我们把级别设置为RemoteSigned这样方便脚本调试运行。
编写的shell程序运行前必须赋予该脚本文件什么权限
题主你好,
linux系统下, 如果想执行一个文件,必须要给该文件赋予可执行权限, 而赋予权限的命令为:
chmod +x 文件名
举例来说, 下图为我编写的输出文本 hello world 的shell脚本内容,脚本名为ok.sh:
a.我们先看一下不给ok.sh这个脚本加可执行权限(x)时,执行它终端会怎么说:
从上图的输出可以看出,终端告诉我们"权限被拒绝", 说白了就是无权对文件做执行操作.
b.下面我们给文件加上可执行权限后, 再执行看一下:
通过上图可以看出, 在使用chmod命令给ok.sh文件加上可执行权限后, 对其执行, 终端成功输出了我们想要的结果: hello world
-----
希望可以帮到题主, 欢迎追问.