Skip to content

Feature request: expose the underlying request for streaming purposes #484

@carsonip

Description

@carsonip

Which service(blob, file, queue) does this issue concern?

Blob

Which version of the SDK was used? Please provide the output of pip freeze.

azure-storage==0.36.0

What problem was encountered?

Situation: I am running a flask web server as a proxy which returns the corresponding blob that is on Azure Blob Storage. I want to stream the bytes to the client instead of downloading all the bytes to the memory and return the bytes to client at once for performance reasons. As far as I can tell, since the calls in this library are synchronous, there is no way to pipe the bytes from azure to my web clients. Actually the underlying requests library supports streaming. If the request can be exposed, the streaming can be as simple as this (copied from a StackOverflow thread):

import requests
from flask import Flask, Response, stream_with_context

app = Flask(__name__)

my_path_to_server01 = 'http://localhost:5000/'

@app.route("/")
def streamed_proxy():
    r = requests.get(my_path_to_server01, stream=True)
    return Response(r.iter_content(chunk_size=10*1024),
                    content_type=r.headers['Content-Type'])

if __name__ == "__main__":
    app.run(port=1234)

Also, the get_blob_to_stream function is all synchronous, which is not helpful at all.

I am happy if there is any other way to workaround this. Otherwise, exposing the underlying request from requests library is the most direct and preferred way. Thanks!

Have you found a mitigation/solution?

No.

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions