OSS 简介
OSS(Object Storage Service)通常指的是对象存储服务,它是一种数据存储架构,用于存储和检索非结构化数据,如图片、视频、文档和备份等。对象存储服务与传统的块存储和文件存储不同,它将数据作为对象来存储,每个对象都包含数据、元数据和一个唯一的标识符。
在对象存储系统中,数据被组织成一个扁平的结构,而不是传统的文件系统中的层级结构。这种结构使得对象存储服务具有以下特点:
- 高扩展性:可以轻松地扩展存储容量,以适应不断增长的数据量。
- 高可用性:通常提供冗余存储,确保数据在硬件故障时仍然可用。
- 易用性:通过简单的API进行数据管理,便于开发者使用。
- 低成本:相对于传统的存储解决方案,对象存储通常具有更低的成本。
OSS可以是任何提供对象存储服务的平台,例如Amazon S3、Azure Blob Storage、Google Cloud Storage以及开源的MinIO。这些服务允许用户通过互联网存储和检索大量数据,并且通常与云计算服务紧密集成,为用户提供灵活、可靠的存储解决方案。
MinIO 核心特性
- 性能:提供了高性能的对象存储服务,特别是在处理大量小文件时表现出色。
- 简单性:安装和配置相对简单,用户界面直观,易于管理,部署简单。
- 轻量级:MinIO具有轻量级的架构,可以快速部署在任何类型的基础设施上,包括Kubernetes、Docker、VMware和裸服务器。
- 可扩展性:分布式架构,支持水平扩展,可以根据需求增加存储容量和性能。
- 数据保护:支持纠删码和数据冗余,确保数据的可靠性和持久性。
- 安全性:提供多种安全特性,包括TLS加密、身份验证和访问控制。
- 社区和企业支持:MinIO有一个活跃的开源社区,并提供企业支持选项。
- 兼容性:MinIO与Amazon S3 API兼容,可以使用现有的S3工具和应用程序与MinIO进行交互。
MinIO 基础使用
部署
这里测试时使用的是 Docker 进行部署。
docker run -p 9000:9000 -p 9001:9001 --name minio -e "MINIO_ROOT_USER=localadmin" -e "MINIO_ROOT_PASSWORD=localadminpassword" -v H:/test/minio/data:/data -v H:/test/minio/config:/root/.minio minio/minio server /data --console-address ":9001"
docker-compose.yaml
services:
minio:
image: minio/minio
container_name: minio
ports:
- 9000:9000
- 9001:9001
volumes:
- H:/test/minio/data:/data
- H:/test/minio/config:/root/.minio
environment:
- MINIO_ROOT_USER=localadmin
- MINIO_ROOT_PASSWORD=localadminpassword
command: server /data --console-address ":9001"
部署成功后,打开 http://127.0.0.1:9001 可看到管理页面。
登录进入控制台
Go SDK 上传文件示例
package main
import (
"context"
"log"
"github.com/minio/minio-go/v7"
"github.com/minio/minio-go/v7/pkg/credentials"
)
func main() {
ctx := context.Background()
endpoint := "127.0.0.1:9000"
accessKeyID := "localadmin"
secretAccessKey := "localadminpassword"
useSSL := false
// Initialize minio client object.
minioClient, err := minio.New(endpoint, &minio.Options{
Creds: credentials.NewStaticV4(accessKeyID, secretAccessKey, ""),
Secure: useSSL,
})
if err != nil {
log.Fatalln(err)
}
// Make a new bucket called testbucket.
bucketName := "testbucket"
location := "us-east-1"
err = minioClient.MakeBucket(ctx, bucketName, minio.MakeBucketOptions{
Region: location})
if