Skip to content
SRE运维进阶之路SRE运维进阶之路
github icon
    • 第一部分 初见shell

      • 第一章 为什么使用shell编程
        • 第二章 和Sha-Bang(#!)一起出发

          • 2.1 调用一个脚本
            • 2.2 牛刀小试
          • 第二部分 shell基础

            • 第三章 特殊字符
              • 第四章 变量与参数

                • 4.1 变量替换
                  • 4.2 变量赋值
                    • 4.3 Bash变量是弱类型的
                      • /code/shell/part2/04_4_special_variable_types
                      • 第五章 引用

                        • 5.1 引用变量
                          • 5.2 转义
                          • 第六章 退出与退出状态
                            • 第七章 测试

                              • 7.1 测试结构
                                • 7.2 文件测试操作
                                  • 7.3 其他比较操作
                                    • 7.4 嵌套 if/then 条件测试
                                      • 7.5 牛刀小试
                                      • 第八章 运算符相关话题

                                        • 8.1 运算符
                                          • 8.2 数字常量
                                            • 8.3 双圆括号结构
                                              • 8.4 运算符优先级
                                            • 第三部分 shell进阶

                                              • 第九章 换个角度看变量

                                                • 9.1 内部变量
                                                  • 9.2 变量类型标注:declare 与 typeset
                                                    • 9.2.1 declare 的另类用法
                                                      • 9.3 $RANDOM:生成随机数
                                                      • 第十章 变量处理

                                                        • 10.1 字符串处理
                                                          • 10.1.1 使用 awk 处理字符串
                                                            • 10.1.2 参考资料
                                                              • 10.2 参数替换
                                                              • 第十一章 循环与分支

                                                                • 11.1 循环
                                                                  • 11.2 嵌套循环
                                                                    • 11.3 循环控制
                                                                      • 11.4 测试与分支
                                                                      • 第十二章 命令替换
                                                                        • 第十三章 算术扩展
                                                                        • 第四部分 命令
                                                                          • 第五部分 高级话题

                                                                            • 18 正则表达式

                                                                              • 18.1 正则表达式简介
                                                                                • 18.2文件名替换
                                                                                  • 18.3 正则表达式对照表
                                                                                  • 19 嵌入文档
                                                                                    • 20 I/O 重定向

                                                                                      • 20.1 使用 exec
                                                                                        • 20.2 重定向代码块
                                                                                          • 20.3 应用程序
                                                                                          • 第二十一章 子shell
                                                                                            • 第二十二章. 限制模式的Shell
                                                                                              • 第二十三章. 进程替换
                                                                                                • 24 函数

                                                                                                  • 24.1 复杂函数和函数复杂性
                                                                                                    • 24.2 局部变量
                                                                                                      • 24.3 不使用局部变量的递归
                                                                                                      • 25. 别名
                                                                                                        • 26. 列表结构
                                                                                                          • 27 数组
                                                                                                            • 30 网络编程
                                                                                                              • 33 选项
                                                                                                                • 第34章 陷阱
                                                                                                                  • 第36章 杂项
                                                                                                                    • echo命令
                                                                                                                    • 第六部分 Google Shell 风格指南
                                                                                                                    • 前端学习笔记

                                                                                                                      20.3 应用程序

                                                                                                                      author iconLinuxStorycalendar icon2021年5月11日category icon
                                                                                                                      • Linux
                                                                                                                      tag icon
                                                                                                                      • Bash
                                                                                                                      timer icon大约 1 分钟

                                                                                                                      # 20.3 应用程序

                                                                                                                      使用 I/O 重定向可以同时解析和固定命令输出的片段(see 样例 15-7open in new window). 这也使得可以生成报告和日志文件.

                                                                                                                      样例 20-12. 日志记录事件

                                                                                                                      #!/bin/bash
                                                                                                                      # logevents.sh
                                                                                                                      # 作者: Stephane Chazelas.
                                                                                                                      # 用于 ABS 许可指南.
                                                                                                                      
                                                                                                                      # 事件记录到文件.
                                                                                                                      # 必须 root 身份执行 (可以写入 /var/log).
                                                                                                                      
                                                                                                                      ROOT_UID=0     # 只有 $UID 为 0 的用户具有 root 权限.
                                                                                                                      E_NOTROOT=67   # 非 root 会报错.
                                                                                                                      
                                                                                                                      
                                                                                                                      if [ "$UID" -ne "$ROOT_UID" ]
                                                                                                                      then
                                                                                                                        echo "Must be root to run this script."
                                                                                                                        exit $E_NOTROOT
                                                                                                                      fi  
                                                                                                                      
                                                                                                                      
                                                                                                                      FD_DEBUG1=3
                                                                                                                      FD_DEBUG2=4
                                                                                                                      FD_DEBUG3=5
                                                                                                                      
                                                                                                                      # === 取消下面两行注释来激活脚本. ===
                                                                                                                      # LOG_EVENTS=1
                                                                                                                      # LOG_VARS=1
                                                                                                                      
                                                                                                                      
                                                                                                                      log()  # 时间和日期写入日志文件.
                                                                                                                      {
                                                                                                                      echo "$(date)  $*" >&7     # *追加* 日期到文件.
                                                                                                                      #     ^^^^^^^  命令替换
                                                                                                                                                 # 见下文.
                                                                                                                      }
                                                                                                                      
                                                                                                                      
                                                                                                                      
                                                                                                                      case $LOG_LEVEL in
                                                                                                                       1) exec 3>&2         4> /dev/null 5> /dev/null;;
                                                                                                                       2) exec 3>&2         4>&2         5> /dev/null;;
                                                                                                                       3) exec 3>&2         4>&2         5>&2;;
                                                                                                                       *) exec 3> /dev/null 4> /dev/null 5> /dev/null;;
                                                                                                                      esac
                                                                                                                      
                                                                                                                      FD_LOGVARS=6
                                                                                                                      if [[ $LOG_VARS ]]
                                                                                                                      then exec 6>> /var/log/vars.log
                                                                                                                      else exec 6> /dev/null                     # 清空输出.
                                                                                                                      fi
                                                                                                                      
                                                                                                                      FD_LOGEVENTS=7
                                                                                                                      if [[ $LOG_EVENTS ]]
                                                                                                                      then
                                                                                                                        # exec 7 >(exec gawk '{print strftime(), $0}' >> /var/log/event.log)
                                                                                                                        # 上述行在最近高于 bash 2.04 版本会失败,为什么?
                                                                                                                        exec 7>> /var/log/event.log              # 追加到 "event.log".
                                                                                                                        log                                      # 写入时间和日期.
                                                                                                                      else exec 7> /dev/null                     # 清空输出.
                                                                                                                      fi
                                                                                                                      
                                                                                                                      echo "DEBUG3: beginning" >&${FD_DEBUG3}
                                                                                                                      
                                                                                                                      ls -l >&5 2>&4                             # 命令1 >&5 2>&4
                                                                                                                      
                                                                                                                      echo "Done"                                # 命令2 
                                                                                                                      
                                                                                                                      echo "sending mail" >&${FD_LOGEVENTS}
                                                                                                                      # 输出信息 "sending mail" 到文件描述符 #7.
                                                                                                                      
                                                                                                                      
                                                                                                                      exit 0
                                                                                                                      
                                                                                                                      1
                                                                                                                      2
                                                                                                                      3
                                                                                                                      4
                                                                                                                      5
                                                                                                                      6
                                                                                                                      7
                                                                                                                      8
                                                                                                                      9
                                                                                                                      10
                                                                                                                      11
                                                                                                                      12
                                                                                                                      13
                                                                                                                      14
                                                                                                                      15
                                                                                                                      16
                                                                                                                      17
                                                                                                                      18
                                                                                                                      19
                                                                                                                      20
                                                                                                                      21
                                                                                                                      22
                                                                                                                      23
                                                                                                                      24
                                                                                                                      25
                                                                                                                      26
                                                                                                                      27
                                                                                                                      28
                                                                                                                      29
                                                                                                                      30
                                                                                                                      31
                                                                                                                      32
                                                                                                                      33
                                                                                                                      34
                                                                                                                      35
                                                                                                                      36
                                                                                                                      37
                                                                                                                      38
                                                                                                                      39
                                                                                                                      40
                                                                                                                      41
                                                                                                                      42
                                                                                                                      43
                                                                                                                      44
                                                                                                                      45
                                                                                                                      46
                                                                                                                      47
                                                                                                                      48
                                                                                                                      49
                                                                                                                      50
                                                                                                                      51
                                                                                                                      52
                                                                                                                      53
                                                                                                                      54
                                                                                                                      55
                                                                                                                      56
                                                                                                                      57
                                                                                                                      58
                                                                                                                      59
                                                                                                                      60
                                                                                                                      61
                                                                                                                      62
                                                                                                                      63
                                                                                                                      64
                                                                                                                      65
                                                                                                                      66
                                                                                                                      67
                                                                                                                      68
                                                                                                                      69
                                                                                                                      70
                                                                                                                      71
                                                                                                                      edit icon编辑此页open in new window
                                                                                                                      上次编辑于: 2022/4/27 15:33:00
                                                                                                                      贡献者: clay-wangzhi
                                                                                                                      上一页
                                                                                                                      20.2 重定向代码块
                                                                                                                      备案号:冀ICP备2021007336号
                                                                                                                      Copyright © 2023 LinuxStory