超时机制

更新时间:

本节主要介绍V2.0 Go SDK的超时配置方式。

超时配置方式

说明

超时配置优先级为:RuntimeOption配置->Client配置->默认,优先级依次降低。

  • 使用默认配置。默认连接超时为5秒,读超时为10秒。

  • 通过运行时参数(RuntimeOptions)配置超时时间。

    package main
    
    import (
    	"encoding/json"
    	"fmt"
    
    	openapi "github.com/alibabacloud-go/darabonba-openapi/v2/client"
    	ecs20140526 "github.com/alibabacloud-go/ecs-20140526/v3/client"
    	util "github.com/alibabacloud-go/tea-utils/v2/service"
    	"github.com/alibabacloud-go/tea/tea"
    )
    
    func main() {
    	config := &openapi.Config{
    		// 从环境变量获取RAM用户的AccessKey ID
    		AccessKeyId: tea.String("<AccessId>"),
    		// 从环境变量获取RAM用户的AccessKey Secret
    		AccessKeySecret: tea.String("<AccessSecret>"),
    		// Region ID
    		RegionId: tea.String("<RegionId>"),
    	}
    	client, _err := ecs20140526.NewClient(config)
    	if _err != nil {
    		panic(_err)
    	}
    	describeRegionsRequest := &ecs20140526.DescribeRegionsRequest{}
    	// 创建RuntimeObject实例并设置运行参数。
    	runtime := &util.RuntimeOptions{}
    	// 超时参数设置,单位 ms(毫秒)
    	runtime.ConnectTimeout = tea.Int(10000) // 设置连接超时为10秒
    	runtime.ReadTimeout = tea.Int(10000) // 设置读超时为10秒
    	resp, _err := client.DescribeRegionsWithOptions(describeRegionsRequest, runtime)
    	if _err != nil {
    		panic(_err)
    	}
    	body, err := json.Marshal(resp.Body)
    	if err != nil {
    		panic(err)
    	}
    	fmt.Printf("body: %s\n", string(body))
    }
    
  • 通过Config在初始化Client阶段配置超时时间。

    package main
    
    import (
    	"encoding/json"
    	"fmt"
    
    	openapi "github.com/alibabacloud-go/darabonba-openapi/v2/client"
    	ecs20140526 "github.com/alibabacloud-go/ecs-20140526/v3/client"
    	util "github.com/alibabacloud-go/tea-utils/v2/service"
    	"github.com/alibabacloud-go/tea/tea"
    )
    
    func main() {
    	config := &openapi.Config{
    		// 从环境变量获取RAM用户的AccessKey ID
    		AccessKeyId: tea.String("<AccessId>"),
    		// 从环境变量获取RAM用户的AccessKey Secret
    		AccessKeySecret: tea.String("<AccessSecret>"),
    		// Region ID
    		RegionId: tea.String("<RegionId>"),
    		// 超时参数设置,单位 ms(毫秒)
    		ConnectTimeout: tea.Int(10000), // 连接超时
    		ReadTimeout:    tea.Int(10000), // 读超时
    	}
    	client, _err := ecs20140526.NewClient(config)
    	if _err != nil {
    		panic(_err)
    	}
    	describeRegionsRequest := &ecs20140526.DescribeRegionsRequest{}
    	// 创建RuntimeObject实例并设置运行参数。
    	runtime := &util.RuntimeOptions{}
    	resp, _err := client.DescribeRegionsWithOptions(describeRegionsRequest, runtime)
    	if _err != nil {
    		panic(_err)
    	}
    	body, err := json.Marshal(resp.Body)
    	if err != nil {
    		panic(err)
    	}
    	fmt.Printf("body: %s\n", string(body))
    }