refactor: meta-service: re-implement export with Stream #13097
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
I hereby agree to the terms of the CLA available at: https://databend.rs/dev/policies/cla/
Summary
refactor: meta-service: re-implement export with Stream
Updated the
export()
function ingrpc_service.rs
to use cratefutures-async-stream
, changed return type of the function to use aBoxStream
that yields a series of JSON strings, instead of returninga big
Vec<String>
.This allows for more efficient handling of asynchronous streams, which
can provide performance improvements.
Note that
export(self: Arc<Sefl>)
takes anArc<Self>
as argumentbecause the generated
gRPC
stream signature requires a'static
lifetime. As a result, the
export(&self)
can not be used:Add dependency crate
futures-async-stream
;Enable unstable feature
#![feature(generators)]
for building aStream
from a generator(yield ...
);Changelog
Related Issues
This change is