目录
一、shell脚本基础
1、shell的作用
Linux 系统中的 Shell 是一个特殊的应用程序,它介于操作系统内核与用户之间,充当了一个“命令解释器”的角色,负责接收用户输入的操作指令(命令)并进行解释,将需要执行的操作传递给内核执行,并输出执行结果。
常见的 Shell 解释器程序有很多种,使用不同的 Shell 时,其内部指令、命令行提示符等方面会存在一些区别。通过/etc/shells 文件可以了解当前系统所支持的 Shell 脚本种类。
查看本机的shell信息
[root@heitui ~]#cat /etc/shells
Linux中常见的shell
-
bash:基于gun的框架下发展的shell
-
csh:类似c语言的shell
-
tcsh:整合了csh提供了更多功能
-
sh:已经被bash替换
-
nologin:让用户无法登录
bash (/bin/bash)是目前大多数Linux 版本采用的默认shell
shell脚本用途
-
将简单的命令组合完成复杂的工作,自动化执行命令,提高工作效率
-
减少手工命令的重复输入,一定程度上避免人为错误
-
将软件或应用的安装及配置实现标准化
-
用于实现日常性的,重复性的运维工作,如:文件打包压缩备份,监控系统运行状态并实现告警等
2、脚本的三种处理逻辑
- 顺序执行:程序按从上到下顺序执行
- 选择执行:程序执行过程中,根据条件的不同,进行选择不同分支继续执行
- 循环执行:程序执行过程中需要重复执行多次某段语句(已知次数 已知条件 死循环)
执行方式
1)指定路径去执行文件(文件需要有执行权限)
2)指定解释器去执行(文件不需要权限)
3)使用source或点“.”执行
在使用路径执行方式中,如果不想使用绝对路径和相对路径,可以将脚本软连接到$PATH中,也可以将存放脚本的目录加入到$PATH中。
查看系统程序
[root@heitui a]#$PATH
3、脚本错误调试
脚本常见的错误有三种:语法错误,命令错误,逻辑错误
1)语法错误,会导致后续的命令不继续执行,可以用bash -n 检查错误,提示的出错行数不一定是准确的
2)命令错误,默认后续的命令还会继续执行,用bash -n 无法检查出来 ,可以使用 bash -x 进行观察
3)逻辑错误:只能使用 bash -x 进行
bash -n 脚本名称 (不在当前目录下加绝对路径) 检查语法错误
bash -x 脚本名称 (不在当前目录下加绝对路径) 逻辑错误
4、重定向与管道符
重定向
类型 | 设备文件 | 文件描述编号 | 默认设备 |
---|---|---|---|
标准输入 | /dev/stdin | 0 | 键盘 |
标准输出 | /dev/stdout | 1 | 显示器 |
标准错误输出 | /dev/stderr | 2 | 显示器 |
交互式硬件设备
-
标准输入:从该设备接收用户输入的数据
-
标准输出:通过该设备向用户输出数据
-
标准错误:通过该设备报告执行出错信息
重定向的意思就是 ,不通过标准输出到屏幕上,输出到你指定的位置
类型 | 操作符 | 用途 |
---|---|---|
重定向输入 | < | 从指定的文件读取数据,而不是从键盘输入 |
重定向输出 | 1> | 将输出结果保存到指定的文件(覆盖原有内容) |
>> | 将输出结果追加到指定的文件尾部 | |
标准错误输出 | 2> | 将错误信息保存到指定的文件(覆盖原有内容) |
2>> | 标准错误输出结果追加到指定的文件尾部 | |
混合输出 | &>无论对错都可以重定向 | 将标准输出、标准错误的内容保存到同一个文件中 |
重定向输入 <
重定向输出 > (会覆盖文件中的内容)
追加 >> (将输出结果追加到指定的文件尾部)
混合输出 &> (将标准输出、标准错误的内容保存到同一个文件中 )
下列哪个不能将正确和错误一起显示出来
A、[root@centos7 ~]#ls /data /xxx > /data/all.log 2>&1
B、[root@centos7 ~]#ls /data /xxx 2> /data/all.log 1>&2
C、[root@centos7 ~]#ls /data /xxx &> /data/all.log
D、[root@centos7 ~]#ls /data /xxx >& /data/all.logE、[root@centos7 ~]#ls /data /xxx 2>&1 1> /data/all.log
1代表 正确输入(不写数字,默认是1)
2代表 错误输入
& 代表混合
多行重定向
可以用来无交互式
[root@heitui opt]#passwd heitui <<EOF
> 123123
> 123123
> EOF
支持变量替换
在写入文件时会先将变量替换成实际值,再结合 cat 命令完成写入
#!/bin/bash
file="a.txt"
i="heitui"
cat > $file <<EOF
I am $i
EOF
cat a.txt
整体赋值给变量,然后通过 echo 命令将变量值打印出来
关闭变量替换的功能,按照字符原本的样子输出,不做任何修改或替换
去掉每行之前的 TAB 字符
多行注释
Bash 的默认注释是“#”,该注释方法只支持单行注释,Here Document 的引入解决了多行注释的问题。
“:”代表什么都不做的空命令。中间标记区域的内容不会被执行,会被bash 忽略掉,因此可达到批量注释的效果。
管道符 |
将左侧的命令输出结果,作为右侧命令的输入(处理对象)可以 叠加使用
二、变量
1、常见Shell变量类型
自定义变量:由用户自己定义,修改和使用
环境变量:由系统维护,用于设置工作环境
只读变量:只可以读取不可以更改
位置变量:通过命令行给脚本传递参数
预定义变量:Bash中内置的一类变量,不能修改 有些规定好的变量 放在那里让你使用
系统内置变量:PATH,UID,HOSTNAME,USER
2、变量命名要求
-
区分大小写
-
不能使程序中的保留字和内置变量:如:if, for,hostname 命令 a=
-
只能使用数字、字母及下划线,且不能以数字开头,注意:不支持短横线 “ - ”,和主机名相反
-
不要使用内置的变量,使用英文尽量使用词义通俗易懂,PATH
-
大驼峰 StudentFirstName
-
小驼峰 studentFirstName
-
下划线 student_name
格式如下:
变量名=变量值
直接字串:name='root'
变量引用:name="$USER"
命令引用:name=`COMMAND` 或者 name=$(COMMAND)
注意:变量赋值是临时生效,当退出终端后,变量会自动删除,无法持久保存,脚本中的变量会随着脚本结束,也会自动删除变量引用:
$name
${name}弱引用和强引用
"$name " 弱引用,其中的变量引用会被替换为变量值
'$name ' 强引用,其中的变量引用不会被替换为变量值,而保持原字符串
3、变量追加值
格式
变量名+=追加值
[root@heitui opt]#a+=10
4、从键盘输入变量内容
read -p
例子:
#!/bin/bash
read -p "请输入内容:" var
echo "welcome to new world!"
echo "$var"
5、变量作用范围
默认情况下,新定义的变量只在当前的shell环境中有效,因此称为局部变量,当进入子程序或新的shell环境中,局部变量将无法再起作用。
可以通过内部命令export将指定的变量为全局变量,使用户定义的变量在所子shell环境中可以继续使用。
格式1:export 变量名
格式2:export 变量名=变量值
6、整数运算
expr只能进行整数的运算
格式: expr 变量1 运算符 变量2 [运算符 变量3]
运算符:加法 + 减法 - 乘法 \ * 除法 / 取余 (取模)%
(1) let var=算术表达式
(2) $((var=算术表达式)) 和上面等价
(3) var= $[算术表达式]
(4) var=$((算术表达式))
(5) var=$(expr arg1 arg2 arg3 ...)
(6) var= `expr arg1 arg2 arg3 ...`
(7) echo '算术表达式' | bc
随机生成数
$RANDOM 范围:0-32767
[root@heitui opt]#echo $RANDOM
[root@heitui opt]#echo $RANDOM%5
[root@heitui opt]#echo $[RANDOM%5]
[root@heitui opt]#echo $(expr $RANDOM % 7 + 1)
[root@heitui opt]#echo $(expr $RANDOM % 7+ 1)
提取系统信息脚本如下
#!/bin/bash
RED="\E[1;31m"
GREEN="\E[1;32m"
END="\E[0m"
echo -e "$GREEN----------------------Host systeminfo--------------------$END"
echo -e "HOSTNAME: $RED`hostname`$END"
echo -e "IPADDR: $RED` ifconfig ens33|grep -Eo '([0-9]{1,3}\.){3}[0-9]
{1,3}' |head -n1`$END"
echo -e "OSVERSION: $RED`cat /etc/redhat-release`$END"
echo -e "KERNEL: $RED`uname -r`$END"
echo -e "CPU: $RED`lscpu|grep 'Model name'|tr -s ' '|cut -d : -f2`$END"
echo -e "MEMORY: $RED`free -h|grep Mem|tr -s ' ' : |cut -d : -f2`$END"
echo -e "DISK: $RED`lsblk |grep '^sd' |tr -s ' ' |cut -d " " -f4`$END"
echo -e "$GREEN---------------------------------------------------------$END"
7、环境变量
-
由系统提前创建,用来设置用户的工作环境
-
可以使用env查看环境变量
-
需要记住的常用环境变量
[root@heitui opt]#env # 查看所有环境变量
$USER 表示用户名称
$HOME 表示用户的宿主目录
$LANG 表示语言和字符集
$PWD 表示当前所在工作目录
$PATH 表示可执行用户程序的默认路径
环境变量的全局配置文件
配置文件位置在
/etc/profile如果修改此文件会作用于所有用户
~/.bash_profile 用户独立的配置文件,修改这个文件只作用于当前用户
可以用来长期变更或设置环境变量
8、只读变量
变量值不允许修改(重新赋值)的情况
无法使用 unset删除
最快方法重启
9、位置变量
位置变量也称为位置参数,使用$1、$2、$3、…、$9 表示,第10个位置起,这样表示$(10),$(11)...
echo "$1" 位置1
echo "$2" 位置2
echo "${10}" 位置10
echo "$10" 位置1和0
echo "$*" 将所有项当成一个值
echo "$@" 所有项
echo "$0" 脚本自身
echo "$#" 后面参数的个数$0 表示当前脚本的名字
10、预定义变量
系统帮你定义好了 拿来用就可以了,你不需要知道为什么,记住
-
$*:表示所有位置参数的内容看成一个整体返回 返回所有
-
$@:表示所有位置参数的内容分割成n份,每份作为一个独立的个体返回 返回所有
-
$?:表示前一条命令执行后的返回状态,返回值为 0 表示执行正确,返回任何非 0值均表示执行出现异常
-
$#:表示命令行中位置参数的总个数
-
$0:表示当前执行的脚本或程序的名称 当前脚本的名字
-
$$:当前进程id
-
$!: 后台任务最后一个id
$* 与 $@ 的区别
通过下方例子解释
现在使用如下命令显示结果
[root@heitui opt]#bash 1.sh 1 2 3
@结果
1
[root@heitui opt]#bash 2.sh 1 2 3
*结果
1 2 3