需求:系统后台有个程序会生成log写入到一个文件中,始终在原文件上写造成覆盖,该文件里面记录的都是错误代码,非明文的错误信息,现在想写一个小工具,达到实时转储那个log文件里面的内容到另外一个文件里进行保存,另外最好能增加一个类似字典的功能,将错误代码转换成明文。
请问使用shell、python、java哪种技术可以比较方便(不依赖环境或者库)的实现上述需求。
tail -f xxx.log
然后你用subprocess模块的相关函数调用,用读写管道,就可以实时的获取了。
你的log4j的配置文件就可以设置日子的累加而不覆盖啊!实时获取tail -f log/XXX.log就行
如果log是在shell里运行生成的,覆盖写入通常是因为使用了‘>’,这时可以改为‘>>’从而实现追加写入。楼上的办法都可行,tail -f 会实时打印文件内容,如果文件被覆盖写入,它会有明显的提示改文件被truncate,然后继续打印新内容。一句话,能简单的就不用复杂化,可以使用系统定时任务
*/1 * * * * test.sh #test.sh tail -f ***.log >> my.log