Skip to content

Commit

Permalink
Improve handling of different path variants on Windows
Browse files Browse the repository at this point in the history
If forward slashes were used on Windows the glob was not matching on startup which lead to the issue that data was resent. This is solved in 5.3 by using path.Abs for all paths which also includes Clean. To make sure Path and Glob are always clean, Cleanup was added to the MatchFile part. This makes sure in case old data / incorrect data is loaded, the comparison will still work. More tests were added for windows to verify change.

Before this change, option 1 below did not work.

```
"F:/wwwLogs/flights-wsapi/WebServicesWebApi.log"
"F:\\wwwLogs\\flights-wsapi\\WebServicesWebApi.log"
'F:\wwwLogs\flights-wsapi\WebServicesWebApi.log'
```

Based on https://discuss.elastic.co/t/duplicate-events-with-filebeat-on-windows-on-service-restart/78743/10
  • Loading branch information
ruflin committed Mar 21, 2017
1 parent cd5d8c1 commit ce72b17
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 11 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,7 @@ https://github.com/elastic/beats/compare/v5.1.1...master[Check the HEAD diff]
- Update regular expressions used for matching file names or lines (multiline, include/exclude functionality) to new matchers improving performance of simple string matches. {pull}3469[3469]
- The `symlinks` and `harverster_limit` settings are now GA, instead of experimental. {pull}3525[3525]
- close_timeout is also applied when the output is blocking. {pull}3511[3511]
- Improve handling of different path variants on Windows. {pull}3781[3781]

*Heartbeat*

Expand Down
10 changes: 3 additions & 7 deletions filebeat/prospector/prospector_log.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,6 @@ import (
"fmt"
"os"
"path/filepath"
"runtime"
"strings"
"time"

"github.com/elastic/beats/filebeat/harvester"
Expand Down Expand Up @@ -182,11 +180,9 @@ func (p *ProspectorLog) getFiles() map[string]os.FileInfo {
func (p *ProspectorLog) matchesFile(filePath string) bool {
for _, glob := range p.config.Paths {

if runtime.GOOS == "windows" {
// Windows allows / slashes which makes glob patterns with / work
// But for match we need paths with \ as only file names are compared and no lookup happens
glob = strings.Replace(glob, "/", "\\", -1)
}
// Path and glob are cleaned to ensure we always compare clean paths
glob = filepath.Clean(glob)
filePath = filepath.Clean(filePath)

// Evaluate if glob matches filePath
match, err := filepath.Match(glob, filePath)
Expand Down
32 changes: 28 additions & 4 deletions filebeat/prospector/prospector_log_windows_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,14 +16,38 @@ var matchTestsWindows = []struct {
result bool
}{
{
"C:\\\\hello\\test\\test.log", // Path are always in windows format
[]string{"C:\\\\hello/test/*.log"}, // Globs can also be with forward slashes
`C:\\hello\test\test.log`,
[]string{`C:\\hello/test/*.log`},
nil,
true,
},
{
"C:\\\\hello\\test\\test.log", // Path are always in windows format
[]string{"C:\\\\hello\\test/*.log"}, // Globs can also be mixed
`C:\\hello\test\test.log`,
[]string{`C:\\hello\test/*.log`},
nil,
true,
},
{
`C:\\hello\test\test.log`,
[]string{`C://hello/test/*.log`},
nil,
true,
},
{
`C:\\hello\test\test.log`,
[]string{`C://hello//test//*.log`},
nil,
true,
},
{
`C://hello/test/test.log`,
[]string{`C:\\hello\test\*.log`},
nil,
true,
},
{
`C://hello/test/test.log`,
[]string{`C:/hello/test/*.log`},
nil,
true,
},
Expand Down

0 comments on commit ce72b17

Please sign in to comment.