17 大数据定制篇-shell编程

news2024/9/22 1:19:01

第 17 章大数据定制篇-Shell 编程

17.1 为什么要学习 Shell 编程

  1. Linux 运维工程师在进行服务器集群管理时,需要编写 Shell 程序来进行服务器管理。

  2. 对于 JavaEE 和 Python 程序员来说,工作的需要,你的老大会要求你编写一些 Shell 脚本进行程序或者是服务器的维 护,比如编写一个定时备份数据库的脚本。

  3. 对于大数据程序员来说,需要编写 Shell 程序来管理集群

17.2 shell 是什么

Shell 是一个命令行解释器,他为用户提供了一个向linux内核发送请求以便运行程序的界面系统级程序,用户可以用Shell 来启动、挂起、停止甚至是编写一些程序。

在这里插入图片描述

17.3 Shell 脚本的执行方式

17.3.1 脚本格式要求
  1. 脚本以#!/bin/bash 开头

  2. 脚本需要有可执行权限

17.3.2 编写第一个 Shell 脚本

需求说明:创建一个 Shell 脚本,输出 hello world!

vim hello.sh

!/bin/bash

echo “hello,world~”

17.3.3 脚本的常用执行方式

方式 1(输入脚本的绝对路径或相对路径) 说明:首先要赋予 helloworld.sh 脚本的+x 权限, 再执行脚本 比如 ./hello.sh 或者使用绝对路径 /root/shcode/hello.sh

方式 2(sh+脚本) 说明:不用赋予脚本+x 权限,直接执行即可。 比如 sh hello.sh , 也可以使用绝对路径

在这里插入图片描述

在这里插入图片描述

17.4 Shell 的变量

17.4.1 Shell 变量介绍
  1. Linux Shell 中的变量分为,系统变量和用户自定义变量。

  2. 系统变量: H O M E 、 HOME、 HOMEPWD、 S H E L L 、 SHELL、 SHELLUSER 等等,比如: echo $HOME 等等…

  3. 显示当前 shell 中所有变量:set

17.4.2 shell 变量的定义

基本语法

  1. 定义变量:变量名=值

  2. 撤销变量:unset 变量

  3. 声明静态变量:readonly 变量,注意:不能 unset

案例演示:

#!/bin/bash
A=3
echo "A=$A"
unset A
echo "A=$A"
readonly B=2
unset B
echo "B=$B"

在这里插入图片描述

17.4.3 shell 变量的定义

定义变量的规则:

1)变量名称可以由字母、数字、和下滑线组成,但是不能以数字开头。5A=200(x)

  1. 等号两侧不能有空格

3)变量名称一般习惯为大写,这是一个规范

将命令的返回值赋给变量:

1)A=date反引号,运行里面的命令,并把结果返回给变量A

2)A=$(date) 等价于反引号

C=`date`
echo "C=$C"
D=$(date)
echo "D=$D"

在这里插入图片描述

17.5 设置环境变量

17.5.1 基本语法
  1. export 变量名=变量值 (功能描述:将 shell 变量输出为环境变量/全局变量)

  2. source 配置文件 (功能描述:让修改后的配置信息立即生效)

  3. echo $变量名 (功能描述:查询环境变量的值)

  4. 示意

在这里插入图片描述

shell 脚本的多行注释

:<<!

内容

:<<!
readonly B=2
unset B
echo "B=$B"
!

17.6 位置参数变量

17.6.1 介绍

当我们执行一个 shell 脚本时,如果希望获取到命令行的参数信息,就可以使用到位置参数变量

比如 : ./myshell.sh 100 200 ,

这个就是一个执行 shell 的命令行,可以在 myshell 脚本中获取到参数信息

17.6.2 基本语法

$n (功能描述:n 为数字,$0 代表命令本身,$1- 9 代表 ∗ ∗ 第一到第九个参数 ∗ ∗ ,十以上的参数,十以上的参数需要用 ∗ ∗ 大括号 ∗ ∗ 包含,如 9 代表**第一到第九个参数**,十以上的参数,十以上的参数需要用 **大括号**包含,如 9代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如{10})

