AWSSDKforGo1.0版本正式推出可在生产环境下使用

AWS SDK for GO 1.0版本正式推出 可在生产环境下使用

原创
作者:原文:Jeff Barr/编译:于雪 2015-11-20 15:28:36

云计算 长期以来,AWS致力于围绕组品促进和帮助开发者社区,AWS非常重视与开发者的直接沟通和协作能力,这也是为什么AWS将许多在GitHub上的库和工具开源出来的原因之一。在开源社区所有的经验中,有关AWS SDK for Go产生的过程是他们特别乐于分享的一个故事。

  “今年早些时候,我的同事Peter Moon分享了关于推出AWS SDK for Go的计划。如同你将看到的下面这封来自Peter的邮件中所提到的,该SDK 现在可以得到广泛使用了!“

— Jeff

长期以来,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完成了一些新的关键性改进,包括:

  • Sessions——易于共享配置和客户端之间的请求处理程序。
  • JMESPATH支持——查询和重塑复杂的API响应和其他使用简单的表达式结构。
  • Paginators——遍历列表类API响应多个页面。
  • Waiters——等待AWS资源内异步状态的变化
  • Documentation——更新开发者指南

下面是一个代码示例,这些示例对一些新功能进行了练习:

// 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 文档
  • 开发者指南

原文作者:Jeff Barr

名称栏目:AWSSDKforGo1.0版本正式推出可在生产环境下使用
网页网址:http://www.hantingmc.com/qtweb/news21/389121.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联