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

#前言:这篇我们接着写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}

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

实践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普通用户输入密码的时候就会直接跳到选项卡页面了

#选项卡页面

==============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条件语句内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • shell中case的用法学习笔记

    shell中的case语句: 可以把变量的内容与多个模板进行匹配,再根据成功匹配的模板去决定应该执行哪部分代码. 使用格式:case 匹配母板 in模板1 [ | 模板2 ] - ) 语句组 ;;模板3 [ | 模板4 ] - ) 语句组 ;;esaccase语句的匹配是从上往下地匹配顺序.因此,case语句编写的原则是从上往下,模板从特殊到普通.在C语言里,case语句中有default模板,而在shell程序设计中,可能将模板写成*,就可以完成相同的功能. 例1: 复制代码 代码如下: #!

  • linux shell流程控制语句实例讲解(if、for、while、case语句实例)

    一.shell条件语句(if用法) if语句结构[if/then/elif/else/fi] 复制代码 代码如下: if 条件测试语句 then action [elif 条件 action else action ] fi 如果对于:条件测试语句不是很清楚,可以参考:linux shell 逻辑运算符.逻辑表达式详解shell命令,可以按照分号分割,也可以按照换行符分割.如果想一行写入多个命令,可以通过"';"分割.如: 复制代码 代码如下: [chengmo@centos5 ~]$

  • Shell脚本case语句简明教程

    Shell case语句为多选择语句.可以用case语句匹配一个值与一个模式,如果匹配成功,执行相匹配的命令.case语句格式如下: 复制代码 代码如下: case 值 in 模式1)     command1     command2     ...     commandN     ;; 模式2)     command1     command2     ...     commandN     ;; esac case工作方式如上所示.取值后面必须为单词in,每一模式必须以右括号结束.取

  • linux bash shell中case语句的实例

    bash case语句的例子. 分享一段bash shell代码,对于学习bash的同学理解case语句的用法,会有帮助. 例子: 复制代码 代码如下: #!/bin/bash### Program:# File operation# 1.) Open file 2.) Display file 3.) Edit file 4.) Delete file# site: WWW.JB51.NETPATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/u

  • 一个shell for循环与case结合的脚本(监控程序状态)

    核心代码: 复制代码 代码如下: #/bin/bashset -xHOSTS="nginx mysql php-cgi"for myhost in $HOSTS  do  count=(`ps aux |grep $myhost |grep -v grep |wc -l`)  echo "$myhost"  echo "$count" if [ $count -eq 0 ]; then  case $myhost in  nginx)   cd

  • Shell编程之case语句实战(小结)

    大家好,今天给大家带来的是Shell编程之case语句的使用! 其实case语句还是很好理解的,在shell编程中,if语句有它的语法,函数也有它的语法,那么在我们shell编程中的case语句也是有它的语法的,如下: case 变量名 in 值1) 指令1 ;; 值2) 指令2 ;; 值3) 指令3 ;; esac 在以上的代码中我们发现,以case开头,以esac结尾,就像我们的if语句,以if开头以fi结束时一样的. 例2: case "找老公条件" in 家里有房子) 嫁给你.

  • shell脚本编程之case语句学习笔记

    case语句是用来实现多个if..else的功能的,但是用法上有些不同,学过其他语言的人都知道,case中要对变量进行匹配,如果有一个匹配成功的话就执行相应的语句.shell编程中的case语句也是这个意思,case会对字符串进行匹配,是从第一个模式开始的,如果有一个模式已经匹配成功的话,其他的模式就不会再进行匹配了,下面看下代码中的用法吧. #!/bin/sh echo "please yes or no" read input #case语句的基本用法,记住每一个匹配后边都有双分号

  • shell脚本中case条件控制语句的一个bug分析

    在shell脚本中,发现case语句的一个问题.就是指定小写字母[a-z]和大写字母[A-Z]的这种方法不管用了. 出现如下情况: 复制代码 代码如下: [root@station1 ~]# cat case.sh#!/bin/bashwhile :doecho -n "input a letter: "read varcase "$var" in  [a-z]) echo "Lowercase letter";;  [A-Z]) echo &q

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

    #前言:这篇我们接着写shell的另外一个条件语句case,上篇讲解了if条件语句.case条件语句我们常用于实现系统服务启动脚本等场景,case条件语句也相当于if条件语句多分支结构,多个选择,case看起来更规范和易读 #case条件语句的语法格式 case "变量" in 值1) 指令1... ;; 值2) 指令2... ;; *) 指令3... esac #说明:当变量的值等于1时,那么就会相应的执行指令1的相关命令输出,值等于2时就执行指令2的命令,以此类推,如果都不符合的话

  • 详解Shell脚本中^M的问题和解决方案

    目录 ^M 是什么? 本质原因 常用工具 在开发过程中,有时候不小心将Windows本地创建的shell脚本(以 .sh 结尾的脚本),传到linux系统中,通过 vi或者view命令查看文件时,发现在末尾发现出现了很多^M字符. ^M 是什么? 这个字符就是换行符.是由于跨平台解析的原因.因为window和Linux下对行尾的换行的定义不同Windows: \r\nLinux/Unix: \nMac: \r 例子 出现的原因:在DOS/Windows里,文本文件的换行符为\r\n,而在nix系

  • 详解Shell脚本中调用另一个Shell脚本的三种方式

    主要以下有几种方式: Command Explanation fork 新开一个子 Shell 执行,子 Shell 可以从父 Shell 继承环境变量,但是子 Shell 中的环境变量不会带回给父 Shell. exec 在同一个 Shell 内执行,但是父脚本中 exec 行之后的内容就不会再执行了 source 在同一个 Shell 中执行,在被调用的脚本中声明的变量和环境变量, 都可以在主脚本中进行获取和使用,相当于合并两个脚本在执行. 第一种:fork 特点:会生成子PID而且可重复被

  • 详解Shell 脚本中 “$” 符号的多种用法

    通常情况下,在工作中用的最多的有如下几项: $0:Shell 的命令本身 1到9:表示 Shell 的第几个参数 $? :显示最后命令的执行情况 $#:传递到脚本的参数个数 $$:脚本运行的当前进程 ID 号 $*:以一个单字符串显示所有向脚本传递的参数 $!:后台运行的最后一个进程的 ID 号 $-:显示 Shell 使用的当前选项 ...... 今天将通过以上几种选项并做进一步的操作案例: 1.引用变量 引用变量时,使用 $ 符号直接来进行引用,以及包括循环变量: [root@localho

  • 详解shell脚本[] [[]] -n -z 的含义解析

    在写脚本的时候,总是搞不懂[] [[]]的区别,这次写一个总结,把它掌握牢固 []和test 两者是一样的,在命令行里test expr和[ expr ]的效果相同. test的三个基本作用是判断文件.判断字符串.判断整数.支持使用 "与或非" 将表达式连接起来. test中可用的比较运算符只有==和!=,两者都是用于字符串比较的,不可用于整数比较,整数比较只能使用-eq, -gt这种形式. 无论是字符串比较还是整数比较都千万不要使用大于号小于号.当然,如果你实在想用也是可以的,对于字

  • 详解shell脚本的编写规范

    编写shell脚本的一些规范 解释器 shell脚本一般选择bash作为解释器,脚本开头应为 #!/bin/bash 或 #!/bin/sh 添加脚本版本和注释功能 在脚本的开头加注释,说明脚本作者.编写时间.脚本功能,最好可以加上脚本的版本号.shell中脚本注释用#,注释语句和#号之间有一个空格 #!/bin/bash # 脚本版本 # 脚本作者 # 脚本时间 # 脚本功能 添加脚本调试 通过set命令添加脚本调试,如果报错,脚本直接退出,不继续执行,对于管道错误也可以直接退出 #!/bin

  • 详解Shell脚本控制docker容器启动顺序

    1.遇到的问题 在分布式项目部署的过程中,经常要求服务器重启之后,应用(包括数据库)能够自动恢复使用.虽然使用docker update --restart=always containerid能够让容器自动随docker启动,但是并不能保证是在数据库启动之后启动,如果数据库未启动,那么将导致应用启动失败;网上还有一种解决方法是通过docker-compose容器编排来控制启动顺序,这个博主研究的比较少. 2.解决思路 使用Shell脚本来控制,思路大致如下 探测数据库端口来检验数据库是否启动成

  • 详解Angular.js中$http拦截器的介绍及使用

    前言 $http service在Angular中用于简化与后台的交互过程,其本质上使用XMLHttpRequest或JSONP进行与后台的数据交互.在与后台的交互过程中,可能会对每条请求发送到Server之前进行预处理(如加入token),或者是在Server返回数据到达客户端还未被处理之前进行预处理(如将非JSON格式数据进行转换):当然还有可能对在请求和响应过程过发生的问题进行捕获处理.所有这些需求在开发中都非常常见,所以Angular为我们提供了$http拦截器,用来实现上述需求. 什么

  • 详解shell中脚本参数传递的两种方式

    方式一:$0,$1,$2.. 采用$0,$1,$2..等方式获取脚本命令行传入的参数,值得注意的是,$0获取到的是脚本路径以及脚本名,后面按顺序获取参数,当参数超过10个时(包括10个),需要使用${10},${11}....才能获取到参数,但是一般很少会超过10个参数的情况. 1.1 示例:新建一个test.sh的文件 #!/bin/bash echo "脚本$0" echo "第一个参数$1" echo "第二个参数$2" 在shell中执行

  • Linux 在Shell脚本中使用函数实例详解

    Linux 在Shell脚本中使用函数实例详解 Shell的函数 Shell程序也支持函数.函数能完成一特定的功能,可以重复调用这个函数. 函数格式如下: 函数名() { 函数体 } 函数调用方式: 函数名 参数列表 实例:编写一函数add求两个数的和,这两个数用位置参数传入,最后输出结果. root@ubuntu:/home/study# vi test3 #!/bin/bash add(){ a=$1; b=$2; z=`expr $a + $b`; echo "The sum is $z&

随机推荐