#前言:这篇我们接着写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-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
(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}
#输入选项中的数字,打印相关信息
#主要思路:
#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 ]
#要求用户登录到跳板机后只能执行管理员给定的选项动作,不能中断脚本而到跳板机服务器上执行任何系统命令
#思路
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条件语句内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
本文向大家介绍Shell脚本的条件控制和循环语句,包括了Shell脚本的条件控制和循环语句的使用技巧和注意事项,需要的朋友参考一下 条件判断:if语句 语法格式: 注意:expression 和方括号([ ])之间必须有空格,否则会有语法错误。 if 语句通过关系运算符判断表达式的真假来决定执行哪个分支。Shell 有三种 if ... else 语句: 示例: if ... else 语句也可以
一、环境 1、Hadoop 0.20.2 2、Hive 0.5 3、操作系统 Linux m131 2.6.9-78.8AXS2smp #1 SMP Tue Dec 16 02:42:55 EST 2008 x86_64 x86_64 x86_64 GNU/Linux 二、步骤 1、直接贴上脚本吧 #!/bin/bash #give the params: name value tablename
问题内容: 从此问题派生而来,是否可以对以下SQL语句使用HQL或Criteria: 尽管google提出了一些命中意见,表明HQL支持CASE语句,但是Hibernate 3.6.6失败并显示 QuerySyntaxException:意外令牌:CASE 当我在EntityManager实例上创建上述查询时。 为每个e.type创建另一个查询来手动确定男性人数(例如针对每个e.type)有多少个
本文向大家介绍shell脚本编程之case语句学习笔记,包括了shell脚本编程之case语句学习笔记的使用技巧和注意事项,需要的朋友参考一下 case语句是用来实现多个if..else的功能的,但是用法上有些不同,学过其他语言的人都知道,case中要对变量进行匹配,如果有一个匹配成功的话就执行相应的语句。shell编程中的case语句也是这个意思,case会对字符串进行匹配,是从第一个模式开始的
本文向大家介绍C#中的switch case使用介绍,包括了C#中的switch case使用介绍的使用技巧和注意事项,需要的朋友参考一下 在C#中 其中type可以是数字,也可以是字符串;
本文向大家介绍MySQL load语句详细介绍,包括了MySQL load语句详细介绍的使用技巧和注意事项,需要的朋友参考一下 load的语法 LOAD DATA INFILE语句用于高速地从一个文本文件中读取行,并装入一个表中。文件名称必须为一个文字字符串。 由character_set_database系统变量指示的字符集被用于解释文件中的信息。SET NAMES和character_set_
主要内容:Redis Lua脚本的引入,开源软件的可扩展性,Redis的扩展性脚本,Redis Lua脚本的基本使用,通过EVAL命令执行Lua脚本,通过脚本与Redis交互,Java中调用Redis Lua脚本,Java调用Lua脚本的方式,Redis Lua脚本的使用建议,脚本缓存,脚本缓存稳定性,脚本参数化,脚本超时处理,Redis集群中Lua脚本的使用,其他限制,Redis 7 Functions,,,Redis Lua脚本的详细介绍以及使用入门。 本次的主要分享主题是:Redis Lu
问题内容: 我有以下查询: 这返回 我将如何使它工作?说参数是否为“有效”,则返回具有以下条件的记录? 问题答案: 您可以使用另一种方法: