Skip to content
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

Unsupported data type when parsing optional UUID field in JSON logs #1045

Open
sfriedowitz opened this issue Dec 19, 2024 · 5 comments
Open
Assignees

Comments

@sfriedowitz
Copy link

sfriedowitz commented Dec 19, 2024

/about output:

{
  "version": "1.6.3",
  ...
}

Description:

We have a field uuid that shows up in our JSON logs, but may not be present for every log event. When it is not present, the logger will output a null in place of the UUID string. We get this error in our log events which are ingested by FluentBit:

2024-12-19T21:14:42.637482Z ERROR parseable::event::format::json: Unsupported datatype Null, value String("4327e7f0-be4e-11ef-864f-db81a31ad329")                                          │
│ thread 'actix-rt|system:0|arbiter:2' panicked at src/event/format/json.rs:228:13:                                                                                                          │
│ internal error: entered unreachable code

Clearly this is an issue with the inferred schema not being able to handle the optional string values for this field. Should we be doing something different, or is this a bug?

@sfriedowitz sfriedowitz changed the title Unreachable data type when parsing optional UUID field in JSON logs Unsupported data type when parsing optional UUID field in JSON logs Dec 19, 2024
@nitisht
Copy link
Member

nitisht commented Dec 20, 2024

We might have to look at how dynamic schema behaves - but in this case if you know the schema you're going to ingest, it might be better to use static streams: https://www.parseable.com/docs/server/concepts/ingestion#static

@nitisht nitisht self-assigned this Dec 20, 2024
@sfriedowitz
Copy link
Author

is there a way to specify an optional field that can be Null or string? From the docs, it looks like theres no notion of an "option" type for a static schema

@sfriedowitz
Copy link
Author

I've also tried changing our log formatter so that null fields are removed from the log record, and am getting new errors in the ingestion pod after purging our old log records from S3

│ thread 'main' panicked at src/utils/arrow/batch_adapter.rs:47:47:                                                                                                                          │
│ called `Result::unwrap()` on an `Err` value: InvalidArgumentError("column types must match schema types, expected Utf8 but found Null at column index 3")                                  │
│ note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace                                                                                                              │
│ 2024-12-20T18:15:06.000019Z ERROR parseable::handlers::http::modal::server: Error joining remote_sync_handler: JoinError::Panic(Id(58), ...)

@nikhilsinhaparseable
Copy link
Contributor

@sfriedowitz Thanks a lot for reporting the issue!
It should get resolved in the latest release 1.7.0
can you please confirm the same and let us know, we can close the issue after your confirmation.

@sfriedowitz
Copy link
Author

@sfriedowitz Thanks a lot for reporting the issue! It should get resolved in the latest release 1.7.0 can you please confirm the same and let us know, we can close the issue after your confirmation.

I will upgrade our version today and try it out! Will report back, thanks.

@nitisht nitisht removed the bug label Jan 26, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants