shell概述
shell是一个命令解释器,接收应用程序和用户命令,调用操作系统内核, 还是一个编程语言。
shell 解析器
linux提供的shell解析器:
/bin/sh
/bin/bash
/sbin/nologin
/bin/dash
/bin/tcsh
/bin/csh
centos默认的解析器是bash
shell脚本
脚本以#!/bin/bash开头(指定解析器)
#! /bin/bash
echo “helloworld”
执行方式:
1.采用bash或sh+脚本的相对路径或绝对路径(不用赋予脚本+x权限)
bash helloworld.sh
2.首先要赋予helloworld.sh 脚本的+x权限
chmod +x helloworld.sh
(b)执行脚本
相对路径
./helloworld.sh
Helloworld
绝对路径
/home/atguigu/datas/helloworld.sh
通常使用第二种比较多
shell脚本可以多命令执行
shell中的变量
1.系统变量
$HOME、$PWD、$SHELL、$USER
显示当前系统所有变量 set
2.自定义变量
定义变量: A=10
撤销: unset A
静态变量 : readonly A(不能撤销unset)
定义规则:
(1)变量名称可以由字母、数字和下划线组成,但是不能以数字开头,环境变量名建议大写。
(2)等号两侧不能有空格
(3)在bash中,变量默认类型都是字符串类型,无法直接进行数值运算。
(4)变量的值如果有空格,需要使用双引号或单引号括起来。
3.export 变量名 可使变量升级为全局环境变量
[at@hadoop101 datas]$ vim helloworld.sh
在helloworld.sh文件中增加echo $B
#!/bin/bash
echo "helloworld"
echo $B
[at@hadoop101 datas]$ ./helloworld.sh
Helloworld
发现并没有打印输出变量B的值。
[at@hadoop101 datas]$ export B
[at@hadoop101 datas]$ ./helloworld.sh
helloworld
*4.特殊变量:$n $# $ * $@ *
$n
$n 功能描述:n为数字,$0代表该脚本名称
,$1--$9代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如${10}
案例:
[root@hadoop001 ~]# touch mybash1.sh
[root@hadoop001 ~]# chmod 777 mybash1.sh
[root@hadoop001 ~]# vi mybash1.sh
#!/bin/bash
echo "$0 $1 $2"
[root@hadoop001 ~]# ./mybash1.sh 1 2
./mybash1.sh 1 2
$# 获取所有输入参数个数,常用于循环
echo $#
$* $@
$* (功能描述:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)
$@ (功能描述:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待)
案例:
[@hadoop101 datas]$ vim parameter.sh
#!/bin/bash
echo "$0 $1 $2"
echo $#
echo $*
echo $@
[@hadoop101 datas]$ bash parameter.sh 1 2 3
parameter.sh 1 2 3
3
1 2 3
1 2 3
$? (功能描述:最后一次执行的命令的返回状态。如果这个变量的值为0,证明上一个命令正确执行;如果这个变量的值为非0(具体是哪个数,由命令自己来决定),则证明上一个命令执行不正确了。)
案例:
[@hadoop101 datas]$ ./helloworld.sh
hello world
[@hadoop101 datas]$ echo $?
0
运算符
语法:
1.“
(
(
运
算
式
)
)
”
或
“
((运算式))”或“
((运算式))”或“[运算式]”
2.expr + , - , *, /, % 加,减,乘,除,取余
(1)计算3+2的值
[@hadoop101 datas]$ expr 2 + 3
5
(2)计算3-2的值
[@hadoop101 datas]$ expr 3 - 2
1
(3)计算(2+3)X4的值
(a)expr一步完成计算
[@hadoop101 datas]$ expr `expr 2 + 3` \* 4
20
(b)采用$[运算式]方式
[@hadoop101 datas]# S=$[(2+3)*4]
[@hadoop101 datas]# echo $S
条件判断
格式 【 s 】 s前后要有空格 条件非空返回true
常用判断条件
(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.if判断
if [ 条件判断式 ];then
程序
fi
或者
if [ 条件判断式 ]
then
程序
elif [ 条件判断式 ]
then
程序
else
程序
fi
注意事项:
(1)[ 条件判断式 ],中括号和条件判断式之间必须有空格
(2)if后要有空格
2.case 语句
1.基本语法
case $变量名 in
"值1")
如果变量的值等于值1,则执行程序1
;;
"值2")
如果变量的值等于值2,则执行程序2
;;
…省略其他分支…
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac
注意事项:
1)case行尾必须为单词“in”,每一个模式匹配必须以右括号“)”结束。
2)双分号“;;”表示命令序列结束,相当于java中的break。
3)最后的“*)”表示默认模式,相当于java中的default。
3.for循环
for (( 初始值;循环控制条件;变量变化 ))
do
程序
done
案例:从1加到100
[@hadoop101 datas]$ touch for1.sh
[@hadoop101 datas]$ vim for1.sh
#!/bin/bash
s=0
for((i=0;i<=100;i++))
do
s=$[$s+$i]
done
echo $s
[@hadoop101 datas]$ chmod 777 for1.sh
[@hadoop101 datas]$ ./for1.sh
“5050”
for 变量 in 值1 值2 值3…
do
程序
done
for i in $*
do
echo " $i "
done
4.while 循环
while [ 条件判断式 ]
do
程序
done
案例:
从1加到100
[@hadoop101 datas]$ touch while.sh
@hadoop101 datas]$ vim while.sh
#!/bin/bash
s=0
i=1
while [ $i -le 100 ]
do
s=$[$s+$i]
i=$[$i+1]
done
echo $s
[@hadoop101 datas]$ chmod 777 while.sh
[@hadoop101 datas]$ ./while.sh
5050
read读取控制台输入
1.基本语法
read(选项)(参数)
选项:
-p:指定读取值时的提示符;
-t:指定读取值时等待的时间(秒)。
参数
变量:指定读取值的变量名
案例:
1)提示10秒内,读取控制台输入的名称
[@hadoop101 datas]$ touch read.sh
[@hadoop101 datas]$ vim read.sh
#!/bin/bash
read -t 10 -p "请在10s内输入你的名字 " NAME
echo $NAME
系统函数和自定义函数
1.basename
返回文件名称,路径后面加后缀会将返回的文件后缀去掉
(1)截取该/home/ss/aa.txt路径的文件名称
[@hadoop101 datas]$ basename /home/ss/aa.txt
banzhang.txt
[@hadoop101 datas]$ basename /home/ss/aa.txt .txt
banzhang
2. dirname
dirname 文件绝对路径
[aa@hadoop101 ~]$ dirname /home/aa/bb.txt
/home/aa
自定义函数
1.基本语法
[ function ] funname[()]
{
Action;
[return int;]
}
funname
案例:
#求两个数的和
#!/bin/bash
function sum()
{
s=0
s=$[ $1 + $2 ]
echo "$s"
}
read -p "Please input the number1: " n1;
read -p "Please input the number2: " n2;
sum $n1 $n2;
定时备份数据库案例
需求
每天凌晨2点备份数据库myDB到 /data/backup/db
备份开始和结束能够给出响应的提示信息
备份后的文件以备份时间为文件名,打包成tar.gz形式
备份的同时,检查是否有10天前备份的数据库文件,如果有就删除
#! /bin/bash
#完成数据库的定时备份
#备份的路径
BACKUP=/data/backup/db
#当前的时间作为文件名
DATETIME=$(date +%Y_%m_%d%H%M%S)
echo "============开始备份========="
echo "============备份的路径是$BACKUP/$DATETIME.tar.gz"
#主机
HOST=localhost
DB_USER=root
DB_PWD=root
#备份数据库名
DATABASE=myDB
#创建备份的数据
#如果备份的路径文件夹存在,就是用,否则就创建
[ ! -d "$BACKUP/$DATETIME" ] mkdir -p "$BACKUP/$DATETIME"
#执行mysql的备份数据库指令
mysqldump -u${DB_USER} -p${DB_PWD} --host=$HOST $DATABASE | gzip > $BACKUP/$DATETIME/$DATETIME.sql.gz
#打包备份文件
cd $BACKUP
tar -zcvf $DATETIME.tar.gz $DATETIME
#删除临时目录
rm -rf $BACKUP/$DATETIME
#删除10天前的备份文件
find $BACKUP -mtime +10 -name "*.tar.gz" -exec rm -rf {} \;
echo "=========================备份文件成功==========="
然后通过系统的定时任务调动这个脚本