現象:
打算利用Perl的模塊File::Tail::Multi實現對多個文件的實時處理,可惜程序可以啟動,但就是不處理文件內容,急煞我也
用法:
- use File::Tail::Multi;
- my @_LIST_OF_FILE_PATHS = ("/path/to/one/file", "/path/to/another/file");
- my $rptTail = File::Tail::Multi->new(
- Function => \&_read_line,
- LastRun_File => "/path/to/app.lastrun",
- Files => @_LIST_OF_FILE_PATHS
- );
- sub _read_line {
- my $lines_ref = shift;
- foreach ( @{$lines_ref} ) {
- chomp;
- next if $_ =~ //;
- #go play, here's the line
- }
- }
要點:
Perl模塊File::Tail::Multi中的屬性LastRun_File指示的是一個文件,此文件記錄被tail的文件最後一次的讀取狀態,上面指的就是“/path/to/app.lastrun”,如果此文件不存在,則Tail操作就不能完成,即使進程啟動正常
解決方法:
因為LastRun_File所指示的文件不會自動生成,故需手動創建:
- touch /path/to/app.lastrun
再啟動程序,文件開始被Tail處理,搞定!