shell基本命令

Shell概述

shell是一个命令解释器,它接受应用程序、用户命令,然后调用操作linux系统内核

Shell解释器

Linux提供的Shell解析器有

1
2
3
4
5
6
7
[root@jude ~]# cat /etc/shells
/bin/sh
/bin/bash
/sbin/nologin
/usr/bin/sh
/usr/bin/bash
/usr/sbin/nologin

bash和sh的关系

1
2
3
4
5
[root@jude bin]# ll | grep bash
-rwxr-xr-x. 1 root root 964600 8月 8 2015 bash
lrwxrwxrwx. 1 root root 10 11月 5 2015 bashbug -> bashbug-64
-rwxr-xr-x. 1 root root 6964 8月 8 2015 bashbug-64
lrwxrwxrwx. 1 root root 4 11月 5 2015 sh -> bash

Centos默认的解析器是bash

1
2
[root@jude bin]# echo $SHELL
/bin/bash

Shell脚本

  • 脚本格式

脚本以#!/bin/bash开头(指定解析器)

第一个Shell脚本:helloworld

1
2
3
4
5
6
[root@hadoop101 datas]$ touch helloworld.sh
[root@hadoop101 datas]$ vi helloworld.sh

在helloworld.sh中输入如下内容
#!/bin/bash
echo "helloworld"
  • 脚本的常用执行方式

第一种:采用bash或sh+脚本的相对路径或绝对路径(不用赋予脚本+x权限)

1
2
3
4
5
6
7
8
9
10
11
12
# sh+脚本的相对路径
[root@hadoop101 datas]$ sh helloworld.sh
Helloworld
# sh+脚本的绝对路径
[root@hadoop101 datas]$ sh /home/root/datas/helloworld.sh
helloworld
# bash+脚本的相对路径
[root@hadoop101 datas]$ bash helloworld.sh
Helloworld
# bash+脚本的绝对路径
[root@hadoop101 datas]$ bash /home/root/datas/helloworld.sh
Helloworld

第二种:采用输入脚本的绝对路径或相对路径执行脚本(必须具有可执行权限+x)

1
2
3
4
5
6
7
8
9
#(a)首先要赋予helloworld.sh 脚本的+x权限
[root@hadoop101 datas]$ chmod 777 helloworld.sh
#(b)执行脚本
# 相对路径
[root@hadoop101 datas]$ ./helloworld.sh
Helloworld
# 绝对路径
[root@hadoop101 datas]$ /home/root/datas/helloworld.sh
Helloworld

注意:第一种执行方法,本质是bash解析器帮你执行脚本,所以脚本本身不需要执行权限。第二种执行方法,本质是脚本需要自己执行,所以需要执行权限。

第二个Shell脚本:多命令处理

  • 需求

在/home/root/目录下创建一个banzhang.txt,在banzhang.txt文件中增加“I love cls”。

1
2
3
4
5
6
7
8
9
[root@hadoop101 datas]$ touch batch.sh
[root@hadoop101 datas]$ vi batch.sh

在batch.sh中输入如下内容
#!/bin/bash

cd /home/root
touch cls.txt
echo "I love cls" >>cls.txt

Shell中的变量

系统变量

  • 常用系统变量

$HOME$PWD$SHELL$USER

1
2
3
4
5
6
7
8
9
#(1)查看系统变量的值
[root@hadoop101 datas]$ echo $HOME
/home/atguigu
#(2)显示当前Shell中所有变量:set
[root@hadoop101 datas]$ set
BASH=/bin/bash
BASH_ALIASES=()
BASH_ARGC=()
BASH_ARGV=()

自定义变量

(1)定义变量:变量=值

(2)撤销变量:unset 变量

(3)声明静态变量:readonly变量,注意:不能unset

  • 变量定义规则

(1)变量名称可以由字母、数字和下划线组成,但是不能以数字开头,环境变量名建议大写。

(2)等号两侧不能有空格

(3)在bash中,变量默认类型都是字符串类型,无法直接进行数值运算。

(4)变量的值如果有空格,需要使用双引号或单引号括起来。

  • 案例实操
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
1)定义变量A
[root@hadoop101 datas]$ A=5
[root@hadoop101 datas]$ echo $A
5
2)给变量A重新赋值
[root@hadoop101 datas]$ A=8
[root@hadoop101 datas]$ echo $A
8
3)撤销变量A
[root@hadoop101 datas]$ unset A
[root@hadoop101 datas]$ echo $A
4)声明静态的变量B=2,不能unset
[root@hadoop101 datas]$ readonly B=2
[root@hadoop101 datas]$ echo $B
2
[root@hadoop101 datas]$ B=9
-bash: B: readonly variable
5)在bash中,变量默认类型都是字符串类型,无法直接进行数值运算
[root@hadoop102 ~]$ C=1+2
[root@hadoop102 ~]$ echo $C
1+2
6)变量的值如果有空格,需要使用双引号或单引号括起来
[root@hadoop102 ~]$ D=I love banzhang
-bash: world: command not found
[root@hadoop102 ~]$ D="I love banzhang"
[root@hadoop102 ~]$ echo $A
I love banzhang
7)可把变量提升为全局环境变量,可供其他Shell程序使用
export 变量名
[root@hadoop101 datas]$ vim helloworld.sh

在helloworld.sh文件中增加echo $B
#!/bin/bash

echo "helloworld"
echo $B

[root@hadoop101 datas]$ ./helloworld.sh
Helloworld
发现并没有打印输出变量B的值。
[root@hadoop101 datas]$ export B
[root@hadoop101 datas]$ ./helloworld.sh
helloworld