∗ (功能描述:这个变量 ∗ ∗ 代表命令行中所有的参数 ∗ ∗ , * (功能描述:这个变量**代表命令行中所有的参数**, (功能描述:这个变量代表命令行中所有的参数*把所有的参数看成一个整体

@ (功能描述:这个变量也代表命令行中 ∗ ∗ 所有的参数 ∗ ∗ ,不过 @(功能描述:这个变量也代表命令行中**所有的参数**,不过 @(功能描述:这个变量也代表命令行中所有的参数,不过@把每个参数区分对待

$#(功能描述:这个变量代表命令行中所有参数的个数

在这里插入图片描述

#!/bin/bash
echo "0=$0,1=$1,2=$2"
echo "所有参数=$*"
echo "$@"
echo "参数个数$#"

17.7 预定义变量

17.7.1 基本介绍

就是 shell 设计者事先已经定义好的变量,可以直接在 shell 脚本中使用

17.7.2 基本语法
  1. $$ (功能描述:当前进程的进程号(PID))

  2. $! (功能描述:后台运行的最后一个进程的进程号(PID))

  3. $?(功能描述:最后一次执行的命令的返回状态。如果这个变量的值为 0,证明上一个命令正确执行;如果这个变 量的值为非 0(具体是哪个数,由命令自己来决定),则证明上一个命令执行不正确了。)

#!/bin/bash 
echo "当前执行的进程 id=$$"
#以后台的方式运行一个脚本,并获取他的进程号 
/root/shcode/myshell.sh & 
echo "最后一个后台方式运行的进程 id=$!" 
echo "执行的结果是=$?"

17.8 运算符

17.8.1 基本介绍

学习如何在 shell 中进行各种运算操作。

17.8.2 基本语法
  1. ( ( 运算式 ) ) ”或“ ((运算式))”或“ ((运算式))[运算式]”或者 expr m + n //expression 表达式

  2. 注意 expr 运算符间要有空格, 如果希望将 expr 的结果赋给某个变量,使用 ``

  3. expr m - n 4) expr *, /, % 乘,除,取余

最常用

#!/bin/bash
echo "$[$1+$2]"

在这里插入图片描述

#!/bin/bash 
#案例 1:计算(2+3)X4 的值 
#使用第一种方式 
RES1=$(((2+3)*4)) 
echo "res1=$RES1" 
#使用第二种方式, 推荐使用 
RES2=$[(2+3)*4] 
echo "res2=$RES2" 
#使用第三种方式 
expr TEMP=`expr 2 + 3` 
RES4=`expr $TEMP \* 4` 
echo "temp=$TEMP"

17.9 条件判断

17.9.1 判断语句

基本语法 [ condition ](注意 condition 前后要有空格)

非空返回 true,可使用$?验证(0 为 true,>1 为 false)

应用实例

[ hspEdu ] 返回 true

[ ] 返回 false

[ condition ] && echo OK || echo notok 条件满足,执行后面的语句

判断语句 常用判断条件

  1. = 字符串比较

  2. 两个整数的比较

-lt 小于

-le 小于等于 little equal

-eq 等于

-gt 大于

-ge 大于等于

-ne 不等于

  1. 按照文件权限进行判断

-r 有读的权限

-w 有写的权限

-x 有执行的权限

  1. 按照文件类型进行判断

-f 文件存在并且是一个常规的文件

-e 文件存在

-d 文件存在并是一个目录

17.10 流程控制

17.10.1 if 判断

基本语法 if [ 条件判断式 ] then 代码 fi

或者 ,多分支

if [ 条件判断式 ] then 代码

elif [条件判断式] then 代码 fi

注意事项:[ 条件判断式 ],中括号和条件判断式之间必须有空格

应用实例 ifCase.sh 案例:

请编写一个 shell 程序,如果输入的参数,大于等于 60,则输出 “及格了”,如果小于 60,则输出 “不及格”

#!/bin/bash
if [ $1 -ge 60 ]
then
echo "及格了"
elif [ $1 -le 60 ]
then
echo "不及格"
fi

在这里插入图片描述

17.10.2 case 语句

基本语法

case $变量名 in “值 1”)

如果变量的值等于值 1,则执行程序 1 ;;

“值 2”) 如果变量的值等于值 2,则执行程序 2 ;;…

省略其他分支…

* 如果变量的值都不是以上的值,则执行此程序 ;;

esac

#!/bin/bash
case $1 in
"1")
echo "zhouyi"
;;
"2")
echo "周二"
;;
*)
echo "其他"
;;
esac

在这里插入图片描述

17.10.3 for 循环

基本语法 1

for 变量 in 值 1 值 2 值 3…

do

程序/代码

done

#!/bin/bash
for i in "$*"
do
echo "num is $i"
done
for j in "$@"
do
echo "num is $j"
done
# $* 是把输入的参数,当作一个整体,所以只会输出一句
# $@ 来获取输入的参数,这是分别对待,所以有几个参数,就输出几句

