shell脚本实现分日志级别输出的方法

2019-09-23 09:11:11王振洲

输出如下:

在写这个函数的遇到一个问题就是不能用内建变量$LINENO来取得调用的行号,只能取得log函数中定义$LINENO那一行,搜了许久找到的解决办法是利用caller命令,关于caller命令的用法,如下:

5.caller的用法

caller命令放到函数中, 将会在stdout上打印出函数的调用者信息.,caller命令也可以在一个被source的脚本中返回调用者信息. 当然这个调用者就是source这个脚本的脚本. 就像函数一样, 这是一个”子例程调用”.你会发现这个命令在调试的时候特别有用.

 #!/bin/bash

 function1 ()
 {
  # 在 function1 () 内部.
  caller 0  # 显示调用者信息.
 }

 function1  # 脚本的第9行.

 # 9 main test.sh
 # ^         函数调用者所在的行号.
 #  ^^^^      从脚本的"main"部分开始调用的.
 #    ^^^^^^^  调用脚本的名字.

 caller 0   # 没效果, 因为这个命令不在函数中.

以上这篇shell脚本实现分日志级别输出的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易采站长站。