欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

详解shell脚本中的case条件语句介绍和使用案例

程序员文章站 2022-06-22 15:21:14
#前言:这篇我们接着写shell的另外一个条件语句case,上篇讲解了if条件语句。case条件语句我们常用于实现系统服务启动脚本等场景,case条件语句也相当于if条件语句多分支结构,多个选择,ca...

#前言:这篇我们接着写shell的另外一个条件语句case,上篇讲解了if条件语句。case条件语句我们常用于实现系统服务启动脚本等场景,case条件语句也相当于if条件语句多分支结构,多个选择,case看起来更规范和易读

#case条件语句的语法格式

case "变量" in
 值1)
 指令1...
 ;;
 值2)
 指令2...
 ;;
 *)
 指令3...
esac

#说明:当变量的值等于1时,那么就会相应的执行指令1的相关命令输出,值等于2时就执行指令2的命令,以此类推,如果都不符合的话,则执行*后面的指令,要注意内容的缩进距离

#简单记忆

case "找工作条件" in
 给的钱多)
 给你工作...
 ;;
 给股份)
 给你工作...
 ;;
 有发展前景)
 可以试试...
 ;;
 *)
 bye bye !!
esac

实践1.根据用户的输入判断用户输入的是哪个数字,执行相应动作

#如果用户输入的是1-9的任意一个数字,则输出对应输入的数字,如果是别的字符,则提示输出不正确并退出程序

[root@shell scripts]# cat num.sh 
#!/bin/bash

#create by guoke
#function number input

read -p "please input a number:" num #打印信息提示用户输入,输入信息赋值给num变量

case "$num" in
 1)
 echo "the num you input is 1"
 ;;
 [2-5])
   echo "the num you input is 2-5"
 ;;
 [6-9])
   echo "the num you input is 6-9"
 ;;
 *)
   echo "please input number[1-9] int"
    exit;
esac

#说明:使用read读取用户输入的数据,然后使用case条件语句进行判断,根据用户输入的值执行相关的操作

#执行效果

[root@shell scripts]# sh num.sh
please input a number:1
the num you input is 1
[root@shell scripts]# sh num.sh
please input a number:3
the num you input is 2-5
[root@shell scripts]# sh num.sh
please input a number:4
the num you input is 2-5
[root@shell scripts]# sh num.sh
please input a number:8
the num you input is 6-9
[root@shell scripts]# sh num.sh
please input a number:a
please input number[1-9] int

实践2.打印一个如下的水果菜单

(1) banana

(2) apple

(3)orange

(4) cherry

#脚本编写

[root@shell scripts]# cat menu.sh 
#!/bin/bash

#create by guoke
#function print menu

red_color='\e[1;31m'
green_color='\e[1;32m'
yellow_color='\e[1;33m'
blue_color='\e[1;34m'
res='\e[0m'

echo ' #使用echo打印菜单
#############################
 1.banana
 2.apple
 3.pear
 4.cherry
#############################
'

read -p "please select a num:" num

case "$num" in
 1)
   echo -e "${yellow_color} banana ${res}"
 ;;
 2)
   echo -e "${red_color} apple ${res}"
 ;;
 3)
   echo -e "${green_color} pear ${res}"
 ;;
 4)
   echo -e "${blue_color} cherry ${res}"
 ;;
 *)
   echo "please input {1|2|3|4}"
esac

#说明:定义颜色,使用read读取用户输入的数据,然后使用case条件语句进行判断,根据用户输入的值执行相关的操作,给用户输入的水果添加颜色

#扩展:输出菜单的另外种方式

cat<<-eof
===============================
 1.banana
 2.apple
 3.pear
 4.cherry
===============================
eof

#执行效果

#如果输入不正确或者不输入的话就打印帮助

[root@shell scripts]# sh menu.sh 

#############################
1.banana
2.apple
3.pear
4.cherry
#############################

please select a num:
please input {1|2|3|4} 

#输入选项中的数字,打印相关信息

详解shell脚本中的case条件语句介绍和使用案例

实践3.开发nginx启动脚本

#主要思路:

#1.主要通过判断nginx的pid文件有无存在,通过返回值查看有没有运行

#2.通过case语句获取参数进行判断

#3.引入系统函数库functions中的action函数

#4.对函数及命令运行的返回值进行处理

#5.设置开机自启动

#附上nginx编译安装过程

#!/bin/bash
yum install gcc pcre pcre-devel wget openssl openssl-devel.x86_64 -y 
mkdir -p /home/demo/tools
cd /home/demo/tools/
wget -q http://nginx.org/download/nginx-1.6.3.tar.gz
useradd nginx -s /sbin/nologin -m
tar xf nginx-1.6.3.tar.gz 
cd nginx-1.6.3/
./configure --user=nginx --group=nginx --prefix=/application/nginx --with-http_stub_status_module --with-http_ssl_module
make
make install
ln -s /application/nginx-1.6.3 /application/nginx/ #做软连接
/application/nginx/sbin/nginx -t #检查语法
/application/nginx/sbin/nginx #启动服务

#脚本编写

[root@shell init.d]# chmod +x /etc/init.d/nginxd
[root@shell init.d]# cat nginxd 
#!/bin/bash
#chkconfig: 2345 40 98 #设定2345级别,开机第40位启动脚本,关机第98位关闭脚本

#create by guoke
#email:1075792988@qq.com
#function nginx start scripts

[ -f /etc/init.d/functions ] && source /etc/init.d/functions #引入系统函数库

pidfile=/application/nginx/logs/nginx.pid #定义pid文件路径
nginx=/application/nginx/sbin/nginx #定义启动命令路径

value(){ #定义返回值函数
 retval=$?
 if [ $retval -eq 0 ];then
   action "nginx is $1" /bin/true
 else
   action "nginx is $1" /bin/true
 fi
}

