shell是一个命令行解释器,它为用户提供了一个向 Linux 内核发送请求以便运行程序的系统级程序mysql
#!/bin/bash echo 'hello world'
代码解释:sql
1.#!/bin/bash:shell
告诉计算机,使用bash解释器来执行代码数据库
2.echo:编程
控制台输出bash
给脚本可执行权限函数
chmod 744 myshell.sh
而后直接运行脚本命令行
./myshell.sh
直接调用shell解释器执行设计
sh myshell.sh
#内容
:<<! 内容 !
1.Linux中变量的分类:系统变量 自定义变量 2.系统变量: $PATH $HOME $PWD $SHELL $USER 3.显示当前shell中全部的变量:set
1.定义变量:变量名=变量值 2.撤销变量:unset 变量名 3.声明静态变量:readonly 变量名. 静态变量不能unset
1.定义变量a 2.撤销变量a 3.声明静态变量b=2,尝试unset撤销
1.变量名称能够由字母、数字和下划线组成,可是不能以数字开头 2.等号两侧不能有空格 3.变量名称通常习惯为大写
1.A=`ls -la` 反引号,运行里面的命令,并把结果返回给变量 A 2.A=$(ls -la) 等价于反引号
1.export 变量名=变量值 将shell变量输出给环境变量 2.source 配置文件 让修改后的配置信息当即生效 3.echo $变量值 查看环境变量的值
1.在/etc/profile文件中定义MY_NAME环境变量 2.查看环境变量MY_NAME的值 强调:在使用MY_NAME前,须要让其生效 3.source /etc/profile 4,在另一个shell程序中使用MY_NAME
当咱们执行一个 shell
脚本时,若是但愿获取到命令行的参数信息,就能够使用到位置参数变量code
1. $n (功能描述:n 为数字,$0 表明命令自己,$1-$9 表明第一到第九个参数,十以上的参数,十以上的参数须要用大 ${10} 括号包含,如${10}) 2. $* (功能描述:这个变量表明命令行中全部的参数,$*把全部的参数当作一个总体) 至关于字符串 3. $@ (功能描述:这个变量也表明命令行中全部的参数,不过$@把每一个参数区分对待) 至关于列表 4. $#(功能描述:这个变量表明命令行中全部参数的个数)
编写一个shell脚本,pasition.sh,在脚本中获取到命令行的各个参数信息 age=$1 age1=$2 echo "$age" echo "$age1" 执行命令: bash pasition.sh 1 2 # 1和2为第一个和第二个参数
就是 shell 设计者事先已经定义好的变量,能够直接在
shell 脚本中使用
$$ (功能描述:当前进程的进程号(PID)) $! (功能描述:后台运行的最后一个进程的进程号(PID)) $? (功能描述:最后一次执行的命令的返回状态。若是这个变量的值为 0,证实上一个命令正确执行;若是这个变量的值为非 0(具体是哪一个数,由命令本身来决定(return)),则证实上一个命令执行失败)
在一个shell脚本pre.sh中简单实用一下预约义变量(提示, ./myshell.sh & 后台运行myshell.sh). echo "$$" echo "$!" echo "$?"
1.$((运算式)) 2.$[运算式] 3.`expr m + n` 特色:运算符之间要有空格 + - / % \* \( \)
写一个demo.sh完成: 1.3种方式计算(2+3)*4的值 2.方式2求出命令行两个参数的和
#!/bin/bash res=$(((2*3)*4)) echo "$res" res2=$[(2*3)*4] echo "$res2" res3=`expr \( 2 \* 3 \) \* 4` echo "$res3"
res4=$[$1+$2] echo "$res4" 执行命令 bash demo.sh 123 456
[ 条件 ] 注意:条件先后要有空格 特别的: [ 非空 ] 为true [ ] 为false [ haha ] && echo true || echo false
= 判等 != 判不相等
-lt 小于 [ 123 -lt 56 ] && echo true || echo false -le 小于等于 -gt 大于 -ge 大于等于 -eg 等于 -ne 不等于
-r 有读的权限 [ -r 文件 ] -w 有写的权限 -x 有执行权限
-f 存在而且是通常文件 [-f 文件] -e 文件存在 -d 存在而且是一个目录
1.'ok'是否等于'ok' 2.'ok100' 是否等于 'ok'
3.23 是否大于 23 4.23 是否大于等于 23
5./root是否存在 6./root是不是通常文件
if [ 条件 ] then 代码 fi
if [ 条件 ] then 代码 else 代码 fi
if [ 条件 ] then 代码 elif [ 条件 ] then 代码 else 代码 fi
编写shell脚本,if.sh: 若是输入参数,大于等于90,优秀,大于等于60,则输出'及格了',若是小于60,则输出'不及格' #!/bin/bash if [ $1 -ge 90 ] then echo "优秀" elif [ $1 -ge 60 ] then echo "及格" else echo "不及格" fi
case $变量名 in '值1') 代码 ;; '值2') 代码 ;; *) 代码 都没命中执行 ;; esac
编写shell脚本,case.sh: 当命令行参数是1时,输出'周一';是2时,输出'周二',其它状况,输出'其它' #!/bin/bash case $1 in "1") echo "星期一" ;; "2") echo "星期二" ;; *) echo "其余" ;; esac
for 变量 in 值1 值2 值3 do 代码 done
编写foreach.sh: 打印命令行输入的参数[这里能够看出$* 和$@的区别] $* 打印一次 $@ 遍历全部 #!/bin/bash for i in "$@" do echo "$i" done
for ((初始值;循环条件;结束语句)) do 代码 done
编写for.sh: 从1加到100,并输出结果 #!/bin/bash for ((i=1;i<=100;i++)) do res=$[$res+$i] done echo "$res"
while [ 条件 ] do 代码 done
编写while.sh: 从命令行中输入一个数n,统计1+...+n的值是多少 #!/bin.bash i=1 res=0 while [ $i -le $1 ] do res=$[$res+$i] i=$[$i+1] done echo "$res"
read 选项 变量 选项: -p:提示信息 -t:等待输入的时间
编写input.sh: 1.读取控制带输入的值 read -p "请输入名字:" name echo "$name" 2.读取控制台输入的值,等待6秒 read -p "请输入名字:" -t 6 name echo "$name"
basename [pathname] [suffix] 得到路径最后一部分 若是指定的suffix,那么会去掉结果中suffix的部分
1.返回/home/aaa/test.txt中'test.txt'的部分 2.返回/home/aaa/test.txt中'test'的部分
dirname [pathname] 得到基础路径
1.返回/home/aaa/test.txt中'/home/aaa'的部分
function 函数名(){ #没有形参 代码; #参数使用:$1,$2,...,${10}... return xxx; } 调用: 函数名 值1 值2
编写func.sh: 用函数的形式,计算两个参数的和 #!/bin/bash function test(){ res=$[$1+$2] echo "$res" } test 130 120
在/root下编写mysql_db_backup.sh 需求: 1.天天凌晨2点10分,备份数据库mydb 到/data/backup/db 2.备份开始和备份结束时可以给出提示信息 3.备份后的文件要求以备份时间为文件名,并打包成.tar.gz的形式,如2019-09-28-044403.tar.gz 4.在备份的同时,检查是否有10天前的备份文件,若是有就删除 mysqldump -uroot -p123 --host=localhost 要备份的数据库名字
#!/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=997997 #备份的数据库 DATABASE=mydb 若是备份路径不存在,就建立 [ ! -d "$BACKUP/DATETIME" ] && mkdir -p "$BACKUP/$DATETIME" #执行mysql的备份指令 mysqldump -u$DB_USER -p$DB_PWD --host=$HOST $DATABASE | gzip > $BACKUO/$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 "=====备份成功+++++"