更新时间:2024-12-12 GMT+08:00
分享

更新全域接入网关路由表

功能介绍

更新修改全域接入网关的路由表

调用方法

请参见如何调用API

URI

PUT /v3/{project_id}/dcaas/gdgw/{gdgw_id}/routetables

表1 路径参数

参数

是否必选

参数类型

描述

project_id

String

租户项目ID

gdgw_id

String

gdgw_id

请求参数

表2 请求Header参数

参数

是否必选

参数类型

描述

X-Auth-Token

String

用户Token。 获取Token,请参考《统一身份认证服务API参考》的“获取用户Token”章节。请求响应成功后在响应消息头中包含的“X-Subject-Token”的值即为Token值。

最小长度:0

最大长度:10240

表3 gdgw_routetable

参数

是否必选

参数类型

描述

add_routes

Array of add_routes objects

添加路由列表

del_routes

Array of del_routes objects

删除的路由列表

表4 add_routes

参数

是否必选

参数类型

描述

destination

String

目的地址

最小长度:0

最大长度:2147483647

nexthop

String

下一跳

最小长度:0

最大长度:255

type

String

'类型'

  • vif_peer
  • peer_link

最小长度:0

最大长度:255

description

String

说明

最小长度:0

最大长度:255

表5 del_routes

参数

是否必选

参数类型

描述

destination

String

目的地址

最小长度:0

最大长度:2147483647

nexthop

String

下一跳

最小长度:0

最大长度:255

type

String

'类型'

  • vif_peer
  • peer_link

最小长度:0

最大长度:255

响应参数

状态码: 200

表6 响应Header参数

参数

参数类型

描述

X-Request-Id

String

-

表7 ShowGdgwRoutetable

参数

参数类型

描述

id

String

全域接入网关路由表ID

tenant_id

String

用户ID

gateway_id

String

全域接入网关ID

destination

String

描述信息

nexthop

String

下一跳

type

String

类型

obtain_mode

String

获取模式

status

String

'状态'

  • ACTIVE 正常
  • ERROR 异常

address_family

String

地址簇:ipv4 | ipv6

description

String

描述信息

请求示例

PUT https://{dc_endpoint}/v3/{project_id}/dcaas/gdgw/0851a5e0-6623-42c2-bb02-b8956e313dd8/routetables

{
    "gdgw_routetable": {
        "add_routes": [
            {
                "destination": "1.1.1.0/24", 
                "nexthop": "b9060822-06bf-4c48-995d-29a3fb04a3c3", 
                "type": "vif_peer", 
                "description": ""
            }
        ]
    }
}

响应示例

{
    "gdgw_routetable": [
        {
            "id": "94912503-0a97-48ee-909b-6676129a565e", 
            "description": "", 
            "tenant_id": "4bd6efdb0fb747b39aa2c0162c112226", 
            "gateway_id": "0851a5e0-6623-42c2-bb02-b8956e313dd8", 
            "destination": "1.1.1.0/24", 
            "nexthop": "b9060822-06bf-4c48-995d-29a3fb04a3c3", 
            "type": "vif_peer", 
            "obtain_mode": "specific", 
            "status": "PENDING_CREATE", 
            "address_family": "ipv4"
        }
    ], 
    "request_id": "d365091f89df06c8737bd81a72efc8b2"
}

SDK代码示例

SDK代码示例如下。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
package com.huaweicloud.sdk.test;

import com.huaweicloud.sdk.core.auth.ICredential;
import com.huaweicloud.sdk.core.auth.BasicCredentials;
import com.huaweicloud.sdk.core.exception.ConnectionException;
import com.huaweicloud.sdk.core.exception.RequestTimeoutException;
import com.huaweicloud.sdk.core.exception.ServiceResponseException;
import com.huaweicloud.sdk.dc.v3.region.DcRegion;
import com.huaweicloud.sdk.dc.v3.*;
import com.huaweicloud.sdk.dc.v3.model.*;


public class UpdateGdgwRouteTableSolution {

    public static void main(String[] args) {
        // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
        // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
        String ak = System.getenv("CLOUD_SDK_AK");
        String sk = System.getenv("CLOUD_SDK_SK");
        String projectId = "{project_id}";

        ICredential auth = new BasicCredentials()
                .withProjectId(projectId)
                .withAk(ak)
                .withSk(sk);

        DcClient client = DcClient.newBuilder()
                .withCredential(auth)
                .withRegion(DcRegion.valueOf("<YOUR REGION>"))
                .build();
        UpdateGdgwRouteTableRequest request = new UpdateGdgwRouteTableRequest();
        request.withGdgwId("{gdgw_id}");
        UpdateGdgwRoutetableRequestBody body = new UpdateGdgwRoutetableRequestBody();
        request.withBody(body);
        try {
            UpdateGdgwRouteTableResponse response = client.updateGdgwRouteTable(request);
            System.out.println(response.toString());
        } catch (ConnectionException e) {
            e.printStackTrace();
        } catch (RequestTimeoutException e) {
            e.printStackTrace();
        } catch (ServiceResponseException e) {
            e.printStackTrace();
            System.out.println(e.getHttpStatusCode());
            System.out.println(e.getRequestId());
            System.out.println(e.getErrorCode());
            System.out.println(e.getErrorMsg());
        }
    }
}
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# coding: utf-8

import os
from huaweicloudsdkcore.auth.credentials import BasicCredentials
from huaweicloudsdkdc.v3.region.dc_region import DcRegion
from huaweicloudsdkcore.exceptions import exceptions
from huaweicloudsdkdc.v3 import *

if __name__ == "__main__":
    # The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    # In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak = os.environ["CLOUD_SDK_AK"]
    sk = os.environ["CLOUD_SDK_SK"]
    projectId = "{project_id}"

    credentials = BasicCredentials(ak, sk, projectId)

    client = DcClient.new_builder() \
        .with_credentials(credentials) \
        .with_region(DcRegion.value_of("<YOUR REGION>")) \
        .build()

    try:
        request = UpdateGdgwRouteTableRequest()
        request.gdgw_id = "{gdgw_id}"
        request.body = UpdateGdgwRoutetableRequestBody(
        )
        response = client.update_gdgw_route_table(request)
        print(response)
    except exceptions.ClientRequestException as e:
        print(e.status_code)
        print(e.request_id)
        print(e.error_code)
        print(e.error_msg)
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
package main

import (
	"fmt"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/basic"
    dc "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dc/v3"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dc/v3/model"
    region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dc/v3/region"
)

func main() {
    // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak := os.Getenv("CLOUD_SDK_AK")
    sk := os.Getenv("CLOUD_SDK_SK")
    projectId := "{project_id}"

    auth := basic.NewCredentialsBuilder().
        WithAk(ak).
        WithSk(sk).
        WithProjectId(projectId).
        Build()

    client := dc.NewDcClient(
        dc.DcClientBuilder().
            WithRegion(region.ValueOf("<YOUR REGION>")).
            WithCredential(auth).
            Build())

    request := &model.UpdateGdgwRouteTableRequest{}
	request.GdgwId = "{gdgw_id}"
	request.Body = &model.UpdateGdgwRoutetableRequestBody{
	}
	response, err := client.UpdateGdgwRouteTable(request)
	if err == nil {
        fmt.Printf("%+v\n", response)
    } else {
        fmt.Println(err)
    }
}

更多编程语言的SDK代码示例,请参见API Explorer的代码示例页签,可生成自动对应的SDK代码示例。

状态码

状态码

描述

200

OK

错误码

请参见错误码

相关文档