zoukankan      html  css  js  c++  java
  • shell script 的追踪与 debug

    shell script 的追踪与 debug

      scripts 在运行之前,最怕的就是出现语法错误的问题了!那么我们如何 debug 呢?有没有办法不需要透过直接运行该 scripts 就可以来判断是否有问题呢?呵呵!当然是有的!我们就直接以 bash 的相关参数来进行判断吧!

    [root@www ~]# sh [-nvx] scripts.sh
    选项与参数:
    -n  :不要运行 script,仅查询语法的问题;
    -v  :再运行 sccript 前,先将 scripts 的内容输出到萤幕上;
    -x  :将使用到的 script 内容显示到萤幕上,这是很有用的参数!
    
    范例一:测试 sh16.sh 有无语法的问题?
    [root@www ~]# sh -n sh16.sh 
    # 若语法没有问题,则不会显示任何资讯!
    
    范例二:将 sh15.sh 的运行过程全部列出来~
    [root@www ~]# sh -x sh15.sh 
    + PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:/root/bin
    + export PATH
    + for animal in dog cat elephant
    + echo 'There are dogs.... '
    There are dogs....
    + for animal in dog cat elephant
    + echo 'There are cats.... '
    There are cats....
    + for animal in dog cat elephant
    + echo 'There are elephants.... '
    There are elephants....

       除了上面的做法我们还可以:

    1. 我们可以在脚本开始的地方加入这个命令
    set -x

    2. 也可以向下面这样直接加在后面
    #!/bin/ksh -x

    3. 可以在执行脚本时这样做
    #ksh -x /locale/shell.sh

      请注意,上面范例二中运行的结果并不会有颜色的显示!鸟哥为了方便说明所以在 + 号之后的数据都加上颜色了! 在输出的信息中,在加号后面的数据其实都是命令串,由於 sh -x 的方式来将命令运行过程也显示出来, 如此使用者可以判断程序码运行到哪一段时会出现相关的资讯!这个功能非常的棒!透过显示完整的命令串, 你就能够依据输出的错误资讯来订正你的脚本了!

      熟悉 sh 的用法,将可以使你在管理 Linux 的过程中得心应手!至於在 Shell scripts 的学习方法上面,需要『多看、多模仿、并加以修改成自己的样式!』 是最快的学习手段了!网络上有相当多的朋友在开发一些相当有用的 scripts ,若是你可以将对方的 scripts 拿来,并且改成适合自己主机的样子!那么学习的效果会是最快的呢!

      另外,我们 Linux 系统本来就有很多的服务启动脚本,如果你想要知道每个 script 所代表的功能是什么? 可以直接以 vim 进入该 script 去查阅一下,通常立刻就知道该 script 的目的了。 举例来说,我们之前一直提到的 /etc/init.d/syslog ,这个 script 是干嘛用的? 利用 vi 去查阅最前面的几行字,他出现如下资讯:

    # description: Syslog is the facility by which many daemons use to log 
    # messages to various system log files.  It is a good idea to always 
    # run syslog.
    ### BEGIN INIT INFO
    # Provides: $syslog
    ### END INIT INFO

      简单的说,这个脚本在启动一个名为 syslog 的常驻程序 (daemon),这个常驻程序可以帮助很多系统服务记载她们的登录档 (log file), 我们的 Linux 建议你一直启动 syslog 是个好主意!嘿嘿!简单的看看您就知道啥是啥啦!

    另外,本章所有的范例都可以在 http://vbird.dic.ksu.edu.tw/linux_basic/0340bashshell-scripts/scripts-v3.tar.bz2 里头找到喔!加油~

    转自:  http://vbird.dic.ksu.edu.tw/linux_basic/0340bashshell-scripts_6.php

  • 相关阅读:
    51nod1600Simple KMP【SAM,树链剖分】
    YbtOJ#493最大分数【斜率优化dp,分治】
    P2611[ZJOI2012]小蓝的好友【Treap,扫描线】
    咽喉炎食疗药膳
    八大方法预防鼻炎发作
    ASP.NET之ViewState
    ASP之利用updatepanel和Timer实现局部定时刷新
    JqueryEasyUI中combotree 加载下拉框中的树形结构
    浅说ruby嵌套函数
    配置android环境
  • 原文地址:https://www.cnblogs.com/mjorcen/p/4005801.html
Copyright © 2011-2022 走看看