すべてのプロダクト
Search
ドキュメントセンター

Object Storage Service:オブジェクトの解凍 (Go SDK V2)

最終更新日:Apr 03, 2026

アーカイブ、コールドアーカイブ、およびディープコールドアーカイブのストレージクラスに格納されたオブジェクトは、読み取り前に解凍する必要があります。オブジェクトを解凍すると、元のアーカイブ済みオブジェクトと並行して存在する一時的なレプリカが作成されます。解凍期間が終了すると、このレプリカは自動的に削除されます。本トピックでは、Object Storage Service (OSS) Go SDK を使用して、アーカイブ、コールドアーカイブ、およびディープコールドアーカイブのストレージクラスからオブジェクトを解凍する方法について説明します。

注意事項

  • RestoreObject メソッドは、アーカイブ、コールドアーカイブ、またはディープコールドアーカイブのストレージクラスに格納されたオブジェクトに対してのみ呼び出すことができます。

  • 本トピックのコード例では、リージョン ID cn-hangzhou の中国 (杭州) リージョンを使用しています。デフォルトではパブリックエンドポイントが使用されます。同一リージョン内の他の Alibaba Cloud サービスから OSS にアクセスする場合は、内部エンドポイントをご利用ください。OSS がサポートするリージョンおよびエンドポイントの詳細については、「リージョンとエンドポイント」をご参照ください。

  • 本トピックのコード例では、アクセス認証情報を環境変数から読み込みます。アクセス認証情報の設定方法については、「アクセス認証情報の設定」をご参照ください。

  • オブジェクトを解凍するには、oss:RestoreObject 権限が必要です。詳細については、「RAM ユーザーへのカスタムポリシーのアタッチ」をご参照ください。

メソッドシグネチャ

func (c *Client) RestoreObject(ctx context.Context, request *RestoreObjectRequest, optFns ...func(*Options)) (*RestoreObjectResult, error)

リクエストパラメーター

パラメーター

説明

ctx

context.Context

リクエストコンテキスト。リクエストの合計タイムアウト持続時間を設定するために使用します。

request

*RestoreObjectRequest

リクエストパラメーター。詳細については、「RestoreObjectRequest」をご参照ください。

optFns

...func(*Options)

(任意)操作レベルの構成パラメーター。詳細については、「Options」をご参照ください。

以下の表に、RestoreObjectRequest の共通パラメーターを示します。

パラメーター

説明

bucket

*string

バケット名。

key

*string

オブジェクト名。

versionId

*string

解凍対象のオブジェクトのバージョン ID。このパラメーターを指定しない場合、OSS は最新バージョンのオブジェクトを解凍します。

restoreRequest

*RestoreRequest

解凍リクエストパラメーター。

以下の表に、RestoreRequest のパラメーターを示します。

パラメーター

説明

days

int32

オブジェクトが解凍状態で保持される日数。詳細については、「オブジェクトの解凍」をご参照ください。

jobParameters

*JobParameters

解凍優先度を指定するパラメーター。Tier フィールドは、オブジェクトの解凍に必要な時間を指定します。詳細については、「オブジェクトの解凍」をご参照ください。

レスポンスパラメーター

パラメーター

説明

result

*RestoreObjectResult

API の戻り値。この値は errnil の場合に有効です。詳細については、「RestoreObjectResult」をご参照ください。

err

error

リクエストが失敗した場合、非 nil のエラー オブジェクトが返されます。

コード例

以下のコードを使用して、アーカイブ、コールドアーカイブ、またはディープコールドアーカイブのストレージクラスからオブジェクトを解凍します。

package main

