|
|
8 years ago | |
|---|---|---|
| ChangeLog.txt | 8 years ago | |
| LICENSE | 8 years ago | |
| README.md | 8 years ago |
欢迎使用阿里云开发者工具套件(SDK)。阿里云Go SDK让您不用复杂编程即可访问云服务器、云监控等多个阿里云服务。这里向您介绍如何获取阿里云Go SDK并开始调用。
Access Key ID和Access Key Secret。 请在阿里云控制台中的AccessKey管理页面上创建和查看您的Access Key,或者联系您的系统管理员使用go get下载安装SDK
go get -u github.com/aliyun/alibaba-cloud-sdk-go/sdk
如果您使用了glide管理依赖,您也可以使用glide来安装阿里云GO SDK
glide get github.com/aliyun/alibaba-cloud-sdk-go
另外,阿里云Java SDK也会发布在 https://develop.aliyun.com/tools/sdk#/go 这个地址。
以下这个代码示例向您展示了调用阿里云GO SDK的3个主要步骤:
import(
github.com/aliyun/aliyun-openapi-go-sdk/services/ecs
github.com/aliyun/aliyun-openapi-go-sdk/services/rds
)
// 创建ecsClient实例
ecsClient, err := ecs.NewClientWithAccessKey(
"<your-region-id>", // 您的可用区ID
"<your-access-key-id>", // 您的Access Key ID
"<your-access-key-secret>") // 您的Access Key Secret
if err != nil {
// 异常处理
}
// 创建API请求并设置参数
request := ecs.CreateDescribeInstancesRequest()
request.PageSize = "10"
// 发起请求并处理异常
response, err := ecsClient.DescribeInstances(request)
if err != nil {
// 异常处理
}
在创建Client实例时,您需要填写3个参数:Region ID、Access Key ID和Access Key Secret。Access Key ID和Access Key Secret可以从控制台获得;而Region ID可以从地域列表中获得
阿里云Go SDK底层使用Go语言原生的net/http收发请求,因此配置方式与net/http相同,您可以通过config直接将配置传递给底层的httpClient
httpTransport := http.Transport{
// set http client options
}
config := sdk.NewConfig()
.WithHttpTransport(httpTransport)
.WithTimeout(timeout)
ecsClient, err := ecs.NewClientWithOptions(config)
// 最大并发数
poolSize := 2
// 可缓存的最大请求数
maxTaskQueueSize := 5
// 在创建时开启异步功能
config := sdk.NewConfig()
.WithEnableAsync(true)
.WithGoRoutinePoolSize(poolSize) // 可选,默认5
.WithMaxTaskQueueSize(maxTaskQueueSize) // 可选,默认1000
ecsClient, err := ecs.NewClientWithOptions(config)
// 也可以在client初始化后再开启
client.EnableAsync(poolSize, maxTaskQueueSize)
阿里云Go SDK支持两种方式的异步调用:
使用channel作为返回值
responseChannel, errChannel := client.FooWithChan(request)
// this will block
response := <-responseChannel
err = <-errChannel
blocker := client.FooWithCallback(request, func(response *FooResponse, err error) {
// handle the response and err
})
// blocker 为(chan int),用于控制同步,返回1为成功,0为失败
// 在<-blocker返回失败时,err依然会被传入的callback处理
result := <-blocker
阿里云Go SDK提供了一个特殊的"泛化调用接口",该接口具有以下特点:
具体的使用方法,请参考官方文档