start(){ #定义启动函数
 if [ -f $pidfile ];then #判断pidfile存不存在,存在就打印运行,否则就启动
   echo "nginx is running"
 else
   $nginx
   value start #调用返回值函数
 fi
}

stop(){ #定义停止函数
 if [ ! -f $pidfile ];then #也是通过判断pid文件是否存在然后进行相关操作
   echo "nginx not running"
 else
   $nginx -s stop
   value stop
 fi
}

reload(){ #定义重启函数
 if [ ! -f $pidfile ];then
   echo "not open $pidfile no such directory"
 else
   $nginx -s reload
   value reload
 fi
}

case "$1" in #使用case接收脚本传参的字符串
 start) #如果第一个参数为start,调用start函数
   start
 ;;
 stop) #如果第一个参数为stop,调用stop函数
   stop
 ;;
 reload)
   stop
   sleep 1
   start
 ;;
 *)
   echo "usage:$0 {stop|start|reload}"
   exit 1
esac

#执行效果

[root@shell init.d]# sh nginx stop
nginx is stop [ ok ]
[root@shell init.d]# sh nginx start
nginx is start [ ok ]
[root@shell init.d]# sh nginx reload
nginx is stop [ ok ]
nginx is start [ ok ]

实践4.开发跳板机

#要求用户登录到跳板机后只能执行管理员给定的选项动作,不能中断脚本而到跳板机服务器上执行任何系统命令

#思路

1.首先做好ssh key验证登录
2.实现远程连接菜单选择脚本
3.利用linux信号防止用户在跳板机上操作
4.用户登录后就调用脚本

#操作过程

3.1.做ssh免密钥登录,发送到各个主机,如果机器多的话可以使用脚本进行循环发送

[demo@shell ~]$ ssh-keygen -t dsa -p "" -f ~/.ssh/id_dsa 
generating public/private dsa key pair.
enter file in which to save the key (/home/demo/.ssh/id_dsa): 
created directory '/home/demo/.ssh'.
your identification has been saved in /home/demo/.ssh/id_dsa.
your public key has been saved in /home/demo/.ssh/id_dsa.pub.
the key fingerprint is:
sha256:btffcc2hmkbzuzeuyylc3qgza7z4x6j3rblwq8beoak demo@shell
the key's randomart image is:
+---[dsa 1024]----+
| + o.*...+o |
| . = b o o +. . |
| = b b * + . |
| o + = b + |
|e = . + s |
| . + o .  |
| + . o  |
| o o.o  |
|..+o...  |
+----[sha256]-----+
#命令说明:一键生成密钥,不用按回车。-t:指定要创建的密钥类型,-p:提供旧密码,空表示不需要密码,-f:指定位置

#将公钥拷贝到其他服务器的demo用户
[demo@shell ~]$ ssh-copy-id -i .ssh/id_dsa.pub "demo@192.168.86.129"
[demo@shell ~]$ ssh-copy-id -i .ssh/id_dsa.pub "demo@192.168.86.130"
[demo@shell ~]$ ssh-copy-id -i .ssh/id_dsa.pub demo@192.168.86.131

#3.2.编写脚本

[root@shell scripts]# cat tiaobanji.sh 
#!/bin/bash

trapper(){ #定义屏蔽信号函数
 trap '' int quit tstp term hub
}

menu(){ #定义菜单列表函数
 cat<<-eof #加-后面的eof就可以不用顶格
==============host list==============
 1) 192.168.86.129
 2) 192.168.86.130
 3) 192.168.86.131
 4) 192.168.86.132
 5) exit
=====================================
 eof
}

user=demo

host(){ #定义主机列表函数
 case "$1" in
 1)
 ssh $user@192.168.86.129
 ;;
 2)
 ssh $user@192.168.86.130
 ;;
 3)
 ssh $user@192.168.86.131
 ;;
 4)
 ssh $user@192.168.86.132
 ;;
 5)
 exit
esac
}

main(){ #定义主函数
 while : #while循环,一直循环
 do
 trapper #调用trapper函数
 clear #清屏
 menu #调用菜单函数
 read -p "please select a num:" num #获取用户输入
 host $num #调用主机列表函数和传入的参数,进行远程登录
 done
}
main #调用主函数

#3.3.编写脚本进行判断,判断是否是root用户登录,如果不是root用户就执行脚本,弹出跳板机界面

[root@shell ~]# cd /etc/profile.d/
[root@shell profile.d]# cat jump.sh 
#!/bin/bash

[ $uid -ne 0 ] && . /scripts/tiaobanji.sh

#3.4.测试

#登录demo普通用户输入密码的时候就会直接跳到选项卡页面了

详解shell脚本中的case条件语句介绍和使用案例

#选项卡页面

==============host list==============
1) 192.168.86.129
2) 192.168.86.130
3) 192.168.86.131
4) 192.168.86.132
5) exit
=====================================
please select a num:1 #进行选择
last login: tue mar 31 23:48:33 2020 from 192.168.86.128
[demo@mysql ~]$

#3.5.提示:跳板机的安全

1.禁止跳板机可以从外网ip进行登录,只能从内网ip登录
2.其他服务器也限制只能内网ip登录,同时禁止root登录,做完ssh key认证,将密码登录禁止,通过免密码登录到其他服务器

#总结:if条件语句主要用于取值判断、比较,应用比较广,case条件语句主要是写服务的启动脚本,各有各的优势。好了,shell脚本的条件语句就讲解到这里了,接下来会继续写shell脚本的循环(包括for,while等),如果写的不好的地方还望指出,多多交流提高,下次再会。。。

到此这篇关于详解shell脚本中的case条件语句介绍和使用案例的文章就介绍到这了,更多相关shell case条件语句内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!