import (
	"context"
	"flag"
	"log"

	"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
	"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)

// コマンドライン引数用のグローバル変数を定義します。
var (
	region     string // OSS リージョン。
	bucketName string // バケット名。
	objectName string // オブジェクト名。
)

// init はコマンドラインフラグの初期化を行います。
func init() {
	flag.StringVar(&region, "region", "", "バケットが配置されているリージョン。")
	flag.StringVar(&bucketName, "bucket", "", "バケット名。")
	flag.StringVar(&objectName, "object", "", "オブジェクト名。")
}

func main() {
	// コマンドラインフラグを解析します。
	flag.Parse()

	// バケット名が空かどうかを確認します。
	if len(bucketName) == 0 {
		flag.PrintDefaults()
		log.Fatalf("無効なパラメーター:バケット名は必須です")
	}

	// リージョンが空かどうかを確認します。
	if len(region) == 0 {
		flag.PrintDefaults()
		log.Fatalf("無効なパラメーター:リージョンは必須です")
	}

	// オブジェクト名が空かどうかを確認します。
	if len(objectName) == 0 {
		flag.PrintDefaults()
		log.Fatalf("無効なパラメーター:オブジェクト名は必須です")
	}

	// デフォルト構成を読み込み、認証情報プロバイダーとリージョンを設定します。
	cfg := oss.LoadDefaultConfig().
		WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
		WithRegion(region)

	// OSS クライアントを作成します。
	client := oss.NewClient(cfg)

	// オブジェクトの解凍リクエストを作成します。
	request := &oss.RestoreObjectRequest{
		Bucket: oss.Ptr(bucketName), // バケット名。
		Key:    oss.Ptr(objectName), // オブジェクト名。
		RestoreRequest: &oss.RestoreRequest{
			Days: 3, // 解凍期間を 3 日間に設定します。
		},
	}

	// オブジェクトの解凍リクエストを送信します。
	result, err := client.RestoreObject(context.TODO(), request)
	if err != nil {
		log.Fatalf("オブジェクトの解凍に失敗しました:%v", err)
	}

	// 結果を出力します。
	log.Printf("オブジェクトの解凍結果:%#v\n", result)
}

ユースケース

一時的なレプリカの削除

コールドアーカイブまたはディープコールドアーカイブのストレージクラスからオブジェクトを解凍すると、アクセス用の一時的なレプリカが作成されます。このレプリカに対しては、解凍期間が終了するまでストレージ料金が発生します。解凍状態を早期に終了し、レプリカに対する課金を停止したい場合は、CleanRestoredObject リクエストを送信できます。リクエストが完了すると、オブジェクトは凍結ステータスに戻り、直接アクセスできなくなります。

package main

import (
	"context"
	"flag"
	"log"

	"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
	"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)

// コマンドライン引数を格納するためのグローバル変数を定義します。
var (
	region     string // OSS リージョン。
	bucketName string // バケット名。
	objectName string // オブジェクト名。
)

// init はコマンドラインフラグパーサーを初期化し、デフォルト値とヘルプメッセージを設定します。
func init() {
	flag.StringVar(&region, "region", "", "バケットが配置されているリージョン。必須。")
	flag.StringVar(&bucketName, "bucket", "", "バケット名。必須。")
	flag.StringVar(&objectName, "object", "", "オブジェクト名。必須。")
}

func main() {
	// コマンドラインフラグを解析します。
	flag.Parse()

	// 必須パラメーターであるリージョンが指定されているか確認します。
	if len(region) == 0 {
		flag.PrintDefaults()
		log.Fatalf("無効なパラメーター:リージョンは必須です")
	}

	// 必須パラメーターであるバケット名が指定されているか確認します。
	if len(bucketName) == 0 {
		flag.PrintDefaults()
		log.Fatalf("無効なパラメーター:バケット名は必須です")
	}

	// 必須パラメーターであるオブジェクト名が指定されているか確認します。
	if len(objectName) == 0 {
		flag.PrintDefaults()
		log.Fatalf("無効なパラメーター:オブジェクト名は必須です")
	}

	// デフォルト構成を読み込み、環境変数から認証情報を読み取るよう認証情報プロバイダーを設定し、リージョンを設定します。
	cfg := oss.LoadDefaultConfig().
		WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
		WithRegion(region)

	// OSS クライアントを作成します。
	client := oss.NewClient(cfg)

	// 解凍済みオブジェクトの一時的なレプリカを削除するリクエストを作成します。
	request := &oss.CleanRestoredObjectRequest{
		Bucket: oss.Ptr(bucketName), // バケット名を設定します。
		Key:    oss.Ptr(objectName), // オブジェクト名を設定します。
	}

	// 一時的なレプリカを削除するリクエストを送信します。
	result, err := client.CleanRestoredObject(context.TODO(), request)
	if err != nil {
		log.Fatalf("解凍済みオブジェクトの削除に失敗しました:%v", err)
	}

	// 結果を出力します。
	log.Printf("解凍済みオブジェクトの削除結果:%#v\n", result)
}

参照

  • オブジェクトを復元するための完全なサンプルコードについては、「GitHub」をご参照ください。

  • オブジェクトを復元するためのAPI オペレーションの詳細については、「RestoreObject」をご参照ください。

  • オブジェクトの復元方法の詳細については、「オブジェクトの復元」をご参照ください。