linux基础--shell编程

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 "=========================备份文件成功==========="

然后通过系统的定时任务调动这个脚本

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值