case语句、case分支应用示例、函数及中断控制、字符串截取、替换、删除
NSD SHELL DAY03
- 案例1:中断及退出
- 案例2:基于case分支编写脚本
- 案例3:编写一键部署软件脚本
- 案例4:启动脚本
- 案例5:使用Shell函数
- 案例6:字符串处理
- 案例7:字符串初值的处理
1 案例1:中断及退出
1.1 问题
本案例要求编写两个Shell脚本,相关要求如下:
- 从键盘循环取整数(0结束)并求和,输出最终结果
1.2 方案
通过break、continue、exit在Shell脚本中实现中断与退出的功能。
exit结束循环以及整个脚本
break可以结束整个循环
continue结束本次循环,进入下一次循环
案例如下:
- [root@svr5 ~]# vim test.sh
- #!/bin/bash
- for i in {1..5}
- do
- [ $i -eq 3 ]&& break #这里将break替换为continue,exit分别测试脚本执行效果 echo $i
- done
- echo "Game Over"
1.3 步骤
实现此案例需要按照如下步骤进行。
步骤一:编写求和脚本sum.sh
1)编写脚本文件
- #!/bin/bash
- x=0
- while :
- do
- read -p "请输入一个整数求和(0是结束并输出结果):" n
- [ -z $n ] && continue #如果n是空值则重新进行循环任务
- [ $n -eq 0 ] && break #如果n是0则退出循环执行循环后任务
- let x+=n #不断的将n的值保存在x里
- done
- echo "总和是$x"
2 案例2:基于case分支编写脚本
2.1 问题
编写脚本,相关要求如下:
- 要求通过位置变量执行不同任务
2.2 方案
case分支属于匹配执行的方式,它针对指定的变量预先设置一个可能的取值,判断该变量的实际取值是否与预设的某一个值相匹配,如果匹配上了,就执行相应的一组操作,如果没有任何值能够匹配,就执行预先设置的默认操作。
case分支的语法结构如下所示:
- case 变量 in
- 模式1)
- 命令序列1 ;;
- 模式2)
- 命令序列2 ;;
- .. ..
- *)
- 默认命令序列
- esac
脚本编写参考如下:
- #!/bin/bash
- case $1 in
- t) #如果$1是t就执行touch任务
- touch $2;;
- m) #如果$1是m就执行mkdir任务
- mkdir $2;;
- r) #如果$1是r就执行rm任务
- rm -rf $2;;
- *)
- echo "请输入t或者m或者r"
- esac
3 案例3:编写一键部署软件脚本
3.1 问题
本案例要求编写脚本实现一键部署Nginx软件(Web服务器):
- 一键源码安装Nginx软件
- 脚本自动安装相关软件的依赖包
3.2 步骤
实现此案例需要按照如下步骤进行。
1)依赖包
源码安装Nginx需要提前安装依赖包软件gcc,openssl-devel,pcre-devel
步骤一:编写脚本
1)参考脚本内容如下:
- [root@svr5 ~]# vim test.sh
- #!/bin/bash
- yum -y install gcc openssl-devel pcre-devel
- tar -xf nginx-1.22.1.tar.gz
- cd nginx-1.22.1
- ./configure
- make
- make install
2)确认安装效果
Nginx默认安装路径为/usr/local/nginx,其中sbin目录下放着主程序nginx
主程序命令参数:
- [root@svr5 ~]# /usr/local/nginx/sbin/nginx #启动服务
- [root@svr5 ~]# /usr/local/nginx/sbin/nginx -s stop #关闭服务
4 案例4:启动脚本
4.1 问题
本案例要求编写Ngin启动脚本,要求如下:
- 脚本支持start、stop、restart、status
- 脚本支持报错提示
- 脚本具有判断是否已经开启或关闭的功能
4.2 步骤
实现此案例需要按照如下步骤进行。
步骤一:编写脚本
脚本通过位置变量$1读取用户的操作指令,判断是start、stop、restart还是status。
ss命令可以查看系统中启动的端口信息,该命令常用选项如下:
-n以数字格式显示端口号
-t显示TCP连接的端口
-u显示UDP连接的端口
-l显示服务正在监听的端口信息,如httpd启动后,会一直监听80端口
-p显示监听端口的服务名称是什么(也就是程序名称)
1)参考脚本内容如下:
- [root@svr5 ~]# vim test.sh
- #!/bin/bash
- case $1 in
- start|kai)
- /usr/local/nginx/sbin/nginx;;
- stop|guan)
- /usr/local/nginx/sbin/nginx -s stop;;
- restart|cq)
- /usr/local/nginx/sbin/nginx -s stop
- /usr/local/nignx/sbin/nginx;;
- status|zt)
- ss -ntulp |grep -q nginx
- if [ $? -eq 0 ];then
- echo 服务已启动
- else
- echo 服务未启动
- fi;;
- *)
- echo Error;;
- esac
2)执行测试脚本:
- [root@svr5 ~]# ./test.sh start
- [root@svr5 ~]# ./test.sh stop
- [root@svr5 ~]# ./test.sh status
- [root@svr5 ~]# ./test.sh xyz
5 案例5:使用Shell函数
5.1 问题
本案例要求编写脚本,相关要求如下:
- 将颜色输出的功能定义为函数
- 调用函数,可以自定义输出内容和颜色
5.2 方案
在Shell脚本中,将一些需重复使用的操作,定义为公共的语句块,即可称为函数。通过使用函数,可以使脚本代码更加简洁,增强易读性,提高Shell脚本的执行效率
1)函数的定义方法
格式1:
- function 函数名 {
- 命令序列
- .. ..
- }
格式2:
- 函数名() {
- 命令序列
- .. ..
- }
2)函数的调用
直接使用“函数名”的形式调用,如果该函数能够处理位置参数,则可以使用“函数名 参数1 参数2 .. ..”的形式调用。
注意:函数的定义语句必须出现在调用之前,否则无法执行。
3) 测试语法格式
- [root@svr5 ~]# a(){ #定义函数
- echo abc
- echo xyz
- }
- [root@svr5 ~]# a #调用函数
5.3 步骤
实现此案例需要按照如下步骤进行。
步骤一:编写mycolor.sh脚本
1)任务需求及思路分析
用户在执行时提供2个整数参数,这个可以通过位置变量$1、$2读入。
调用函数时,将用户提供的两个参数传递给函数处理。
颜色输出的命令:echo -e "\033[32mOK\033[0m"。
3X为字体颜色,4X为背景颜色。
2)根据实现思路编写脚本文件
- [root@svr5 ~]# vim mycolor.sh
- #!/bin/bash
- cecho() {
- echo -e "\033[$1m$2\033[0m"
- }
- cecho 32 OK
- cecho 33 OK
- cecho 34 OK
- cecho 35 OK
- [root@svr5 ~]# chmod +x mycolor.sh
3)测试脚本执行效果
- [root@svr5 ~]# ./mycolor.sh
还可以利用函数优化之前的nginx脚本
6 案例6:字符串处理
6.1 问题
本案例要求熟悉字符串的常见处理操作,完成以下任务练习:
- 参考课上示范操作,完成字符串截取、替换等操作
- 编写批量修改扩展名脚本
6.2 方案
字符串截取的用法:
- ${变量名:起始位置:长度}
- 起始位置从0开始计数
字符串替换的两种用法:
- 只替换第一个匹配结果:${变量名/old/new}
- 替换全部匹配结果:${变量名//old/new}
字符串掐头去尾:
- 从左向右,最短匹配删除:${变量名#*关键词}
- 从左向右,最长匹配删除:${变量名##*关键词}
- 从右向左,最短匹配删除:${变量名%关键词*}
- 从右向左,最长匹配删除:${变量名%%关键词*}
6.3 步骤
实现此案例需要按照如下步骤进行。
步骤一:字符串的截取
1)使用 ${}表达式
格式:${变量名:起始位置:长度}
- [root@proxy opt]# a=abcd
- [root@proxy opt]# echo ${a:1:2} #从第二位截取两位
- bc
- [root@proxy opt]# echo ${a:0:2} #从头截取两位
- ab
一个随机密码的案例
首先实现1个字符的随机产生
- #!/bin/bash
- x=abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789
- n=$[RANDOM%62] #得到0~61随机数存在变量n中
- p=${x:n:1} #通过截取,将1个随机字符赋值给变量p
然后完善:
- #!/bin/bash
- x=abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789
- pass= #使用变量pass
- for i in {1..8}
- do
- n=$[RANDOM%62]
- p=${x:n:1}
- pass+=$p #将随机得到的字符赋值给变量pass
- done
- echo $pass #最后喊出,得到8位长度随机字符串
步骤二:字符串的替换
1)只替换第1个子串
格式:${变量名/old/new}
还以前面的phone变量为例,确认原始值:
- [root@svr5 ~]# echo $phone
- 13788768897
将字符串中的第1个8替换为X:
- [root@svr5 ~]# echo ${phone/8/X}
- 137X8768897
2)替换全部子串
格式:${变量名//old/new}
将phone字符串中的所有8都替换为X:
- [root@svr5 ~]# echo ${phone//8/X}
- 137XX76XX97
步骤三:字符串的匹配删除
以处理系统默认的账户信息为例,定义变量A:
- [root@svr5 ~]# a=`head -1 /etc/passwd`
- [root@svr5 ~]# echo $a
- root:x:0:0:root:/root:/bin/bash
1)从左向右,最短匹配删除
格式:${变量名#*关键词}
删除从左侧第1个字符到最近的关键词“:”的部分,* 作通配符理解:
- [root@svr5 ~]# echo ${a#*:}
- x:0:0:root:/root:/bin/bash
2)从左向右,最长匹配删除
格式:${变量名##*关键词}
删除从左侧第1个字符到最远的关键词“:”的部分:
- [root@svr5 ~]# echo $a #确认变量a的值
- root:x:0:0:root:/root:/bin/bash
- [root@svr5 ~]# echo ${a##*:}
- /bin/bash
3)从右向左,最短匹配删除
格式:${变量名%关键词*}
删除从右侧最后1个字符到往左最近的关键词“:”的部分,* 做通配符理解:
- [root@svr5 ~]# echo ${a%:*}
- root:x:0:0:root:/root
4)从右向左,最长匹配删除
格式:${变量名%%关键词*}
删除从右侧最后1个字符到往左最远的关键词“:”的部分:
- [root@svr5 ~]# echo ${a%%:*}
- root
步骤四:编写批量修改扩展名脚本
可以先用touch abc{01..10}.txt 创建10个文件作为素材
- #!/bin/bash
- for i in $(ls *.txt) #找到所有的txt文件交给for循环
- do
- n=${i%.*} #用去尾的方法删除扩展名
- mv $i $n.doc #再将源文件扩展名修改为doc
- done
7 案例7:字符串初值的处理
7.1 问题
本案例要求编写一个脚本可以创建账户,密码可以自定义也可以使用默认值123456
7.2 方案
通过${var:-初值}判断变量是否存在,决定变量的初始值。
7.3 步骤
实现此案例需要按照如下步骤进行。
步骤一:认识字符串初值的最常见处理方法
1)只取值,${var:-word}
若变量var已存在且非空,则返回 $var 的值;否则返回字串“word”,原变量var的值不受影响。
变量值已存在的情况:
- [root@svr5 ~]# XX=11
- [root@svr5 ~]# echo $XX #查看原变量值
- 11
- [root@svr5 ~]# echo ${XX:-123} #因XX已存在,输出变量XX的值
- 11
步骤二:
- [root@svr5 ~]# cat /root/test.sh
- #!/bin/bash
- read -p "请输入用户名:" user
- [ -z $user ] && exit #如果无用户名,则脚本退出
- read -p "请输入密码:" pass
- pass=${pass:-123456} #如果用户没有输入密码,则默认密码为123456
- useradd $user
- echo "$pass" | passwd --stdin $user
CSDN-Ada助手: 恭喜您撰写了第20篇博客!标题内容非常丰富,涵盖了NAT作用、私有IP地址、NAT实现方式与工作过程以及VRRP概述和实现案例。这些主题都是网络领域的重要知识点,读者们一定会从中受益匪浅。 在下一步的创作中,或许您可以考虑将这些主题进一步展开,例如深入探讨NAT的优缺点、私有IP地址的应用场景、VRRP在网络容错中的作用等等。另外,您也可以考虑结合实际案例或者提供更多的实际操作指南,这将使您的博客更具实用性和可操作性。 再次恭喜您取得的不懈努力和成就!期待您在未来的创作中继续展现您的才华与热情!
CSDN-Ada助手: 恭喜你,获得了 2023 博客之星评选的入围资格,请看这个帖子 (https://bbs.csdn.net/topics/616959061?utm_source=blogger_star_comment)。 请在这里提供反馈: https://blogdev.blog.csdn.net/article/details/129986459?utm_source=blogger_star_comment。
CSDN-Ada助手: 恭喜您写出了一篇非常实用的博客,介绍了命令行基础、命令编辑技巧、常用快捷键、访问设备资源等内容,非常详细和全面。这些内容对于初学者来说非常有帮助,可以帮助他们更好地理解和应用命令行。 我建议您在下一篇博客中可以介绍一些高级的命令行技巧和应用,比如如何通过命令行进行文件搜索、如何进行文本编辑和文件比较等。希望您能够继续创作,分享更多有价值的知识。 CSDN 正在通过评论红包奖励优秀博客,请看红包流:https://bbs.csdn.net/?type=4&header=0&utm_source=csdn_ai_ada_blog_reply3,我们会奖励持续创作和学习的博主,请看:https://bbs.csdn.net/forums/csdnnews?typeId=116148&utm_source=csdn_ai_ada_blog_reply3
CSDN-Ada助手: 恭喜您写出了这篇关于归档、压缩、重定向与管道操作的博客!这篇博客非常详尽地讲述了这些操作的使用方法和细节,对读者非常有用。下一步,建议您可以继续扩展博客内容,比如加入更多的实例和案例,让读者更好地理解操作的具体应用场景。期待您的下一篇博客! CSDN 会根据你创作的前四篇博客的质量,给予优秀的博主博客红包奖励。请关注 https://bbs.csdn.net/forums/csdnnews?typeId=116148&utm_source=csdn_ai_ada_blog_reply4 看奖励名单。
CSDN-Ada助手: 恭喜您写了这么有用的一篇博客,介绍了RPM软件管理机制、获取RPM软件、RPM软件查询、文件的查询等内容。这些知识对于使用Linux系统的用户来说非常实用。接下来,我建议您可以继续分享一些关于Linux系统的实用技巧、常见问题解决方法等内容,让更多人受益。谢谢您的分享! 如何快速涨粉,请看该博主的分享:https://hope-wisdom.blog.csdn.net/article/details/130544967?utm_source=csdn_ai_ada_blog_reply5