
前言
后缀:name.sh
文件,可以使用 ./
来运行
语法
变量
1 | 设置变量默认值的两种方式,如果不输入参数,则默认为 |
- $n:表示输入的第n个参数,
$0
是特殊的,表示程序本身 - 变量赋值
=
周围不得有空格
1 | export VAR="var data" |
- 使用范围为
./file.sh
对应的那一次命令 - 如果需要范围扩展到整个命令窗口,需要使用
source ./file.sh
特殊变量
变量 | 含义 |
---|---|
$0 | 当前脚本的文件名 |
$n | 传递给脚本或函数的参数。n 是一个数字,表示第几个参数。例如,第一个参数是$1,第二个参数是$2。 |
$# | 传递给脚本或函数的参数个数。 |
$* | 传递给脚本或函数的所有参数。 |
$@ | 传递给脚本或函数的所有参数。被双引号(“ “)包含时,与 $* 稍有不同,下面将会讲到。 |
$? | 上个命令的退出状态,或函数的返回值。 |
$$ | 当前Shell进程ID。对于 Shell 脚本,就是这些脚本所在的进程ID。 |
逻辑
逻辑非:
!
if [!表达式 ]
逻辑与:
–a
if [ 表达式1 –a 表达式2 ]
逻辑或:
-o
if [ 表达式1 –o 表达式2 ]
1 | if []; then |
1 |
表达式
文件表达式
- -e filename:如果 filename存在,则为真
- -d filename:如果 filename为目录,则为真
- -f filename:如果 filename为常规文件,则为真
- -L filename:如果 filename为符号链接,则为真
- -r filename:如果 filename可读,则为真
- -w filename:如果 filename可写,则为真
- -x filename:如果 filename可执行,则为真
- -s filename:如果文件长度不为0,则为真
- -h filename:如果文件是软链接,则为真
- filename1 -nt filename2:如果 filename1比 filename2新,则为真。
- filename1 -ot filename2:如果 filename1比 filename2旧,则为真。
整数表达式
- -eq:等于,equal
- -ne:不等于,not equal
- -gt:大于,greater than
- -ge:大于等于,greater equal
- -lt:小于,less than
- -le:小于等于,less equal
字符串表达式
if [ $string1 = $string2 ]
:如果string1等于string2,则为真- 字符串允许使用赋值号做等号
if [ $string1 != $string2 ]
:如果string1不等于string2,则为真if [ -n $string ]
:如果string 非空(非0),返回0(true)if [ -z $string ]
:如果string 为空,则为真if [ $sting ]
:如果string 非空,返回0 (和-n类似)
输入输出
echo
向标准输出输出后面跟着的部分,直到第一个换行符出停止
注意:
- 直接跟输出的内容,如果有换行时,将会在第一个换行处停止,无法执行后面的部分
- ‘ ‘,引号中间的所有符号都将被字符串化,因此不可以使用
${NAME}
来读取参数内容,但是加引号不会在换行符处停止,而是在引号结尾停止 - ``,将会执行此符号中间的部分
1 | 即需要换行,也有参数时: |
重定向
就像我们平时写的程序一样,一段程序会处理外部的输入,然后将运算结果输出到指定的位置。在交互式的程序中,输入来自用户的键盘和鼠标,结果输出到用户的屏幕,甚至播放设备中。而对于某些后台运行的程序,输入可能来自于外部的一些文件,运算的结果通常又写到其他的文件中。而且程序在运行的过程中,会有一些关键性的信息,比如异常堆栈,外部接口调用情况等,这些都会统统写到日志文件里。
shell脚本也一样,但是我们一般在使用shell命令的时候,更多地还是通过键盘输入,然后在屏幕上查看命令的执行结果。如果某些情况下,我们需要将shell命令的执行结果存储到文件中,那么我们就需要使用输入输出的重定向功能。
文件描述符
当执行shell命令时,会默认打开3个文件,每个文件有对应的文件描述符来方便我们使用:
类型 | 文件描述符 | 默认情况 | 对应文件句柄位置 |
---|---|---|---|
标准输入(standard input) | 0 | 从键盘获得输入 | /proc/self/fd/0 |
标准输出(standard output) | 1 | 输出到屏幕(即控制台) | /proc/self/fd/1 |
错误输出(error output) | 2 | 输出到屏幕(即控制台) | /proc/self/fd/2 |
输出重定向
命令 | 介绍 |
---|---|
command >filename | 把标准输出重定向到新文件中 |
command 1>filename | 同上 |
command >>filename | 把标准输出追加到文件中 |
command 1>>filename | 同上 |
command 2>filename | 把标准错误重定向到新文件中 |
command 2>>filename | 把标准错误追加到新文件中 |
输入重定向
命令 | 介绍 |
---|---|
command <filename | 以filename文件作为标准输入 |
command 0<filename | 同上 |
command <<delimiter | 从标准输入中读入,直到遇到delimiter分隔符 |
重定向绑定
command > /dev/null 2>&1
这条命令分为两命令,一个是 >/dev/null
,另一个是 2>&1
。
1、> /dev/null
这条命令的作用是将标准输出1重定向到
/dev/null
中。/dev/null
代表linux的空设备文件,所有往这个文件里面写入的内容都会丢失,俗称“黑洞”。那么执行了>/dev/null
之后,标准输出就会不再存在,没有任何地方能够找到输出的内容。
2、2>&1
- 这条命令用到了重定向绑定,采用
&
可以将两个输出绑定在一起。 - 这条命令的作用是错误输出将和标准输出同用一个文件描述符,说人话就是错误输出将会和标准输出输出到同一个地方。
linux在执行shell命令之前,就会确定好所有的输入输出位置,并且从左到右依次执行重定向的命令,所以 > /dev/null 2>&1
的作用就是让标准输出重定向到 /dev/null
中(丢弃标准输出),然后错误输出由于重用了标准输出的描述符,所以错误输出也被定向到了 /dev/null
中,错误输出同样也被丢弃了。执行了这条命令之后,该条shell命令将不会输出任何信息到控制台,也不会有任何信息输出到文件中。
> /dev/null 2>&1
VS 2>&1 > /dev/null
linux在执行shell命令之前,就会确定好所有的输入输出位置,并且从左到右依次执行重定向的命令。那么我们同样从左到右地来分析2>&1 >/dev/null
:
2>&1
,将错误输出绑定到标准输出上。由于此时的标准输出是默认值,也就是输出到屏幕,所以错误输出会输出到屏幕。>/dev/null
,将标准输出1重定向到/dev/null
中。
用一个表格来更好地说明这两条命令的区别:
命令 | 标准输出 | 错误输出 |
---|---|---|
>/dev/null 2>&1 | 丢弃 | 丢弃 |
2>&1 >/dev/null | 丢弃 | 屏幕 |
指令
nohup
nohup command >/dev/null 2>&1 &
- 启动一些进程在后台挂起并且无任何输出到控制台
- Post title:shell
- Post author:Wei Jieyang
- Create time:2021-03-31 16:57:07
- Post link:https://jieyang-wei.github.io/2021/03/31/shell/
- Copyright Notice:All articles in this blog are licensed under BY-NC-SA unless stating additionally.