1# 适用于与Amazon S3兼容云存储的Minio Go SDK [![Slack](https://slack.minio.io/slack?type=svg)](https://slack.minio.io) [![Sourcegraph](https://sourcegraph.com/github.com/minio/minio-go/-/badge.svg)](https://sourcegraph.com/github.com/minio/minio-go?badge)
2
3Minio Go Client SDK提供了简单的API来访问任何与Amazon S3兼容的对象存储服务。
4
5**支持的云存储:**
6
7- AWS Signature Version 4
8   - Amazon S3
9   - Minio
10
11- AWS Signature Version 2
12   - Google Cloud Storage (兼容模式)
13   - Openstack Swift + Swift3 middleware
14   - Ceph Object Gateway
15   - Riak CS
16
17本文我们将学习如何安装Minio client SDK,连接到Minio,并提供一下文件上传的示例。对于完整的API以及示例,请参考[Go Client API Reference](https://docs.minio.io/docs/golang-client-api-reference)18
19本文假设你已经有 [Go开发环境](https://docs.minio.io/docs/how-to-install-golang)20
21## 从Github下载
22```sh
23go get -u github.com/minio/minio-go
24```
25
26## 初始化Minio Client
27Minio client需要以下4个参数来连接与Amazon S3兼容的对象存储。
28
29| 参数  | 描述|
30| :---         |     :---     |
31| endpoint   | 对象存储服务的URL   |
32| accessKeyID | Access key是唯一标识你的账户的用户ID。 |
33| secretAccessKey | Secret key是你账户的密码。 |
34| secure | true代表使用HTTPS |
35
36
37```go
38package main
39
40import (
41	"github.com/minio/minio-go"
42	"log"
43)
44
45func main() {
46	endpoint := "play.minio.io:9000"
47	accessKeyID := "Q3AM3UQ867SPQQA43P2F"
48	secretAccessKey := "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG"
49	useSSL := true
50
51	// 初使化 minio client对象。
52	minioClient, err := minio.New(endpoint, accessKeyID, secretAccessKey, useSSL)
53	if err != nil {
54		log.Fatalln(err)
55	}
56
57	log.Printf("%#v\n", minioClient) // minioClient初使化成功
58}
59```
60
61## 示例-文件上传
62本示例连接到一个对象存储服务,创建一个存储桶并上传一个文件到存储桶中。
63
64我们在本示例中使用运行在 [https://play.minio.io:9000](https://play.minio.io:9000) 上的Minio服务,你可以用这个服务来开发和测试。示例中的访问凭据是公开的。
65
66### FileUploader.go
67```go
68package main
69
70import (
71	"github.com/minio/minio-go"
72	"log"
73)
74
75func main() {
76	endpoint := "play.minio.io:9000"
77	accessKeyID := "Q3AM3UQ867SPQQA43P2F"
78	secretAccessKey := "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG"
79	useSSL := true
80
81	// 初使化minio client对象。
82	minioClient, err := minio.New(endpoint, accessKeyID, secretAccessKey, useSSL)
83	if err != nil {
84		log.Fatalln(err)
85	}
86
87	// 创建一个叫mymusic的存储桶。
88	bucketName := "mymusic"
89	location := "us-east-1"
90
91	err = minioClient.MakeBucket(bucketName, location)
92	if err != nil {
93		// 检查存储桶是否已经存在。
94		exists, err := minioClient.BucketExists(bucketName)
95		if err == nil && exists {
96			log.Printf("We already own %s\n", bucketName)
97		} else {
98			log.Fatalln(err)
99		}
100	}
101	log.Printf("Successfully created %s\n", bucketName)
102
103	// 上传一个zip文件。
104	objectName := "golden-oldies.zip"
105	filePath := "/tmp/golden-oldies.zip"
106	contentType := "application/zip"
107
108	// 使用FPutObject上传一个zip文件。
109	n, err := minioClient.FPutObject(bucketName, objectName, filePath, minio.PutObjectOptions{ContentType:contentType})
110	if err != nil {
111		log.Fatalln(err)
112	}
113
114	log.Printf("Successfully uploaded %s of size %d\n", objectName, n)
115}
116```
117
118### 运行FileUploader
119```sh
120go run file-uploader.go
1212016/08/13 17:03:28 Successfully created mymusic
1222016/08/13 17:03:40 Successfully uploaded golden-oldies.zip of size 16253413
123
124mc ls play/mymusic/
125[2016-05-27 16:02:16 PDT]  17MiB golden-oldies.zip
126```
127
128## API文档
129完整的API文档在这里。
130* [完整API文档](https://docs.minio.io/docs/golang-client-api-reference)
131
132### API文档 : 操作存储桶
133* [`MakeBucket`](https://docs.minio.io/docs/golang-client-api-reference#MakeBucket)
134* [`ListBuckets`](https://docs.minio.io/docs/golang-client-api-reference#ListBuckets)
135* [`BucketExists`](https://docs.minio.io/docs/golang-client-api-reference#BucketExists)
136* [`RemoveBucket`](https://docs.minio.io/docs/golang-client-api-reference#RemoveBucket)
137* [`ListObjects`](https://docs.minio.io/docs/golang-client-api-reference#ListObjects)
138* [`ListObjectsV2`](https://docs.minio.io/docs/golang-client-api-reference#ListObjectsV2)
139* [`ListIncompleteUploads`](https://docs.minio.io/docs/golang-client-api-reference#ListIncompleteUploads)
140
141### API文档 : 存储桶策略
142* [`SetBucketPolicy`](https://docs.minio.io/docs/golang-client-api-reference#SetBucketPolicy)
143* [`GetBucketPolicy`](https://docs.minio.io/docs/golang-client-api-reference#GetBucketPolicy)
144
145### API文档 : 存储桶通知
146* [`SetBucketNotification`](https://docs.minio.io/docs/golang-client-api-reference#SetBucketNotification)
147* [`GetBucketNotification`](https://docs.minio.io/docs/golang-client-api-reference#GetBucketNotification)
148* [`RemoveAllBucketNotification`](https://docs.minio.io/docs/golang-client-api-reference#RemoveAllBucketNotification)
149* [`ListenBucketNotification`](https://docs.minio.io/docs/golang-client-api-reference#ListenBucketNotification) (Minio Extension)
150
151### API文档 : 操作文件对象
152* [`FPutObject`](https://docs.minio.io/docs/golang-client-api-reference#FPutObject)
153* [`FGetObject`](https://docs.minio.io/docs/golang-client-api-reference#FPutObject)
154* [`FPutObjectWithContext`](https://docs.minio.io/docs/golang-client-api-reference#FPutObjectWithContext)
155* [`FGetObjectWithContext`](https://docs.minio.io/docs/golang-client-api-reference#FGetObjectWithContext)
156
157### API文档 : 操作对象
158* [`GetObject`](https://docs.minio.io/docs/golang-client-api-reference#GetObject)
159* [`PutObject`](https://docs.minio.io/docs/golang-client-api-reference#PutObject)
160* [`GetObjectWithContext`](https://docs.minio.io/docs/golang-client-api-reference#GetObjectWithContext)
161* [`PutObjectWithContext`](https://docs.minio.io/docs/golang-client-api-reference#PutObjectWithContext)
162* [`PutObjectStreaming`](https://docs.minio.io/docs/golang-client-api-reference#PutObjectStreaming)
163* [`StatObject`](https://docs.minio.io/docs/golang-client-api-reference#StatObject)
164* [`CopyObject`](https://docs.minio.io/docs/golang-client-api-reference#CopyObject)
165* [`RemoveObject`](https://docs.minio.io/docs/golang-client-api-reference#RemoveObject)
166* [`RemoveObjects`](https://docs.minio.io/docs/golang-client-api-reference#RemoveObjects)
167* [`RemoveIncompleteUpload`](https://docs.minio.io/docs/golang-client-api-reference#RemoveIncompleteUpload)
168
169### API文档: 操作加密对象
170* [`GetEncryptedObject`](https://docs.minio.io/docs/golang-client-api-reference#GetEncryptedObject)
171* [`PutEncryptedObject`](https://docs.minio.io/docs/golang-client-api-reference#PutEncryptedObject)
172
173### API文档 : Presigned操作
174* [`PresignedGetObject`](https://docs.minio.io/docs/golang-client-api-reference#PresignedGetObject)
175* [`PresignedPutObject`](https://docs.minio.io/docs/golang-client-api-reference#PresignedPutObject)
176* [`PresignedHeadObject`](https://docs.minio.io/docs/golang-client-api-reference#PresignedHeadObject)
177* [`PresignedPostPolicy`](https://docs.minio.io/docs/golang-client-api-reference#PresignedPostPolicy)
178
179### API文档 : 客户端自定义设置
180* [`SetAppInfo`](http://docs.minio.io/docs/golang-client-api-reference#SetAppInfo)
181* [`SetCustomTransport`](http://docs.minio.io/docs/golang-client-api-reference#SetCustomTransport)
182* [`TraceOn`](http://docs.minio.io/docs/golang-client-api-reference#TraceOn)
183* [`TraceOff`](http://docs.minio.io/docs/golang-client-api-reference#TraceOff)
184
185## 完整示例
186
187### 完整示例 : 操作存储桶
188* [makebucket.go](https://github.com/minio/minio-go/blob/master/examples/s3/makebucket.go)
189* [listbuckets.go](https://github.com/minio/minio-go/blob/master/examples/s3/listbuckets.go)
190* [bucketexists.go](https://github.com/minio/minio-go/blob/master/examples/s3/bucketexists.go)
191* [removebucket.go](https://github.com/minio/minio-go/blob/master/examples/s3/removebucket.go)
192* [listobjects.go](https://github.com/minio/minio-go/blob/master/examples/s3/listobjects.go)
193* [listobjectsV2.go](https://github.com/minio/minio-go/blob/master/examples/s3/listobjectsV2.go)
194* [listincompleteuploads.go](https://github.com/minio/minio-go/blob/master/examples/s3/listincompleteuploads.go)
195
196### 完整示例 : 存储桶策略
197* [setbucketpolicy.go](https://github.com/minio/minio-go/blob/master/examples/s3/setbucketpolicy.go)
198* [getbucketpolicy.go](https://github.com/minio/minio-go/blob/master/examples/s3/getbucketpolicy.go)
199* [listbucketpolicies.go](https://github.com/minio/minio-go/blob/master/examples/s3/listbucketpolicies.go)
200
201### 完整示例 : 存储桶通知
202* [setbucketnotification.go](https://github.com/minio/minio-go/blob/master/examples/s3/setbucketnotification.go)
203* [getbucketnotification.go](https://github.com/minio/minio-go/blob/master/examples/s3/getbucketnotification.go)
204* [removeallbucketnotification.go](https://github.com/minio/minio-go/blob/master/examples/s3/removeallbucketnotification.go)
205* [listenbucketnotification.go](https://github.com/minio/minio-go/blob/master/examples/minio/listenbucketnotification.go) (Minio扩展)
206
207### 完整示例 : 操作文件对象
208* [fputobject.go](https://github.com/minio/minio-go/blob/master/examples/s3/fputobject.go)
209* [fgetobject.go](https://github.com/minio/minio-go/blob/master/examples/s3/fgetobject.go)
210* [fputobject-context.go](https://github.com/minio/minio-go/blob/master/examples/s3/fputobject-context.go)
211* [fgetobject-context.go](https://github.com/minio/minio-go/blob/master/examples/s3/fgetobject-context.go)
212
213### 完整示例 : 操作对象
214* [putobject.go](https://github.com/minio/minio-go/blob/master/examples/s3/putobject.go)
215* [getobject.go](https://github.com/minio/minio-go/blob/master/examples/s3/getobject.go)
216* [putobject-context.go](https://github.com/minio/minio-go/blob/master/examples/s3/putobject-context.go)
217* [getobject-context.go](https://github.com/minio/minio-go/blob/master/examples/s3/getobject-context.go)
218* [statobject.go](https://github.com/minio/minio-go/blob/master/examples/s3/statobject.go)
219* [copyobject.go](https://github.com/minio/minio-go/blob/master/examples/s3/copyobject.go)
220* [removeobject.go](https://github.com/minio/minio-go/blob/master/examples/s3/removeobject.go)
221* [removeincompleteupload.go](https://github.com/minio/minio-go/blob/master/examples/s3/removeincompleteupload.go)
222* [removeobjects.go](https://github.com/minio/minio-go/blob/master/examples/s3/removeobjects.go)
223
224### 完整示例 : 操作加密对象
225* [put-encrypted-object.go](https://github.com/minio/minio-go/blob/master/examples/s3/put-encrypted-object.go)
226* [get-encrypted-object.go](https://github.com/minio/minio-go/blob/master/examples/s3/get-encrypted-object.go)
227* [fput-encrypted-object.go](https://github.com/minio/minio-go/blob/master/examples/s3/fputencrypted-object.go)
228
229### 完整示例 : Presigned操作
230* [presignedgetobject.go](https://github.com/minio/minio-go/blob/master/examples/s3/presignedgetobject.go)
231* [presignedputobject.go](https://github.com/minio/minio-go/blob/master/examples/s3/presignedputobject.go)
232* [presignedheadobject.go](https://github.com/minio/minio-go/blob/master/examples/s3/presignedheadobject.go)
233* [presignedpostpolicy.go](https://github.com/minio/minio-go/blob/master/examples/s3/presignedpostpolicy.go)
234
235## 了解更多
236* [完整文档](https://docs.minio.io)
237* [Minio Go Client SDK API文档](https://docs.minio.io/docs/golang-client-api-reference)
238* [Go 音乐播放器完整示例](https://docs.minio.io/docs/go-music-player-app)
239
240## 贡献
241[贡献指南](https://github.com/minio/minio-go/blob/master/docs/zh_CN/CONTRIBUTING.md)
242
243[![Build Status](https://travis-ci.org/minio/minio-go.svg)](https://travis-ci.org/minio/minio-go)
244[![Build status](https://ci.appveyor.com/api/projects/status/1d05e6nvxcelmrak?svg=true)](https://ci.appveyor.com/project/harshavardhana/minio-go)
245
246