shell 重定向错误输出到文件 加上时间(标明错误抛出的时间)
来源:互联网 发布:人工智能 发展战略 编辑:程序博客网 时间:2024/05/17 23:55
在开发中,我们避免不了写crontab脚本来异步执行一些东西,一般设置crontab用下面的方法:
*/1 * * * * commond > /tmp/t.log 2>&1
前面的> /tmp/t.log代表把标准输出重定向到/tmp/t.log文件,后面的 2>&1 代表把标准错误输出指向标准输出,意思是当commond异常退出时,把异常退出时的日志也写到 /tmp/t.log 下面,这时记录的日志是没有时间信息的,就是说日志里的数据没有办法知道是什么时候打印出来的。
下面通过一个shell来解决这件事,代码如下:
#!/bin/shif [ $# -gt 1 ];then date=`date +%Y-%m-%d@%H:%M:%S` for((i=2;i<=$#;i++)) do string=$string""${!i} done c=$date":"$string echo "">>$1 echo $c >>$1fi
把上面的代码保存为 datecrontalog.sh。
附:linux下shell的特殊字符解释
$0 这个程式的执行名字
$n 这个程式的第n个参数值,n=1..9
$* 这个程式的所有参数,此选项参数可超过9个。
$# 这个程式的参数个数
$$ 这个程式的PID(脚本运行的当前进程ID号)
$! 执行上一个背景指令的PID(后台运行的最后一个进程的进程ID号)
$? 执行上一个指令的返回值 (显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误)
$- 显示shell使用的当前选项,与set命令功能相同
$@ 跟$*类似,但是可以当作数组用
然后在crontab -e用下面的脚本代替
*/1 * * * * commond 2>&1 | xargs $HOME/datecrontalog.sh /tmp/t.log
附:| 管道符与xargs的区别
| 管道符是实现“将前面的标准输出作为后面的标准输入”
xargs是实现“将标准输入作为命令的参数”
0 0
- shell 重定向错误输出到文件 加上时间(标明错误抛出的时间)
- crontab 重定向错误日志 加上时间
- crontab 重定向错误日志 加上时间
- shell 错误输出重定向到标准输出
- 将Linux 标准输出,错误输出重定向到文件
- python 记录编译错误和输出重定向到文件
- ffmpeg shell输出重定向到文件
- Linux重定向:将标准输出stdout和标准错误stderr重定向到一个文件
- linux下重定向,把标准输出和错误输出一起同定向到文件
- Linux 执行命令或脚本的屏幕输出(正常输出、警告、错误等信息)重定向输出到文件
- shell将标准错误输出重定向为标准输出
- 重定向标准输出错误输出到编辑控件中!
- 重定向标准错误输出
- linux输出错误重定向
- 重定向标准错误输出
- 重定向标准错误输出
- DOS命令行下如何把标准错误和标准输出重定向到同一个文件
- linux 重定向 标准错误与标准输出到同一文件
- 《项目推荐》Unity官方新的多人坦克大战项目
- 层次聚类算法总结
- 如何利用wordpress搭建自己独立的博客(个人网站)
- 关系性并查集
- BZOJ 2657 [Zjoi2012] 旅游(journey)
- shell 重定向错误输出到文件 加上时间(标明错误抛出的时间)
- 查表显示LED灯
- 菜鸟浅谈计算机中CPU、内存、硬盘和指令之间的关系
- 北大 C++ 2.1 面向对象程序设计方法
- 一个高性能交互式查询与分析引擎的设计思路
- 老罗的个人网站创建备忘
- 将某个文件从一个目录拷贝到另一个目录下
- 百步者半九十、关于Activity也许还能知道的更多
- Yslow的23条前端性能优化建议Grade(等级视图)