脚本作业–函数练习

1、编写服务脚本/root/bin/testsrv.sh,完成如下要求
(1) 脚本可接受参数:start, stop, restart, status
(2) 如果参数非此四者之一,提示使用格式后报错退出
(3) 如是start:则创建/var/lock/subsys/SCRIPT_NAME, 并显示“启动成功”
考虑:如果事先已经启动过一次,该如何处理?
(4) 如是stop:则删除/var/lock/subsys/SCRIPT_NAME, 并显示“停止完成”
考虑:如果事先已然停止过了,该如何处理?
(5) 如是restart,则先stop, 再start
考虑:如果本来没有start,如何处理?
(6) 如是status, 则如果/var/lock/subsys/SCRIPT_NAME文件存在,则显示“SCRIPT_NAMEis running…”
如果/var/lock/subsys/SCRIPT_NAME文件不存在,则显示“SCRIPT_NAME is stopped…”

其中:SCRIPT_NAME为当前脚本名

[root@fengl bin]# cat testsrv.sh 
#!/bin/bash

name=`basename $0`
filename=/var/lock/subsys/$name
creatfile ()
{
    if [ -f ${filename} ] ;then
        echo "程序已启动,正在运行...";exit
    else 
        echo "程序正在启动..."
        touch ${filename}
        [ $? -eq 0 ] && echo "启动成功"
    fi
}
delfile ()
{
    if [ -f ${filename} ] ;then
        echo "程序正在停止..."
        rm -f ${filename} && echo "停止成功"
    else 
        echo "程序未运行"
    fi    
}
stat ()
{
    if [ -f ${filename} ];then
        echo "${name} is running ..."
    else
        echo "${name} is stopped ..."
    fi
}
case $1 in
start)
    creatfile
    ;;
stop)
    delfile
    ;;
restart)
    delfile
    creatfile
    ;;
status)
    stat
    ;;
*)
    echo "输入格式错误";exit
    ;;
esac

1GIF.gif

2、编写脚本/root/bin/copycmd.sh
(1) 提示用户输入一个可执行命令名称;
(2) 获取此命令所依赖到的所有库文件列表
(3) 复制命令至某目标目录(例如/mnt/sysroot)下的对应路径下;
如:/bin/bash ==> /mnt/sysroot/bin/bash
/usr/bin/passwd==> /mnt/sysroot/usr/bin/passwd
(4) 复制此命令依赖到的所有库文件至目标目录下的对应路径下:
如:/lib64/ld-linux-x86-64.so.2 ==> /mnt/sysroot/lib64/ld-linux-x86-64.so.2
(5)每次复制完成一个命令后,不要退出,而是提示用户键入新的要复制的命令,并重复完成上述功能;直到用户输入quit退出

[root@fengl bin]# cat copycmd.sh 
#!/bin/bash

copydir="/mnt/sysroot"
[ ! -d ${copydir} ] && mkdir ${copydir}
bincopy () {
    if which $1 &> /dev/null ;then
        local cmd_path=`which --skip-alias $1`
        local bin_dir=`dirname ${cmd_path}`
        [ -d ${copydir}${bin_dir} ] || mkdir -p ${copydir}${bin_dir}
        [ -f ${copydir}${cmd_path} ] || cp ${cmd_path} ${copydir}${bin_dir}
        echo "${cmd_path}---->文件复制完成"
    else
        echo "输入的命令不存在";exit
    fi
}

libcopy () {
    local lib_list=$(ldd `which --skip-alias $1` | grep -Eo '/[^[:space:]]+')
    for loop in ${lib_list};do
        local lib_dir=`dirname ${loop}`
        [ -d ${copydir}${lib_dir} ] || mkdir -p ${copydir}${lib_dir}
        [ -f ${copydir}${loop} ] || cp ${loop} ${copydir}${lib_dir}
        echo "${loop}---->文件复制完成"
    done
}

    read -p "请输入一个可执行命令:" cmd
while [ "${cmd}" != "quit" ];do
    if bincopy ${cmd} ;then
    libcopy ${cmd}
    fi
    read -p "请输入一个可执行命令或退出(quit):" cmd
done

2GIF.gif

3、汉诺塔(又称河内塔)问题是源于印度一个古老传说。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。
利用函数,实现N片盘的汉诺塔的移动步骤

[root@fengl bin]# cat heneita.sh 
#!/bin/bash

step=0
heneita () {
    [[ ! $1 =~ ^[1-9][0-9]*$ ]] && echo "输入错误,请重新输入碟子的数量" && exit
    if [ $1 -eq 1 ] ; then
        let step++
        echo "$step: move plate $1   $2------>$4"
    else
        heneita "$[$1-1]" $2 $4 $3
        let step++
        echo "$step: move plate $1   $2------>$4"
        heneita "$[$1-1]" $3 $2 $4
    fi
}
read -p "请输入碟子的数量:" number
heneita $number A B C

3GIF.gif

原创文章,作者:苦涩咖啡,如若转载,请注明出处:http://www.178linux.com/38904

(0)
苦涩咖啡苦涩咖啡
上一篇 2016-08-24 21:22
下一篇 2016-08-24 21:22

相关推荐

  • mount挂载

    mount 1 挂载mount                                               &nb…

    Linux干货 2017-04-24
  • 文件管理

    compress:压缩命令 -d:解压缩(=uncompress) -c:结果输出到标准输出,不删除原文件 -v:显示详情 zcat:不解压文件查看内容   gzip:压缩命令 -d:解压缩 -c:结果输出到标准输出,不删除原文件 -#:1-9代表压缩比,默认为6 zcat:不解压文件查看内容   bzip2:压缩命令 -k:保留原文件 …

    Linux干货 2016-08-18
  • nginx 基础笔记

    一、Nginx 优点 高性能web,可以支持反向代理 比Apache性能优越,支持更多的并发连接,但资源占用很少,轻量级的web服务器。可以支持高达50000个并发连接数的响应 Nginx 在Linux 2.6+ 使用epoll模型,提供卓越性能 做为负载均衡服务器,可以在内部直接支持PHP和Rails,也可以支持作为HTTP代理服务器对外进行服务 Ngin…

    Linux干货 2016-03-19
  • 第二周作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示 答:针对文件常用的命令有如下几大类: a)文件创建命令 touch       touch /path/filename  —-新建一个空的文件 b)文件复制命令 cp       cp /path1/…

    Linux干货 2016-11-19
  • N22-第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 ~]# cp -r /etc/skel /home/tuser1 ~]# chmod -R go= /home/tuser1/ 2、编辑/etc…

    Linux干货 2016-09-06
  • yum总结之概述篇

    前言 一个linux菜鸟往往因为对与linux安装软件的复杂而望而却步,特别是从windows到linux的用户肯定表示接受不了。确实linux下装软件想做到win下下一步下一步完成目前来说是不可能的。 linux下软件安装有3种方法:   一种是源码安装,需要用户自己手动编译,另一种是RPM包(RedHat Linux Packet M…

    Linux干货 2016-03-01