Bash脚本进阶指南
Repo
  • 正文
    • 第一部分 初见shell
      • 1. 为什么使用shell编程
      • 2. 和Sha-Bang(#!)一起出发
        • 2.1 调用一个脚本
        • 2.2 牛刀小试
    • 第二部分 shell基础
      • 3. 特殊字符
      • 4. 变量与参数
        • 4.1 变量替换
        • 4.2 变量赋值
        • 4.3 Bash弱类型变量
        • 4.4 特殊变量类型
      • 5. 引用
        • 5.1 引用变量
        • 5.2 转义
      • 6. 退出与退出状态
      • 7. 测试
        • 7.1 测试结构
        • 7.2 文件测试操作
        • 7.3 其他比较操作
        • 7.4 嵌套 if/then 条件测试
        • 7.5 牛刀小试
      • 8. 运算符相关话题
        • 8.1 运算符
        • 8.2 数字常量
        • 8.3 双圆括号结构
        • 8.4 运算符优先级
    • 第三部分 shell进阶
      • 9. 换个角度看变量
        • 9.1 内部变量
        • 9.2 变量类型标注:declare 与 typeset
          • 9.2.1 declare 的另类用法
        • 9.3 $RANDOM:生成随机数
      • 10. 变量处理
        • 10.1 字符串处理
          • 10.1.1 使用 awk 处理字符串
          • 10.1.2 参考资料
        • 10.2 参数替换
      • 11. 循环与分支
        • 11.1 循环
        • 11.2 嵌套循环
        • 11.3 循环控制
        • 11.4 测试与分支
      • 12. 命令替换
      • 13. 算术扩展
      • 14. 休息时间
    • 第四部分 命令
      • 15. 内建命令
        • 15.1 任务控制命令
      • 16. 外部筛选器,任务及命令
        • 16.1 基础命令
        • 16.2 复杂命令
        • 16.3 时间/日期命令
        • 16.4 文本处理命令
        • 16.5 文件与归档命令
        • 16.6 通信命令
        • 16.7 终端控制命令
        • 16.8 数学命令
        • 16.9 杂项命令
      • 17. 系统与管理命令
        • 17.1 分析一个系统脚本
    • 第五部分 高级话题
      • 18.正则表达式
        • 18.1正则表达式简介
        • 18.2文件名替换
      • 19. 嵌入文档
      • 20. I/O 重定向
        • 20.1 使用 exec
        • 20.2 重定向代码块
        • 20.3 应用程序
      • 21. 子shell
      • 22. 限制模式的Shell
      • 23. 进程替换
      • 24. 函数
        • 24.1 复杂函数和函数复杂性
        • 24.2 局部变量
        • 24.3 不适用局部变量的递归
      • 25. 别名
      • 26. 列表结构
      • 27. 数组
      • 28. 间接引用
      • 29. /dev 和 /proc
        • 29.1 /dev
        • 29.2 /proc
      • 30. 网络编程
      • 32. 调试
      • 33. 选项
      • 34. 陷阱
      • 36. 杂项
        • 36.1 交互和非交互shell以及脚本
        • 36.2 shell wrappers
        • 36.3 测试和比较的其他方法
        • 36.4 递归:调用自己的脚本
        • 36.5 “彩色”的脚本
        • 36.6 优化
        • 36.7 其他技巧
        • 36.8 安全问题
        • 36.9 可移植性问题
        • 36.10 Windows系统下的脚本
    • 38. 后记
      • 38.1 作者后记
      • 38.2 关于作者
      • 38.3 从哪里可以获得帮助
      • 38.4 用来制作这本书的工具
      • 38.5 致谢
      • 38.6 免责声明
  • 附录及索引
    • 参考文献
    • 附录
    • 索引
由 GitBook 提供支持
在本页

这有帮助吗?

  1. 正文
  2. 第四部分 命令
  3. 17. 系统与管理命令

17.1 分析一个系统脚本

上一页17. 系统与管理命令下一页第五部分 高级话题

最后更新于1年前

这有帮助吗?

让我们利用对系统管理命令的了解,一起分析一个系统脚本吧。最简单易懂的脚本之一是“killall”,用于在系统关闭时暂停正在运行的进程。

样例 17-12. killall脚本,来自/etc/rc.d/init.d

#!/bin/sh

# --> 本文档作者添加的注释为“#-->”。

# --> 这是'rc'脚本软件包的一部分。
# --> 该脚本由Miquel van Smoorenburg所撰,<miquels@drinkel.nl.mugnet.org>.

# --> 该脚本似乎仅用于特定的Red Hat / FC系统
# --> (可能不会出现在其他发行版中)。

#  关闭所有非必需但仍在运行的服务。
#  (其实并不应该有,所以这只是一个健全性检查)

for i in /var/lock/subsys/*; do
        # --> 标准的for/in循环,但“do”写在同一行,
        # --> 有必要加";"。
        # 检查是否脚本还在那里。
        [ ! -f $i ] && continue
        # --> 这是一个“与列表”的巧妙运用,等价于:
        # --> if [ ! -f "$i" ]; then continue

        # 获取子系统名称。
        subsys=${i#/var/lock/subsys/}
        # --> 匹配变量名,在本例中是文件名。
        # --> 完全等价于 subsys=`basename $i`。

        # -->  从锁文件中获取
        # -->  (如果存在锁文件,
        # -->   那就证明了进程还在运行)。
        # -->  请参见上面的“锁文件”条目。


        # 关闭子系统。
        if [ -f /etc/rc.d/init.d/$subsys.init ]; then
           /etc/rc.d/init.d/$subsys.init stop
        else
           /etc/rc.d/init.d/$subsys stop
        # -->  挂起正在运行的工作和守护进程。
        # -->  注意"stop"是一个位置参数,
        # -->  并不是一个shell内置程序。
        fi
done

仔细看看还是能读懂的。除了一点变量匹配的小技巧,没有新的东西。

练习 2.请观察/etc/rc.d/init.d下一些更复杂的脚本,试着至少理解它们的一部分。按照上面的过程来分析它们。为了获得更多的信息,你还可以检查/usr/share/doc/initscripts-?.??中的sysvinitfile文件,它们是“初始脚本”文档中的一部分。

注记

练习 1.请分析位于/etc/rc.d/init.d目录下的halt脚本。它比killall稍长,但概念相似。请复制将这个脚本拷贝到主目录中的某个地方进行试验(不要以root用户身份运行它)。可以使用-vn标志(sh -vn scriptname)模拟运行脚本。在此过程中,你可以添加更多的注释。把命令改成。

请不要将killall系统脚本与位于/usr/bin中的命令相混淆。

[1]
echo
[1]
killall