Documentation ¶
Overview ¶
Copyright 2015 Beijing Venusource Tech.Co.Ltd. All rights reserved. Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.
ECS API使用的数据类型 ¶
Copyright 2015 Beijing Venusource Tech.Co.Ltd. All rights reserved. Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.
阿里云ECS API go语言版本
Index ¶
- Constants
- func AddNotNullFieldToParams(params *util.OrderedParams, value string, fieldName string)
- type AccountType
- type AllocatePublicIpAddressResponse
- type AuthorizeSecurityGroupEgressRequest
- type AuthorizeSecurityGroupRequest
- type AutoSnapshotExecutionStatusType
- type AutoSnapshotPolicyType
- type AvailableDiskCategoriesType
- type AvailableResourceCreationType
- type Client
- func (c *Client) AllocatePublicIpAddress(instanceId string) (string, error)
- func (c *Client) AuthorizeSecurityGroup(request *AuthorizeSecurityGroupRequest) (*EcsBaseResponse, error)
- func (c *Client) AuthorizeSecurityGroupEgress(request *AuthorizeSecurityGroupEgressRequest) (*EcsBaseResponse, error)
- func (c *Client) CreateInstance(instance InstanceAttributesType, password string, securityGroupId string) (string, error)
- func (c *Client) CreateInstanceByRequest(request *CreateInstanceRequest) (*CreateInstanceResponse, error)
- func (c *Client) CreateSecurityGroup(request *CreateSecurityGroupRequest) (*CreateSecurityGroupResponse, error)
- func (c *Client) Debug(enabled bool)
- func (c *Client) DeleteInstance(instanceId string) error
- func (c *Client) DeleteSecurityGroup(request *DeleteSecurityGroupRequest) (*EcsBaseResponse, error)
- func (c *Client) DescribeInstanceAttribute(regionId string, instanceId string) (*InstanceAttributesType, error)
- func (c *Client) DescribeInstances(regionId string) (*DescribeInstancesResponse, error)
- func (c *Client) DescribeInstancesByRequest(request *DescribeInstancesRequest) (*DescribeInstancesResponse, error)
- func (c *Client) DescribeRegions(request *DescribeRegionsRequest) (*DescribeRegionsResponse, error)
- func (c *Client) RebootInstance(instanceId string, forceStop string) error
- func (c *Client) RevokeSecurityGroup(request *RevokeSecurityGroupRequest) (*EcsBaseResponse, error)
- func (c *Client) RevokeSecurityGroupEgress(request *RevokeSecurityGroupEgressRequest) (*EcsBaseResponse, error)
- func (c *Client) StartInstance(instanceId string) error
- func (c *Client) StopInstance(instanceId string, forceStop string) error
- type ClusterType
- type CreateInstanceRequest
- type CreateInstanceResponse
- type CreateSecurityGroupRequest
- type CreateSecurityGroupResponse
- type DeleteSecurityGroupRequest
- type DescribeInstancesRequest
- type DescribeInstancesResponse
- type DescribeRegionsRequest
- type DescribeRegionsResponse
- type DiskDeviceMapping
- type DiskItemType
- type DiskMonitorDataType
- type DiskSetType
- type EcsBaseResponse
- type EipAddressAssociateType
- type EipAddressSetType
- type EipMonitorDataType
- type ImageType
- type InstanceAttributesType
- type InstanceMonitorDataType
- type InstanceStatusItemType
- type InstanceStatusSetType
- type InstanceTypeItemType
- type Instances
- type IpAddressSetType
- type IpRangeSetType
- type OperationLocksType
- type PermissionSetType
- type PermissionType
- type RegionType
- type Regions
- type RevokeSecurityGroupEgressRequest
- type RevokeSecurityGroupRequest
- type RouteEntrySetType
- type RouteTableSetType
- type SecurityGroupIdSetType
- type SecurityGroupItemType
- type SecurityGroupSetType
- type ShareGroupType
- type SnapshotType
- type VRouterSetType
- type VSwitchSetType
- type VpcAttributesType
- type VpcSetType
- type ZoneType
Examples ¶
Constants ¶
const ( API_SERVER = "http://ecs.aliyuncs.com/" VERSION = "2014-05-26" //API版本 SIGNATURE_VERSION = "1.0" //签名版本 SIGNATURE_METHOD_HMAC_SHA1 = "HMAC-SHA1" //HMAC-SHA1签名 ACCESS_KEY_ID_PARAM = "AccessKeyId" //access key id SIGNATURE_VERSION_PARAM = "SignatureVersion" NONCE_PARAM = "SignatureNonce" SIGNATURE_METHOD_PARAM = "SignatureMethod" SIGNATURE_PARAM = "Signature" TIMESTAMP_PARAM = "Timestamp" VERSION_PARAM = "Version" )
定义常量
Variables ¶
This section is empty.
Functions ¶
func AddNotNullFieldToParams ¶
func AddNotNullFieldToParams(params *util.OrderedParams, value string, fieldName string)
Types ¶
type AllocatePublicIpAddressResponse ¶
type AllocatePublicIpAddressResponse struct { EcsBaseResponse IpAddress string `json:"IpAddress"` //公网IP地址 }
分配公网IP返回对象
type AuthorizeSecurityGroupEgressRequest ¶
type AuthorizeSecurityGroupEgressRequest struct { Action string SecurityGroupId string RegionId string // IP协议,取值:tcp | udp | icmp | gre | all;all表示同时支持四种协议 IpProtocol string // IP协议相关的端口号范围 // 协议为tcp、udp时默认端口号,取值范围为1~65535;例如“1/200”意思是端口号范围为1~200,若输入值为:“200/1”接口调用将报错。 // 协议为icmp时端口号范围值为-1/-1; // gre协议时端口号范围值为-1/-1; // 协议为all时端口号范围值为-1/-1 PortRange string DestGroupId string DestGroupOwnerAccount string // 目标IP地址范围(采用CIDR格式来指定IP地址范围),默认值为0.0.0.0/0(表示不受限制),其他支持的格式如10.159.6.18/12或10.159.6.186。仅支持IPV4。 DestCidrIp string // 授权策略,参数值可为:accept(接受访问),drop (拒绝访问) 默认值为:accept Policy string // 授权策略优先级,参数值可为:1-100 默认值为:1 Priority string // 网络类型,取值: // internet // intranet; // 默认值为internet // 当对安全组进行相互授权时(即指定了SourceGroupId且没有指定SourceCidrIp),必须指定NicType为intranet NicType string }
授权安全组In方向的访问权限
func (*AuthorizeSecurityGroupEgressRequest) AddToParams ¶
func (r *AuthorizeSecurityGroupEgressRequest) AddToParams(params *util.OrderedParams) error
func (*AuthorizeSecurityGroupEgressRequest) Validate ¶
func (r *AuthorizeSecurityGroupEgressRequest) Validate() error
type AuthorizeSecurityGroupRequest ¶
type AuthorizeSecurityGroupRequest struct { Action string SecurityGroupId string RegionId string // IP协议,取值:tcp | udp | icmp | gre | all;all表示同时支持四种协议 IpProtocol string // IP协议相关的端口号范围 // 协议为tcp、udp时默认端口号,取值范围为1~65535;例如“1/200”意思是端口号范围为1~200,若输入值为:“200/1”接口调用将报错。 // 协议为icmp时端口号范围值为-1/-1; // gre协议时端口号范围值为-1/-1; // 协议为all时端口号范围值为-1/-1 PortRange string SourceGroupId string SourceGroupOwnerAccount string // 源IP地址范围(采用CIDR格式来指定IP地址范围),默认值为0.0.0.0/0(表示不受限制),其他支持的格式如10.159.6.18/12或10.159.6.186。仅支持IPV4。 SourceCidrIp string // 授权策略,参数值可为:accept(接受访问),drop (拒绝访问) 默认值为:accept Policy string // 授权策略优先级,参数值可为:1-100 默认值为:1 Priority string // 网络类型,取值: // internet // intranet; // 默认值为internet // 当对安全组进行相互授权时(即指定了SourceGroupId且没有指定SourceCidrIp),必须指定NicType为intranet NicType string }
授权安全组In方向的访问权限
func (*AuthorizeSecurityGroupRequest) AddToParams ¶
func (r *AuthorizeSecurityGroupRequest) AddToParams(params *util.OrderedParams) error
func (*AuthorizeSecurityGroupRequest) Validate ¶
func (r *AuthorizeSecurityGroupRequest) Validate() error
type AutoSnapshotExecutionStatusType ¶
type AutoSnapshotExecutionStatusType struct { /* 返回最近一次执行的状态:Standby|Executed|Failed Standby:刚设置完成还未开始执行或者系统盘的策略被关闭 Executed:执行成功 Failed:执行失败 */ SystemDiskExecutionStatus string /* 返回最近一次执行的状态:Standby|Executed|Failed Standby:刚设置完成还未开始执行或者数据盘的策略被关闭 Executed:执行成功 Failed:执行失败 */ DataDiskExecutionStatus string }
自动快照执行状态类型,返回上一次的执行结果。
type AutoSnapshotPolicyType ¶
type AutoSnapshotPolicyType struct { SystemDiskPolicyEnabled string //系统盘自动快照策略开关:true:该磁盘属性的磁盘打自动快照 false:不打自动快照 //系统盘自动快照策略的时间段 //4个时间段: //1:1:00-7:00 //2:7:00-13:00 //3:13:00-19:00 //4:19:00-1:00 SystemDiskPolicyTimePeriod int SystemDiskPolicyRetentionDays int //系统盘自动快照策略的保留天数 可选值, 1,2,3 SystemDiskPolicyRetentionLastWeek string //系统盘自动快照策略的保留上周日选项: true:代表保留上周日的快照 false:不保留 DataDiskPolicyEnabled string //数据盘自动快照策略开关: true:该磁盘属性的磁盘打自动快照 false:不打自动快照 //数据盘自动快照策略的时间段 //4个时间段: //1:1:00-7:00 //2:7:00-13:00 //3:13:00-19:00 //4:19:00-1:00 DataDiskPolicyTimePeriod int DataDiskPolicyRetentionDays int //数据盘自动快照策略的保留天数 可选值, 1,2,3 DataDiskPolicyRetentionLastWeek string //数据盘自动快照策略的保留上周日选项:true:代表保留上周日的快照 false:不保留 }
自动快照策略类型,自动快照策略的详细设置信息。
type AvailableDiskCategoriesType ¶
type AvailableDiskCategoriesType struct { //磁盘种类 //cloud:支持创建普通云盘和独立普通云盘 //ephemeral:支持创建本地磁盘 //ephemeral_ssd:支持创建本地 SSD 盘 DiskCategories string `json:"DiskCategories"` }
支持的磁盘种类
type AvailableResourceCreationType ¶
type AvailableResourceCreationType struct { //资源类型,如下: //Instance:支持实例创建 //Disk:支持磁盘创建 //VSwitch:支持专有网络创建 ResourceTypes string `json:"ResourceTypes"` }
允许创建的资源类型
type Client ¶
type Client struct {
// contains filtered or unexported fields
}
调用API的Client
func (*Client) AllocatePublicIpAddress ¶
给一个特定实例分配一个可用公网IP地址。
实例的状态必须为 Running 或 Stopped 状态,才可以调用此接口。
分配的 IP 必须在实例启动或重启后才能生效。
分配的时候只能是 IP,不能是 IP 段。
目前,一个实例只能分配一个 IP。当调用此接口时,如果实例已经拥有一个公网 IP,将直接返回原 IP 地址。
被安全控制在实例的 OperationLocks 中标记了 "LockReason" : "security" 的锁定状态时,不能分配公网 IP。
func (*Client) AuthorizeSecurityGroup ¶
func (c *Client) AuthorizeSecurityGroup(request *AuthorizeSecurityGroupRequest) (*EcsBaseResponse, error)
授权安全组In方向的访问权限
func (*Client) AuthorizeSecurityGroupEgress ¶
func (c *Client) AuthorizeSecurityGroupEgress(request *AuthorizeSecurityGroupEgressRequest) (*EcsBaseResponse, error)
添加安全组Out方向的访问规则
func (*Client) CreateInstance ¶
func (c *Client) CreateInstance(instance InstanceAttributesType, password string, securityGroupId string) (string, error)
This function is @deprecated and replaced by CreateInstanceByRequest
Example ¶
package main import ( "fmt" "github.com/ChangjunZhao/aliyun-api-golang/ecs" "os" ) func main() { c := ecs.NewClient( os.Getenv("ECS_ACCESS_KEY_ID"), os.Getenv("ECS_ACCESS_KEY_SECRET"), ) c.Debug(true) //创建实例 request := &ecs.CreateInstanceRequest{ RegionId: "cn-beijing", ImageId: "m-25mtsy38b", InstanceType: "ecs.t1.small", SecurityGroupId: "securitygroup", Password: "rootpassword", InternetChargeType: "PayByTraffic", InternetMaxBandwidthIn: "10", InternetMaxBandwidthOut: "10", } if response, err := c.CreateInstanceByRequest(request); err == nil { fmt.Println(response.InstanceId) } else { fmt.Println("error:", err) } //查询实例 if instance, err := c.DescribeInstanceAttribute("cn-beijing", "instanceId"); err == nil { fmt.Println("instance:", instance) } else { fmt.Println("error:", err) } }
Output:
func (*Client) CreateInstanceByRequest ¶
func (c *Client) CreateInstanceByRequest(request *CreateInstanceRequest) (*CreateInstanceResponse, error)
func (*Client) CreateSecurityGroup ¶
func (c *Client) CreateSecurityGroup(request *CreateSecurityGroupRequest) (*CreateSecurityGroupResponse, error)
创建安全组
func (*Client) DeleteInstance ¶
删除实例
根据传入实例的名称来释放实例资源。释放后实例所使用的物理资源都被回收,包括磁盘及快照,相关数据全部丢失且永久不可恢复。 实例状态必须为 Stopped,才可以进行删除操作。删除后,实例的状态为 Deleted,表示资源已释放,删除完成。 实例被删除时,挂载在实例上的 DeleteWithInstance的属性为 True 的磁盘会相应被删除,这些磁盘的快照任旧保留, 自动快照根据磁盘的 DeleteAutoSnapshot 属性,如果为 false 的,保留自动快照,如果为 true 的,则删除自动快照。 实例被删除后,相关数据全部丢失且永久不可恢复。 如果删除实例时,实例被安全控制在实例的 OperationLocks 中标记了 "LockReason" : "security" 的锁定状态时, 即使独立普通云盘的 DeleteWithInstnace 的属性为 False,系统会忽略这个属性而释放挂载在实例上面的普通云盘。
func (*Client) DeleteSecurityGroup ¶
func (c *Client) DeleteSecurityGroup(request *DeleteSecurityGroupRequest) (*EcsBaseResponse, error)
删除安全组
func (*Client) DescribeInstanceAttribute ¶
func (c *Client) DescribeInstanceAttribute(regionId string, instanceId string) (*InstanceAttributesType, error)
查询实例信息
instanceId :实例ID
返回值:InstanceAttributesType 实例对象
func (*Client) DescribeInstances ¶
func (c *Client) DescribeInstances(regionId string) (*DescribeInstancesResponse, error)
查询实例列表
regionId 地域ID,如cn-beijing
返回值InstanceAttributesType数组及错误信息 This function is @deprecated and replaced by DescribeInstancesByRequest
func (*Client) DescribeInstancesByRequest ¶
func (c *Client) DescribeInstancesByRequest(request *DescribeInstancesRequest) (*DescribeInstancesResponse, error)
查询实例列表
返回值InstanceAttributesType数组及错误信息
func (*Client) DescribeRegions ¶
func (c *Client) DescribeRegions(request *DescribeRegionsRequest) (*DescribeRegionsResponse, error)
查询可用区域
func (*Client) RebootInstance ¶
重启指定的实例
只有状态为 Running 的实例才可以进行此操作。
接口调用成功后实例进入 Starting 状态。
支持强制重启,强制重启等同于传统服务器的断电重启,可能丢失实例操作系统中未写入磁盘的数据。
被安全控制在实例的 OperationLocks 中标记了 "LockReason" : "security" 的锁定状态时,不能重启实例。
func (*Client) RevokeSecurityGroup ¶
func (c *Client) RevokeSecurityGroup(request *RevokeSecurityGroupRequest) (*EcsBaseResponse, error)
撤销安全组授权规则
func (*Client) RevokeSecurityGroupEgress ¶
func (c *Client) RevokeSecurityGroupEgress(request *RevokeSecurityGroupEgressRequest) (*EcsBaseResponse, error)
撤销安全组Out方向的访问规则
func (*Client) StartInstance ¶
启动一个指定的实例
接口调用成功后实例进入 Starting 状态。
实例状态必须为 Stopped,才可以调用该接口。
被安全控制在实例的 OperationLocks 中标记了 "LockReason" : "security" 的锁定状态时,不能启动实例。
func (*Client) StopInstance ¶
停止一个指定的实例。
只有状态为 Running 的实例才可以进行此操作。 接口调用成功后实例进入 Stopping 状态。系统后台会在实例实际 Stop 成功后进入 Stopped 状态。 实例支持强制停止,强制停止等同于断电处理,可能丢失实例操作系统中未写入磁盘的数据。 被安全控制在实例的 OperationLocks 中标记了 "LockReason" : "security" 的锁定状态时,不能停止实例。
type CreateInstanceRequest ¶
type CreateInstanceRequest struct { Action string RegionId string ZoneId string ImageId string InstanceType string SecurityGroupId string InstanceName string Description string InternetChargeType string InternetMaxBandwidthIn string InternetMaxBandwidthOut string HostName string Password string IoOptimized string SystemDiskCategory string SystemDiskDiskName string SystemDiskDescription string VSwitchId string PrivateIpAddress string }
Create instance http request object
func (*CreateInstanceRequest) AddToParams ¶
func (r *CreateInstanceRequest) AddToParams(params *util.OrderedParams) error
func (*CreateInstanceRequest) Validate ¶
func (r *CreateInstanceRequest) Validate() error
type CreateInstanceResponse ¶
type CreateInstanceResponse struct { EcsBaseResponse InstanceId string `json:"InstanceId"` //实例ID }
创建实例返回对象
type CreateSecurityGroupRequest ¶
type CreateSecurityGroupRequest struct { Action string RegionId string SecurityGroupName string Description string VpcId string }
创建安全组请求
func (*CreateSecurityGroupRequest) AddToParams ¶
func (r *CreateSecurityGroupRequest) AddToParams(params *util.OrderedParams) error
type CreateSecurityGroupResponse ¶
type CreateSecurityGroupResponse struct { EcsBaseResponse SecurityGroupId string `json:"SecurityGroupId"` //安全组ID }
type DeleteSecurityGroupRequest ¶
删除安全组请求
func (*DeleteSecurityGroupRequest) AddToParams ¶
func (r *DeleteSecurityGroupRequest) AddToParams(params *util.OrderedParams) error
type DescribeInstancesRequest ¶
type DescribeInstancesRequest struct { Action string RegionId string VpcId string VSwitchId string ZoneId string InstanceIds string InstanceNetworkType string PrivateIpAddresses string InnerIpAddresses string PublicIpAddresses string SecurityGroupIds string InstanceChargeType string InternetChargeType string InstanceName string ImageId string Status string DeviceAvailable string IoOptimized string PageNumber int PageSize int }
func (*DescribeInstancesRequest) AddToParams ¶
func (r *DescribeInstancesRequest) AddToParams(params *util.OrderedParams) error
type DescribeInstancesResponse ¶
type DescribeInstancesResponse struct { EcsBaseResponse TotalCount int `json:"TotalCount"` //总实例数 PageNumber int `json:"PageNumber"` //页码 PageSize int `json:"PageSize"` //单页实例数量 Instances Instances `json:"Instances"` //实例列表 }
查询实例列表返回对象
type DescribeRegionsRequest ¶
type DescribeRegionsRequest struct {
Action string
}
func (*DescribeRegionsRequest) AddToParams ¶
func (r *DescribeRegionsRequest) AddToParams(params *util.OrderedParams) error
type DescribeRegionsResponse ¶
type DescribeRegionsResponse struct { EcsBaseResponse Response Regions `json:"Regions"` }
查询可用区域返回对象
type DiskDeviceMapping ¶
type DiskItemType ¶
type DiskItemType struct { DiskId string // 磁盘ID RegionId string // 磁盘所属的地域 ID ZoneId string // 磁盘所属的可用区ID DiskName string // 磁盘名 Description string //磁盘描述 Type string //磁盘类型 可选值:system: 系统盘 data: 数据盘 Category string //磁盘种类 可选值: cloud: 普通云盘 ephemeral: 临时磁盘 ephemeral_ssd: 临时SSD盘 Size int //磁盘大小,单位GB ImageId string //创建磁盘的镜像ID,只有通过镜像创建的磁盘才有值,否则为空。这个值在磁盘的生命周期内始终不变 SourceSnapshotId string //创建磁盘使用的快照,如果创建磁盘时,没有指定快照,则为空。这个值在磁盘的生命周期内始终不变。 ProductCode string //镜像市场的商品标识 Portable string //磁盘是否可卸载 true代表是独立普通云盘,可以独立存在且可以自由在可用区内挂载和下载 false代表非独立普通云盘,只能和实例同生同灭。用户如果需要做attach和detach操作,必须先查询一下这个属性为true的磁盘才能操作。临时磁盘,临时SSD盘,普通云盘的系统盘和包月的普通云盘,该属性都为false。这个属性用户不能更改。 Status string //磁盘状态 In_use | Available | Attaching | Detaching | Creating | ReIniting OperationLocks OperationLocksType //磁盘锁定原因类型 InstanceId string //所属Instance ID 只有在Status为In_use时才有值,其他状态为空。 Device string //所属Instance的Device信息:比如/dev/xvdb 只有在Status为In_use是才有值,其他状态为空。 DeleteWithInstance string //True表示Instance释放时,这块磁盘随Instance一起释放;false表示Instance释放时,这块磁盘保留不释放。 DeleteAutoSnapshot string //是否同时删除自动快照,true | false。通过CreateSnapshot或者在控制台创建的快照,不受这个参数的影响,始终会被保留。 EnableAutoSnapshot string //磁盘是否执行自动快照策略,true | false。true表示这块磁盘执行自动快照策略,false表示这块磁盘不执行自动快照策略 CreationTime string //创建时间。按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ AttachedTime string //挂载时间。按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ 只有在Status为In_use时才有意义 DetachedTime string //卸载时间。按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ只有在Status为Available时才有意义 }
type DiskMonitorDataType ¶
type DiskMonitorDataType struct { DiskId string // 磁盘编号 IOPSRead int // 磁盘IO读操作,单位:次/s IOPSWrite int // 磁盘IO写操作,单位:次/s IOPSTotal int // 磁盘IO读写总操作,单位:次/s BPSRead int // 磁盘读带宽,单位:byte/s BPSWrite int // 磁盘写带宽,单位:byte/s BPSTotal int // 磁盘读写总带宽,单位:byte/s TimeStamp string // 查询的时间点,按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ }
包含磁盘监控数据的类型
type DiskSetType ¶
type DiskSetType struct {
Disk DiskItemType
}
type EcsBaseResponse ¶
type EcsBaseResponse struct {
RequestId string `json:"RequestId"` //请求ID
}
API基础返回对象
type EipAddressAssociateType ¶
type EipAddressSetType ¶
type EipAddressSetType struct { RegionId string // 弹性公网IP所在的地域 IpAddress string // 弹性公网IP AllocationId string // 弹性公网IP实例Id Status string // 弹性公网IP当前的状态,包括Associating、Unassociating、InUse和Available InstanceId string // 弹性公网IP当前绑定的实例,如果未绑定则值为空。 Bandwidth int // 弹性公网IP的公网带宽限速,默认是5Mbps InternetChargeType string // 弹性公网IP的计费方式。 OperationLocks OperationLocksType //LockReason组成的字符串数组,如果没有被锁定则其子节点不出现。 AllocationTime string // 分配时间。按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ }
包含弹性公网IP信息的集合
type EipMonitorDataType ¶
type EipMonitorDataType struct { EipRX int // 一段时间(Period)内,EIP接收到的数据流量,单位:kbytes。 EipTX int // 一段时间(Period)内,EIP接发送的数据流量,单位:kbytes。 EipFlow int // 一段时间(Period)内,EIP网络流量,单位Kbytes。 EipBandwidth int // 弹性公网IP的带宽(单位时间内的网络流量),单位为kbytes/s。 EipPackets int // 一段时间(Period)内,EIP接受和发送的报文总数。 TimeStamp string // 查询流量的时间点,按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ }
包含弹性公网IP监控数据的类型
type ImageType ¶
type ImageType struct { ImageId string //镜像编码 ImageVersion string //镜像版本 Architecture string //镜像系统类型:i386 | x86_64 ImageName string //镜像的名称 Description string //描述信息 Size int //镜像大小 ImageOwnerAlias string //镜像所有者别名 有效值:system – 系统公共镜像 self – 用户的自定义镜像 others – 其他用户的公开镜像 marketplace -镜像市场镜像 OSName string //操作系统的显示名称 DiskDeviceMappings DiskDeviceMapping //镜像下包含磁盘和快照的系统描述 ProductCode string //镜像市场的镜像商品标示 IsSubscribed string //用户是否订阅了该镜像的ProductCode对应的镜像商品的服务条款. true:表示已经订阅 false:表示未订阅 Progress string //镜像完成的进度,单位为百分比 Status string //镜像的状态,可能的值有:UnAvailable 不可用 Available 可用 Creating 创建中 CreateFailed 创建失败 CreationTime string //创建时间。按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ }
type InstanceAttributesType ¶
type InstanceAttributesType struct { InstanceId string `json:"InstanceId"` //实例ID InstanceName string `json:"InstanceName"` //实例的显示名称 Description string `json:"Description"` //实例的描述 ImageId string `json:"ImageId"` //镜像ID RegionId string `json:"RegionId"` //实例所属地域ID ZoneId string `json:"ZoneId"` //实例所属可用区 InstanceType string `json:"InstanceType"` //实例资源规格 HostName string `json:"HostName"` //实例机器名称 Status string `json:"Status"` //实例状态 SecurityGroupIds SecurityGroupIdSetType `json:"SecurityGroupIds"` //实例所属安全组的集合SecurityGroupIdSetType InnerIpAddress IpAddressSetType `json:"InnerIpAddress"` //实例的内网IP地址 PublicIpAddress IpAddressSetType `json:"PublicIpAddress"` //实例的公网IP地址 InternetMaxBandwidthIn int `json:"InternetMaxBandwidthIn"` //公网入带宽最大值 InternetMaxBandwidthOut int `json:"InternetMaxBandwidthOut"` //公网出带宽最大值 InternetChargeType string `json:"InternetChargeType"` //网络计费类型,PayByBandwidth | PayByTraffic两个值中的一个。预付费实例显示PayByBandwidth(按带宽计费) CreationTime string `json:"CreationTime"` //创建时间。按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ VpcAttributes VpcAttributesType `json:"VpcAttributes"` //VpcAttributesType类型 EipAddress EipAddressAssociateType `json:"EipAddress"` //EipAddressAssociateType类型 InstanceNetworkType string `json:"InstanceNetworkType"` //实例网络类型,可选值Classic | Vpc OperationLocks OperationLocksType `json:"OperationLocks"` //锁定列表 }
云服务器实例属性
type InstanceMonitorDataType ¶
type InstanceMonitorDataType struct { InstanceId string //实例ID CPU int //CPU的使用比例,单位:百分比(%) IntranetRX int //云服务器实例接收到的数据流量,单位:kbits IntranetTX int //云服务器实例接发送的数据流量,单位:kbits IntranetBandwidth int //云服务器实例的带宽(单位时间内的网络流量),单位为kbits/s InternetRX int //云服务器实例接收到的数据流量,单位:kbits InternetTX int //云服务器实例接发送的数据流量,单位:kbits InternetBandwidth int //云服务器实例的带宽(单位时间内的网络流量),单位为kbits/s IOPSRead int //系统盘IO读操作,单位:次/s IOPSWrite int //系统盘IO写操作,单位:次/s BPSRead int //系统盘磁盘读带宽,单位:Byte/s BPSWrite int //系统盘磁盘写带宽,单位:Byte/s TimeStamp string //查询流量的时间点,按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ }
type InstanceStatusItemType ¶
实例状态的类型
type InstanceStatusSetType ¶
type InstanceStatusSetType struct {
InstanceStatus InstanceStatusItemType //由InstanceStatusItemType组成的集合
}
实例状态的项的集合
type InstanceTypeItemType ¶
type InstanceTypeItemType struct { InstanceTypeId string `json:"InstanceTypeId"` //实例规格的ID CpuCoreCount int `json:"CpuCoreCount"` //CPU的内核数目 MemorySize int `json:"MemorySize"` //内存大小,单位GB }
实例资源规格项的类型
type IpAddressSetType ¶
type IpAddressSetType struct {
IpAddress []string `json:"IpAddress"` //IP地址
}
type IpRangeSetType ¶
type IpRangeSetType struct { IpAddress string //采用CIDR格式来指定IP地址范围。 NicType string //网络类型internet | intranet的一种 }
IP段集合的类型
type OperationLocksType ¶
type OperationLocksType struct { //锁定类型 //financial:因欠费被锁定 //security:因安全原因被锁定 LockReason []string `json:"LockReason"` }
type PermissionSetType ¶
type PermissionSetType struct {
Permision PermissionType //安全组规则PermissionType
}
安全组规则组类型集合
type PermissionType ¶
type PermissionType struct { IpProtocol string //授权指定的IP协议 PortRange string //授权指定的端口范围 SourceCidrIp string //授权给指定IP地址段 SourceGroupId string //源安全组编码 SourceGroupOwnerAccount string //源安全组所属阿里云账户 DestCidrIp string //授权访问指定IP地址段 DestGroupId string //目标安全组编码 DestGroupOwnerAccount string //目标安全组所属阿里云账户 Policy string //授权策略 NicType string //网络类型 Priority string //规则优先级 }
安全组规则类型
type RegionType ¶
type RegionType struct { RegionId string `json:"RegionId"` //Region ID LocalName string `json:"LocalName"` //Region名称 }
Region信息的类型
type RevokeSecurityGroupEgressRequest ¶
type RevokeSecurityGroupEgressRequest AuthorizeSecurityGroupEgressRequest
撤销安全组Out方向的访问规则
func (*RevokeSecurityGroupEgressRequest) AddToParams ¶
func (r *RevokeSecurityGroupEgressRequest) AddToParams(params *util.OrderedParams) error
func (*RevokeSecurityGroupEgressRequest) Validate ¶
func (r *RevokeSecurityGroupEgressRequest) Validate() error
type RevokeSecurityGroupRequest ¶
type RevokeSecurityGroupRequest AuthorizeSecurityGroupRequest
撤销安全组授权规则请求
func (*RevokeSecurityGroupRequest) AddToParams ¶
func (r *RevokeSecurityGroupRequest) AddToParams(params *util.OrderedParams) error
func (*RevokeSecurityGroupRequest) Validate ¶
func (r *RevokeSecurityGroupRequest) Validate() error
type RouteEntrySetType ¶
type RouteEntrySetType struct { RouteTableId string //路由条目所在的虚拟路由器 DestinationCidrBlock string //目标网段地址 Type string //路由类型(System | Custom) NextHopId string //下一跳实例ID Status string //路由条目状态Pending | Available | Modifying }
包含路由条目数据的集合
type RouteTableSetType ¶
type RouteTableSetType struct { VRouterId string // 虚拟路由器的ID RouteTableId string // 路由表的ID RouteEntrys []RouteEntrySetType //路由条目详情RouteEntrySetType组成的集合 RouteTableType string // 路由表类型,System | Custom 二者选其一 CreationTime string // 创建时间。按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ }
包含路由表数据的集合
type SecurityGroupIdSetType ¶
type SecurityGroupIdSetType struct {
SecurityGroupId []string `json:"SecurityGroupId"` //安全组ID
}
type SecurityGroupItemType ¶
type SecurityGroupSetType ¶
type SecurityGroupSetType struct {
SecurityGroup SecurityGroupItemType //安全组SecurityGroupItemType
}
type SnapshotType ¶
type SnapshotType struct { SnapshotId string `json:"SnapshotId"` //快照ID SnapshotName string `json:"SnapshotName"` //快照显示名称。如果创建时指定了快照显示名称,则返回 Description string `json:"Description"` //描述信息 Progress string `json:"Progress"` //快照创建进度,单位为百分比 SourceDiskId string `json:"SourceDiskId"` //源磁盘ID,如果快照的源磁盘已经被删除,该字段任旧保留 SourceDiskSize int `json:"SourceDiskSize"` //源磁盘容量,GB SourceDiskType string `json:"SourceDiskType"` //源磁盘属性,System | Data ProductCode string `json:"ProductCode"` //从镜像市场继承的产品编号 CreationTime string `json:"CreationTime"` //创建时间。按照ISO8601标准表示,并需要使用UTC时间。 }
快照详情的数据类型
type VRouterSetType ¶
type VRouterSetType struct { VRouterId string // 虚拟路由器的Id RegionId string // 地域Id VpcId string // 专有网络Id RouteTableIds string // 虚拟路由表Id列表 VRouterName string // 虚拟路由器名称 Description string // 虚拟路由器的描述,不填则为空,默认值为空,[2,256]英文或中文字符,不能以http:// 和https:// 开头。 CreationTime string // 创建时间。按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ }
包含虚拟路由器信息的集合
type VSwitchSetType ¶
type VSwitchSetType struct { VSwitchId string // 虚拟交换机ID VpcId string // 虚拟交换机所在的专有网络 Status string // 虚拟交换机状态,包括Pending和Available两种 CidrBlock string // 虚拟交换机的地址 ZoneId string // 虚拟交换机所在的可用区 AvailableIpAddressCount int // 虚拟交换机当前可用的IP地址数量 Description string // 描述,不填则为空,默认值为空,[2,256]英文或中文字符,不能以http:// 和https:// 开头。 VSwitchName string // 虚拟交换机名字,不填则为空,默认值为空,[2,128]英文或中文字符,必须以大小字母或中文开头,可包含数字,”_”或”-”,这个值会展示在控制台。不能以http:// 和https:// 开头。 CreationTime string // 创建时间。按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ }
包含虚拟交换机信息的集合
type VpcAttributesType ¶
type VpcAttributesType struct { VpcId string `json:"VpcId"` //虚拟专有网络Id VSwitchId string `json:"VSwitchId"` //虚拟交换机Id PrivateIpAddress IpAddressSetType `json:"PrivateIpAddress"` NatIpAddress string `json:"NatIpAddress"` //云产品Ip,用于云产品之间的网络互通 }
type VpcSetType ¶
type VpcSetType struct { VpcId string // VpcId RegionId string // VPC所在的地域 Status string // VPC状态,包括Pending和Available两种 VpcName string // VPC名称,不填则为空,默认值为空,[2,128]英文或中文字符,必须以大小字母或中文开头,可包含数字,”_”或”-”,这个值会展示在控制台。不能以http:// 和https:// 开头。 VSwitchIds string // VSwitchId列表 CidrBlock string // VPC的网段地址 VRouterId string // VRouter的Id Description string // 描述,不填则为空,默认值为空,[2,256]英文或中文字符,不能以http:// 和https:// 开头。 CreationTime string // 创建时间。按照ISO8601标准表示,并需要使用UTC时间。格式为:YYYY-MM-DDThh:mmZ }
包含Vpc信息的集合
type ZoneType ¶
type ZoneType struct { ZoneId string `json:"ZoneId"` //可用区ID LocalName string `json:"LocalName"` //可用区本地语言名 AvailableResourceCreation AvailableResourceCreationType `json:"AvailableResourceCreation"` AvailableDiskCategories AvailableDiskCategoriesType `json:"AvailableDiskCategories"` }
可用区信息的类型