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
)
echo "The num you input is 1"
;;
[-])
echo "The num you input is 2-5"
;;
[-])
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:
The num you input is
[root@shell scripts]# sh num.sh
please input a number:
The num you input is -
[root@shell scripts]# sh num.sh
please input a number:
The num you input is -
[root@shell scripts]# sh num.sh
please input a number:
The num you input is -
[root@shell scripts]# sh num.sh
please input a number:a
please input number[-] 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打印菜单
#############################
.banana
.apple
.pear
.cherry
#############################
' read -p "please select a num:" num case "$num" in
)
echo -e "${YELLOW_COLOR} banana ${RES}"
;;
)
echo -e "${RED_COLOR} apple ${RES}"
;;
)
echo -e "${GREEN_COLOR} pear ${RES}"
;;
)
echo -e "${BLUE_COLOR} cherry ${RES}"
;;
*)
echo "please input {1|2|3|4}"
esac
#说明:定义颜色,使用read读取用户输入的数据,然后使用case条件语句进行判断,根据用户输入的值执行相关的操作,给用户输入的水果添加颜色
#扩展:输出菜单的另外种方式
cat<<-EOF
===============================
.banana
.apple
.pear
.cherry
===============================
EOF
#执行效果
#如果输入不正确或者不输入的话就打印帮助
[root@shell scripts]# sh menu.sh #############################
.banana
.apple
.pear
.cherry
############################# please select a num:
please input {|||}
#输入选项中的数字,打印相关信息
实践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..tar.gz
cd nginx-1.6./
./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. /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:@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 ];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
start
;;
*)
echo "USAGE:$0 {stop|start|reload}"
exit
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.开发跳板机
#要求用户登录到跳板机后只能执行管理员给定的选项动作,不能中断脚本而到跳板机服务器上执行任何系统命令
#思路
.首先做好ssh key验证登录
.实现远程连接菜单选择脚本
.利用Linux信号防止用户在跳板机上操作
.用户登录后就调用脚本
#操作过程
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 ]----+
| + 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==============
) 192.168.86.129
) 192.168.86.130
) 192.168.86.131
) 192.168.86.132
) exit
=====================================
EOF
} USER=demo host(){ #定义主机列表函数
case "$1" in
)
ssh $USER@192.168.86.129
;;
)
ssh $USER@192.168.86.130
;;
)
ssh $USER@192.168.86.131
;;
)
ssh $USER@192.168.86.132
;;
)
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 ] && . /scripts/tiaobanji.sh
#3.4.测试
#登录demo普通用户输入密码的时候就会直接跳到选项卡页面了
#选项卡页面
==============Host List==============
) 192.168.86.129
) 192.168.86.130
) 192.168.86.131
) 192.168.86.132
) exit
=====================================
please select a num:1 #进行选择
Last login: Tue Mar :: from 192.168.86.128
[demo@mysql ~]$
#3.5.提示:跳板机的安全
.禁止跳板机可以从外网IP进行登录,只能从内网IP登录
.其他服务器也限制只能内网IP登录,同时禁止root登录,做完ssh key认证,将密码登录禁止,通过免密码登录到其他服务器
#总结:if条件语句主要用于取值判断、比较,应用比较广,case条件语句主要是写服务的启动脚本,各有各的优势。好了,shell脚本的条件语句就讲解到这里了,接下来会继续写shell脚本的循环(包括for,while等),如果写的不好的地方还望指出,多多交流提高,下次再会。。。
shell脚本中的case条件语句介绍和使用案例的更多相关文章
- shell脚本中的if条件语句介绍和使用案例
#前言:在生产工作中if条件语句是最常使用的,如使用来判断服务状态,监控服务器的CPU,内存,磁盘等操作,所以我们需要熟悉和掌握if条件语句. #简介 if条件语句,简单来说就是:如果,那么.有if单 ...
- shell脚本中多个条件判断的语法
if [ "$content" = "hello" ]\ || [ "$content" = "kitty" ] the ...
- 『忘了再学』Shell流程控制 — 35、多分支case条件语句
目录 1.case条件语句介绍 2.case语句需要注意的内容 3.练习 示例1 示例2 1.case条件语句介绍 case语句和if-elif-else语句一样都是多分支条件语句,不过和if多分支条 ...
- shell脚本中的逻辑判断、文件目录属性判断、if特殊用法、case判断
7月12日任务 20.5 shell脚本中的逻辑判断20.6 文件目录属性判断20.7 if特殊用法20.8/20.9 case判断 20.5 shell脚本中的逻辑判断 逻辑判断在shell中随处可 ...
- 在shell脚本中进行条件控制以及使用循环
转载请标明:http://www.cnblogs.com/winifred-tang94/ if条件语句语法: if [ 条件表达式 ] then 代码 else 代码 fi 注意:在上面的if条件语 ...
- Shell脚本中的逻辑判断、文件目录属性判断、if的特殊用法、case判断
1.Shell脚本中的逻辑判断 格式1:if 条件 ; then 语句; fi格式2:if 条件; then 语句; else 语句; fi格式3:if …; then … ;elif …; then ...
- centos shell脚本编程2 if 判断 case判断 shell脚本中的循环 for while shell中的函数 break continue test 命令 第三十六节课
centos shell脚本编程2 if 判断 case判断 shell脚本中的循环 for while shell中的函数 break continue test 命令 ...
- Linux centosVMware shell脚本中的逻辑判断、文件目录属性判断、if特殊用法、case判断
一.shell脚本中的逻辑判断 格式1:if 条件 ; then 语句; fi 格式2:if 条件; then 语句; else 语句; fi 格式3:if …; then … ;elif …; th ...
- Linux centosVMware shell脚本介绍、shell脚本结构和执行、date命令用法、shell脚本中的变量
一. shell脚本介绍 shell是一种脚本语言 aming_linux blog.lishiming.net 可以使用逻辑判断.循环等语法 可以自定义函数 shell是系统命令的集合 shell脚 ...
随机推荐
- Neural Turing Machine - 神经图灵机
Neural Turing Machine - 神经图灵机 论文原文地址: http://arxiv.org/pdf/1410.5401.pdf 一般的神经网络不具有记忆功能,输出的结果只基于当前的输 ...
- 禁止用户使用 sudo su 命令进入root 模式
禁止普通用户通过sudo su命令进入root模式的方法(在root模式下操作): 1. 修改 /etc/sudoers 的权限, 用来写入文件 # chmod 777 /etc/sudoers 2. ...
- node跨域方法
第一种:jsonp 参看用nodejs实现json和jsonp服务 第二种:res.wirteHeadnode部分 var http = require('http') var url = requi ...
- OC和C++混编需要注意的问题
文章首发于github.io 2018-12-17 21:01:55 方案一 1. .c文件的identify and type右边栏修改为Objective-C source 2. Built se ...
- DUBBO 面试灵魂18问
一.Dubbo 是什么 dubbo 是一个分布式框架,是一个远程服务调用的分布式框架,其核心部分包含: 1)集群容错: 提供基于接口方法的透明远程过程调用,包含多协议支持,以及软负债均衡.失败容错.地 ...
- apache搭建Tomcat集群(Cluster)
搭建集群: apache:特点处理静态资源(html 图片 js等) apache的请求操作,Cluster工具 tomcat:特点处理动态资源 apache+tomcat(apache是web服 ...
- 阿里云上docker部署nginx实现反向代理
简介 需要从镜像仓库找到所需要的nginx版本pull下来.(地址:https://hub.docker.com/) 1.docker pull nginx 1.挂载目录 1.1 获取nginx. ...
- weex 和 appcan 的个人理解
appcan是浏览器技术,前端代码运行在webview上,而weex是原生引擎渲染,说白了就是把H5翻译成原生. weex的官网上说,在开发weex页面就像开发普通网页一样,在渲染weex页面时和原生 ...
- Generator的异步编程
对比下常用的异步处理的方案: 1,回调 我们常说的 “回调地狱”,就是多个异步操作时候,代码多重嵌套,异步之前形成强耦合,如果修改一处,其他地方也是跟着修改.(callback hell). 2,pr ...
- Docker深入浅出系列 | Swarm多节点实战
目录 前期准备 Swarm基本概念 什么是Docker Swarm 为什么要用Swarm Swarm的网络模型 Swarm的核心实现机制 服务发现机制 负载均衡机制Routing Mesh Docke ...