特殊变量:$n

  • 基本语法

$n (功能描述:n为数字,$0代表该脚本名称,$1-$9代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如${10}

1
2
3
4
5
6
7
8
9
10
# 输出该脚本文件名称、输入参数1和输入参数2 的值
[root@hadoop101 datas]$ touch parameter.sh
[root@hadoop101 datas]$ vim parameter.sh

#!/bin/bash
echo "$0 $1 $2"

[root@hadoop101 datas]$ chmod 777 parameter.sh
[root@hadoop101 datas]$ ./parameter.sh cls xz
./parameter.sh cls xz

特殊变量:$#

$# (功能描述:获取所有输入参数个数,常用于循环)

1
2
3
4
5
6
7
8
9
10
11
12
# 获取输入参数的个数
[root@hadoop101 datas]$ vim parameter.sh

#!/bin/bash
echo "$0 $1 $2"
echo $#

[root@hadoop101 datas]$ chmod 777 parameter.sh

[root@hadoop101 datas]$ ./parameter.sh cls xz
parameter.sh cls xz
2

特殊变量:$*$@

$* (功能描述:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)

$@ (功能描述:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
# 打印输入的所有参数
[root@hadoop101 datas]$ vim parameter.sh

#!/bin/bash
echo "$0 $1 $2"
echo $#
echo $*
echo $@

[root@hadoop101 datas]$ bash parameter.sh 1 2 3
parameter.sh 1 2
3
1 2 3
1 2 3

特殊变量:$?

$? (功能描述:最后一次执行的命令的返回状态。如果这个变量的值为0,证明上一个命令正确执行;如果这个变量的值为非0(具体是哪个数,由命令自己来决定),则证明上一个命令执行不正确了。)

1
2
3
4
5
1)判断helloworld.sh脚本是否正确执行
[root@hadoop101 datas]$ ./helloworld.sh
hello world
[root@hadoop101 datas]$ echo $?
0

运算符

  • 基本语法

(1)“$((运算式))”“$[运算式]”

(2)expr + , - , \*, /, % 加,减,乘,除,取余

注意:expr运算符间要有空格

  • 示例
1
2
3
4
5
6
7
8
9
10
11
12
13
1)计算3+2的值
[root@hadoop101 datas]$ expr 2 + 3
5
2)计算3-2的值
[root@hadoop101 datas]$ expr 3 - 2
1
3)计算(2+3)X4的值
(a)expr一步完成计算
[root@hadoop101 datas]$ expr `expr 2 + 3` \* 4
20
(b)采用$[运算式]方式
[root@hadoop101 datas]# S=$[(2+3)*4]
[root@hadoop101 datas]# echo $S

条件判断

  • 基本语法

[ condition ](注意condition前后要有空格)

注意:条件非空即为true,[ root ]返回true,[] 返回false

  • 常用判断条件

(1)两个整数之间比较

= 字符串比较

-lt 小于(less than) -le 小于等于(less equal)

-eq 等于(equal) -gt 大于(greater than)

-ge 大于等于(greater equal) -ne 不等于(Not equal)

(2)按照文件权限进行判断

-r 有读的权限(read) -w 有写的权限(write)

-x 有执行的权限(execute)

(3)按照文件类型进行判断

-f 文件存在并且是一个常规的文件(file)

-e 文件存在(existence) -d 文件存在并是一个目录(directory)

  • 案例实操
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
123是否大于等于22
[root@hadoop101 datas]$ [ 23 -ge 22 ]
[root@hadoop101 datas]$ echo $?
0
2)helloworld.sh是否具有写权限
[root@hadoop101 datas]$ [ -w helloworld.sh ]
[root@hadoop101 datas]$ echo $?
0
3)/home/root/cls.txt目录中的文件是否存在
[root@hadoop101 datas]$ [ -e /home/root/cls.txt ]
[root@hadoop101 datas]$ echo $?
1
4)多条件判断(&& 表示前一条命令执行成功时,才执行后一条命令,|| 表示上一条命令执行失败后,才执行下一条命令)
[root@hadoop101 ~]$ [ condition ] && echo OK || echo notok
OK
[root@hadoop101 datas]$ [ condition ] && [ ] || echo notok
notok

流程控制

if 判断

1
2
3
4
5
6
7
8
if [ 条件判断式 ];then 
程序
fi
或者
if [ 条件判断式 ]
then
程序
fi

注意事项:

(1)[ 条件判断式 ],中括号和条件判断式之间必须有空格

(2)if后要有空格

  • 案例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
[root@hadoop101 datas]$ touch if.sh
[root@hadoop101 datas]$ vim if.sh

#!/bin/bash

if [ $1 -eq "1" ]
then
echo "banzhang zhen shuai"
elif [ $1 -eq "2" ]
then
echo "cls zhen mei"
fi

[root@hadoop101 datas]$ chmod 777 if.sh
[root@hadoop101 datas]$ ./if.sh 1
banzhang zhen shuai

case 语句

1
2
3
4
5
6
7
8
9
10
11
12
case $变量名 in 
"值1")
如果变量的值等于值1,则执行程序1
;;
"值2")
如果变量的值等于值2,则执行程序2
;;
…省略其他分支…
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac

注意事项:

1) case行尾必须为单词“in”,每一个模式匹配必须以右括号“)”结束。

2) 双分号“;;”表示命令序列结束,相当于java中的break。

3) 最后的“*)”表示默认模式,相当于java中的default。


本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!