Amazon Simple Storage Service (Amazon S3)

Amazon S3 是一种面向 Internet 的存储服务。该服务旨在降低开发人员进行网络规模计算的难度。

Amazon S3 提供一个简明的 Web 服务界面,用户可通过它随时在 Web 上的任何位置存储和检索的任意大小的数据。此服务让所有开发人员都能访问同一个具备高扩展性、可靠性、安全性和性价比的基础设施,而 Amazon 正是使用此种基础设施来运行其全球的网站网络的。该服务旨让扩展带来的优势得以最大化,并将这种优势传递给开发人员。

 【以上介绍引自aws官方介绍:http://aws.amazon.com/cn/s3/】

简单来说,s3就是一种存储服务,动态为客户提供所需的存储空间,用户通过注册aws账户便可以拥有自己的s3,但是会根据其使用的存储容量适当收费。s3中包含的基本单位是bucket,可以叫作“桶”。反正不都是把东西往里面“砸”么~吼吼。一般而言一个用户最多可以拥有100个bucket("Each AWS account can own up to 100 buckets at a time.")。但是每个bucket里面可以创建n个文件夹(在java里面bucket里面的所有文件都被定义为“object”)。

从s3上存取文件方法很多,可以登录控制台进行存取,或者干脆在本地通过命令行输入进行存储(该方法需要到官网上下载相应的command line tools:http://docs.aws.amazon.com/AWSEC2/latest/CommandLineReference/Welcome.html),当然除此之外也可以通过编程来实现上述功能,以Java为例进行下面讲解:

1.首先去官网下载sdk:http://aws.amazon.com/cn/sdkforjava/

2.将sdk里面的jar包全部导入java项目中(这样做其实是有点偷懒了,事实上很多jar包在这里是不需要的)

3.开始编程实现功能:

 

package testS3;

import java.io.BufferedReader; 
import java.io.File; 
import java.io.IOException; 
import java.io.InputStreamReader; 
import java.util.List; 
import com.amazonaws.auth.AWSCredentials; 
import com.amazonaws.auth.BasicAWSCredentials; 
import com.amazonaws.services.s3.AmazonS3Client; 
import com.amazonaws.services.s3.model.Bucket; 
import com.amazonaws.services.s3.model.GetObjectRequest; 
import com.amazonaws.services.s3.model.ObjectListing; 
import com.amazonaws.services.s3.model.Region; 
import com.amazonaws.services.s3.model.S3Object; 
import com.amazonaws.services.s3.model.S3ObjectSummary; 


public class TestS3_Put_Get { 

public static void main(String[] args) throws IOException { 
        //get IAM 
        AWSCredentials myCredentials = new BasicAWSCredentials(yourKey,yourSecret );//输入你的key和secret,你得去“我的帐户”里找 
        AmazonS3Client s3 = new AmazonS3Client(myCredentials); 
         
        //创建bucket,存入obejct 
        s3.createBucket("mybuckethaha", Region.US_West_2);//bucket名和s3所在地域 
        s3.putObject("mybuckethaha", "docs/tt.txt", new File("d:/data1.txt"));//上传一个txt文件 
        System.out.println("finished!"); 
         
        //上传完毕 
        //现在获取bucket和object 
        List bls=s3.listBuckets(); 
        for(Bucket bl:bls){ 
         System.out.println(bl.getName()+":"); 
         ObjectListing ols=s3.listObjects(bl.getName()); 
         List osls=ols.getObjectSummaries(); 
         for(S3ObjectSummary osl:osls){ 
         System.out.println("-\t"+osl.getKey()); 
         if(osl.getKey().contains(".txt")){ 
         System.out.println("print: "+osl.getKey()); 
         S3Object s3o=s3.getObject(new GetObjectRequest(bl.getName(),osl.getKey())); 
                 BufferedReader reader = new BufferedReader(new InputStreamReader(s3o.getObjectContent(),"utf-8")); 
                 String s=""; 
                 while((s=reader.readLine())!=null){ 
                  System.out.println(s); 
                 } 
                 reader.close(); 
         } 
         } 
        } 
} 
}

简单吧,哈哈,改天再发表ec2是怎么实现的,还有auto scaling等等~~~

你可能感兴趣的:(IT)