/*
* Copyright (c) 2018 THL A29 Limited, a Tencent company. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
namespace TencentCloud.As.V20180419.Models
{
using Newtonsoft.Json;
using System.Collections.Generic;
using TencentCloud.Common;
public class UpgradeLaunchConfigurationRequest : AbstractModel
{
///
/// 启动配置ID。
///
[JsonProperty("LaunchConfigurationId")]
public string LaunchConfigurationId{ get; set; }
///
/// 指定有效的[镜像](https://cloud.tencent.com/document/product/213/4940)ID,格式形如`img-8toqc6s3`。镜像类型分为四种:
公共镜像自定义镜像共享镜像服务市场镜像
可通过以下方式获取可用的镜像ID:
`公共镜像`、`自定义镜像`、`共享镜像`的镜像ID可通过登录[控制台](https://console.cloud.tencent.com/cvm/image?rid=1&imageType=PUBLIC_IMAGE)查询;`服务镜像市场`的镜像ID可通过[云市场](https://market.cloud.tencent.com/list)查询。通过调用接口 [DescribeImages](https://cloud.tencent.com/document/api/213/15715) ,取返回信息中的`ImageId`字段。
///
[JsonProperty("ImageId")]
public string ImageId{ get; set; }
///
/// 实例机型列表,不同实例机型指定了不同的资源规格,最多支持5种实例机型。
///
[JsonProperty("InstanceTypes")]
public string[] InstanceTypes{ get; set; }
///
/// 启动配置显示名称。名称仅支持中文、英文、数字、下划线、分隔符"-"、小数点,最大长度不能超60个字节。
///
[JsonProperty("LaunchConfigurationName")]
public string LaunchConfigurationName{ get; set; }
///
/// 实例数据盘配置信息。若不指定该参数,则默认不购买数据盘,最多支持指定11块数据盘。
///
[JsonProperty("DataDisks")]
public DataDisk[] DataDisks{ get; set; }
///
/// 增强服务。通过该参数可以指定是否开启云安全、云监控等服务。若不指定该参数,则默认开启云监控、云安全服务。
///
[JsonProperty("EnhancedService")]
public EnhancedService EnhancedService{ get; set; }
///
/// 实例计费类型,CVM默认值按照POSTPAID_BY_HOUR处理。
///
POSTPAID_BY_HOUR:按小时后付费
///
SPOTPAID:竞价付费
///
[JsonProperty("InstanceChargeType")]
public string InstanceChargeType{ get; set; }
///
/// 实例的市场相关选项,如竞价实例相关参数,若指定实例的付费模式为竞价付费则该参数必传。
///
[JsonProperty("InstanceMarketOptions")]
public InstanceMarketOptionsRequest InstanceMarketOptions{ get; set; }
///
/// 实例类型校验策略,取值包括 ALL 和 ANY,默认取值为ANY。
///
ALL,所有实例类型(InstanceType)都可用则通过校验,否则校验报错。
///
ANY,存在任何一个实例类型(InstanceType)可用则通过校验,否则校验报错。
///
/// 实例类型不可用的常见原因包括该实例类型售罄、对应云盘售罄等。
/// 如果 InstanceTypes 中一款机型不存在或者已下线,则无论 InstanceTypesCheckPolicy 采用何种取值,都会校验报错。
///
[JsonProperty("InstanceTypesCheckPolicy")]
public string InstanceTypesCheckPolicy{ get; set; }
///
/// 公网带宽相关信息设置。若不指定该参数,则默认公网带宽为0Mbps。
///
[JsonProperty("InternetAccessible")]
public InternetAccessible InternetAccessible{ get; set; }
///
/// 实例登录设置。通过该参数可以设置实例的登录方式密码、密钥或保持镜像的原始登录设置。默认情况下会随机生成密码,并以站内信方式知会到用户。
///
[JsonProperty("LoginSettings")]
public LoginSettings LoginSettings{ get; set; }
///
/// 实例所属项目ID。该参数可以通过调用 [DescribeProject](https://cloud.tencent.com/document/api/378/4400) 的返回值中的`projectId`字段来获取。不填为默认项目。
///
[JsonProperty("ProjectId")]
public long? ProjectId{ get; set; }
///
/// 实例所属安全组。该参数可以通过调用 [DescribeSecurityGroups](https://cloud.tencent.com/document/api/215/15808) 的返回值中的`SecurityGroupId`字段来获取。若不指定该参数,则默认不绑定安全组。
///
[JsonProperty("SecurityGroupIds")]
public string[] SecurityGroupIds{ get; set; }
///
/// 实例系统盘配置信息。若不指定该参数,则按照系统默认值进行分配。
///
[JsonProperty("SystemDisk")]
public SystemDisk SystemDisk{ get; set; }
///
/// 经过 Base64 编码后的自定义数据,最大长度不超过16KB。
///
[JsonProperty("UserData")]
public string UserData{ get; set; }
///
/// 标签列表。通过指定该参数,可以为扩容的实例绑定标签。最多支持指定10个标签。
///
[JsonProperty("InstanceTags")]
public InstanceTag[] InstanceTags{ get; set; }
///
/// CAM角色名称。可通过DescribeRoleList接口返回值中的roleName获取。
///
[JsonProperty("CamRoleName")]
public string CamRoleName{ get; set; }
///
/// 云服务器主机名(HostName)的相关设置。
///
[JsonProperty("HostNameSettings")]
public HostNameSettings HostNameSettings{ get; set; }
///
/// 云服务器实例名(InstanceName)的相关设置。
///
[JsonProperty("InstanceNameSettings")]
public InstanceNameSettings InstanceNameSettings{ get; set; }
///
/// 预付费模式,即包年包月相关参数设置。通过该参数可以指定包年包月实例的购买时长、是否设置自动续费等属性。若指定实例的付费模式为预付费则该参数必传。
///
[JsonProperty("InstanceChargePrepaid")]
public InstanceChargePrepaid InstanceChargePrepaid{ get; set; }
///
/// For internal usage only. DO NOT USE IT.
///
internal override void ToMap(Dictionary map, string prefix)
{
this.SetParamSimple(map, prefix + "LaunchConfigurationId", this.LaunchConfigurationId);
this.SetParamSimple(map, prefix + "ImageId", this.ImageId);
this.SetParamArraySimple(map, prefix + "InstanceTypes.", this.InstanceTypes);
this.SetParamSimple(map, prefix + "LaunchConfigurationName", this.LaunchConfigurationName);
this.SetParamArrayObj(map, prefix + "DataDisks.", this.DataDisks);
this.SetParamObj(map, prefix + "EnhancedService.", this.EnhancedService);
this.SetParamSimple(map, prefix + "InstanceChargeType", this.InstanceChargeType);
this.SetParamObj(map, prefix + "InstanceMarketOptions.", this.InstanceMarketOptions);
this.SetParamSimple(map, prefix + "InstanceTypesCheckPolicy", this.InstanceTypesCheckPolicy);
this.SetParamObj(map, prefix + "InternetAccessible.", this.InternetAccessible);
this.SetParamObj(map, prefix + "LoginSettings.", this.LoginSettings);
this.SetParamSimple(map, prefix + "ProjectId", this.ProjectId);
this.SetParamArraySimple(map, prefix + "SecurityGroupIds.", this.SecurityGroupIds);
this.SetParamObj(map, prefix + "SystemDisk.", this.SystemDisk);
this.SetParamSimple(map, prefix + "UserData", this.UserData);
this.SetParamArrayObj(map, prefix + "InstanceTags.", this.InstanceTags);
this.SetParamSimple(map, prefix + "CamRoleName", this.CamRoleName);
this.SetParamObj(map, prefix + "HostNameSettings.", this.HostNameSettings);
this.SetParamObj(map, prefix + "InstanceNameSettings.", this.InstanceNameSettings);
this.SetParamObj(map, prefix + "InstanceChargePrepaid.", this.InstanceChargePrepaid);
}
}
}