如何读取实时log

需求:系统后台有个程序会生成log写入到一个文件中,始终在原文件上写造成覆盖,该文件里面记录的都是错误代码,非明文的错误信息,现在想写一个小工具,达到实时转储那个log文件里面的内容到另外一个文件里进行保存,另外最好能增加一个类似字典的功能,将错误代码转换成明文。

请问使用shell、python、java哪种技术可以比较方便(不依赖环境或者库)的实现上述需求。

阅读 4.5k
3 个回答

如果log是在shell里运行生成的,覆盖写入通常是因为使用了‘>’,这时可以改为‘>>’从而实现追加写入。楼上的办法都可行,tail -f 会实时打印文件内容,如果文件被覆盖写入,它会有明显的提示改文件被truncate,然后继续打印新内容。一句话,能简单的就不用复杂化,可以使用系统定时任务

*/1  *  *  *  * test.sh 

#test.sh 
tail -f ***.log >> my.log

你的log4j的配置文件就可以设置日子的累加而不覆盖啊!实时获取tail -f log/XXX.log就行

新手上路,请多包涵

tail -f xxx.log
然后你用subprocess模块的相关函数调用,用读写管道,就可以实时的获取了。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题