Shell脚本的用处
经常会在网上看到一些一键XXX脚本。例如一键LAMP,LNMP脚本。只需要执行简单的命令,然后跟着脚本提示操作就能够完成搭建一个简单的网站,带数据库后台和各种环境。Shell脚本可以帮助我们完成很多冗杂的工作,也可以通过编写shell脚本达到快速部署环境的目的。能够大大提高工作效率。类似windows里的.BAT文件。
编写简单的Shell脚本
编写Shell脚本的方式非常简单。只需要使用常用的文本编辑器如VIM创建一个文件,然后在文件中输入命令即可。例如,如果想查看当前所在的工作路径并列出当前目录下所有文件及属性信息,实现这个功能的脚本就可以这么编写
1 | [root@remilia ~]# vi example.sh |
那么一个个来解释这其中的含义吧
- 第一行#!/bin/bash 代表脚本声明,即告诉系统使用哪种命令解释器执行这个脚本。
- 第二行#为注释信息。如果有学过C语言或者其他编程语言应该能很快了解。注释信息不会被执行。是对这个脚本功能的解释。方便他人查看脚本的时候知道这个脚本的功能。
- 后面的就是Linux的命令,就不再赘述了。另外。Linux不以后缀名分辨文件类型。也可以说Linux中没有后缀名的概念。所以脚本名字的.sh是一个约定俗成的规矩 表示这是一个可执行的脚本。
一个写好的脚本文件可以通过bash去执行。结果如下
1 | [root@remilia ~]# bash example.sh |
除了用bash这种方式执行之外,还可以使用“./”去执行。但是可能会报错提示权限不足。这边先使用chmod命令给脚本执行的权限。权限部分的知识在这暂且不提。在此只需要知道脚本的另一种执行方法就行。
1 | [root@remilia ~]# ./example.sh |
接收用户的参数
上面这种简单的shell脚本只能执行一些预先定义好的功能。有时候需要接收用户的输入,才能更好的满足需求。
在Shell语言中,内设了用于接收参数的变量。变量之间可以用空格间隔。例如$0代表当前shell脚本程序的名称,$#对应的是总共有几个参数。、$*对应的是所有位置的参数值,$?对应的是上一个命令执行的返回值。$1 $2 $3 … $N代表第一个,第二个,第三个….第N个参数的值
尝试编写一个脚本程序示例,通过引用上面的变量参数来看下真实效果:
1 | [root@remilia ~]# cat example.sh |
判断用户的参数
系统在执行mkdir命令时会判断用户输入的信息,即判断用户指定的文件夹名称是否已经存在,如果存在则提示报错;反之则自动创建。Shell脚本中的条件测试语法可以判断表达式是否成立,若条件成立则返回数字0,否则便返回其他随机数值。条件测试语法的执行格式如下:
[ 条件表达式 ]注意两边一定要有空格
按照测试对象来划分,条件测试语句可以分为4种
文件测试语句
逻辑测试语句
整数值比较语句
字符串比较语句
文件测试即使用指定条件来判断文件是否存在或权限是否满足等情况的运算符.具体参数如下:
运算符 | 作用 |
---|---|
-d | 测试文件是否为目录类型 |
-e | 测试文件是否存在 |
-f | 判断是否为一般文件 |
-r | 测试当前用户是否有权限读取 |
-w | 测试当前用户是否有权限写入 |
-x | 测试当前用户是否有权限执行 |
下面使用文件测试语句来判断/etc/fstab是否为一个目录类型的文件,然后通过Shell解释器的内设$?变量显示上一条命令执行后的返回值。如果返回值为0,则目录存在;如果返回值为非零的值,则意味着目录不存在:
1 | [root@remilia ~]# [ -d /etc/fstab ] |
再使用文件测试语句来判断/etc/fstab是否为一般文件,如果返回值为0,则代表文件存在,且为一般文件:
1 | [root@remilia ~]# [ -e /etc/fstab ] |