在这里插入图片描述

基本语法 2

for (( 初始值;循环控制条件;变量变化 ))

do

程序/代码

done

#!/bin/bash
sum=0
for(( i=1; i<=$1; i++ ))
do
sum=$[$sum+$i]
done
echo "总额为$sum"

在这里插入图片描述

17.10.4 while 循环

基本语法 1

while [ 条件判断式 ]

do

程序 /代码

done

注意:while 和 [有空格条件判断式和 [也有空格

#!/bin/bash
i=0
sum=0
while [ $i -le $1 ]
do
sum=$[$sum+$i]
i=$[$i+1]
done
echo "总和为$sum"

在这里插入图片描述

17.11 read 读取控制台输入

read(选项)(参数) 选项:

-p:指定读取值时的提示符;

-t:指定读取值时等待的时间(秒),如果没有在指定的时间内输入,就不再等待了。。

参数

变量:指定读取值的变量名

#!/bin/bash
read -p "请输入一个数" a
echo "你输入的数是$a"
# 注意 -p 的提示词与参数之间要有空格

在这里插入图片描述

17.12函数

17.12.1 函数介绍

shell 编程和其它编程语言一样,有系统函数,也可以自定义函数。系统函数中,我们这里就介绍两个。

17.12.2 系统函数

basename基本语法

功能:返回完整路径最后 / 的部分,常用于获取文件名

basename [pathname] [suffix]

basename [string] [suffix]

(功能描述:basename 命令会删掉所有的前缀包括最后一个(‘/’)字符,然后将字符串 显示出来。

选项: suffix 为后缀,如果 suffix 被指定了,basename 会将 pathname 或 string 中的 suffix 去掉

dirname 基本语法

功能:返回完整路径最后 / 的前面的部分,常用于返回路径部分 dirname 文件绝对路径

(功能描述:从给定的包含绝对路径的文件名中去除文件名(非目录的部分),然后返回剩 下的路径(目录的部分))

17.12.3 自定义函数

基本语法

[ function ] funname[()]

{

Action;

[return int;]

}

调用直接写函数名:funname [值]

#!/bin/bash
function getSum()
{
        sum=$[$n1+$n2]
echo "两数之和为$sum"
}
read -p "请输入一个数" n1
read -p "请输入另一个" n2
getSum $n1 $n2

在这里插入图片描述

17.13Shell 编程综合案例

17.13.1 需求分析
  1. 每天凌晨 2:30 备份 数据库 hspedu 到 /data/backup/db

  2. 备份开始和备份结束能够给出相应的提示信息

  3. 备份后的文件要求以备份时间为文件名并打包成 .tar.gz 的形式,比如:2021-03-12_230201.tar.gz

  4. 在备份的同时,检查是否有 10 天前备份的数据库文件,如果有就将其删除

  5. 画一个思路分析图

在这里插入图片描述

#备份目录 
BACKUP=/data/backup/db 
#当前时间 
DATETIME=$(date +%Y-%m-%d_%H%M%S) 
echo $DATETIME 
#数据库的地址 
HOST=localhost 
#数据库用户名 
DB_USER=root 
#数据库密码 
DB_PW=hspedu100 
#备份的数据库名 
DATABASE=hspedu 
#创建备份目录, 如果不存在,就创建 
[ ! -d "${BACKUP}/${DATETIME}" ] && mkdir -p "${BACKUP}/${DATETIME}"
#备份数据库 
mysqldump -u${DB_USER} -p${DB_PW} --host=${HOST} -q -R --databases ${DATABASE} | gzip > ${BACKUP}/${DATETIME}/$DATETIME.sql.gz 
#将文件处理成 tar.gz 
cd ${BACKUP} 
tar -zcvf $DATETIME.tar.gz ${DATETIME} 
#删除对应的备份目录 
rm -rf ${BACKUP}/${DATETIME} 
#删除 10 天前的备份文件 
find ${BACKUP} -atime +10 -name "*.tar.gz" -exec rm -rf {} \; 
echo "备份数据库${DATABASE} 成功~"

ost
#数据库用户名
DB_USER=root
#数据库密码
DB_PW=hspedu100
#备份的数据库名
DATABASE=hspedu
#创建备份目录, 如果不存在,就创建
[ ! -d “ B A C K U P / {BACKUP}/ BACKUP/{DATETIME}” ] && mkdir -p “ B A C K U P / {BACKUP}/ BACKUP/{DATETIME}”
#备份数据库
mysqldump -u D B U S E R − p {DB_USER} -p DBUSERp{DB_PW} --host=${HOST} -q -R --databases ${DATABASE} | gzip > B A C K U P / {BACKUP}/ BACKUP/{DATETIME}/$DATETIME.sql.gz
#将文件处理成 tar.gz
cd ${BACKUP}
tar -zcvf $DATETIME.tar.gz ${DATETIME}
#删除对应的备份目录
rm -rf B A C K U P / {BACKUP}/ BACKUP/{DATETIME}
#删除 10 天前的备份文件
find B A C K U P − a t i m e + 10 − n a m e " ∗ . t a r . g z " − e x e c r m − r f    e c h o " 备份数据库 {BACKUP} -atime +10 -name "*.tar.gz" -exec rm -rf {} \; echo "备份数据库 BACKUPatime+10name".tar.gz"execrmrfecho"备份数据库{DATABASE} 成功~"


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1631062.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ERP系统和SRM系统有什么关系?

一、什么是ERP系统和SRM系统&#xff1f; ERP系统是一种集成化的管理软件&#xff0c;能够帮助企业实现资源的优化配置&#xff0c;提高运营效率。ERP系统涵盖了企业的各个方面&#xff0c;包括财务、采购、库存、生产、销售、人力资源等&#xff0c;通过对这些方面的管理&…

MMSeg搭建自己的网络

配置结构 首先&#xff0c;我们知道MMSeg矿机的配置文件很多&#xff0c;主要结构如下图所示。 在configs/_base_下是模型配置、数据集配置、以及一些其他的常规配置和运行配置&#xff0c;四类。 configs/all_config目录下存放&#xff0c;即是将四种配置聚合在一起的一个总…

Android优化RecyclerView图片展示:Glide成堆加载批量Bitmap在RecyclerView成片绘制Canvas,Kotlin(b)

Android优化RecyclerView图片展示&#xff1a;Glide成堆加载批量Bitmap在RecyclerView成片绘制Canvas&#xff0c;Kotlin&#xff08;b&#xff09; 对 Android GridLayoutManager Glide批量加载Bitmap绘制Canvas画在RecyclerView&#xff0c;Kotlin&#xff08;a&#xff09;-…

【调研分析】目标在不同焦距和距离下与画面的比例(2.8-3.6-4.0)

之前在做项目中需要极度优化效果和代码运行速度 为此测试了同一个目标在不同焦距和距离下与画面的比例&#xff0c;从而可以方便在指定大小情况下搜索目标 NOTE: 这是早期滑窗检测做目标检测下的工作

分布式与一致性协议之Raft算法(一)

Raft算法 概述 Raft算法属于Multi-Paxos算法&#xff0c;它在兰伯特Multi-Paxos思想的基础上做了一些简化和限制&#xff0c;比如日志必须是连续的&#xff0c;只支持领导者(Leader)、跟随者(Follwer)和候选人(Candidate)3种状态。在理解和算法实现上&#xff0c;Raft算法相对…

【城市】2023浙江省/杭州市定居与生活相关政策(居住证、户籍、引进人才、高层次人才、车房)

【城市】2023浙江省/杭州市定居与生活相关政策1&#xff08;居住证、户籍、引进人才、高层次人才、车房&#xff09; 文章目录 一、户籍身份1、浙江省居住证&#xff08;杭州/地方&#xff09;2、户籍落户/身份证/户口本 二、人才引进1、应届生补贴2、引进人才居住证3、杭州市高…

Kubernetes学习-核心概念篇(三) 核心概念和专业术语

&#x1f3f7;️个人主页&#xff1a;牵着猫散步的鼠鼠 &#x1f3f7;️系列专栏&#xff1a;Kubernetes渐进式学习-专栏 &#x1f3f7;️个人学习笔记&#xff0c;若有缺误&#xff0c;欢迎评论区指正 1. 前言 在前面两篇文章我们简单介绍了什么是K8S&#xff0c;以及K8S的…

【介绍下分布式系统】

&#x1f308;个人主页: 程序员不想敲代码啊 &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共…

C语言中的三大循环

C语言中为我们提供了三种循环语句&#xff0c;今天我就来与诸君细谈其中之奥妙。循环这一板块总结的内容较多&#xff0c;而且&#xff0c;很重要&#xff01;&#xff08;敲黑板&#xff01;&#xff01;&#xff01;)&#xff0c;所以诸君一定要对此上心&#xff0c;耐住性子…

算法训练营day25

零、回溯算法理论 参考链接13.1 回溯算法 - Hello 算法 (hello-algo.com) 1.尝试与回退 之所以称之为回溯算法&#xff0c;是因为该算法在搜索解空间时会采用“尝试”与“回退”的策略。当算法在搜索过程中遇到某个状态无法继续前进或无法得到满足条件的解时&#xff0c;它会…

41. UE5 RPG 设置火球术的碰撞类型

在上一篇中&#xff0c;我们设置了火球术从发射到击中敌人的整个周期使用的音效和特效&#xff0c;现在看上去它像一个真正的火球术了。在这一篇文章里面&#xff0c;我们主要解决一下火球术碰撞的问题&#xff0c;现在已知的问题是&#xff0c;有些不需要和火球产生碰撞的物体…

同事上班这样摸鱼,我坐边上咋看他都在专心写代码啊

我边上有个同事&#xff0c;我坐他边上&#xff0c;但是每天看着他都眉头紧锁&#xff0c;忙的不亦乐乎&#xff0c;但终于有一天&#xff0c;我发现了他上班摸鱼的秘诀。 我劝你千万不要学会这4招&#xff0c;要不就该不好好上班了。 目录 1 上班看电影&#xff1f; 2 上班…

代码随想录(番外)图论3|1020. 飞地的数量|130. 被围绕的区域

代码随想录&#xff08;番外&#xff09;图论3|1020. 飞地的数量|130. 被围绕的区域 1020. 飞地的数量 class Solution { public:int dir[4][2]{0,1,1,0,0,-1,-1,0};int count;void dfs(vector<vector<int>>& grid,int x,int y){grid[x][y]0;count;for(int i…

网站内容下载软件有哪些 网站内容下载软件推荐 网站内容下载软件安全吗 idm是啥软件 idm网络下载免费

一招搞定网页内容下载&#xff0c;并且各大网站通用&#xff01;绕过资源审查&#xff0c;所有网站内容随意下载。解锁速度限制&#xff0c;下载即高速无视网站限速。跳过会员充值&#xff0c;所有VIP资源免费下载。有关网站内容下载软件有哪些&#xff0c;网站内容下载软件推荐…

【数据分析】NumPy

文章目录 [toc]ndarray的创建np.array()方法np.arange()方法np.zeros()方法np.ones()方法np.full()方法np.eye()方法np.random模块np.random.random()方法np.random.randint()方法np.random.choice()方法np.random.shuffle()方法 ndarray的属性ndarray.dtypendarray.ndimndarra…

用数据检验函数正确性,matlab2C

数据存取格式 filename1 g.txt; fid1 fopen(filename1,w); for i 1 : length(g)for j1:size(g,2)if(j1)fprintf(fid1,{%.16f,,g(i,j)); elseif(j>1&&j<151)fprintf(fid1,%.16f,,g(i,j)); elsefprintf(fid1,%.16f},\n,g(i,j));endend%fprintf(fid1,\n…

【小梦C嘎嘎——启航篇】C++特殊类设计

【小梦C嘎嘎——启航篇】C特殊类设计&#x1f60e; 前言&#x1f64c;1.请设计一个类&#xff0c;该类不能被继承2.请设计一个类&#xff0c;只能在堆上创建对象3.请设计一个类&#xff0c;只能在栈上创建对象4.请设计一个类&#xff0c;该类不能发生拷贝5.请设计一个类&#x…

uniapp真机调试无法调用之前页面的方法

在uniapp通过getCurrentPages&#xff08;&#xff09;页面栈调用之前页面方法&#xff0c;h5可生效但app真机调试找不到方法 let pages getCurrentPages()let beforePage pages[pages.length - 3]beforePage.refresh() //真机调试refresh为undefined解决&#xff1a; 后面…

【kettle004】kettle访问本地MySQL数据库并处理数据至execl文件

一直以来想写下基于kettle的系列文章&#xff0c;作为较火的数据ETL工具&#xff0c;也是日常项目开发中常用的一款工具&#xff0c;最近刚好挤时间梳理、总结下这块儿的知识体系。 熟悉、梳理、总结下MySQL关系数据库相关知识体系 kettle访问MySQL数据库并处理数据至execl文件…

Python AI库 Pandas的常见操作的扩展知识

Python AI库 Pandas的常见操作的扩展知识 本文默认读者具备以下技能&#xff1a; 熟悉python基础知识&#xff0c;vscode或其它编辑工具 熟悉表格文件的基本操作 具备自主扩展学习能力 前文中对Pandas的数据结构以及基础操作做了介绍,本文中会在前文的基础上,对常见的操作进…