文章目录
一、shell脚本基础
shell的作用
Linux 系统中的 Shell 是一个特殊的应用程序,它介于操作系统内核与用户之间,充当了一个“命令解释器”的角色,负责接收用户输入的操作指令(命令)并进行解释,将需要执行的操作传递给内核执行,并输出执行结果。
查看本机的shell信息
shell脚本用途
- 将简单的命令组合完成复杂的工作,自动化执行命令,提高工作效率。
- 减少手工命令的重复输入,一定程度上避免人为错误。
- 将软件或应用的安装及配置实现标准化。
- 用于实现日常性的,重复性的运维工作,如:文件打包压缩备份,监控系统运行状态并实现告警等。
什么是shell脚本
- 就是命令的对齐
- 执行需要权限,也可以用绝对路径去执行
构成:
1.脚本申明(解释器):第一行开头“#!/bin/bash”,表示此行以下的代码语句是通过/bin/bash程序来解释执行。
#!/bin/bash为默认的解释器还有其他类型的解释器,#!/bin/python #!/bin/expect
2.注释信息:以#开头的语句表示为注释信息
3.可执行语句
注意:虽然Linux系统中并不以文件名来区分文件类型,但是shell脚本通常以.sh结尾,这样通过vim编辑器编辑时,会检查语法是否有明显错误。上图中出现了第一次执行失败的画面,所以请注意加上执行权限。
执行脚本的方式
1.直接使用shell程序来读取脚本中的命令,不需要执行权限
2.使用路径来执行脚本 绝对和相对都可以,需要执行权限
3.source . 点等于source,不需要权限(不推荐使用)
原因:第一、第二种执行方式不会影响当前环境中bash设置,会开启一个新的bash环境运行脚本。而第三种会直接在当前bash环境下运行,影响参数。
脚本执行逻辑
脚本执行逻辑
-
顺序执行:程序按从上到下顺序执行 ,注意这种不能出现命令的交互。
-
选择执行:程序执行过程中,根据条件的不同,进行选择不同分支继续执行
-
循环执行:程序执行过程中需要重复执行多次某段语句
脚本错误调试
脚本错误通常有三种:
-
语法错误,会导致后续的命令不继续执行,可以用bash -n 检查错误,但是提示的出错行数不一定是准确的。
-
命令错误,默认后续的命令还会继续执行,用bash -n 无法检查出来 ,可以使用 bash -x 进行观察。
-
逻辑错误:只能使用 bash -x 进行 。
bash -n 检查语法错误
bash -x 将脚本的所有语句都执行一遍,查看是哪里出现错误。
在脚本前加上 set -e 表示一旦出错立即停止执行命令。
二、重定向与管道符
重定向
重定向的含义,不输出到默认的设备上,输出到指定的位置
- 标准输入:从该设备接收用户输入的数据
- 标准输出:通过该设备向用户输出数据
- 标准错误:通过该设备报告执行出错信息
类型 | 设备文件 | 文件描述编号 | 默认设备 |
---|---|---|---|
标准输入 | /dev/stdin | 0 | 键盘等输入设备 |
标准输出 | /dev/stdout | 1 | 显示器 |
标准错误输出 | /dev/stderr | 2 | 显示器 |
类型 | 操作符 | 用途 |
---|---|---|
重定向输入 | < | 从指定的文件读取数据,而不是从键盘输入 |
重定向输出 | 1> | 将输出结果保存到指定的文件(覆盖原有内容) |
>> | 将输出结果追加到指定的文件尾部 | |
标准错误输出 | 2> | 将错误信息保存到指定的文件(覆盖原有内容) |
2>> | 标准错误输出结果追加到指定的文件尾部 | |
混合输出 | &>无论对错都可以重定向 | 将标准输出、标准错误的内容保存到同一个文件中 |
注意:>前有无&的结果是有很大区别的。
[root@centos7 ~]#ls /data /xxx 2>&1 1> /data/all.log
- 将标准错误(2)重定向到标准输出(1)
- 将标准输出(1)重定向到文件 /data/all.log
[root@centos7 ~]#ls /data /xxx 1>&2 2> /data/all.log
- 将标准输出(1)重定向到标准错误(2)
- 将标准错误(2)重定向到文件 /data/all.log
[root@centos7 ~]#ls /data /xxx 1> /data/all.log 2>&1
- 将标准输出(1)重定向到文件 /data/all.log
- 将标准错误(2)重定向到标准输出(1)
[root@centos7 ~]#ls /data /xxx 2> /data/all.log 1>&2
- 将标准错误(2)重定向到文件 /data/all.log
- 将标准输出(1)重定向到标准错误(2)
[root@centos7 ~]#ls /data /xxx &> /data/all.log
- 将标准输出(1)和标准错误(2)都重定向到文件 /data/all.log
[root@centos7 ~]#ls /data /xxx >& /data/all.log
- 将标准输出(1)和标准错误
-(2)都重定向到文件 /data/all.log
管道符
将左侧的命令的输出结果,作为右侧命令的输入(处理对象)。可以叠加使用。
三、变量
变量基础
变量类型:
自定义变量:由用户自己定义,可以修改和使用
预定义变量:bash中内置的一类变量,不能修改,规定好的变量,只能调用。
环境变量:用于设置工作环境
只读变量:顾名思义,只可以读取不可以更改
位置变量:通过命令行给脚本传递参数
命名要求:
-
区分大小写
-
不能使程序中的保留字和内置变量
-
只能使用数字、字母及下划线,且不能以数字开头,注意:不支持短横线 “ - ”,只能使用下划线。
关于变量的一些符号
1.{ }确定变量的起始和结束的范围,只要有变量就加
2." "弱引用可以识别变量
3.‘ ’强引用不可以识别变量
4.` `(反撇) 、$( ) 调用命令的执行结果
解释:弱引用和强引用
"$name " 弱引用,其中的变量引用会被替换为变量值
‘$name’ 强引用,其中的变量引用不会被替换为变量值,而保持原字符串
变量追加值
变量名+=追加值
直接覆盖也可以
read -p
从键盘输入的内容变成变量
变量的作用范围
默认情况下,新定义的变量只在当前的shell环境中有效,因此称为局部变量,当进入子程序或者新的shell环境中,局部变量将无法再起作用。可以通过内部命令export将指定的变量为全局变量,使用户定义的变量在所子shell环境中可以继续使用。
整数的运算
运算符:加法 +;减法 -;乘法 \ *(前面\是转义字符的意思);除法 /;取余 (取模)%
expr只能进行整数的运算
注意需要空格
let的用法
let支持加加,使用较多;i++ 是先赋值再加;++i 是加后再赋值。
系统中自带的计算机bc
默认只显示一位小数,需要个人指定。
随机数生成器变量:$RANDOM(0-65535)
环境变量
- 由系统提前创建,用来设置用户的工作环境
- 可以使用env查看环境变量
- 需要记住的常用环境变量
$USER 表示用户名称
$HOME 表示用户的宿主目录
$LANG 表示语言和字符集
$PWD 表示当前所在工作目录
$PATH 表示可执行用户程序的默认路径
环境变量的全局配置文件
配置文件位置在:
1./etc/profile如果修改此文件会作用于所有用户
2.~/.bash_profile 用户独立的配置文件,修改这个文件只作用于当前用户,可以用来长期变更或设置环境变量。
只读变量
变量值不允许修改,不允许重新赋值,且无法用unset删除,如果想要删除,可以重启。
readonly 变量名即将变量变成只读变量
预定义(状态)变量
bash 帮你定义好了,不可以更改,只能调用。
- $*:表示所有位置参数的内容看成一个整体返回 (即一个字符串)
- $@:表示所有位置参数的内容分割成n份,每份作为一个独立的个体返回 (即n个字符串)
- $?:表示前一条命令执行后的返回状态,返回值为 0 表示执行正确,返回任何非 0值均表示执行出现异常
- $#:表示命令行中位置参数的总个数
- $0:表示当前执行的脚本或程序的名称 当前脚本的名字
- $$:当前bash的进程id
- $!: 后台任务最后一个id