golang aws-sdk-go 之 s3 服务
s3 是 aws 提供的分布式文件服务,价格比较优惠,经常被用来作为日志的持久化存储,大数据处理结果的输入输出等 s3 服务提供命令行工具,可以很方便地上传、下载、删除文件,普通 golang 程序如果需要访问 s3 上文件,一种简单方式可以先将 s3 上文件下载到本地,然后直接访问本地文件即可,但是这种方式需要一个额外的步骤,下载到本地,有额外的运维成本,需要额外的磁盘空间,使用上面不是很灵活,此外,微服务应该尽可能地降低对本地数据的依赖,这种设计也不符合微服务的设计思想 使用 aws-sdk-go 可以直接访问 s3 服务,实现文件的上传和读取 以下使用的代码:https://github.com/hatlonely/... 创建会话首先需要创建一个会话,后续的访问都可以通过这个会话进行,如果访问的服务需要授权,也可以在 config 里面指定授权文件 sess := session.Must(session.NewSession(&aws.Config{ Region: aws.String(endpoints.ApSoutheast1RegionID),})) service := s3.New(sess) 这里必须指定 s3 桶所在的地区 上传文件fp,err := os.Open("s3_test.go") So(err,ShouldBeNil) defer fp.Close() ctx,cancel := context.WithTimeout(context.Background(),time.Duration(30)*time.Second) defer cancel() _,err = service.PutObjectWithContext(ctx,&s3.PutObjectInput{ Bucket: aws.String("hatlonely"),Key: aws.String("test/s3_test.go"),Body: fp,}) So(err,ShouldBeNil) 使用 可以通过 context 设置访问超时时间 下载文件ctx,time.Duration(30)*time.Second) defer cancel() out,err := service.GetObjectWithContext(ctx,&s3.GetObjectInput{ Bucket: aws.String("hatlonely"),Key: aws.String("test/s3_test.go"),ShouldBeNil) defer out.Body.Close() scanner := bufio.NewScanner(out.Body) for scanner.Scan() { Println(scanner.Text()) } 使用 最后要记得调用 遍历目录var objkeys []string ctx,err := service.ListObjectsWithContext(ctx,&s3.ListObjectsInput{ Bucket: aws.String("hatlonely"),Prefix: aws.String("test/"),ShouldBeNil) for _,content := range out.Contents { objkeys = append(objkeys,aws.StringValue(content.Key)) } Println(objkeys) 大数据一般都是并发输出,每个节点都会输出一个文件,到一个指定的目录下面,所以有时候我们需要去获取一个目录下面到底有哪些文件,可以使用 var objkeys []string ctx,time.Duration(30)*time.Second) defer cancel() err := service.ListObjectsPagesWithContext(ctx,},func(output *s3.ListObjectsOutput,b bool) bool { for _,content := range output.Contents { objkeys = append(objkeys,aws.StringValue(content.Key)) } return true }) So(err,ShouldBeNil) Println(objkeys) 也可以使用 参考链接
转载请注明出处 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |