一、引言
因为公司遜要开发一款saas系统,需要使用自动部署脚本,部署web项目,所以就去了解了一下相关的知识,这里并不做深入的研究。
1.1 概述
Shell是一个命令行解释器,它为用户提供了一个向Linux内核发送请求以便运行程序的界面系统级程序,用户可以用Shell来启动、挂起、停止甚至是编写一些程序。
Shell还是一个功能相当强大的编程语言,易编写、易调试、灵活性强。Shell是解释执行的脚本语言,在Shell中可以调用Linux系统命令。
1.2 shell脚本的执行方式
1)echo输出内容到控制台
|
选项:
-e: 支持反斜线控制的字符转换
控制字符 | 作 用 |
---|---|
\ | 输出\本身 |
\a | 输出警告音 |
\b | 退格键,也就是向左删除键 |
\c | 取消输出行末的换行符。和“-n”选项一致 |
\e | ESCAPE键 |
\f | 换页符 |
\n | 换行符 |
\r | 回车键 |
\t | 制表符,也就是Tab键 |
\v | 垂直制表符 |
\0nnn | 按照八进制ASCII码表输出字符。其中0为数字零,nnn是三位八进制数 |
\xhh | 按照十六进制ASCII码表输出字符。其中hh是两位十六进制数 |
(2)案例
|
2)脚本格式
|
3)第一个Shell脚本
(1)需求:创建一个Shell脚本,输出helloworld
(2)实操:
|
4)脚本的常用执行方式
第一种:输入脚本的绝对路径或相对路径
(1)首先要赋予helloworld.sh 脚本的+x权限
[kingge@hadoop101 datas]$ chmod 777 helloworld.sh
(2)执行脚本
/root/helloWorld.sh
./helloWorld.sh
第二种:bash或sh+脚本(不用赋予脚本+x权限)
sh /root/helloWorld.sh
sh helloWorld.sh
1.3 shell中的变量
1)Linux Shell中的变量分为,系统变量和用户自定义变量。
2)系统变量:$HOME、$PWD、$SHELL、$USER等等
3)显示当前shell中所有变量:set
1.3.1 定义变量
1)基本语法:
(1)定义变量:变量=值
(2)撤销变量:unset 变量
(3)声明静态变量:readonly变量,注意:不能unset
2)变量定义规则
(1)变量名称可以由字母、数字和下划线组成,但是不能以数字开头。
(2)等号两侧不能有空格
(3)变量名称一般习惯为大写
3)案例
(1)定义变量A
A=8
(2)撤销变量A
unset A
(3)声明静态的变量B=2,不能unset
readonly B=2
(4)可把变量提升为全局环境变量,可供其他shell程序使用
export 变量名
1.3.2 将命令的返回值赋给变量
(1)A=ls -la
反引号,运行里面的命令,并把结果返回给变量A
(2)A=$(ls -la) 等价于反引号
1.3.3 设置环境变量
1)基本语法:
(1)export 变量名=变量值 (功能描述:设置环境变量的值)
(2)source 配置文件 (功能描述:让修改后的配置信息立即生效)
(3)echo $变量名 (功能描述:查询环境变量的值)
2)案例:
(1)在/etc/profile文件中定义JAVA_HOME环境变量
export JAVA_HOME=/opt/module/jdk1.7.0_79
export PATH=$PATH:$JAVA_HOME/bin
(2)查看环境变量JAVA_HOME的值
[kingge@hadoop101 datas]$ echo $JAVA_HOME
/opt/module/jdk1.7.0_79
1.3.4 位置参数变量
1)基本语法
|
2)案例
(1)输出输入的的参数1,参数2,所有参数,参数个数
|
(2)$*与$@的区别
|
a)$*和$@都表示传递给函数或脚本的所有参数,不被双引号“”包含时,都以$1 $2 …$n的形式输出所有参数
b)当它们被双引号“”包含时,“$*”会将所有的参数作为一个整体,以“$1 $2 …$n”的形式输出所有参数;“$@”会将各个参数分开,以“$1” “$2”…”$n”的形式输出所有参数
1.3.5 预定义变量
1)基本语法:
|
2)案例
计算(2+3)X4的值
|
1.4 运算符
1)基本语法:
(1)“$((运算式))”或“$[运算式]”
(2)expr m + n
注意expr运算符间要有空格
(3)expr m - n
(4)expr *, /, % 乘,除,取余
2)案例:计算(2+3)X4的值
(1)采用$[运算式]方式
[root@hadoop101 datas]# S=$[(2+3)*4]
[root@hadoop101 datas]# echo $S
(2)expr分布计算
S=expr 2 + 3
expr $S * 4
(3)expr一步完成计算
expr expr 2 + 3
* 4
1.5 条件判断
1.5.1 判断语句
1)基本语法:
[ condition ](注意condition前后要有空格)
#非空返回true,可使用$?验证(0为true,>1为false)
2)案例:
[kingge] 返回true
[] 返回false
[condition] && echo OK || echo notok 条件满足,执行后面的语句
1.5.2 常用判断条件
1)两个整数之间比较
= 字符串比较
-lt 小于
-le 小于等于
-eq 等于
-gt 大于
-ge 大于等于
-ne 不等于
2)按照文件权限进行判断
-r 有读的权限
-w 有写的权限
-x 有执行的权限
3)按照文件类型进行判断
-f 文件存在并且是一个常规的文件
-e 文件存在
-d 文件存在并是一个目录
4)案例
(1)23是否大于等于22
[ 23 -ge 22 ]
(2)student.txt是否具有写权限
[ -w student.txt ]
(3)/root/install.log目录中的文件是否存在
[ -e /root/install.log ]
1.6 流程控制
1.6.1 if判断
1)基本语法:
if [ 条件判断式 ];then
程序
fi
或者
if [ 条件判断式 ]
then
程序
fi
注意事项:(1)[ 条件判断式 ],中括号和条件判断式之间必须有空格
2)案例
|
1.6.2 case语句
1)基本语法:
case $变量名 in
“值1”)
如果变量的值等于值1,则执行程序1
;;
“值2”)
如果变量的值等于值2,则执行程序2
;;
…省略其他分支…
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac
2)案例
|
1.6.3 for循环
1)基本语法1:
for 变量 in 值1 值2 值3…
do
程序
done
2)案例:
(1)打印输入参数
|
3)基本语法2:
for (( 初始值;循环控制条件;变量变化 ))
do
程序
done
4)案例
(1)从1加到100
|
1.6.4 while循环
1)基本语法:
while [ 条件判断式 ]
do
程序
done
2)案例
(1)从1加到100
|
1.7 read读取控制台输入
1)基本语法:
read(选项)(参数)
选项:
-p:指定读取值时的提示符;
-t:指定读取值时等待的时间(秒)。
参数
变量:指定读取值的变量名
2)案例
读取控制台输入的名称
|
1.8 函数
1.8.1 系统函数
1)basename基本语法
basename [pathname] [suffix]
basename [string] [suffix] (功能描述:basename命令会删掉所有的前缀包括最后一个(‘/’)字符,然后将字符串显示出来。
选项:
suffix为后缀,如果suffix被指定了,basename会将pathname或string中的suffix去掉。
2)案例
[kingge@hadoop101 opt]$ basename /opt/test.txt
test.txt
[kingge@hadoop101 opt]$ basename /opt/test.txt .txt
test
3)dirname基本语法
dirname 文件绝对路径 (功能描述:从给定的包含绝对路径的文件名中去除文件名(非目录的部分),然后返回剩下的路径(目录的部分))
4)案例
[kingge@hadoop101 opt]$ dirname /opt/test.txt
/opt
1.8.2 自定义函数
1)基本语法:
|
注意:
(1)必须在调用函数地方之前,先声明函数,shell脚本是逐行运行。不会像其它语言一样先编译。
(2)函数返回值,只能通过$?系统变量获得,可以显示加:return返回,如果不加,将以最后一条命令运行结果,作为返回值。return后跟数值n(0-255)
2)案例
(1)计算输入参数的和
|