- Fixed problem in Windows where some paths would fail to return an identifier ("inode"). Make path into a C style String before encoding to UTF-16LE. #232
- Fixed issue where logs were being spammed with needless error messages #224
- Fixed problem in tail and read modes where the read loop could get stuck if an IO error occurs in the loop. The file appears to be being read but it is not, suspected with file truncation schemes. Issue #205
- Fixed problem in rotation handling where the target file being rotated was subjected to the start_position setting when it must always start from the beginning. Issue #214
- Fixed Errno::ENOENT exception in Discoverer. Issue #204
- Fixed text anchor by changing it from hardcoded to asciidoc reference to work in versioned plugin reference
- Fixed a regression where files discovered after first discovery were not always read from the beginning. Applies to tail mode only. #198
- Added much better support for file rotation schemes of copy/truncate and rename cascading. Applies to tail mode only.
- Added support for processing files over remote mounts e.g. NFS. Before, it was possible to read into memory allocated but not filled with data resulting in ASCII NUL (0) bytes in the message field. Now, files are read up to the size as given by the remote filesystem client. Applies to tail and read modes.
- Fixed
read
mode of regular files sincedb write is requested in each read loop iteration rather than waiting for the end-of-file to be reached. Note: for gz files, the sincedb entry can only be updated at the end of the file as it is not possible to seek into a compressed file and begin reading from that position. #196 - Added support for String Durations in some settings e.g.
stat_interval => "750 ms"
#194
- Fix
require winhelper
error in WINDOWS. Issue #184 - Fix when no delimiter is found in a chunk, the chunk is reread - no forward progress is made in the file. Issue #185
- Fix JAR_VERSION read problem, prevented Logstash from starting. Issue #180
- Fix sincedb write error when using /dev/null, repeatedly causes a plugin restart. Issue #182
- Move Filewatch code into the plugin folder, rework Filewatch code to use Logstash facilities like logging and environment.
- New feature:
mode
setting. Introduces two modes,tail
mode is the existing behaviour for tailing,read
mode is new behaviour that is optimized for the read complete content scenario. Please read the docs to fully appreciate the benefits ofread
mode. - New feature: File completion actions. Settings
file_completed_action
andfile_completed_log_path
control what actions to do after a file is completely read. Applicable:read
mode only. - New feature: in
read
mode, compressed files can be processed, GZIP only. - New feature: Files are sorted after being discovered. Settings
file_sort_by
andfile_sort_direction
control the sort order. Applicable: any mode. - New feature: Banded or striped file processing. Settings:
file_chunk_size
andfile_chunk_count
control banded or striped processing. Applicable: any mode. - New feature:
sincedb_clean_after
setting. Introduces expiry of sincedb records. The default is 14 days. If, aftersincedb_clean_after
days, no activity has been detected on a file (inode) the record expires and is not written to disk. The persisted record now includes the "last activity seen" timestamp. Applicable: any mode. - Docs: extensive additions to introduce the new features.
- Docs: Set the default_codec doc attribute.
- Update gemspec summary
- Fix some documentation issues
- Docs: Fix the description with the logstash documentation generator
- Fix an issue with the rspec suite not finding log4j
- Breaking:
ignore_older
settings is disabled by default. Previously if the file was older than 24 hours (the default for ignore_older), it would be ignored. This confused new users a lot, specially when they were reading new files with Logstash (withstart_position => beginning
). This setting also makes it consistent with Filebeat.
- Adjust a few log call levels
- Add host to @metadata
- Breaking: Use native
--path.data
for Logstash 5.0 for sincedb files.
- Relax constraint on logstash-core-plugin-api to >= 1.60 <= 2.99
- relax constrains of
logstash-devutils
see elastic/logstash-devutils#48
- Republish all the gems under jruby.
- Update the plugin to the version 2.0 of the plugin api, this change is required for Logstash 5.0 compatibility. See elastic/logstash#5141
- Depend on logstash-core-plugin-api instead of logstash-core, removing the need to mass update plugins on major releases of logstash
- New dependency requirements for logstash-core for the 5.0 release
- Fix for: Filewatch library complains if HOME or SINCEDB_PATH variables are unset.
- Issue #101
- PR, filewatch 78 introduces the fix
- Issue, filewatch 76
- Improve documentation on ignore_older and close_older options #104 Documentation
- Fix spec failures on CI Linux builds (not seen on local OSX and Linux)
- Use ruby-filewatch 0.8.0, major rework of filewatch. See Pull Request 74
- add max_open_files config option, defaults to 4095, the input will process much more than this but have this number of files open at any time - files are closed based on the close_older setting, thereby making others openable.
- Changes the close_older logic to measure the time since the file was last read internlly rather than using the file stat modified time.
- Use logstash-codec-multiline 2.0.7, fixes a bug with auto_flush deadlocking when multiple file inputs are defined in the LS config.
- Use ruby-filewatch 0.7.1, re-enable close after file is modified again
- Isolate test helper class in their own namespace
- Correct LS core dependency version
- Implement new config options: ignore_older and close_older. When close_older is set, any buffered data will be flushed.
- Fixes #81
- Fixes #81
- Fixes #81
- Implement Stream Identity mapping of codecs: distinct codecs will collect input per stream identity (filename)
- Change LS core dependency version
- Add CI badge
- Change LS core dependency version
- Plugins were updated to follow the new shutdown semantic, this mainly allows Logstash to instruct input plugins to terminate gracefully, instead of using Thread.raise on the plugins' threads. Ref: elastic/logstash#3895
- Dependency on logstash-core update to 2.0
- Force dependency on filewatch >= 0.6.5 that fixes a sincedb bug
- Better documentation and error handling regarding the "sincedb_path" parameter