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

Different Exporter::shutdown() interface across signals #2262

Open
lalitb opened this issue Oct 29, 2024 · 7 comments · May be fixed by #2381
Open

Different Exporter::shutdown() interface across signals #2262

lalitb opened this issue Oct 29, 2024 · 7 comments · May be fixed by #2381
Labels
help wanted Good for taking. Extra help will be provided by maintainers/approvers
Milestone

Comments

@lalitb
Copy link
Member

lalitb commented Oct 29, 2024

Metrics:

fn shutdown(&self) -> MetricResult<()>;

Trace:

Logs:

Logs and Trace are similar, Metrics return the status. Specs doesn't mandates returning status.

This should not be a big deal, just opening the issue to track.

@lalitb lalitb added the help wanted Good for taking. Extra help will be provided by maintainers/approvers label Nov 12, 2024
@scottgerring
Copy link
Contributor

scottgerring commented Nov 29, 2024

Hey @lalitb , happy to clean this one up, but first some questions:

  • Do we want to return the status, or not?
  • This looks like a breaking change either way. How do we handle that?

Feel free to assign it to me 💪

@scottgerring
Copy link
Contributor

Following chat on CNCF slack, I'll pick this one up!

@lalitb
Copy link
Member Author

lalitb commented Dec 3, 2024

@scottgerring

Do we want to return the status, or not?

I vote for returning the status, so tracing and logs to be consistent with metrics. Also, good to see what specs says and other language implementation does.

This looks like a breaking change either way. How do we handle that?

We are still good with doing breaking changes with SDK. If it can be deprecated first while introducing new API that will be ideal.

@scottgerring
Copy link
Contributor

@lalitb , thanks for the input 💪

I vote for returning the status, so tracing and logs to be consistent with metrics.

I agree; there's a couple situations where actual errors pop up in each of these cases that are being swallowed in the trace and logs impls. This is mainly to do with the acquisition of locks:

    /// If another user of this mutex panicked while holding the mutex, then
    /// this call will return an error once the mutex is acquired.

In the metrics case, we have e.g. this, where we are propagating the error:

fn shutdown(&self) -> MetricResult<()> {
let _ = self.client.lock()?.take();
Ok(())
}

One trace variant has the potential to hit a similar error, but this is swallowed:

fn shutdown(&mut self) {
let _ = self.client.lock().map(|mut c| c.take());
}

... and the same for logs:

fn shutdown(&mut self) {
let _ = self.client.lock().map(|mut c| c.take());
}

These are admittedly unlikely errors, but if they do come up something must be fairly wrong, and at least logging these would be helpful!

@scottgerring
Copy link
Contributor

We are still good with doing breaking changes with SDK. If it can be deprecated first while introducing new API that will be ideal.

We could do this, but it would have to be a whole new method, and it'd be quite a sprawl through the code base, as we'd have to handle the variants down through the tree of clients too. You can get a feel for the scope of this on the PR I linked above.

As it's "only" a lint for users - "You should do something with this return value" - my gut feeling is that it'd be better to include a note about this in release notes, and pull the bandaid off. What do you think @lalitb ?

@cijothomas
Copy link
Member

cijothomas commented Dec 4, 2024

If it can be deprecated first while introducing new API that will be ideal.

It'll be hard to do that, as there is only one release (0.28) planned before stable, and we should not have breaking changes after 0.28... I am okay with breaking change for 0.28.

@cijothomas cijothomas added this to the 0.28.0 milestone Jan 24, 2025
@cijothomas
Copy link
Member

Moving this to 0.28. This looks like part of a bigger cleanup/refactor @scottgerring 's PR is tackling some of them, but given the amount of breaking change, its best to delay 0.28 to include this.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
help wanted Good for taking. Extra help will be provided by maintainers/approvers
Projects
None yet
3 participants