第一个shell脚本

打开文本编辑器,新建一个文件,扩展名为sh(sh表明shell),扩展名并不影响脚本执行,见名知意就好,若是你用php写shell 脚本,扩展名就用php好了。php

输入如下代码:linux

#!/bin/bash
echo "Hello Word"

“#!”是一个约定的标记,他告诉系统这个脚本须要什么解释器来执行,即便用哪种Shell。echo命令用于向窗口输出文本。shell

 

运行Shell脚本有两种方法。bash

做为可执行程序

将上面的代码保存为guojg.sh编辑器

[root@lvs-2 bash]# ls
 guojg.sh
[root@lvs-2 bash]# chmod +x guojg.sh   #使脚本具备执行权限
[root@lvs-2 bash]# ./guojg.sh #执行脚本
Hello Word

注意,必定要写成./test.sh,而不是test.sh。运行其它二进制的程序也同样,直接写test.sh,linux系统会去PATH里寻找有没有叫test.sh的,而只有/bin, /sbin, /usr/bin,/usr/sbin等在PATH里,你的当前目录一般不在PATH里,因此写成test.sh是会找不到命令的,要用./test.sh告诉系统说,就在当前目录找。spa

经过这种方式运行bash脚本,第一行必定要写对,好让系统查找到正确的解释器。code

这里的"系统",其实就是shell这个应用程序(想象一下Windows Explorer),但我故意写成系统,是方便理解,既然这个系统就是指shell,那么一个使用/bin/sh做为解释器的脚本是否是能够省去第一行呢?是的。blog

做为解释器参数

这种运行方式是,直接运行解释器,其参数就是shell脚本的文件名,如:class

[root@lvs-2 bash]# /bin/sh guojg.sh 
Hello Word

这种方式运行的脚本,不须要在第一行指定解释器信息,写了也没用。test

再看一个例子。下面的脚本使用 read 命令从 stdin 获取输入并赋值给 PERSON 变量,最后在 stdout 上输出:

#!/bin/bash
echo "What is your name?"
read name
echo "Hello,$name"

运行脚本:

[root@lvs-2 bash]# chmod +x guojg.sh 
[root@lvs-2 bash]# ./guojg.sh 
 What is your name?
 guojg                      
 Hello,guojg
相关文章
相关标签/搜索