访问web应用使用在Marathon UI显示的信息,我可以访问URL为http://coreos1.rest:31000的Web应用程序。 当应用程序运行时页面左上角会显示容器名称,用于上载和下载的图片的Amazon S3终端(endpoint)会显示在左下角,并表明ViPR用于存储数据。 我们现在可以上传图片了。 下面是由Web应用程序发送到浏览器的代码,以让浏览器直接上传图片到对象存储平台。 var files = $("#file")[0].files; var reader = new FileReader(); reader.onload = function(event){ var content = event.target.result; try { $.ajax({ url: 'http://bucket1.denisnamespace.ns.viprds.rest:80/pictures/B6C3OuVCIAEfwjm.jpg', data: content, cache: false, processData: false, type: 'PUT', beforeSend: function (request) { request.setRequestHeader('Content-Length','35964'); request.setRequestHeader('Content-Type','binary/octet-stream'); request.setRequestHeader('x-amz-date','Sun, 11 Jan 2015 12:53:12 UTC'); request.setRequestHeader('host','bucket1.denisnamespace.ns.viprds.rest'); request.setRequestHeader('Authorization','AWS denis@rest:iCnahEUOy8/lanI96tQYA3WKQVE='); }, success: function(data, textStatus, request){ $('#alert-success').html("Picture uploaded").show().delay(5000).fadeOut(); }, error: function(data, textStatus, request){ $('#alert-danger').html("Upload failed").show().delay(5000).fadeOut(); } }); } catch (e) { alert(e); } } reader.readAsArrayBuffer(files[0]); 图片直接上传到对象存储平台的事实意味着该Web应用程序中并没有数据路径。也就是说无需部署数百个实例应用程序就可以扩展。 这个Web应用程序,也可用于显示所有存储在相应的Amazon S3的图片。 图片下方显示的URL表明图片可以直接从对象存储平台下载,而这又意味着Web应用程序不是从数据路径直接下载。 对象存储是事实上的标准网络规模应用。
原文:http://www./post/how-to-create-a-web-scale-infrastructure-based-on-docker-coreos-vulcand-and-mesos-and-why-object-storage-becomes-the-de-facto-data-repository/
|
|