阿里云开发者Go工具套件

简介:

欢迎使用阿里云开发者工具套件(SDK)。阿里云Go SDK让您不用复杂编程即可访问云服务器、云监控等多个阿里云服务。这里向您介绍如何获取阿里云Go SDK并开始调用。如果您在使用SDK的过程中遇到任何问题,欢迎前往阿里云SDK问答社区提问,提问前请阅读提问引导。亦可在当前GitHub提交Issues。
环境准备
要使用阿里云Go SDK,您需要一个云账号以及一对Access Key ID和Access Key Secret。 请在阿里云控制台中的AccessKey管理页面上创建和查看您的Access Key,或者联系您的系统管理员
要使用阿里云SDK访问某个产品的API,您需要事先在阿里云控制台中开通这个产品。
SDK获取和安装
使用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
另外,阿里云Go SDK也会发布在 https://develop.aliyun.com/tools/sdk#/go 这个地址。

开始调用
以下这个代码示例向您展示了调用阿里云GO SDK的3个主要步骤:

创建Client实例
创建API请求并设置参数
发起请求并处理异常
package main

import (

"github.com/aliyun/alibaba-cloud-sdk-go/services/ecs"
"fmt"

)

func main() {

// 创建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 {
    // 异常处理
    panic(err)
}
// 创建API请求并设置参数
request := ecs.CreateDescribeInstancesRequest()
request.PageSize = "10"
// 发起请求并处理异常
response, err := ecsClient.DescribeInstances(request)
if err != nil {
    // 异常处理
    panic(err)
}
fmt.Println(response)

}
在创建Client实例时,您需要填写3个参数:Region ID、Access Key ID和Access Key Secret。Access Key ID和Access Key Secret可以从控制台获得;而Region ID可以从地域列表中获得

Keepalive
阿里云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)
并发请求
因Go语言的并发特性,我们建议您在应用层面控制SDK的并发请求。
为了方便您的使用,我们也提供了可直接使用的并发调用方式,相关的并发控制由SDK内部实现。
开启SDK Client的并发功能
// 最大并发数
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
使用callback控制回调
blocker := client.FooWithCallback(request, func(response *FooResponse, err error) {

    // handle the response and err
})

// blocker 为(chan int),用于控制同步,返回1为成功,0为失败
// 在<-blocker返回失败时,err依然会被传入的callback处理
result := <-blocker
泛化调用接口(CommonApi)
什么是CommonAPI
CommonAPI是阿里云SDK推出的,泛用型的API调用方式。CommonAPI具有以下几个特点:

轻量:只需Core包即可发起调用,无需下载安装各产品线SDK。
简便:无需更新SDK即可调用最新发布的API。
快速迭代
开始使用
CommonAPI,需要配合相应的API文档使用,以查询API的相关信息。

您可以在 文档中心 查询到所有产品的API文档。

发起一次CommonAPI请求,需要您查询到以下几个参数:

域名(domain):即该产品的通用访问域名,一版可以在”调用方式”页查看到
API版本(version):即该API的版本号,以’YYYY-MM-DD’的形式表现,一般可以在”公共参数”页面查到
接口名称(apiName):即该API的名称
我们以Ecs产品的DescribeInstanceStatus API为例

package main

import (

"github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests"
"github.com/aliyun/alibaba-cloud-sdk-go/sdk"
"fmt"

)

func main() {

client, err := sdk.NewClientWithAccessKey("cn-hangzhou", "{your_access_key_id}", "{your_access_key_id}")
if err != nil {
    panic(err)
}

request := requests.NewCommonRequest()
request.Domain = "ecs.aliyuncs.com"
request.Version = "2014-05-26"
request.ApiName = "DescribeInstanceStatus"

request.QueryParams["PageNumber"] = "1"
request.QueryParams["PageSize"] = "30"

response, err := client.ProcessCommonRequest(request)
if err != nil {
    panic(err)
}

fmt.Print(response.GetHttpContentString())

}
转自:阿里云优惠券

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
目录
相关文章
|
6月前
|
网络协议 Linux Go
分享一个go开发的工具-SNMP Server
分享一个go开发的工具-SNMP Server
147 0
|
19天前
|
JSON 监控 安全
go语言选择合适的工具和库
【10月更文挑战第17天】
11 2
|
3月前
|
Shell Go
Go 语言Air 工具使用入门
在Go开发中,频繁的手动重启应用以加载新代码既耗时又低效。为此,我们引入了Air——一款专为Go项目设计的自动重载工具。Air通过监听文件变化,实现代码更改后的自动编译与运行,极大提升了开发效率。本文将指导你完成Air的安装与配置,包括如何启动Air、忽略临时文件以及理解其工作原理,让Go项目开发更加流畅高效。
|
3月前
|
Kubernetes 数据可视化 Java
|
3月前
|
算法 测试技术 Go
|
3月前
|
关系型数据库 MySQL Go
Go - 代码生成工具
Go - 代码生成工具
34 3
|
3月前
|
JSON Go 数据格式
Go - 使用工具生成易读的 Protocol 文档
Go - 使用工具生成易读的 Protocol 文档
23 1
|
3月前
|
编译器 Go
Go语言中的闭包:封装数据与功能的强大工具
Go语言中的闭包:封装数据与功能的强大工具
|
3月前
|
Java Go PHP
Go - 关于 protoc 工具的小疑惑
Go - 关于 protoc 工具的小疑惑
26 0
|
6月前
|
编译器 Go 索引
浅谈go语言中的符文字符处理工具
【5月更文挑战第20天】本文简述了Go 1.20之后的rune符文处理工具和函数,`unsafe`包新增了SliceData、String和StringData函数,支持直接将slice转换为array,明确了数组和结构体比较顺序。
47 1
浅谈go语言中的符文字符处理工具