文章目录
一、Shell
(1)、Shell的作用
shell——命令解释器,“翻译官”
- 介于系统内核与用户之间,负责解释命令行
(2)、用户登录Shell
登录后默认使用的Shell程序,一般为/bin/bash
不同Shell的内部指令、运行环境等会有所区别
二、Shell脚本的概述
Shell脚本的概念
1、将要执行的命令按顺序保存到一个文本文件
2、给该文件可执行权限
3、可结合各种Shell控制语句以完成更复杂的操作
Shell脚本的应用场景
- 重复性操作
- 交互性任务
- 批量事务处理
- 服务运行状态监控
- 定时任务执行
- ……
三、编写Shell脚本
1、编写脚本代码
- 使用vim文本编辑器
- 每行一条Linux命令,按执行顺序依次编写
完善的脚本构成:

- 脚本声明
- 注释信息
- 可执行语句
1.脚本申明(解释器):若第一行为“#!/bin/bash”,表示此行以下的代码语句是通过/bin/bash程序来解释执行,#!/bin/bash为默认解释器。还有其它类型的解释器,比如#!/usr/bin/python、#!/usr/bin/expect。
2.注释信息:以“#”开头的语句表示为注释信息,被注释的语句在运行脚本时不会被执行。
3.可执行语句:比如echo命令,用于输出" "之间的字符串
#!/bin/bash :代表固定格式,相当于声明
#this is my first shell-script:对于该脚本的注释信息,没有具体作用
cd /boot :跳转到boot目录
echo"当前目录位于":表示输出字符串,方便理解,没有具体作用
pwd :显示目前所在工作环境的目录
echo"其中以vm开头的文件包括:":表示输出字符串,方便理解,没有具体作用
ls -lh * :长格式友好显示所有文件。
2、执行脚本文件(三种方法)
注意:我们在执行脚本前我们要赋予脚本可执行权限,否则会操作失败。。。就像这样
方法一:脚本文件路径(绝对路径与相对路径)
[root@localhost ~]# ./first.sh #必须有 X 权限
指定绝对路径:/root/first.sh
指定相对路径:./first.sh
方法二:sh 脚本文件路径(不需要x权限)
[root@localhost ~]# sh first.sh
不要求脚本拥有执行权限,如果脚本中执行了切换位置的命令,此方式不会进行切换。
方法三:source 脚本文件路径(不需要x权限)
[root@localhost ~]# source first.sh
也可以通过“.”来执行 . first.sh
这两种方法不要求脚本拥有执行权限,但若脚本中执行了切换位置的命令,此方式会进行切换。
四、重定向与管道操作
(1)、交互式硬件设备
⭕ 标准输入:从该设备接收用户输入的数据
⭕ 标准输出:通过该设备向用户输出数据
⭕ 标准错误:通过该设备报告执行出错信息
类型 | 设备文件 | 文件描述编号 | 默认设备 |
---|---|---|---|
标准输入 | /dev/stdin | 0 | 键盘 |
标准输出 | /dev/stdout | 1 | 显示器 |
标准错误输出 | /dev/stderr | 2 | 显示器 |
(2)、重定向操作
类型 | 操作符 | 用途 |
---|---|---|
重定向输入 | < | 从指定的文件读取数据 |
重定向输出 | > | 将标准输出结果 保存 到指定的文件,并且覆盖原有内容 |
重定向输出 | >> | 将标准输出结果 追加 到指定的文件的尾部,不覆盖原有内容 |
标准错误输出 | 2> | 将错误信息 保存 到指定的文件,并且覆盖原有内容 |
标准错误输出 | 2>> | 将错误信息 追加 到指定的文件的尾部,不覆盖原有内容 |
混合输出 | &> | 将标准输出、标准错误保存到同一文件中 |
混合输出 | 2>&1 | 将标准错误输出重定向到标准输出 |
例如:
例如:
例:
ls -lh > log.txt 2>&1 等同于 ls -lh &> log.txt
(将标准输出结果保存到指定的文件)
2>&1(将标准错误输出重定向到标准输出)
&>(将标准输出、标准错误输出保存到同一文件)
(3)、管道符号操作“|”
将左侧的命令输出结果,作为右侧命令的处理对象
ps aux | wc -l
echo "abc123" | passwd --stdin zhangsan
五、Shell变量的作用、类型
变量是会变化的值,不会变化的是常量
(1)、变量的作用
●用来存放系统和用户需要使用的特定参数(值)
●变量名:使用固定的名称,由系统预设或用户定义
●变量值:能够根据用户设置、系统环境的变化而变化
(2)、变量的类型
●自定义变量:由用户自己定义、修改和使用
●特殊变量:环境变量、只读变量、位置变量、预定义变量
(一)、自定义变量
定义一个新的变量
变量名以字母或下划线开头,区分大小写,建议全部大写
变量名=变量值 #变量名以字母或下划线开头,区分大小写,建议全大写
echo $变量名 #查看变量的值
举个栗子
“=” 为赋值符号,代表把赋值符号右边的内容赋予给左边的变量名,=两边不要有空格。(= 也就是赋值作用)
{两个等于"==“他的意思就是等于”="的意思}
1)、赋值时使用引号
双引号:允许通过$符号引用其他变量值
单引号:禁止引用其他变量值, $视为普通字符
反撇号:命令替换,提取命令执行后的输出结果,``和$(…)作用相同
2)、从键盘输入内容为变量赋值
read [-p "提示信息"] 变量名
执行结果:
3)、设置变量的作用范围
可以使用 pstree 命令查看Shell环境,输入 bash 命令进入子Shell环境,
按Ctrl+D组合键或输入 exit 命令退出子Shell环境
(1)变量作用范围
默认情况下,新定义的变量只在当前的shell环境中有效,因此称为局部变量,当进入子程序或新的子shell环境时,局部变量将无法在使用
(2)命令格式:
可以通过内部命令export指定变量导出为全局变量,使用户定义变量在所有的子shell环境中能够继续使用
格式1: export 变量名
格式2: export 变量名=变量值
4)、整数变量的运算
运算符:+ 加法、- 减法、* 乘法、/ 除法、% 取余
常用的运算表达式:
i=$(expr 12 \* 5)
i=$((10 * 5))
i=$[10 * 4]
let i=10*3
i++ 相当于 i=$[$i+1]
i-- 相当于 i=$[$i-1]
i+=2 相当于 i=$[$i+2]
例子:
[root@localhost opt]# expr 3+2 '错误格式,不加空格'
3+2
[root@localhost opt]# expr 3 + 2 '正确格式,加法运算'
5
[root@localhost opt]# expr 3 - 2 '正确格式,减法运算'
1
[root@localhost opt]# expr 3 * 2 '错误格式,乘法运算'
expr: syntax error
[root@localhost opt]# expr 3 \* 2 '正确格式,乘法运算'
6
[root@localhost opt]# expr 3 / 2 '正确格式,除法运算'
1
[root@localhost opt]# expr 3 % 2 '正确格式,取余运算'
1
[root@localhost opt]# expr 32 % 21
11
[root@localhost opt]# expr 32 % 5
2
[root@localhost opt]# sum=`expr 30+30` '错误格式,求和变量运算'
[root@localhost opt]# echo $sum
30+30
[root@localhost opt]# sum=`expr 30 + 30` '正确格式,求和变量运算'
[root@localhost opt]# echo $sum
60
(二)、特殊的Shell变量
1、环境变量
由系统提前创建,用来设置用户的工作环境
配置文件:/etc/profile(全局生效)、~/.bash_profile(当前用户环境)
2、常见环境变量
PWD、PATH
USER、SHELL、HOME
使用 env 命令可以查看到当前工作环境下的环境变量
PWD(当前所在的工作目录)、PATH(可执行程序的默认搜索路径)
USER(用户名称)、SHELL、HOME(用户的宿主目录)
举例:
[root@localhost opt]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
3、只读变量
用于变量值不允许被修改的情况
readonly 命令设置只读变量
readonly PRODUCT #设置为只读变量
echo $PRODUCT
PRODUCT=Python #只读变量不可以被重新赋值
unset PRODUCT #只读变量不可以被删除,unset 命令用于删除变量,但无法删除只读变量,只能重启系统解决
4、位置变量
当执行命令行操作时,第一个字段表示命令名或脚本程序名,其余的字符串参数按照从左到右的顺序依次赋值给位置变量。
$n:n为数字
$0代表命令本身
1~9代表第一个到第九个参数
十以上的参数需要使用大括号表示,比如第十个参数为 ${10}
5、预定义变量
$*、$@:表示命令或脚本要处理的参数。
$*:把所有参数看成以空格分隔的一个字符串整体,代表"$1 $2 $3 $4"。
$@:把各个参数加上双引号分隔成n份的参数列表,每个参数是独立 的,代表"$1" "$2" "$3" "$4"。
$0:表示当前执行的脚本或命令的名称。
$#:表示命令或脚本要处理的参数的个数。
$?:表示前一条命令或脚本执行后的返回状态码,返回值为0表示执行正确,返回任何非0值均表示执行出现异常。
也常被用于Shell脚本中return退出函数并返回的退出值。
vim nnn.sh
#!/bin/bash
echo $1
echo $2
echo "$[$1 + $2]"
echo $0
[root@localhost ~]#chmod +x nnn.sh
[root@localhost ~]#./nnn.sh 10 20 30 40
10
20
30
./nnn.sh
[root@localhost ~]#echo $?
0
[root@localhost opt]#
%Y 表示年
%m 表示月
%d 表示日
%H 表示小时
%M 表示分钟
%S 表示秒
%s 表示从 1970 年 1 月 1 日 00:00:00 UTC 到目前为止的秒数,相当于time函数
%w 表示一周中的第几天。
[root@localhost opt]#date
2020年 12月 16日 星期三 16:14:03 CST
[root@localhost opt]#date +%s '从 1970 年 1 月 1 日 00:00:00 UTC 到目前为止的秒数(时间戳)'
1608106480
[root@localhost opt]# date +%F '显示当前日期'
2020-12-16
[root@localhost opt]# date +%Y%m%d '显示年月日'
20201216
[root@localhost opt]# date "+%Y-%m-%d %H-%M-%S" 现在的时间是:
现在的时间是:2020-12-16 16-16-20
[root@localhost opt]# date "+%Y-%m-%d %H-%M-%S" -d "-3 year" 三年前的时间是:
三年前的时间是:2016-11-26 00-23-31