在开发中,我们避免不了写crontab脚本来异步执行一些东西,一般设置crontab用下面的方法:

*/1 * * * * commond > /tmp/t.log 2>&1

前面的> /tmp/t.log代表把标准输出重定向到/tmp/t.log文件,后面的 2>&1 代表把标准错误输出指向标准输出,意思是当commond异常退出时,把异常退出时的日志也写到 /tmp/t.log 下面,这时记录的日志是没有时间信息的,就是说日志里的数据没有办法知道是什么时候打印出来的。

下面通过一个shell来解决这件事,代码如下:

#!/bin/sh

if [ $# -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 >>$1

fi

把上面的代码保存为 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是实现“将标准输入作为命令的参数”

linux重定向输出时加时间变量,shell 重定向错误输出到文件 加上时间(标明错误抛出的时间)...相关推荐

  1. Linux管道指令(pipe)与shell 重定向的区别

    2019独角兽企业重金招聘Python工程师标准>>> 多指令执行 符号 格式 作用 ; comd1;comd2  依次执行 && comd1 && ...

  2. Linux kernel编译时编译选项多选一如何固化在config文件

    每次在进行裁剪的Linux kernel编译时,都会碰到有提示,让你在某些编译选项多选一,如: Initialize kernel stack variables at function entry ...

  3. linux安装软件时/usr/lib/python2.7/site-packages/urlgrabber/grabber.py文件异常

    linux安装软件时,经常出现以下异常信息 Traceback (most recent call last):File "/usr/libexec/urlgrabber-ext-down& ...

  4. python诞生的时间地点人物事件_教程|计算任意视频中各人物的出镜时间(附Python实现)...

    ,内容略有删改 前言 简介 当我开始接触深度学习时,学到的第一件事就是图像分类.这个话题非常有趣,包括我在内的很多人都沉浸在它的魅力之中.但是在我处理图像分类时总会思考,如果我能将学到的东西迁移到视频 ...

  5. linux切换用户无法加载变量,Linux 中用户切换:su 和 su- 的使用 环境变量详解

    大部分Linux发行版的默认帐户是普通用户,而更改系统文件或者执行某些命令,须要root身份才能进行,这就须要从当前用户切换到root用户,Linux中切换用户的命令是su或su -,下面就su命令和 ...

  6. C++中cout后面输出时加endl和不加endl的区别

    endl就是end line的意思,也就是"结束此行",实际上有两个操作 1 换行 2 对缓冲流进行冲刷,使得流中所有剩余字符被写入输出序列. 其实作用说白了就是加<< ...

  7. linux脚本使用scp自动传输,使用Shell脚本自动传输SCP文件

    我的unix系统上的目录中有n个文件. 有没有一种方法可以编写Shellscript,该脚本将通过scp将所有这些文件传输到指定的远程系统. 我将在脚本中指定密码,这样就不必为每个文件输入密码. 您能 ...

  8. java中输出时 什么作用_JAVA中输入和输出处理(Java I/O)重点总结

    文件-使用File类操作文件: 什么是文件?  文件可认为是相关记录或放在一起的数据的集合. 文件一般存储在哪里?  储存在存储设备里. Java程序如何访问文件?  Java API:java.io ...

  9. python输出时怎么保留两位小数_python输出怎么保留两位小数-Python教程

    python输入保存两位小数的四种办法: a = 5.5461 办法一:round(a,2) 办法二:float('%.2f' % a) 相干保举:<Python视频教程> 办法三:'%. ...

最新文章

  1. Spring Cloud 使用 FeignClient 启动报错
  2. SAP信用控制配置事物码
  3. python matplotlib.pyplot中add_subplot subplot函数的用法与区别(其实没什么区别)
  4. boost::foreach模块一些杂项的测试程序
  5. PyOpenCV 基本操作
  6. 树莓派apt-get update速度慢的解决方法
  7. PAT-A1020:Tree Traversal(二叉树的重建及其中序、后序遍历)
  8. 摩拜单车开锁实现原理剖析
  9. WebMagic抓取阿里司法拍卖信息
  10. 正交实验法,软件测试用例的特性,编写方法,软件缺陷的基础知识
  11. 闲人闲谈ERP项目逸事——德国做SAP项目回忆
  12. sjtu1313 太湖旅行
  13. 贝壳找房的2021,依然充满变数
  14. 微信小程序:block制作动态商品列表
  15. 简易处理字典MDX文件的方法
  16. 关于Debian10的网络配置
  17. html怎么做密码的判断,用户密码格式判断 .html
  18. 大数据技术课堂小笔记
  19. 关于mstar TV芯片苹果设备Airplay投屏播放画面竖屏窗体旋转、窗体显示不正常的解决方案
  20. oem718d 基准站设置_「北斗终端设备」诺瓦泰NovAtel OEM718D全系统多频单机测向板卡-北京创宇星通-马可波罗网...

热门文章

  1. 自定义构建基于.net core 的基础镜像
  2. 【C】KoobooJson在asp.net core中的使用
  3. 深入源码理解.NET Core中Startup的注册及运行
  4. 如何优雅的利用Windows服务来部署ASP.NET Core程序
  5. 张高兴的 .NET Core IoT 入门指南:(二)GPIO 的使用
  6. .NET Core实战项目之CMS 第十四章 开发篇-防止跨站请求伪造(XSRF/CSRF)攻击处理...
  7. .NET Core 1.1 Preview 1上线:支持macOS 10.12/Linux Mint 18
  8. mysql8.0.12插件_MySQL8.0.12 安装及配置
  9. 将excel多个工作表(表结构相同)合并后生成csv文件
  10. [转]ES7、ES8、ES9、ES10新特性大盘点