-
-
Notifications
You must be signed in to change notification settings - Fork 414
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
[💡FEATURE REQUEST]: Streaming request [WIP] & responses [HTTP-DONE] #923
Comments
It can be done by locking done and working with one worker within the request. This is definitely something we are going to consider adding going forward. |
I have put a foundation for streaming responses into a newer version. Streaming requests will be looked at once this feature it complete. See #9 |
This will be coming in a separate server due async mode of underlying workers. |
I would love to see streaming support as well, but for large HTTP responses. I noticed this issue was reopened a few days ago, so does that mean that some progress will be made here? If I had time to learn Go I'd offer to help, but as it is, I can only offer my encouragement - this would be a really cool feature to have. |
Yes, this issue will be reconsidered for 1.5.0. No timeline yet but there are some initial experiments already made. |
Not in 1.5.0. We are working on a protocol update (with few extra features and perf improvements), so most likely it will be 2.0.0. |
Ha, this is quite a roadblock: I was trying to migrate an existing system to RR this weekend, and one of the payloads that we stream is a GIGANTIC XML Sitemap that needs to be produced chunk-by-chunk (especially important to avoid running into memory limits). I'm unsure about whether this is to be done in the GO components, or in the PHP-side of things (PSR-7 stream response missing there too, perhaps?). I haven't done a detailed analysis, but this is indeed the biggest limitation I faced so far with the tool, whereas everything else is, I must say, quite impressive :-) |
With RR2 refactor we might be able to take a look at this issue with a fresh approach. We will discuss this internally to see if it is possible. |
Discussion: Local pipelining with jobs + broadcast plugin |
Essentially we have an idea of how to solve this issue with:
|
@rustatian we should consider doing the same for GRPC (streaming). |
A little update about streaming file responses. The |
@rustatian streaming files usually not the problem though: streaming batches (think "massive CSV generated from DB") is still the issue though |
Yep, sure. That's was just a little update about streaming in general. Not about the ticket's topic. |
Hi, are there any updates on how this is going? Do we have an ETA on when this might be released? Thanks |
Hey @Matt-Woz 👋🏻 |
Would it be possible to add also the HTTP request streaming after the move of internal communication from JSON to protobuf? It would make big file uploads extremely simple to do, instead of the current approach of sending small chunks. (Is there currently a better way?) |
@FluffyDiscord Sure 😃 If someone willing to help me (with the PHP part) with that, I'm all ears 👂 Since I'm not a PHP dev at all. |
I think RR could create and pass to PHP a port (assuming locally running RR and PHP app) or TCP endpoint alongside the normal request. We could then read from the opened socket. Basically RR would be just a passthrough. Then whenever PHP returns a response the stream would close. I am completely new in communication using a sockets, but I think this is the only way. Saving the request as temp file (not talking about sockets) would be probably an option too, but I would like to not use file buffering. This might be more of a question to the Spiral team, which are experienced with this kind of stuff I imagine. |
I don't think that's even necessary. I'm not sure how protobuf comms work, but since the worker comms are running in a goroutine in RR, blocking on sending the request shouldn't pose a problem, so in PHP we simply would need to signal that the request is ongoing. Thinking about it, RR could enable it by sending a request in 2-3 frames (signal for stream + request line, headers, body), with the second/third frame only after it was requested by the PHP side. In return the PHP side would not need much change. Nyholm's PSR7 request object already supports a lazily loaded body, so there should be minimal change necessary (most likely the framework integrations would need to add support for wrapping the RPC request for the request body in some manner for the framework). I'm not sure what work would need to be done in Go though, since I don't exactly know if it's waiting for the full request right now or already streams it internally. But if you need some support for this @rustatian hit me up (after the async + circuitbreaker stuff 😆 ) :) |
Just pinging to see if there's been any progress made on gRPC streaming? Particularly I'm interested in server-side streaming, what needs to be done to push it across the finish line? |
Hey @Matt-Woz 👋
I don't know PHP and we don't have a persistent team to work on a PHP part of the RR. So, if somebody is (seriously) ready to work on this stuff with me (on the PHP part), I would be happy to help to start implementing this. But, good news everyone: try https://temporal.io + https://docs.temporal.io/develop/php/. It might cover all your needs of the server-side communication. (this is RR as well) |
This project looks like it could be very useful in building a GRPC server bridge for PHP, which would be amazing.
GRPC has the concept of streaming request & responses, is that something you'd consider adding to roadrunner/goridge?
Thanks
This ticket (since most of the users know it) split into the four parts:
v2023.3
]The text was updated successfully, but these errors were encountered: