|
12.2 云存储的产品形态8 \# ^$ A0 v" e& K7 F- J8 C/ W
早在2006年3月,Amazon就推出了针对企业的S3简单存储服务(Amazon Simple
8 \9 U0 N0 r# R" W. _4 [2 d$ Z. GStorage Service),它是Amazon云计算平台(Amazon Web Service,AWS)的一种对象
* j# p6 |7 r; W$ |; o( c+ B存储服务,用于存储照片、图片、视频、音乐等个人文件。S3被认为是目前最为成
+ a' ^7 s6 z# A' @0 \4 }功的云存储系统,它定义的云存储应用编程对外接口(API)被Google Cloud
: g! |$ E( l. s- c1 ?% ~/ d3 {Storage、阿里云开放存储服务(Open Storage Service,OSS)、盛大云存储等国内外云# R+ z2 _/ F) |! N1 S4 @
存储系统所效仿,成为业界对象云存储系统的事实标准。Amazon S3以桶(bucket)- ~% _+ K d+ F! N
或者目录为单位管理对象,每个桶包含若干个对象(Object),每个对象可以是照; T- J8 m1 p4 X, h ^( C
片、图片、视频、音乐等个人文件,支持REST、SOAP以及BitTorrent下载协议。
- o$ t( L; ?& L: @# sAmazon S3的应用编程接口如下:
f! ~- H& c9 Z8 {+ M" b# `/ \●List Bucket:列出桶中所有的对象。每次操作最多返回1000个对象,如果桶中3 v% {0 R1 j: `
元素超过1000个,可以将前一次获取的最后一个对象的主键作为本次获取的起始) \* f# C/ H8 ?6 [4 C5 l
点,直到遍历完成。另外,本操作还支持前缀查询,即只列出桶中主键前缀为特定
$ m9 ^. j" w, z0 ?值的对象。* l! J1 C: S7 s
●Put Bucket:创建一个桶,创建桶时可以选择桶所在的数据中心。# o4 C2 y% H6 d7 W7 |: @2 `& g
●Delete Bucket:删除一个桶,桶删除之前必须确保其中所有的对象已经提前被! ?+ j8 N3 c* t# {4 w6 p' d
删除。
. u# O; l/ r( ?* d5 a7 g●Head Bucket:判断桶是否存在且具有访问权限。
# O$ t/ D2 v3 `●Put Object:创建一个对象并加入到桶中或者修改一个已有对象。如果对象多版
% X( A$ } _( G9 |+ H本策略生效,S3会自动为每个新建对象生成唯一的版本号,同一个对象可能存储多
. J) A D' \$ }3 y3 ?7 p+ x个版本。: `! `- C% p, q- J- y- A0 }3 }
●Get Object:读取对象的数据及元数据,元数据包括对象长度,MD5哈希值,% M7 l8 K; x( n% r
创建时间等。 a% ]8 d) M* O7 t
●Delete Object(s):删除一个或者多个对象。6 h- A2 Y4 F- _0 q0 J b- N
●Head Object:获取对象的元数据。! u5 h' W3 g" I! I8 M
S3支持几GB甚至上TB的对象,如果对象过大,可以使用多次上传接口:8 y8 g' k, Y8 R m: X8 T& W |
●Initial Multipart Upload:初始化多次上传,获取多次上传的编号(upload
% w: _/ \: m- E" |# d5 \( m- l& }ID)。+ p, q7 b% Y' f% V7 }7 C! S: O
●Upload Part:上传部分数据,每次请求都要带上上传编号以及本次上传序号
! R# n7 M% Z( [% D9 `3 l; C6 o6 L; a(part number)。如果前后两次上传的序号相同,后一次上传的内容将直接覆盖前一: D/ S% f' K. q" J/ `0 }1 W
次上传的内容。8 h, J3 {# Z4 i: H1 e
●Complete Multipart Upload:完成多次上传,S3会将之前上传的部分数据连接为+ A% ~; @# R1 D/ c- z
一个大对象。, p, f; k! C+ @" n
●Abort Multipart Upload:中止多次上传请求。
% \: C* ]; R) d4 r! ?用户可以将本地的文件通过Put接口上传到云端,如果文件太大,可以分多次上
0 x; z6 u; X+ ~" q% Q7 h, N传;用户也可以通过List方法读取云端某个桶中包含的所有文件或者通过Get方法读+ @& s) P# B5 \2 U1 m
取某个文件。另外,如果文件太大,可以指定读取的数据范围,从而分多次读取大
' i" t# Z6 H: y" F文件。: m$ p' D5 U( w9 K: `
作为AWS的存储部分,Amazon S3云存储服务针对企业和程序员,需要自行开发2 H$ u9 Y" R" O+ t7 M/ |
使用界面,除此之外,云存储还可以以单独的产品形态提供给个人用户,比如
$ d$ _2 I+ i5 @ Z) e0 D1 lAmazon“云盘”(Amazon Cloud Drive),苹果iCloud,Google Drive,Windows
1 L7 {6 T7 L: P! OLiveSkyDrive,Dropbox,金山快盘等,这类产品称为个人云存储产品。简单地说,个0 z1 K6 g3 ^* t6 o i
人云存储产品主要定位是用来存储个人文件的,而且从电脑到手机,从苹果到安9 z5 W; Q& n+ ~( x0 Y3 b# j
卓,个人云存储可以跨平台,走到哪里,都能访问到你的个人文件,就像使用U盘这; l% L4 X& f& J6 l& z1 ?; ~
么简单,但又无须随时携带,更不用担心这个U盘会丢失。相比云存储平台,个人云
1 S! n+ X2 h/ x# ^3 i. r存储不需要专门的计算实例来托管应用程序,个人用户可以通过各种终端设备,如2 G' `3 H0 z, g) w
PC机,平板电脑,智能手机直接访问云数据中心的存储服务,将终端设备中的个人
- k# O. K( l9 o- I1 H* {数据实时同步到云存储中。通过个人云存储服务,可以实现多个终端设备之间数据
5 \7 E% H p6 X7 }' h同步,数据分享,备份等功能。
4 ^* I4 r7 i& L( [除了个人云存储产品,云存储也经常用于企业的数据集中备份,存档。中小企
" m- s& [! w: S2 X8 ~业往往没有自建云存储的能力,内部数据管理也比较混乱,通过企业云存储,可以
- w+ z% `: s9 ?省去自建和管理的麻烦,并提供一定的灾难恢复能力。
/ r \5 q ]+ u& L最后,大型互联网服务的后端也构建在互联网内容提供商的私有云存储系统之
v3 o% A1 y- e6 G2 e" D上,Google,Amazon,Facebook,Taobao等互联网内容提供商都维护了各自的私有
$ H9 y E% `2 g5 F7 u云存储系统。云存储产品形态如图12-2所示。
2 \3 k Q+ z1 P( W图 12-2 云存储产品形态* }4 k/ I( _' B: b
! _( u2 Y4 a5 g9 h* O7 j* |3 R5 u# M: l2 H8 V: X8 m/ _0 r
|
|