Shell概述
shell是一个命令解释器,它接受应用程序、用户命令,然后调用操作linux系统内核
Shell解释器
Linux提供的Shell解析器有
| [root@jude ~]# cat /etc/shells /bin/sh /bin/bash /sbin/nologin /usr/bin/sh /usr/bin/bash /usr/sbin/nologin
|
bash和sh的关系
| [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
| [root@jude bin]# echo $SHELL /bin/bash
|
Shell脚本
脚本以#!/bin/bash开头(指定解析器)
第一个Shell脚本:helloworld
| [root@hadoop101 datas]$ touch helloworld.sh [root@hadoop101 datas]$ vi helloworld.sh
在helloworld.sh中输入如下内容 #!/bin/bash echo "helloworld"
|
第一种:采用bash或sh+脚本的相对路径或绝对路径(不用赋予脚本+x权限)
| [root@hadoop101 datas]$ sh helloworld.sh Helloworld
[root@hadoop101 datas]$ sh /home/root/datas/helloworld.sh helloworld
[root@hadoop101 datas]$ bash helloworld.sh Helloworld
[root@hadoop101 datas]$ bash /home/root/datas/helloworld.sh Helloworld
|
第二种:采用输入脚本的绝对路径或相对路径执行脚本(必须具有可执行权限+x)
| [root@hadoop101 datas]$ chmod 777 helloworld.sh
[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”。
| [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
等
| [root@hadoop101 datas]$ echo $HOME /home/atguigu
[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
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}
)
| [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
|
特殊变量:$#
$# (功能描述:获取所有输入参数个数,常用于循环)
| [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
|
特殊变量:$*
、$@
$*
(功能描述:这个变量代表命令行中所有的参数,$*
把所有的参数看成一个整体)
$@
(功能描述:这个变量也代表命令行中所有的参数,不过$@
把每个参数区分对待)
| [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)判断helloworld.sh脚本是否正确执行 [root@hadoop101 datas]$ ./helloworld.sh hello world [root@hadoop101 datas]$ echo $? 0
|
运算符
(1)“$((运算式))”
或“$[运算式]”
(2)expr + , - , \*, /, %
加,减,乘,除,取余
注意:expr运算符间要有空格
| (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
| 1)23是否大于等于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 判断
| if [ 条件判断式 ];then 程序 fi 或者 if [ 条件判断式 ] then 程序 fi
|
注意事项:
(1)[ 条件判断式 ],中括号和条件判断式之间必须有空格
(2)if
后要有空格
| [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 语句
| case $变量名 in "值1") 如果变量的值等于值1,则执行程序1 ;; "值2") 如果变量的值等于值2,则执行程序2 ;; …省略其他分支… *) 如果变量的值都不是以上的值,则执行此程序 ;; esac
|
注意事项:
1) case行尾必须为单词“in”,每一个模式匹配必须以右括号“)”结束。
2) 双分号“;;”表示命令序列结束,相当于java中的break。
3) 最后的“*)”表示默认模式,相当于java中的default。