Search code examples
node.jsibm-cloudobject-storage

Download File from IBM Bluemix Object Storage using NodeJS


I have a problem with downloading files from IBM Bluemix Object Storage using NodeJS script, the problem is that it takes very long time to download file from the storage, 100K file takes around 21 seconds, around 8 seconds waiting for the first chunk and rest for reading all the chunks

I am using the service to store images and using NodeJS script read these images from the storage, and the images are downloaded via the HTML img tag, so what exactly I am doing wrong here ?

The nodeJS code:

app.get("/ostore/image/:filename", function(request, response) {
    response.set('Content-Type', 'image/jpg');
    response.set('cache-control', 'max-age=604800');
    response.set('Last-Modified', 'Sat, 05 Dec 2015 03:17:48 GMT');
    var credentials = app.appEnv.services['Object-Storage'][0].credentials
    var pkgcloud = require("pkgcloud");
    var client = pkgcloud.storage.createClient({
        provider: 'openstack',
        username: credentials.userId,
        password: credentials.password,
        authUrl: credentials.auth_url,
        tenantId: credentials.projectId,
        region: credentials.region,
        version: "2"
    });
    client.download({
        container: app.storageContainer,
        remote: request.params.filename,
        stream: response
    }, function() {
        response.end('done');
    });
});

Solution

  • Try something like this:

    routes.js

    var vcap_os = require(__dirname + '/../utils/vcap')('Object-Storage'),
        os = require(__dirname + '/../modules/object-storage');
    
    module.exports = function(app) {
        var router = app.loopback.Router();
    
        // proxy for object storage service
        router.get('/api/Products/image/:container/:file', function(req, res) {
            os(vcap_os.credentials).download(req.params.container, req.params.file, function(download) {
                download.pipe(res);
            });
        });
    
        app.use(router);
    }
    

    modules/object-storage.js

    var pkgcloud = require('pkgcloud');
    
    module.exports = function(creds) {
        var config = {
            provider: 'openstack',
            useServiceCatalog: true,
            useInternal: false,
            keystoneAuthVersion: 'v3',
            authUrl: creds.auth_url,
            tenantId: creds.projectId,
            domainId: creds.domainId,
            username: creds.username,
            password: creds.password,
            region: creds.region
        };
    
        return {
            download: function(container, file, cbk) {
                var client = pkgcloud.storage.createClient(config);
                client.auth(function (error) {
                    if(error) {
                        console.error("Authorization error for storage client (pkgcloud): ", error);
                    }
                    else {
                        var request = client.download({
                            container: container,
                            remote: file
                        });
    
                        cbk(request);
                    }
                });
            }
        };
    };