对于Linux来说,我们一般都是用命令形式去处理信息的采集整理等而不像Windows上图形的交互式直观,往往有时候我们为了得到某一信息,要输入大量的命令。那么有没有那么一种稍微简单点的工具处理这些大量繁琐的命令呢?在Linux中恰好有这么一个工具可以编辑Linux小脚本的,可以把许多的命令写到里面去,那就是vim,可以避免大量的时间写重复的命令执行相同的任务,功能相对也可以的。
shell脚本:
包含一些命令或声明,并符合一定格式的文本文件
shell脚本的用途有:
自动化常用命令
执行系统管理和故障排除
创建简单的应用程序
处理文本或文件
一,脚本的起名:
一般来说我们建一个小脚本,名字都是起一个直观一看就知道是什么含义的名字,如我们想写个自动创建模板的脚本,我们可以取名为“shtemplet.sh”等等,自己在大量的文件中也可快速的识别到,别人看到基本就知道这个作用。
二、开头:
我们首行要写shebang机制,
#!/bin/bash
#!/usr/bin/python
#!/usr/bin/perl
为什么要写shebang机制?
1.Shebang这个符号通常在Linux或Unix系统的脚本中第一行开头中写到,它指明了执行这个脚本文件的解释程序。
2. 如果脚本文件中没有#!这一行,那么它执行时会默认用当前Shell去解释这个脚本(即:$SHELL环境变量)。
3. 如果#!之后的解释程序是一个可执行文件,那么执行这个脚本时,它就会把文件名及其参数一起作为参数传给那个解释程序去执行。
4. 如果#!指定的解释程序没有可执行权限,则会报错“bad interpreter: Permission denied”。如果#!指定的解释程序不是一个可执行文件,那么指定的解释程序会被忽略,转而交给当前的SHELL去执行这个脚本。
5. 如果#!指定的解释程序不存在,那么会报错“bad interpreter: No such file or directory”。注意:#!之后的解释程序,需要写其绝对路径(如:#!/bin/bash),它是不会自动到$PATH中寻找解释器的。
6. 当然,如果你使用”bash test.sh”这样的命令来执行脚本,那么#!这一行将会被忽略掉,解释器当然是用命令行中显式指定的bash。```
###三.注释:
不管一个程序的大小都有一个注释,它给人一种解释,了解程序的详细信息,如
```#!/bin/bash
#Author: XXX
#Version: 1.0
#Date:2017-05-01 Mail:
#Description:...```
写这个脚本的作者、版本信息、日期、邮箱、脚本说明...等。
###四.内容
如果我们每天要执行相同的命令,就可以集中的往这里写了。
echo "Current User is :"
echo $(ps | grep "$$" | awk '{print $2}')
.......
这是打印应当前的用户
内容尽量简单明了
###五.权限、语法
当我们写完脚本,我们发现有时候用不了,这是为什么?
一是我们没有开起权限,我们可以通过chmod +x 来添加执行权限。
二是写的脚本是否存在语法,或其他类型的错误?我们可通过bash -x [file]来排查一下
###创建一个自动脚本模板
例:
root@centos7 app]#vim shtemplet.sh
!/bin/bash 注:shebang机制
author:xxxxx QQ:******* mail:****** 注:作者的信息
version:1.0 注:版本之类
date :2017-6-5 注:日期
description:This is a program that automatically creates a template 注:说明
-----------------------------------------------------------------
file=$1
[ x"$1" = x ] && read -p "请输入一个脚本名: " file
[ -e ${file} ] &> /dev/null && read -p "文件已存在请重新输入一个脚本名: " file
输入一个脚本的文件名,并判断它是否存在。
echo -e "#!/bin/bash
filename:${file}
author:XXXXXX QQ:****** mail:
verion:1.0
date:date
description:this is \n" > ${file} 注:把模板重定向到要新建脚本之中。
vim + ${file} 注:自动打开vim编辑脚本并跳到最后一行。
chmod +x ${file} 注:给文件加一个执行权限,使它可以运行。
如有不足请多多指教......