-
-
Notifications
You must be signed in to change notification settings - Fork 192
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
Maybe Logger metadata should affect grouping #837
Comments
Mmmm what do we do for errors, do you know? I haven't looked and won't have time til the end of the day. |
@whatyouhide this is what we do: # Used to compare events for deduplication. See "Sentry.Dedupe".
@doc false
@spec hash(t()) :: non_neg_integer()
def hash(%__MODULE__{} = event) do
:erlang.phash2([
event.exception,
event.message,
event.level,
event.fingerprint
])
end Adding metadata to this sounds like a good idea to me. |
I’m not sure because metadata might contain fleeting data that gets updated on every call (imagine a timestamp) but that shouldn't affect deduplication. What do other SDKs do? |
I'm not sure - @sl0thentr0py do you happen to know? |
@solnic you could probably grep through source code of at least the Python and Ruby SDKs because I remember finding this in there pretty easily. |
@whatyouhide I did look for it in ruby and couldn't find it 😅 I'll give it another shot hah |
Maybe:
|
You can either
either way is fine with me. In general, we have comprehensive server side grouping, so these SDK side dedupes are mainly for not sending the exact same payload twice. |
Since that's the case, I think it makes more sense to include the meta in the deduplication then, or do the deduplication at a later stage (so that logger messages just become |
I'd be happy to open a PR with this approach if this issue is not taken yet! :)
Isn't that what's already happening? As per #837 (comment) def hash(%__MODULE__{} = event) do
# for a log event it's something like
:erlang.phash2([
_exception = nil,
_message = "error from logs",
_level = "error",
_fingerprint = nil
])
end |
Even for events the deduplication might be buggy here, because |
Right now logged errors seem to be grouped by message only.
Would it make sense to consider a hash of
:sentry
metadata as well?The text was updated successfully, but these errors were encountered: