SDK Golang
Puisque RustFS est un système de stockage d'objets entièrement compatible S3, vous pouvez construire un SDK Golang adapté à RustFS en encapsulant le SDK TypeScript S3. Grâce au SDK, vous pouvez opérer sur RustFS, y compris la création et la suppression de buckets/objets, le téléchargement et le téléchargement de fichiers, etc.
Prérequis
- Une instance RustFS fonctionnelle (consultez le Guide d'installation pour l'installation).
- Clés d'accès (consultez la Gestion des clés d'accès pour la création).
Construction du SDK Golang RustFS
Utilisez RUSTFS_ACCESS_KEY_ID
, RUSTFS_SECRET_ACCESS_KEY
, RUSTFS_ENDPOINT_URL
, RUSTFS_REGION
pour construire un aws.Config
, puis utilisez s3.NewFromConfig
du SDK S3 Golang pour construire un Client RustFS :
region := os.Getenv("RUSTFS_REGION")
access_key_id := os.Getenv("RUSTFS_ACCESS_KEY_ID")
secret_access_key := os.Getenv("RUSTFS_SECRET_ACCESS_KEY")
endpoint := os.Getenv("RUSTFS_ENDPOINT_URL")
// usePathStyle := strings.ToLower(os.Getenv("AWS_S3_USE_PATH_STYLE")) == "true"
if access_key_id == "" || secret_access_key == "" || region == "" || endpoint == "" {
log.Fatal("missing the env: RUSTFS_ACCESS_KEY_ID / RUSTFS_SECRET_ACCESS_KEY / RUSTFS_REGION / RUSTFS_ENDPOINT_URL")
}
// build aws.Config
cfg := aws.Config{
Region: region,
EndpointResolver: aws.EndpointResolverFunc(func(service, region string) (aws.Endpoint, error) {
return aws.Endpoint{
URL: endpoint,
}, nil
}),
Credentials: aws.NewCredentialsCache(credentials.NewStaticCredentialsProvider(access_key_id, secret_access_key, "")),
}
// build S3 client
client := s3.NewFromConfig(cfg, func(o *s3.Options) {
o.UsePathStyle = true
})
Ensuite, vous pouvez utiliser le Client RustFS construit pour effectuer des opérations de buckets et d'objets.
Créer un Bucket
_, err = client.CreateBucket(ctx, &s3.CreateBucketInput{
Bucket: aws.String("go-sdk-rustfs"),
})
if err != nil {
log.Fatalf("create bucket failed: %v", err)
}
Lister les Buckets
resp, err := client.ListBuckets(ctx, &s3.ListBucketsInput{})
if err != nil {
log.Fatalf("list buckets failed: %v", err)
}
fmt.Println("Buckets:")
for _, b := range resp.Buckets {
fmt.Println(" -", *b.Name)
}
Supprimer un Bucket
_, err = client.DeleteBucket(ctx, &s3.DeleteBucketInput{
Bucket: aws.String("go-sdk-rustfs"),
})
if err != nil {
log.Fatalf("delete bucket failed: %v", err)
}
Lister les Objets
resp, err := client.ListObjectsV2(ctx, &s3.ListObjectsV2Input{
Bucket: aws.String("bucket-target"),
})
if err != nil {
log.Fatalf("list object failed: %v", err)
}
for _, obj := range resp.Contents {
fmt.Println(" -", *obj.Key)
}
Télécharger un Objet
_, err = client.PutObject(ctx, &s3.PutObjectInput{
Bucket: aws.String("bucket-target"),
Key: aws.String("test.txt"),
Body: strings.NewReader("hello rustfs"),
})
if err != nil {
log.Fatalf("upload object failed: %v", err)
}
Télécharger un Objet
resp, err := client.GetObject(ctx, &s3.GetObjectInput{
Bucket: aws.String("bucket-target"),
Key: aws.String("1.txt"),
})
if err != nil {
log.Fatalf("download object fail: %v", err)
}
defer resp.Body.Close()
// read object content
data, err := io.ReadAll(resp.Body)
if err != nil {
log.Fatalf("read object content fail: %v", err)
}
fmt.Println("content is :", string(data))
Pour d'autres utilisations, vous pouvez explorer par vous-même. Avec Vibe Coding, c'est encore plus simple !