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

Research usage of big Payloads #110

Open
whyoleg opened this issue Oct 18, 2020 · 6 comments
Open

Research usage of big Payloads #110

whyoleg opened this issue Oct 18, 2020 · 6 comments

Comments

@whyoleg
Copy link
Member

whyoleg commented Oct 18, 2020

On current moment Payload contains 2 properties data and metadata which can store bytes. The problem is, that those properties store ByteReadPacket which works like in-memory buffer. So f.e. to send big file through in one Payload(+fragmentation), it will be needed to firstly read everything from file to ByteReadPacket, so in memory.

Need to research, if and how it's possible to send such big payloads without reading everything to memory

@yschimke
Copy link
Member

My mental model has been around an individual payload being available via a stream API, like Channel, InputStream/OutputStream or similar.

@whyoleg
Copy link
Member Author

whyoleg commented Oct 18, 2020

For inspiration: ktor-io byte channels
Also it has integration with File IO and JVM IO-streams.

@yschimke
Copy link
Member

I'd be interested in hooking it into the CLI once it's barely working. Can testing with streaming STDIN/STDOUT pipes etc.

@ghost
Copy link

ghost commented Jul 21, 2021

better to postpone this task until ktor/ktor-io will have 2.0.0 version, which will change some Input API.

@ghost
Copy link

ghost commented Aug 7, 2021

POC api change: https://github.com/olme04/rsocket-kotlin/commit/5946241c3997cf3f711152d37ddd2b05719d19e3#diff-b20323f12dc29bebdc7845234a305c8f22b468cb7c98964cb14ad808696ec65f
Main breaking change is that when using Input instead of BRP we will loose possibility to copy payload (or data/metadata).
This will affect user code.

@whyoleg whyoleg added this to the 1.0.0 milestone Nov 24, 2022
@whyoleg
Copy link
Member Author

whyoleg commented Jun 14, 2023

Someday I think we will need to migrate to Kotlin/kotlinx-io#131, though, it depends on how well it will interop with ktor and so ktor-io, as this is the main transport now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants