-
Notifications
You must be signed in to change notification settings - Fork 2.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
windows paths not supported by filelog receiver (include and exclude parameters) #33657
Comments
Pinging code owners:
See Adding Labels via Comments if you do not have permissions to add labels yourself. |
I'm not sure there's anything to be done here. As you noted, using |
Agreed with @djaglowski. If it would be helpful we could add some documentation to this receiver to make this functionality more obvious, or a Windows-specific config example to show the required |
This issue has been inactive for 60 days. It will be closed in 60 days if there is no activity. To ping code owners by adding a component label, see Adding Labels via Comments, or if you are unsure of which component this issue relates to, please ping Pinging code owners:
See Adding Labels via Comments if you do not have permissions to add labels yourself. |
We should document this is a general observation for Windows when specifying paths directly on the YAML file. |
Actually, after re-reading this @akumetsu183 has a point: The backslash, as already pointed above needs to be escaped as explained above. |
We're using But then, we're using |
This issue has been inactive for 60 days. It will be closed in 60 days if there is no activity. To ping code owners by adding a component label, see Adding Labels via Comments, or if you are unsure of which component this issue relates to, please ping Pinging code owners:
See Adding Labels via Comments if you do not have permissions to add labels yourself. |
This issue has been closed as inactive because it has been stale for 120 days with no activity. |
Component(s)
receiver/filelog
What happened?
Description
Support of Windows paths (on Windows OS) is problematic for
include
andexclude
.Inside include, windows
\
are not working, and inside exclude, neither one works (\ or /), but it can be worked around.INCLUDE Examples:
["C:\*.log"]
WINDOWS STYLE (NOT WORKING), receiver will log errors["C:/*.log"]
LINUX STYLE, (WORKS)Based on this, one might think that only
/
is supported by this receiver, on both Linux and Windows.However that is not true. When configuring exclude, even linux style
/
is does not work there (on WINDOWS OS).Only when using Windows style, escaped
\
, will exclude work.EXCLUDE Examples:
["C:\*exclude.log"]
WINDOWS STYLE, (NOT WORKING), receiver will log errors["C:/*exclude.log"]
LINUX STYLE, (NOT WORKING), receiver starts, but exclude is not respected["C:\\*exclude.log"]
WORKING WORKAROUNDFrom my brief investigation, the exclude issue seems to be happenning here, when comparing found vs excluded paths on windows.
It uses function doublestar.FilepathGlob to find all files, but that returns paths with slashes based on OS, which I suspect returns path with double windows slashes, and that is why the workaround with extra slash works.
Steps to Reproduce
Test the following, on a windows machine. (include and exclude both windows style
\
)Include and exclude are both broken in this case. (you can try the same with linux style in both parameters
/
, but then only the exclude will not work, unless you use the workaround mentioned above, with the doule escape)Expected Result
Include and exclude parameters both support the same set of
/
or\
or both.I would expect one of 2 things:
/
only, for include and exclude. If so, the above should NOT work, but the fact that paths should be only linux style should be mentioned in readme, next to the parameters. Also, both include and exclude should work with linux style/
, but it does not.\
is supported (on windows OS) for both include and exclude the same way, and these paths work for both. Also, readme could mention that paths need to be based on OS.Cherry on top, receiver could detect OS and validate that it gets paths in expected format, and log if there are some detected issues (linux path used windows OS or vice versa). Or something like that.
Actual Result
In the above scenario with windows
\
for both include and exclude, receiver logs errors. See below.No logs are monitored.
"""
2024-06-18T15:22:02.365Z ERROR Processing configuration record has failed {"error": "cannot unmarshal the feature configuration: yaml: line 4: did not find expected hexdecimal number", "feature-name": "filelog"}
2024-06-18T15:22:02.365Z INFO Got new configuration revision for OTEL collector {"new-config-revision": 1, "current-config-revision": 0}
2024-06-18T15:22:02.365Z INFO Running OTEL service {"config-revision": 1}
2024-06-18T15:22:02.365Z ERROR Failed to run OTEL service {"error": "failed to get config: cannot unmarshal the feature configuration: yaml: line 4: did not find expected hexdecimal number", "config-revision": 1}
"""
Because
import
on windows OS works only when path contains linux style/
, and export only works with paths that have escaped windows style\\
.Collector version
v0.99.0
Environment information
Environment
OS: Windows Server 2022
OpenTelemetry Collector configuration
Log output
Additional context
Just to make it clear. This is what you have to currently specify for include and exclude to make it all work on windows os in v99.
Using linux style for include, and workaround for exclude.
The text was updated successfully, but these errors were encountered: