文档首页 > > API参考> 应用示例> 示例5:弹性云服务器挂载网卡

示例5:弹性云服务器挂载网卡

分享
更新时间: 2019/11/05 GMT+08:00

场景描述

当弹性云服务器需要多个网卡时,可以调用接口创建网卡,然后挂载至弹性云服务器。

您可以在创建云服务器时,通过设置“nics”参数值挂载网卡,也可以在创建云服务器成功后挂载网卡。本节主要介绍云服务器创建成功后挂载网卡的场景。

操作步骤

  1. 创建网卡。

    1. 创建网络。
      • 接口相关信息

        URI格式:POST /v2.0/networks

        详情请参见创建网络

      • 请求示例

        POST: https://{endpoint}/v2.0/networks

        {endpoint}信息请从地区和终端节点获取。

        Body:

        {
          "network": {
            "shared": false, 
            "name": "demo-net", 
            "admin_state_up": true, 
            "tenant_id": "74610f3a5ad941998e91f076297ecf27"
          }
        }
      • 响应示例
        {
          "network": {
            "id": "c4a3019d-1ac0-4cfb-a838-2342eb992e6b",
            "name": "demo-net",
            "status": "ACTIVE",
            "shared": false,
            "subnets": [],
            "availability_zone_hints": [],
            "availability_zones": [
             "az_test_01",
             "az_test_02"
            ],
            "admin_state_up": true,
            "tenant_id": "74610f3a5ad941998e91f076297ecf27",
            "provider:network_type": "vxlan",
            "router:external": false
          }
        }
    2. 记录响应中“network”的ID。
    3. 创建子网。
      • 接口相关信息

        URI格式:POST /v2.0/subnets

        详情请参见创建子网

      • 请求示例

        POST: https://{endpoint}/v2.0/subnets

        {endpoint}信息请从地区和终端节点获取。

        Body:

        {
            "subnet": {
                "name": "testsubnet",
                "enable_dhcp": true,
                "network_id": "c4a3019d-1ac0-4cfb-a838-2342eb992e6b",
                "tenant_id": "74610f3a5ad941998e91f076297ecf27",
                "dns_nameservers": [
                    "8.8.8.8",
                    "8.8.8.7"
                ],
                "allocation_pools": [
                    {
                        "start": "10.0.10.2",
                        "end": "10.0.10.254"
                    }
                ],
                "host_routes": [],
                "ip_version": 4,
                "gateway_ip": "10.0.10.1",
                "cidr": "10.0.10.0/24"
            }
        }
      • 响应示例
        {
          "subnet": {
            "name": "testsubnet",
            "cidr": "10.0.10.0/24",
            "id": "877b5567-e8c6-4a0d-aabf-0f13da225fe5",
            "enable_dhcp": true,
            "network_id": "c4a3019d-1ac0-4cfb-a838-2342eb992e6b",
            "tenant_id": "74610f3a5ad941998e91f076297ecf27",
            "dns_nameservers": [
              "8.8.8.8",
              "8.8.8.7"
            ],
            "allocation_pools": [
              {
                "start": "10.0.10.2",
                "end": "10.0.10.254"
              }
            ],
            "host_routes": [],
            "ip_version": 4,
            "gateway_ip": "10.0.10.1"
          }
        }
    4. 记录响应中“subnet”的ID。
    5. 创建端口。
      • 接口相关信息

        URI格式:POST /v2.0/ports

        详情请参见创建端口

      • 请求示例

        POST: https://{endpoint}/v2.0/ports

        {endpoint}信息请从地区和终端节点获取。

        Body:

        {
            "port": {
                "admin_state_up": true, 
        
                "fixed_ips": [
                    {
                        "subnet_id": "877b5567-e8c6-4a0d-aabf-0f13da225fe5"
                    }
                ], 
                "name": "test", 
                "network_id": "c4a3019d-1ac0-4cfb-a838-2342eb992e6b",
                "tenant_id": "74610f3a5ad941998e91f076297ecf27"
            }
        }
      • 响应示例
        {
          "port": {
            "id": "7bf1c36f-e7f8-478a-be3d-674b486abbc4",
            "name": "test",
            "status": "DOWN",
            "admin_state_up": true,
            "fixed_ips": [
              {
                "subnet_id": "877b5567-e8c6-4a0d-aabf-0f13da225fe5",
                "ip_address": "10.0.10.233"
              }
            ],
            "mac_address": "fa:16:3e:db:91:f6",
            "network_id": "c4a3019d-1ac0-4cfb-a838-2342eb992e6b",
            "tenant_id": "74610f3a5ad941998e91f076297ecf27",
            "device_id": "",
            "device_owner": "",
            "security_groups": [
              "93031677-2895-4b83-855a-637e309aa9e6"
            ],
            "extra_dhcp_opts": [],
            "allowed_address_pairs": [],
            "binding:vnic_type": "normal",
            "binding:vif_details": {},
            "binding:profile": {}
          }
        }
    6. 记录响应中“port”的ID。

  2. 挂载网卡。

    • 接口相关信息

      URI格式:POST /v2.1/{tenant_id}/servers/{server_id}/os-interface

      详情请参见“添加云服务器网卡”。

    • 请求示例

      POST: https://{endpoint}/v2.1/74610f3a5ad941998e91f076297ecf27/servers/9f4d9281-95e7-4915-a126-1ee597101e2e/os-interface

      {endpoint}信息请从地区和终端节点获取。

      Body:

      {
          "interfaceAttachment": {
              "port_id": "7bf1c36f-e7f8-478a-be3d-674b486abbc4"
          }
      }
    • 响应示例
      {
        "interfaceAttachment": {
          "port_state": "ACTIVE",
          "fixed_ips": [
            {
              "subnet_id": "877b5567-e8c6-4a0d-aabf-0f13da225fe5",
              "ip_address": "10.0.10.233"
            }
          ],
          "port_id": "7bf1c36f-e7f8-478a-be3d-674b486abbc4",
          "net_id": "c4a3019d-1ac0-4cfb-a838-2342eb992e6b",
          "mac_addr": "fa:16:3e:db:91:f6"
        }
      }

  3. 确认挂载结果。

    • 接口相关信息

      URI格式:GET /v2.1/{tenant_id}/servers/{server_id}/os-interface

      详情请参见查询云服务器网卡信息

    • 请求示例

      GET: https://{endpoint}/v2.1/74610f3a5ad941998e91f076297ecf27/servers/9f4d9281-95e7-4915-a126-1ee597101e2e/os-interface

      {endpoint}信息请从地区和终端节点获取。

    • 响应示例
      {
        "interfaceAttachments": [
          {
            "port_state": "ACTIVE",
            "fixed_ips": [
              {
                "subnet_id": "46712fe4-25bd-4eae-874b-a528abfb76be",
                "ip_address": "192.168.0.50"
              }
            ],
            "port_id": "dd706739-b696-40be-a9f4-477ce478cb18",
            "net_id": "17251a8f-a671-4d7c-85d9-af5415962994",
            "mac_addr": "fa:16:3e:a5:e0:3c"
          },
      {
            "port_state": "ACTIVE",
            "fixed_ips": [
              {
                "subnet_id": "877b5567-e8c6-4a0d-aabf-0f13da225fe5",
                "ip_address": "10.0.10.233"
              }
            ],
            "port_id": "7bf1c36f-e7f8-478a-be3d-674b486abbc4",
            "net_id": "c4a3019d-1ac0-4cfb-a838-2342eb992e6b",
            "mac_addr": "fa:16:3e:db:91:f6"
          }
        ]
      }

分享:

    相关文档

    相关产品

文档是否有解决您的问题?

提交成功!

非常感谢您的反馈,我们会继续努力做到更好!

反馈提交失败,请稍后再试!

*必选

请至少选择或填写一项反馈信息

字符长度不能超过200

提交反馈 取消

如您有其它疑问,您也可以通过华为云社区问答频道来与我们联系探讨

跳转到云社区