Go以AWS提供的SDK aws-sdk-go-v2
來取得操作VPC資源的API client。
事前要求
參考「AWS 建立IAM管理使用者及credentials」設定供應用程式存取AWS需要的credentials。
下載AWS SDK Go V2 modules
在專案根目錄執行以下命令下載需要的aws-sdk-go-v2
modules。
go get github.com/aws/aws-sdk-go-v2
go get github.com/aws/aws-sdk-go-v2/config
go get github.com/aws/aws-sdk-go-v2/service/ec2
建立VPC API client
操作VPC資源的API多位在ec2 package。
在Go程式中呼叫config.LoadDefaultConfig
傳入region參數(e.g. "ap-northeast-1"
)建立aws.Conifg
物件,AWS SDK預設會讀取$HOME/.aws/credentials
的access keys來通過權限驗證,然後依此參數呼叫ec2.NewFromConfig
建立ec2.Client
。
main.go
package main
import (
"context"
"github.com/aws/aws-sdk-go-v2/config"
"github.com/aws/aws-sdk-go-v2/service/ec2"
)
func NewEC2Client(ctx context.Context) *ec2.Client {
cfg, err := config.LoadDefaultConfig(
ctx,
config.WithRegion("ap-northeast-1"),
)
if err != nil {
panic(err)
}
return ec2.NewFromConfig(cfg) // Create an Amazon EC2 service client
}
func main() {
ctx := context.TODO()
client := NewEC2Client(ctx)
...
}
沒有留言:
張貼留言