只能获取fixed语句初始值_详解shell脚本case条件语句,开发各种服务启动脚本跳板机...

作者:老油条IT记
公众号:老油条IT记

#前言: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 inputread -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:1The num you input is 1[root@shell scripts]# sh num.sh please input a number:3The num you input is 2-5[root@shell scripts]# sh num.sh please input a number:4The num you input is 2-5[root@shell scripts]# sh num.sh please input a number:8The num you input is 6-9[root@shell scripts]# sh num.shplease input a number:aplease 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 menuRED_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:" numcase "$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<===============================    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/bashyum install  gcc  pcre pcre-devel wget openssl  openssl-devel.x86_64  -y  mkdir -p /home/demo/toolscd /home/demo/tools/wget  -q http://nginx.org/download/nginx-1.6.3.tar.gzuseradd  nginx -s /sbin/nologin -Mtar  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_modulemakemake installln -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:107988@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 1esac#执行效果[root@shell init.d]# sh nginx stopNginx is stop                                              [  OK  ][root@shell init.d]# sh nginx startNginx is start                                             [  OK  ][root@shell init.d]# sh nginx reloadNginx 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@shellThe 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/bashtrapper(){  #定义屏蔽信号函数    trap  '' INT QUIT TSTP TERM HUB}menu(){ #定义菜单列表函数    cat<==============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=demohost(){ #定义主机列表函数    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)        exitesac}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.1292) 192.168.86.1303) 192.168.86.1314) 192.168.86.1325) 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条件语句主要是写服务的启动脚本,各有各的优势。

#公众号推送

77838948f47f2ba26350d6312bcb1380.png

陈冠男的游戏人生

        个人公众号, 主要更新方向为二进制、PWN、 vulnhub 靶机

6942d71551f50c2678207069d304062b.png

Python编程和深度学习

公众号主要研究图像处理、机器学习和深度学习领域相关知识,并及时对最新的深度学习领域的文章进行解读和分享

0d84614d46b7eca0387a9c33e5175e53.png

贝塔安全实验室

致力于安全攻防研究,公众号包括但不限于,红队建设、靶场攻略、企业安全、资源推荐等。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值