AWS SDK for Go 1.0版本正式推出
发布日期:2016-7-9 19:7:45
长期以来,AWS致力于围绕其产品促进和帮助开发者社区的进步。AWS十分重视与开发者的直接沟通和协作能力,这也是为何其将许多在GitHub上的库和工具开源出来的原因之一。在这所有经验中,有关AWS SDK for Go产生的过程是一个他们特别乐于分享的故事。 11月19日,AWS宣布AWS SDK for Go 1.0版本正式发布并推荐在生产环境中使用。像AWS许多项目一样,该SDK同样遵循语义化版本号Sematic Versioning,也就是说若你从1.0版本开始上手,之后的SDK升级都可在任意1.X版本内进行,不会影响开发者用现有的代码继续工作。 自六月开发者预览版本发布后,AWS SDK For Go完成了一些新的关键性改进,包括: Paginators——遍历列表类API响应多个页面。 Sessions——易于共享配置和客户端之间的请求处理程序。 Documentation——更新开发者指南 Waiters——等待AWS资源内异步状态的变化 JMESPATH支持——查询和重塑复杂的API响应和其他使用简单的表达式结构。 下面是一个代码示例,这些示例对一些新功能进行了练习: // Create a session s := session.New(aws.NewConfig().WithRegion("us-west-2")) // Add a handler to print every API request for the session s.Handlers.Send.PushFront(func(r *request.Request) { fmt.Printf("Request: %s/%s\n", r.ClientInfo.ServiceName, r.Operation) }) // We want to start all instances in a VPC, so let's get their IDs first. ec2client := ec2.New(s) var instanceIDsToStart []*string describeInstancesInput := &ec2.DescribeInstancesInput{ Filters: []*ec2.Filter{ &ec2.Filter{ Name: aws.String("vpc-id"), Values: aws.StringSlice([]string{"vpc-82977de9"}), }, }, } // Use a paginator to easily iterate over multiple pages of response ec2client.DescribeInstancesPages(describeInstancesInput, func(page *ec2.DescribeInstancesOutput, lastPage bool) bool { // Use JMESPath expressions to query complex structures ids, _ := awsutil.ValuesAtPath(page, "Reservations[].Instances[].InstanceId") for _, id := range ids { instanceIDsToStart = append(instanceIDsToStart, id.(*string)) } return !lastPage }) // The SDK provides several utility functions for literal <--> pointer transformation fmt.Println("Starting:", aws.StringValueSlice(instanceIDsToStart)) // Skipped for brevity here, but *always* handle errors in the real world :) ec2client.StartInstances(&ec2.StartInstancesInput{ InstanceIds: instanceIDsToStart, }) // Finally, use a waiter function to wait until the instances are running ec2client.WaitUntilInstanceRunning(describeInstancesInput) fmt.Println("Instances are now running.") 了解更多信息请参阅: AWS SDK for Go仓库 API 文档 开发者指南
|