var Minio = require('minio')
var minioClient = new Minio.Client({
endPoint: 'play.min.io',
port: 9000,
useSSL: true,
accessKey: 'Q3AM3UQ867SPQQA43P2F',
secretKey: 'zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG'
});
var Minio = require('minio')
var s3Client = new Minio.Client({
endPoint: 's3.amazonaws.com',
accessKey: 'YOUR-ACCESSKEYID',
secretKey: 'YOUR-SECRETACCESSKEY'
})
new Minio.Client ({endPoint, port, useSSL, accessKey, secretKey}) |
初使化一个新的client对象。 |
参数
参数 | 类型 | 描述 |
---|---|---|
endPoint |
string | endPoint是一个主机名或者IP地址。 |
port |
number | TCP/IP端口号。可选,默认值是,如果是http,则默认80端口,如果是https,则默认是443端口。 |
accessKey |
string | accessKey类似于用户ID,用于唯一标识你的账户。 |
secretKey |
string | secretKey是你账户的密码。 |
useSSL |
bool | 如果是true,则用的是https而不是http,默认值是true。 |
region |
string | 设置该值以覆盖自动发现存储桶region。(可选) |
transport |
string | Set this value to pass in a custom transport. (Optional) - To be translated |
sessionToken |
string | Set this value to provide x-amz-security-token (AWS S3 specific). (Optional) - To be translated |
partSize |
number | Set this value to override default part size of 64MB for multipart uploads. (Optional) - To be translated |
示例
var Minio = require('minio')
var minioClient = new Minio.Client({
endPoint: 'play.min.io',
port: 9000,
useSSL: true,
accessKey: 'Q3AM3UQ867SPQQA43P2F',
secretKey: 'zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG'
});
var Minio = require('minio')
var s3Client = new Minio.Client({
endPoint: 's3.amazonaws.com',
accessKey: 'YOUR-ACCESSKEYID',
secretKey: 'YOUR-SECRETACCESSKEY'
})
创建一个新的存储桶。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
region |
string | 存储桶被创建的region(地区),默认是us-east-1(美国东一区),下面列举的是其它合法的值: |
us-east-1 | ||
us-west-1 | ||
us-west-2 | ||
eu-west-1 | ||
eu-central-1 | ||
ap-southeast-1 | ||
ap-northeast-1 | ||
ap-southeast-2 | ||
sa-east-1 | ||
cn-north-1 | ||
callback(err) |
function | 回调函数,err 做为错误信息参数。如果创建存储桶成功则err 为null。如果没有传callback的话,则返回一个Promise 对象。 |
示例
minioClient.makeBucket('mybucket', 'us-east-1', function(err) {
if (err) return console.log('Error creating bucket.', err)
console.log('Bucket created successfully in "us-east-1".')
})
列出所有存储桶。
参数
参数 | 类型 | 描述 |
---|---|---|
callback(err, bucketStream) |
function | 回调函数,第一个参数是错误信息。bucketStream 是带有存储桶信息的流。如果没有传callback的话,则返回一个Promise 对象。 |
bucketStream格式如下:-
参数 | 类型 | 描述 |
---|---|---|
bucket.name |
string | 存储桶名称 |
bucket.creationDate |
Date | 存储桶创建时间。 |
示例
minioClient.listBuckets(function(err, buckets) {
if (err) return console.log(err)
console.log('buckets :', buckets)
})
验证存储桶是否存在。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
callback(err) |
function | 如果存储桶存在的话err 就是null,否则err.code 是NoSuchBucket 。如果没有传callback的话,则返回一个Promise 对象。 |
示例
minioClient.bucketExists('mybucket', function(err) {
if (err) {
if (err.code == 'NoSuchBucket') return console.log("bucket does not exist.")
return console.log(err)
}
// if err is null it indicates that the bucket exists.
console.log('Bucket exists.')
})
删除存储桶。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
callback(err) |
function | 如果存储桶删除成功则err 为null 。如果没有传callback的话,则返回一个Promise 对象。 |
示例
minioClient.removeBucket('mybucket', function(err) {
if (err) return console.log('unable to remove bucket.')
console.log('Bucket removed successfully.')
})
列出存储桶中所有对象。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
prefix |
string | 要列出的对象的前缀 (可选,默认值是'' )。 |
recursive |
bool | true 代表递归查找,false 代表类似文件夹查找,以'/'分隔,不查子文件夹。(可选,默认值是false ) |
返回值
参数 | 类型 | 描述 |
---|---|---|
stream |
Stream | 存储桶中对象信息的流。 |
对象的格式如下:
参数 | 类型 | 描述 |
---|---|---|
obj.name |
string | 对象名称。 |
obj.prefix |
string | 对象名称的前缀。 |
obj.size |
number | 对象的大小。 |
obj.etag |
string | 对象的etag值。 |
obj.lastModified |
Date | 最后修改时间。 |
示例
var stream = minioClient.listObjects('mybucket','', true)
stream.on('data', function(obj) { console.log(obj) } )
stream.on('error', function(err) { console.log(err) } )
使用S3 listing objects V2版本API列出所有对象。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
prefix |
string | 要列出的对象的前缀。(可选,默认值是'' ) |
recursive |
bool | true 代表递归查找,false 代表类似文件夹查找,以'/'分隔,不查子文件夹。(可选,默认值是false ) |
返回值
参数 | 类型 | 描述 |
---|---|---|
stream |
Stream | 存储桶中对象信息的流。 |
对象的格式如下:
参数 | 类型 | 描述 |
---|---|---|
obj.name |
string | 对象名称。 |
obj.prefix |
string | 对象名称的前缀。 |
obj.size |
number | 对象的大小。 |
obj.etag |
string | 对象的etag值。 |
obj.lastModified |
Date | 最后修改时间。 |
示例
var stream = minioClient.listObjectsV2('mybucket','', true)
stream.on('data', function(obj) { console.log(obj) } )
stream.on('error', function(err) { console.log(err) } )
列出存储桶中未完整上传的对象。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketname |
string | 存储桶名称。 |
prefix |
string | 未完整上传的对象的前缀。(可选,默认值是'' )。 |
recursive |
bool | true 代表递归查找,false 代表类似文件夹查找,以'/'分隔,不查子文件夹。(可选,默认值是false ) |
返回值
参数 | 类型 | 描述 |
---|---|---|
stream |
Stream | 对象格式如下: |
参数 | 类型 | 描述 |
---|---|---|
part.key |
string | 对象名称。 |
part.uploadId |
string | 对象的上传ID。 |
part.size |
Integer | 未完整上传的对象的大小。 |
示例
var Stream = minioClient.listIncompleteUploads('mybucket', '', true)
Stream.on('data', function(obj) {
console.log(obj)
})
Stream.on('end', function() {
console.log('End')
})
Stream.on('error', function(err) {
console.log(err)
})
下载对象。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
callback(err, stream) |
function | 回调函数,第一个参数是错误信息。stream 是对象的内容。如果没有传callback的话,则返回一个Promise 对象。 |
示例
var size = 0
minioClient.getObject('mybucket', 'photo.jpg', function(err, dataStream) {
if (err) {
return console.log(err)
}
dataStream.on('data', function(chunk) {
size += chunk.length
})
dataStream.on('end', function() {
console.log('End. Total size = ' + size)
})
dataStream.on('error', function(err) {
console.log(err)
})
})
下载对象中指定区间的字节数组,并返回流。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
offset |
number | offset 是从第几个字节始 |
length |
number | length 是要下载的字节数组长度(可选值,如果为空的话则代表从offset一直到文件的末尾)。 |
callback(err, stream) |
function | 回调函数,第一个参数是错误信息。stream 是对象的内容。如果没有传callback的话,则返回一个Promise 对象。 |
示例
var size = 0
// reads 30 bytes from the offset 10.
minioClient.getPartialObject('mybucket', 'photo.jpg', 10, 30, function(err, dataStream) {
if (err) {
return console.log(err)
}
dataStream.on('data', function(chunk) {
size += chunk.length
})
dataStream.on('end', function() {
console.log('End. Total size = ' + size)
})
dataStream.on('error', function(err) {
console.log(err)
})
})
下载并将对象保存成本地文件。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
filePath |
string | 要写入的本地文件路径。 |
callback(err) |
function | 如果报错的话,则会调用回调函数,传入err 参数。 如果没有传callback的话,则返回一个Promise 对象。 |
示例
var size = 0
minioClient.fGetObject('mybucket', 'photo.jpg', '/tmp/photo.jpg', function(err) {
if (err) {
return console.log(err)
}
console.log('success')
})
从一个stream/Buffer中上传一个对象。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
stream |
Stream | 可以读的流。 |
size |
number | 对象的大小(可选)。 |
contentType |
string | 对象的Content-Type(可选,默认是application/octet-stream )。 |
callback(err, etag) |
function | 如果err 不是null则代表有错误,etag _string_是上传的对象的etag值。如果没有传callback的话,则返回一个Promise 对象。 |
示例
单个对象的最大大小限制在5TB。putObject在对象大于5MiB时,自动使用multiple parts方式上传。这样的话,当上传失败的时候,客户端只需要上传未成功的部分即可(类似断点上传)。上传的对象使用MD5SUM签名进行完整性验证。
var Fs = require('fs')
var file = '/tmp/40mbfile'
var fileStream = Fs.createReadStream(file)
var fileStat = Fs.stat(file, function(err, stats) {
if (err) {
return console.log(err)
}
minioClient.putObject('mybucket', '40mbfile', fileStream, stats.size, function(err, etag) {
return console.log(err, etag) // err should be null
})
})
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
string or Buffer |
Stream or Buffer | 字符串可者缓冲区 |
contentType |
string | 对象的Content-Type(可选,默认是application/octet-stream )。 |
callback(err, etag) |
function | 如果err 不是null则代表有错误,etag _string_是上传的对象的etag值。 |
示例
var buffer = 'Hello World'
minioClient.putObject('mybucket', 'hello-file', buffer, function(err, etag) {
return console.log(err, etag) // err should be null
})
上传文件。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
filePath |
string | 要上传的文件路径。 |
contentType |
string | 对象的Content-Type。 |
callback(err, etag) |
function | 如果err 不是null则代表有错误,etag _string_是上传的对象的etag值。如果没有传callback的话,则返回一个Promise 对象。 |
示例
var file = '/tmp/40mbfile'
minioClient.fPutObject('mybucket', '40mbfile', file, 'application/octet-stream', function(err, etag) {
return console.log(err, etag) // err should be null
})
将源对象拷贝到指定存储桶的新对象中。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
sourceObject |
string | 源对象的名称 |
conditions |
CopyConditions | 允许拷贝需要满足的条件。 |
callback(err, {etag, lastModified}) |
function | 如果err 不是null则代表有错误,etag _string_是上传的对象的etag值,lastModified _Date_是新拷贝对象的最后修改时间。如果没有传callback的话,则返回一个Promise 对象。 |
示例
var conds = new Minio.CopyConditions()
conds.setMatchETag('bd891862ea3e22c93ed53a098218791d')
minioClient.copyObject('mybucket', 'newobject', '/mybucket/srcobject', conds, function(e, data) {
if (e) {
return console.log(e)
}
console.log("Successfully copied the object:")
console.log("etag = " + data.etag + ", lastModified = " + data.lastModified)
})
获取对象的元数据。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
callback(err, stat) |
function | 如果err 不是null则代表有错误,stat 含有对象的元数据信息,格式如下所示。如果没有传callback的话,则返回一个Promise 对象。 |
参数 | 类型 | 描述 |
---|---|---|
stat.size |
number | 对象的大小。 |
stat.etag |
string | 对象的etag值。 |
stat.contentType |
string | 对象的Content-Type。 |
stat.lastModified |
string | Last 最后修改时间。 |
示例
minioClient.statObject('mybucket', 'photo.jpg', function(err, stat) {
if (err) {
return console.log(err)
}
console.log(stat)
})
删除一个对象。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName | string | 对象名称。 |
callback(err) |
function | 如果err 不是null则代表有错误。如果没有传callback的话,则返回一个Promise 对象。 |
示例
minioClient.removeObject('mybucket', 'photo.jpg', function(err) {
if (err) {
return console.log('Unable to remove object', err)
}
console.log('Removed the object')
})
删除一个未完整上传的对象。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
callback(err) |
function | 如果err 不是null则代表有错误。如果没有传callback的话,则返回一个Promise 对象。 |
示例
minioClient.removeIncompleteUpload('mybucket', 'photo.jpg', function(err) {
if (err) {
return console.log('Unable to remove incomplete object', err)
}
console.log('Incomplete object removed successfully.')
})
Presigned URLs用于对私有对象提供临时的上传/下载功能。
生成一个给指定HTTP方法('httpMethod')请求用的presigned URL。浏览器/移动端的客户端可以用这个URL进行下载,即使其所在的存储桶是私有的。这个presigned URL可以设置一个失效时间,默认值是7天。
参数
参数 | 类型 | 描述 |
---|---|---|
httpMethod |
string | http方法,put、get等。 |
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
expiry |
number | 失效时间(以秒为单位),默认是7天,不得大于七天。 |
reqParams |
object | 请求参数。 |
callback(err, presignedUrl) |
function | 如果err 不是null则代表有错误。presignedUrl 就是可临时上传/下载文件的URL。如果没有传callback的话,则返回一个Promise 对象。 |
示例1
// presigned url for 'getObject' method.
// expires in a day.
minioClient.presignedUrl('GET', 'mybucket', 'hello.txt', 24*60*60, function(err, presignedUrl) {
if (err) return console.log(err)
console.log(presignedUrl)
})
示例2
// presigned url for 'listObject' method.
// Lists objects in 'myBucket' with prefix 'data'.
// Lists max 1000 of them.
minioClient.presignedUrl('GET', 'mybucket', '', 1000, {'prefix': 'data', 'max-keys': 1000}, function(err, presignedUrl) {
if (err) return console.log(err)
console.log(presignedUrl)
})
生成一个给HTTP GET请求用的presigned URL。浏览器/移动端的客户端可以用这个URL进行下载,即使其所在的存储桶是私有的。这个presigned URL可以设置一个失效时间,默认值是7天。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
expiry |
number | 失效时间(以秒为单位),默认是7天,不得大于七天。 |
callback(err, presignedUrl) |
function | 如果err 不是null则代表有错误。presignedUrl 就是可用于临时下载的URL。 如果没有传callback的话,则返回一个Promise 对象。 |
示例
// expires in a day.
minioClient.presignedGetObject('mybucket', 'hello.txt', 24*60*60, function(err, presignedUrl) {
if (err) return console.log(err)
console.log(presignedUrl)
})
生成一个给HTTP PUT请求用的presigned URL。浏览器/移动端的客户端可以用这个URL进行上传,即使其所在的存储桶是私有的。这个presigned URL可以设置一个失效时间,默认值是7天。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectName |
string | 对象名称。 |
expiry |
number | 失效时间(以秒为单位),默认是7天,不得大于七天。 |
callback(err, presignedUrl) |
function | 如果err 不是null则代表有错误。presignedUrl 用于使用PUT请求进行上传。如果没有传callback的话,则返回一个Promise 对象。 |
示例
// expires in a day.
minioClient.presignedPutObject('mybucket', 'hello.txt', 24*60*60, function(err, presignedUrl) {
if (err) return console.log(err)
console.log(presignedUrl)
})
允许给POST请求的presigned URL设置条件策略。比如接收上传的存储桶名称、名称前缀、过期策略。
参数
参数 | 类型 | 描述 |
---|---|---|
policy |
object | 通过minioClient.newPostPolicy()创建的Policy对象。 |
callback(err, {postURL, formData}) |
function | 如果err 不是null则代表有错误。postURL 用于使用post请求上传。formData 是POST请求体中的键值对对象。如果没有传callback的话,则返回一个Promise 对象。 |
创建策略:
var policy = minioClient.newPostPolicy()
设置上传策略:
// Policy restricted only for bucket 'mybucket'.
policy.setBucket('mybucket')
// Policy restricted only for hello.txt object.
policy.setKey('hello.txt')
或者
// Policy restricted for incoming objects with keyPrefix.
policy.setKeyStartsWith('keyPrefix')
var expires = new Date
expires.setSeconds(24 * 60 * 60 * 10)
// Policy expires in 10 days.
policy.setExpires(expires)
// Only allow 'text'.
policy.setContentType('text/plain')
// Only allow content size in range 1KB to 1MB.
policy.setContentLengthRange(1024, 1024*1024)
使用superagent
通过浏览器POST你的数据:
minioClient.presignedPostPolicy(policy, function(err, data) {
if (err) return console.log(err)
var req = superagent.post(data.postURL)
_.each(data.formData, function(value, key) {
req.field(key, value)
})
// file contents.
req.attach('file', '/path/to/hello.txt', 'hello.txt')
req.end(function(err, res) {
if (err) {
return console.log(err.toString())
}
console.log('Upload successful.')
})
})
存储桶可以配置在指定事件类型和相应路径上触发通知。
获取指定存储桶名称的通知配置。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
callback(err, bucketNotificationConfig) |
function | 如果err 不是null则代表有错误。bucketNotificationConfig 是相应存储桶上的通知配置对象。如果没有传callback的话,则返回一个Promise 对象。 |
示例
minioClient.getBucketNotification('mybucket', function(err, bucketNotificationConfig) {
if (err) return console.log(err)
console.log(bucketNotificationConfig)
})
上传一个用户创建的通知配置,并绑定到指定的存储桶上。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
bucketNotificationConfig |
BucketNotification | 包含通知配置的Javascript对象。 |
callback(err) |
function | 如果err 不是null则代表有错误。如果没有传callback的话,则返回一个Promise 对象。 |
示例
// Create a new notification object
var bucketNotification = new Minio.NotificationConfig();
// Setup a new Queue configuration
var arn = Minio.buildARN('aws', 'sqs', 'us-west-2', '1', 'webhook')
var queue = new Minio.QueueConfig(arn)
queue.addFilterSuffix('.jpg')
queue.addFilterPrefix('myphotos/')
queue.addEvent(Minio.ObjectReducedRedundancyLostObject)
queue.addEvent(Minio.ObjectCreatedAll)
// Add the queue to the overall notification object
bucketNotification.add(queue)
minioClient.setBucketNotification('mybucket', bucketNotification, function(err) {
if (err) return console.log(err)
console.log('Success')
})
删除指定存储桶上的通知配置。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
callback(err) |
function | 如果err 不是null则代表有错误。如果没有传callback的话,则返回一个Promise 对象。 |
minioClient.removeAllBucketNotification('my-bucketname', function(e) {
if (e) {
return console.log(e)
}
console.log("True")
})
监听存储桶上的通知,可通过前缀、后缀、事件类型进行过滤。使用本API并不需要预先设置存储桶通知。这是Minio的一个扩展API,服务端基于过来的请求使用唯一ID自动注册或者取消注册。
返回一个EventEmitter
对象,它可以广播一个通知
事件。
停止监听,调用EventEmitter
的stop()
方法。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
prefix |
string | 用于过滤通知的对象名称前缀。 |
suffix |
string | 用于过滤通知的对象名称后缀。 |
events |
Array | 在指定事件类型上开启通知。 |
这里是你要的完整示例,拿走不谢。
var listener = minioClient.listenBucketNotification('my-bucketname', 'photos/', '.jpg', ['s3:ObjectCreated:*'])
listener.on('notification', function(record) {
// For example: 's3:ObjectCreated:Put event occurred (2016-08-23T18:26:07.214Z)'
console.log('%s event occurred (%s)', record.eventName, record.eventTime)
listener.stop()
})
获取指定存储桶的访问策略,如果objectPrefix
不为空,则会取相应对象前缀上的访问策略。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectPrefix |
string | 用于过滤的对象前缀,'' 代表整个存储桶。 |
callback(err, policy) |
function | 如果err 不是null则代表有错误。policy 是存储桶策略的字符串表示(minio.Policy.NONE ,minio.Policy.READONLY ,minio.Policy.WRITEONLY ,或者minio.Policy.READWRITE ). 如果没有传callback的话,则返回一个Promise 对象。 |
// Retrieve bucket policy of 'my-bucketname' that applies to all objects that
// start with 'img-'.
minioClient.getBucketPolicy('my-bucketname', 'img-', function(err, policy) {
if (err) throw err
console.log(`Bucket policy: ${policy}`)
})
设置指定存储桶的策略。如果objectPrefix
不为空,则会给符合该前缀的对象(们)设置策略。
参数
参数 | 类型 | 描述 |
---|---|---|
bucketName |
string | 存储桶名称。 |
objectPrefix |
string | 要设置访问策略的对象前缀。'' 代表整个存储桶。 |
bucketPolicy |
string | 存储桶策略。可选值有:minio.Policy.NONE ,minio.Policy.READONLY ,minio.Policy.WRITEONLY 或者minio.Policy.READWRITE 。 |
callback(err) |
function | 如果err 不是null则代表有错误。如果没有传callback的话,则返回一个Promise 对象。 |
// Set the bucket policy of `my-bucketname` to `readonly` (only allow retrieval),
// but only for objects that start with 'img-'.
minioClient.setBucketPolicy('my-bucketname', 'img-', minio.Policy.READONLY, function(err) {
if (err) throw err
console.log('Set bucket policy to \'readonly\'.')
})