# frozen_string_literal: true # Copyright (c) 2017-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. module TencentCloud module Mongodb module V20190725 # 修改实例节点详情 class AddNodeList < TencentCloud::Common::AbstractModel # @param Role: 需要新增的节点角色。 # - SECONDARY:Mongod 节点。 # - READONLY:只读节点。 # - MONGOS:Mongos 节点。 # @type Role: String # @param Zone: 节点所对应的可用区。 # - 单可用区,所有节点在同一可用区。 # - 多可用区:当前标准规格是三可用区分布,主从节点不在同一可用区,需注意配置新增节点对应的可用区,且新增后必须满足任意2个可用区节点数大于第3个可用区原则。 # @type Zone: String attr_accessor :Role, :Zone def initialize(role=nil, zone=nil) @Role = role @Zone = zone end def deserialize(params) @Role = params['Role'] @Zone = params['Zone'] end end # AssignProject请求参数结构体 class AssignProjectRequest < TencentCloud::Common::AbstractModel # @param InstanceIds: 实例ID列表,格式如:cmgo-p8vn****。与云数据库控制台页面中显示的实例ID相同 # @type InstanceIds: Array # @param ProjectId: 项目ID,用户已创建项目的唯一ID,非自定义 # @type ProjectId: Integer attr_accessor :InstanceIds, :ProjectId def initialize(instanceids=nil, projectid=nil) @InstanceIds = instanceids @ProjectId = projectid end def deserialize(params) @InstanceIds = params['InstanceIds'] @ProjectId = params['ProjectId'] end end # AssignProject返回参数结构体 class AssignProjectResponse < TencentCloud::Common::AbstractModel # @param FlowIds: 返回的异步任务ID列表 # @type FlowIds: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :FlowIds, :RequestId def initialize(flowids=nil, requestid=nil) @FlowIds = flowids @RequestId = requestid end def deserialize(params) @FlowIds = params['FlowIds'] @RequestId = params['RequestId'] end end # 用户权限 class Auth < TencentCloud::Common::AbstractModel # @param Mask: 当前账号具有的权限信息。 # @type Mask: Integer # @param NameSpace: 指具有当前账号权限的数据库名。 # # @type NameSpace: String attr_accessor :Mask, :NameSpace def initialize(mask=nil, namespace=nil) @Mask = mask @NameSpace = namespace end def deserialize(params) @Mask = params['Mask'] @NameSpace = params['NameSpace'] end end # 备份下载任务 class BackupDownloadTask < TencentCloud::Common::AbstractModel # @param CreateTime: 任务创建时间 # @type CreateTime: String # @param BackupName: 备份文件名 # @type BackupName: String # @param ReplicaSetId: 分片名称 # @type ReplicaSetId: String # @param BackupSize: 备份数据大小,单位为字节 # @type BackupSize: Integer # @param Status: 任务状态。0-等待执行,1-正在下载,2-下载完成,3-下载失败,4-等待重试 # @type Status: Integer # @param Percent: 任务进度百分比 # @type Percent: Integer # @param TimeSpend: 耗时,单位为秒 # @type TimeSpend: Integer # @param Url: 备份数据下载链接 # @type Url: String # @param BackupMethod: 备份文件备份类型,0-逻辑备份,1-物理备份 # @type BackupMethod: Integer # @param BackupDesc: 发起备份时指定的备注信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type BackupDesc: String attr_accessor :CreateTime, :BackupName, :ReplicaSetId, :BackupSize, :Status, :Percent, :TimeSpend, :Url, :BackupMethod, :BackupDesc def initialize(createtime=nil, backupname=nil, replicasetid=nil, backupsize=nil, status=nil, percent=nil, timespend=nil, url=nil, backupmethod=nil, backupdesc=nil) @CreateTime = createtime @BackupName = backupname @ReplicaSetId = replicasetid @BackupSize = backupsize @Status = status @Percent = percent @TimeSpend = timespend @Url = url @BackupMethod = backupmethod @BackupDesc = backupdesc end def deserialize(params) @CreateTime = params['CreateTime'] @BackupName = params['BackupName'] @ReplicaSetId = params['ReplicaSetId'] @BackupSize = params['BackupSize'] @Status = params['Status'] @Percent = params['Percent'] @TimeSpend = params['TimeSpend'] @Url = params['Url'] @BackupMethod = params['BackupMethod'] @BackupDesc = params['BackupDesc'] end end # 创建备份下载任务结果 class BackupDownloadTaskStatus < TencentCloud::Common::AbstractModel # @param ReplicaSetId: 分片名 # @type ReplicaSetId: String # @param Status: 任务当前状态。0-等待执行,1-正在下载,2-下载完成,3-下载失败,4-等待重试 # @type Status: Integer attr_accessor :ReplicaSetId, :Status def initialize(replicasetid=nil, status=nil) @ReplicaSetId = replicasetid @Status = status end def deserialize(params) @ReplicaSetId = params['ReplicaSetId'] @Status = params['Status'] end end # 备份信息 class BackupInfo < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID。 # @type InstanceId: String # @param BackupType: 备份方式,0-自动备份,1-手动备份 # @type BackupType: Integer # @param BackupName: 备份名称 # @type BackupName: String # @param BackupDesc: 备份备注 # 注意:此字段可能返回 null,表示取不到有效值。 # @type BackupDesc: String # @param BackupSize: 备份文件大小,单位KB # 注意:此字段可能返回 null,表示取不到有效值。 # @type BackupSize: Integer # @param StartTime: 备份开始时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartTime: String # @param EndTime: 备份结束时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type EndTime: String # @param Status: 备份状态,1-备份中,2-备份成功 # @type Status: Integer # @param BackupMethod: 备份方法,0-逻辑备份,1-物理备份 # @type BackupMethod: Integer # @param BackId: 备份记录id # @type BackId: Integer # @param DeleteTime: 备份删除时间 # @type DeleteTime: String # @param BackupRegion: 异地备份地域 # 注意:此字段可能返回 null,表示取不到有效值。 # @type BackupRegion: String attr_accessor :InstanceId, :BackupType, :BackupName, :BackupDesc, :BackupSize, :StartTime, :EndTime, :Status, :BackupMethod, :BackId, :DeleteTime, :BackupRegion def initialize(instanceid=nil, backuptype=nil, backupname=nil, backupdesc=nil, backupsize=nil, starttime=nil, endtime=nil, status=nil, backupmethod=nil, backid=nil, deletetime=nil, backupregion=nil) @InstanceId = instanceid @BackupType = backuptype @BackupName = backupname @BackupDesc = backupdesc @BackupSize = backupsize @StartTime = starttime @EndTime = endtime @Status = status @BackupMethod = backupmethod @BackId = backid @DeleteTime = deletetime @BackupRegion = backupregion end def deserialize(params) @InstanceId = params['InstanceId'] @BackupType = params['BackupType'] @BackupName = params['BackupName'] @BackupDesc = params['BackupDesc'] @BackupSize = params['BackupSize'] @StartTime = params['StartTime'] @EndTime = params['EndTime'] @Status = params['Status'] @BackupMethod = params['BackupMethod'] @BackId = params['BackId'] @DeleteTime = params['DeleteTime'] @BackupRegion = params['BackupRegion'] end end # 客户端连接信息,包括客户端IP和连接数 class ClientConnection < TencentCloud::Common::AbstractModel # @param IP: 连接的客户端IP # @type IP: String # @param Count: 对应客户端IP的连接数 # @type Count: Integer # @param InternalService: 是否为内部ip # @type InternalService: Boolean attr_accessor :IP, :Count, :InternalService def initialize(ip=nil, count=nil, internalservice=nil) @IP = ip @Count = count @InternalService = internalservice end def deserialize(params) @IP = params['IP'] @Count = params['Count'] @InternalService = params['InternalService'] end end # CreateAccountUser请求参数结构体 class CreateAccountUserRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例 ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param UserName: 新账号名称。其格式要求如下: # @type UserName: String # @param Password: 新账号密码。密码复杂度要求如下: # @type Password: String # @param MongoUserPassword: mongouser 账号对应的密码。mongouser 为系统默认账号,即为创建实例时,设置的密码。 # @type MongoUserPassword: String # @param UserDesc: 账号备注信息。 # @type UserDesc: String # @param AuthRole: 账号的读写权限信息。 # @type AuthRole: Array attr_accessor :InstanceId, :UserName, :Password, :MongoUserPassword, :UserDesc, :AuthRole def initialize(instanceid=nil, username=nil, password=nil, mongouserpassword=nil, userdesc=nil, authrole=nil) @InstanceId = instanceid @UserName = username @Password = password @MongoUserPassword = mongouserpassword @UserDesc = userdesc @AuthRole = authrole end def deserialize(params) @InstanceId = params['InstanceId'] @UserName = params['UserName'] @Password = params['Password'] @MongoUserPassword = params['MongoUserPassword'] @UserDesc = params['UserDesc'] unless params['AuthRole'].nil? @AuthRole = [] params['AuthRole'].each do |i| auth_tmp = Auth.new auth_tmp.deserialize(i) @AuthRole << auth_tmp end end end end # CreateAccountUser返回参数结构体 class CreateAccountUserResponse < TencentCloud::Common::AbstractModel # @param FlowId: 创建任务ID。 # @type FlowId: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :FlowId, :RequestId def initialize(flowid=nil, requestid=nil) @FlowId = flowid @RequestId = requestid end def deserialize(params) @FlowId = params['FlowId'] @RequestId = params['RequestId'] end end # CreateBackupDBInstance请求参数结构体 class CreateBackupDBInstanceRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例 ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param BackupMethod: 设置备份方式。 # - 0:逻辑备份。 # - 1:物理备份。 # @type BackupMethod: Integer # @param BackupRemark: 备份备注信息。 # @type BackupRemark: String attr_accessor :InstanceId, :BackupMethod, :BackupRemark def initialize(instanceid=nil, backupmethod=nil, backupremark=nil) @InstanceId = instanceid @BackupMethod = backupmethod @BackupRemark = backupremark end def deserialize(params) @InstanceId = params['InstanceId'] @BackupMethod = params['BackupMethod'] @BackupRemark = params['BackupRemark'] end end # CreateBackupDBInstance返回参数结构体 class CreateBackupDBInstanceResponse < TencentCloud::Common::AbstractModel # @param AsyncRequestId: 查询备份流程的状态。 # @type AsyncRequestId: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :AsyncRequestId, :RequestId def initialize(asyncrequestid=nil, requestid=nil) @AsyncRequestId = asyncrequestid @RequestId = requestid end def deserialize(params) @AsyncRequestId = params['AsyncRequestId'] @RequestId = params['RequestId'] end end # CreateBackupDownloadTask请求参数结构体 class CreateBackupDownloadTaskRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同。 # @type InstanceId: String # @param BackupName: 要下载的备份文件名,可通过DescribeDBBackups接口获取。 # @type BackupName: String # @param BackupSets: 指定要下载的副本集的节点名称 或 分片集群的分片名称列表。 # 如副本集cmgo-p8vnipr5,示例(固定取值):BackupSets.0=cmgo-p8vnipr5_0,可下载全量数据。 # 如分片集群cmgo-p8vnipr5,示例:BackupSets.0=cmgo-p8vnipr5_0&BackupSets.1=cmgo-p8vnipr5_1,即下载分片0和分片1的数据,分片集群如需全量下载,请按示例方式传入全部分片名称。 # @type BackupSets: Array attr_accessor :InstanceId, :BackupName, :BackupSets def initialize(instanceid=nil, backupname=nil, backupsets=nil) @InstanceId = instanceid @BackupName = backupname @BackupSets = backupsets end def deserialize(params) @InstanceId = params['InstanceId'] @BackupName = params['BackupName'] unless params['BackupSets'].nil? @BackupSets = [] params['BackupSets'].each do |i| replicasetinfo_tmp = ReplicaSetInfo.new replicasetinfo_tmp.deserialize(i) @BackupSets << replicasetinfo_tmp end end end end # CreateBackupDownloadTask返回参数结构体 class CreateBackupDownloadTaskResponse < TencentCloud::Common::AbstractModel # @param Tasks: 下载任务状态 # @type Tasks: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Tasks, :RequestId def initialize(tasks=nil, requestid=nil) @Tasks = tasks @RequestId = requestid end def deserialize(params) unless params['Tasks'].nil? @Tasks = [] params['Tasks'].each do |i| backupdownloadtaskstatus_tmp = BackupDownloadTaskStatus.new backupdownloadtaskstatus_tmp.deserialize(i) @Tasks << backupdownloadtaskstatus_tmp end end @RequestId = params['RequestId'] end end # CreateDBInstanceHour请求参数结构体 class CreateDBInstanceHourRequest < TencentCloud::Common::AbstractModel # @param Memory: 实例内存大小,单位:GB。具体售卖的内存规格,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # @type Memory: Integer # @param Volume: 实例硬盘大小,单位:GB。每一个 CPU 规格对应的最大磁盘与最小磁盘范围,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # @type Volume: Integer # @param ReplicateSetNum: - 创建副本集实例,指副本集数量,该参数只能为1。 # - 创建分片集群实例,指分片的数量。请通过接口[DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567)查询分片数量的取值范围,其返回的数据结构SpecItems中的参数MinReplicateSetNum与MaxReplicateSetNum分别对应其最小值与最大值。 # @type ReplicateSetNum: Integer # @param NodeNum: - 创建副本集实例,指每个副本集内主从节点数量。每个副本集所支持的最大节点数与最小节点数,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # - 创建分片集群实例,指每个分片的主从节点数量。每个分片所支持的最大节点数与最小节点数,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # @type NodeNum: Integer # @param MongoVersion: 指版本信息。具体支持的版本信息 ,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # - MONGO_36_WT:MongoDB 3.6 WiredTiger存储引擎版本。 # - MONGO_40_WT:MongoDB 4.0 WiredTiger存储引擎版本。 # - MONGO_42_WT:MongoDB 4.2 WiredTiger存储引擎版本。 # - MONGO_44_WT:MongoDB 4.4 WiredTiger存储引擎版本。 # - MONGO_50_WT:MongoDB 5.0 WiredTiger存储引擎版本。 # - MONGO_60_WT:MongoDB 6.0 WiredTiger存储引擎版本。 # @type MongoVersion: String # @param MachineCode: 产品规格类型。 # - HIO10G:通用高HIO万兆型。 # - HCD:云盘版类型。 # @type MachineCode: String # @param GoodsNum: 实例数量,最小值1,最大值为10。 # @type GoodsNum: Integer # @param Zone: 可用区信息,输入格式如:ap-guangzhou-2。 # - 具体信息,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # - 该参数为主可用区,如果多可用区部署,Zone必须是AvailabilityZoneList中的一个。 # @type Zone: String # @param ClusterType: 实例架构类型。 # - REPLSET:副本集。 # - SHARD:分片集群。 # @type ClusterType: String # @param VpcId: 私有网络ID。请登录 [私有网络控制台](https://console.cloud.tencent.com/vpc) 查询确认正确的ID。 示例值:vpc-pxyzim13 # @type VpcId: String # @param SubnetId: 私有网络VPC的子网。请登录 [私有网络控制台](https://console.cloud.tencent.com/vpc) 查询子网列表确认正确的 ID。 示例值:subnet-7jbabche # @type SubnetId: String # @param Password: 实例密码。自定义密码长度为8-32个字符,至少包含字母、数字和字符(!@#%^*()_)中的两种。 # @type Password: String # @param ProjectId: 项目ID。 # - 若不设置该参数,则为默认项目。 # - 在 [MongoDB 控制台项目管理](https://console.cloud.tencent.com/project)页面,可获取项目ID。 # @type ProjectId: Integer # @param Tags: 实例标签信息。 # @type Tags: Array # @param Clone: 实例类型。- 1:正式实例。- 3:只读实例。- 4:灾备实例。-5:克隆实例,注意:克隆实例RestoreTime为必填项。 # @type Clone: Integer # @param Father: 父实例 ID。当参数**Clone**为3或者4时,即实例为只读或灾备实例时,该参数必须配置。 # @type Father: String # @param SecurityGroup: 安全组 ID。 # @type SecurityGroup: Array # @param RestoreTime: 克隆实例回档时间。 # - 若为克隆实例,则必须配置该参数。输入格式示例:2021-08-13 16:30:00。 # - 回档时间范围:仅能回档7天内时间点的数据。 # @type RestoreTime: String # @param InstanceName: 实例名称。仅支持长度为60个字符的中文、英文、数字、下划线_、分隔符- 。 # @type InstanceName: String # @param AvailabilityZoneList: 若多可用区部署云数据库实例,指定多可用区列表。 # - 多可用区部署实例,参数 **Zone** 指定实例主可用区信息;**AvailabilityZoneList** 指定所有可用区信息,包含主可用区。输入格式如:[ap-guangzhou-2,ap-guangzhou-3,ap-guangzhou-4]。 # - 通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 可获取云数据库不同地域规划的可用区信息,以便指定有效的可用区。 # - 多可用区部署节点只能部署在3个不同可用区。不支持将集群的大多数节点部署在同一个可用区。例如:3节点集群不支持2个节点部署在同一个区。 # @type AvailabilityZoneList: Array # @param MongosCpu: Mongos CPU 核数,支持1、2、4、8、16。购买分片集群时,必须填写。 # @type MongosCpu: Integer # @param MongosMemory: Mongos 内存大小。 # - 购买分片集群时,必须填写。 # - 单位:GB,支持1核2GB、2核4GB、4核8GB、8核16GB、16核32GB。 # @type MongosMemory: Integer # @param MongosNodeNum: Mongos 数量。购买分片集群时,必须填写。 # - 单可用区部署实例,其数量范围为[3,32]。 # - 多可用区部署实例,其数量范围为[6,32]。 # @type MongosNodeNum: Integer # @param ReadonlyNodeNum: 只读节点数量,取值范围[0,5]。 # @type ReadonlyNodeNum: Integer # @param ReadonlyNodeAvailabilityZoneList: 指只读节点所属可用区数组。跨可用区部署实例,参数**ReadonlyNodeNum**不为**0**时,必须配置该参数。 # @type ReadonlyNodeAvailabilityZoneList: Array # @param HiddenZone: Hidden节点所属可用区。跨可用区部署实例,必须配置该参数。 # @type HiddenZone: String # @param ParamTemplateId: 参数模板 ID。参数模板是一组 MongoDB 的参数并为预设置了参数值的集合,将一组有相同诉求的参数及值 存为模板,在创建实例时,可直接引用参数值到新实例。合理使用参数模板,可以提高MongoDB数据库的效率。模板列表从 DescribeDBInstanceParamTpl 接口获取,注意模板支持的版本。 # @type ParamTemplateId: String attr_accessor :Memory, :Volume, :ReplicateSetNum, :NodeNum, :MongoVersion, :MachineCode, :GoodsNum, :Zone, :ClusterType, :VpcId, :SubnetId, :Password, :ProjectId, :Tags, :Clone, :Father, :SecurityGroup, :RestoreTime, :InstanceName, :AvailabilityZoneList, :MongosCpu, :MongosMemory, :MongosNodeNum, :ReadonlyNodeNum, :ReadonlyNodeAvailabilityZoneList, :HiddenZone, :ParamTemplateId def initialize(memory=nil, volume=nil, replicatesetnum=nil, nodenum=nil, mongoversion=nil, machinecode=nil, goodsnum=nil, zone=nil, clustertype=nil, vpcid=nil, subnetid=nil, password=nil, projectid=nil, tags=nil, clone=nil, father=nil, securitygroup=nil, restoretime=nil, instancename=nil, availabilityzonelist=nil, mongoscpu=nil, mongosmemory=nil, mongosnodenum=nil, readonlynodenum=nil, readonlynodeavailabilityzonelist=nil, hiddenzone=nil, paramtemplateid=nil) @Memory = memory @Volume = volume @ReplicateSetNum = replicatesetnum @NodeNum = nodenum @MongoVersion = mongoversion @MachineCode = machinecode @GoodsNum = goodsnum @Zone = zone @ClusterType = clustertype @VpcId = vpcid @SubnetId = subnetid @Password = password @ProjectId = projectid @Tags = tags @Clone = clone @Father = father @SecurityGroup = securitygroup @RestoreTime = restoretime @InstanceName = instancename @AvailabilityZoneList = availabilityzonelist @MongosCpu = mongoscpu @MongosMemory = mongosmemory @MongosNodeNum = mongosnodenum @ReadonlyNodeNum = readonlynodenum @ReadonlyNodeAvailabilityZoneList = readonlynodeavailabilityzonelist @HiddenZone = hiddenzone @ParamTemplateId = paramtemplateid end def deserialize(params) @Memory = params['Memory'] @Volume = params['Volume'] @ReplicateSetNum = params['ReplicateSetNum'] @NodeNum = params['NodeNum'] @MongoVersion = params['MongoVersion'] @MachineCode = params['MachineCode'] @GoodsNum = params['GoodsNum'] @Zone = params['Zone'] @ClusterType = params['ClusterType'] @VpcId = params['VpcId'] @SubnetId = params['SubnetId'] @Password = params['Password'] @ProjectId = params['ProjectId'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| taginfo_tmp = TagInfo.new taginfo_tmp.deserialize(i) @Tags << taginfo_tmp end end @Clone = params['Clone'] @Father = params['Father'] @SecurityGroup = params['SecurityGroup'] @RestoreTime = params['RestoreTime'] @InstanceName = params['InstanceName'] @AvailabilityZoneList = params['AvailabilityZoneList'] @MongosCpu = params['MongosCpu'] @MongosMemory = params['MongosMemory'] @MongosNodeNum = params['MongosNodeNum'] @ReadonlyNodeNum = params['ReadonlyNodeNum'] @ReadonlyNodeAvailabilityZoneList = params['ReadonlyNodeAvailabilityZoneList'] @HiddenZone = params['HiddenZone'] @ParamTemplateId = params['ParamTemplateId'] end end # CreateDBInstanceHour返回参数结构体 class CreateDBInstanceHourResponse < TencentCloud::Common::AbstractModel # @param DealId: 订单ID。 # @type DealId: String # @param InstanceIds: 创建的实例ID列表。 # @type InstanceIds: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :DealId, :InstanceIds, :RequestId def initialize(dealid=nil, instanceids=nil, requestid=nil) @DealId = dealid @InstanceIds = instanceids @RequestId = requestid end def deserialize(params) @DealId = params['DealId'] @InstanceIds = params['InstanceIds'] @RequestId = params['RequestId'] end end # CreateDBInstanceParamTpl请求参数结构体 class CreateDBInstanceParamTplRequest < TencentCloud::Common::AbstractModel # @param TplName: 参数模板名称。 # @type TplName: String # @param MongoVersion: 版本号,该参数模板支持的售卖版本请参照查询云数据库的售卖规格(DescribeSpecInfo)返回结果。参数与版本对应关系是:MONGO_36_WT:MongoDB 3.6 WiredTiger存储引擎版本,MONGO_40_WT:MongoDB 4.0 WiredTiger存储引擎版本,MONGO_42_WT:MongoDB 4.2 WiredTiger存储引擎版本。当MirrorTplId为空时,该字段必填。 # @type MongoVersion: String # @param ClusterType: 实例类型,REPLSET-副本集,SHARD-分片集群,STANDALONE-单节点 # 当MirrorTplId为空时,该字段必填。 # @type ClusterType: String # @param TplDesc: 模板描述信息。 # @type TplDesc: String # @param Params: 模板参数,若为空,则以系统默认模板作为新版本参数。 # @type Params: Array # @param MirrorTplId: 镜像模板ID,若该字段不为空,则以该模板为镜像,克隆出一个新的模板。注意:MirrorTplId不为空时,MongoVersion及ClusterType将以MirrorTpl模板的版本及实例类型为准。 # @type MirrorTplId: String attr_accessor :TplName, :MongoVersion, :ClusterType, :TplDesc, :Params, :MirrorTplId def initialize(tplname=nil, mongoversion=nil, clustertype=nil, tpldesc=nil, params=nil, mirrortplid=nil) @TplName = tplname @MongoVersion = mongoversion @ClusterType = clustertype @TplDesc = tpldesc @Params = params @MirrorTplId = mirrortplid end def deserialize(params) @TplName = params['TplName'] @MongoVersion = params['MongoVersion'] @ClusterType = params['ClusterType'] @TplDesc = params['TplDesc'] unless params['Params'].nil? @Params = [] params['Params'].each do |i| paramtype_tmp = ParamType.new paramtype_tmp.deserialize(i) @Params << paramtype_tmp end end @MirrorTplId = params['MirrorTplId'] end end # CreateDBInstanceParamTpl返回参数结构体 class CreateDBInstanceParamTplResponse < TencentCloud::Common::AbstractModel # @param TplId: 模板ID # @type TplId: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TplId, :RequestId def initialize(tplid=nil, requestid=nil) @TplId = tplid @RequestId = requestid end def deserialize(params) @TplId = params['TplId'] @RequestId = params['RequestId'] end end # CreateDBInstance请求参数结构体 class CreateDBInstanceRequest < TencentCloud::Common::AbstractModel # @param NodeNum: - 创建副本集实例,指每个副本集内主从节点数量。每个副本集所支持的最大节点数与最小节点数,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # - 创建分片集群实例,指每个分片的主从节点数量。每个分片所支持的最大节点数与最小节点数,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # @type NodeNum: Integer # @param Memory: 实例内存大小,单位:GB。具体售卖的内存规格,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # @type Memory: Integer # @param Volume: 实例硬盘大小,单位:GB。每一个 CPU 规格对应的最大磁盘与最小磁盘范围,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # @type Volume: Integer # @param MongoVersion: 指版本信息。具体支持的版本信息 ,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # - MONGO_36_WT:MongoDB 3.6 WiredTiger存储引擎版本。 # - MONGO_40_WT:MongoDB 4.0 WiredTiger存储引擎版本。 # - MONGO_42_WT:MongoDB 4.2 WiredTiger存储引擎版本。 # - MONGO_44_WT:MongoDB 4.4 WiredTiger存储引擎版本。 # - MONGO_50_WT:MongoDB 5.0 WiredTiger存储引擎版本。 # - MONGO_60_WT:MongoDB 6.0 WiredTiger存储引擎版本。 # @type MongoVersion: String # @param GoodsNum: 实例数量, 最小值1,最大值为10。 # @type GoodsNum: Integer # @param Zone: 可用区信息,输入格式如:ap-guangzhou-2。 # - 具体信息,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # - 该参数为主可用区,如果多可用区部署,Zone必须是AvailabilityZoneList中的一个。 # @type Zone: String # @param Period: 指定购买实例的购买时长。取值可选:[1,2,3,4,5,6,7,8,9,10,11,12,24,36];单位:月。 # @type Period: Integer # @param MachineCode: 产品规格类型。 # - HIO10G:通用高HIO万兆型。 # - HCD:云盘版类型。 # @type MachineCode: String # @param ClusterType: 实例架构类型。 # - REPLSET:副本集。 # - SHARD:分片集群。 # @type ClusterType: String # @param ReplicateSetNum: - 创建副本集实例,指副本集数量,该参数只能为1。 # - 创建分片集群实例,指分片的数量。请通过接口[DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567)查询分片数量的取值范围,其返回的数据结构SpecItems中的参数MinReplicateSetNum与MaxReplicateSetNum分别对应其最小值与最大值。 # @type ReplicateSetNum: Integer # @param ProjectId: 项目ID。 # - 若不设置该参数,则为默认项目。 # - 在 [MongoDB 控制台项目管理](https://console.cloud.tencent.com/project)页面,可获取项目ID。 # @type ProjectId: Integer # @param VpcId: 私有网络ID。请登录[私有网络控制台](https://console.cloud.tencent.com/vpc)查询确认正确的ID。 示例值:vpc-pxyzim13 # @type VpcId: String # @param SubnetId: 私有网络VPC的子网。请登录 [私有网络控制台](https://console.cloud.tencent.com/vpc) 查询子网列表确认正确的 ID。 示例值:subnet-7jbabche # @type SubnetId: String # @param Password: 实例密码。自定义密码长度为8-32个字符,至少包含字母、数字和字符(!@#%^*()_)中的两种。 # @type Password: String # @param Tags: 实例标签信息。 # @type Tags: Array # @param AutoRenewFlag: 自动续费标记。 # - 0:不自动续费。 # - 1:自动续费。 # @type AutoRenewFlag: Integer # @param AutoVoucher: 是否自动选择代金券。 # - 1:是。 # - 0:否。默认为0。 # @type AutoVoucher: Integer # @param Clone: 实例类型。- 1:正式实例。- 3:只读实例。- 4:灾备实例。-5:整实例克隆,注意:克隆实例时,RestoreTime为必填项。 # @type Clone: Integer # @param Father: 父实例 ID。当参数**Clone**为3或者4时,即实例为只读或灾备实例时,该参数必须配置。 # @type Father: String # @param SecurityGroup: 安全组 ID。 # @type SecurityGroup: Array # @param RestoreTime: 克隆实例回档时间,当Clone取值为5或6时为必填。- 若为克隆实例,则必须配置该参数。输入格式示例:2021-08-13 16:30:00。- 回档时间范围:仅能回档7天内时间点的数据。 # @type RestoreTime: String # @param InstanceName: 实例名称。仅支持长度为60个字符的中文、英文、数字、下划线_、分隔符- 。 # @type InstanceName: String # @param AvailabilityZoneList: 若多可用区部署云数据库实例,指定多可用区列表。 # - 多可用区部署实例,参数 **Zone** 指定实例主可用区信息;**AvailabilityZoneList** 指定所有可用区信息,包含主可用区。输入格式如:[ap-guangzhou-2,ap-guangzhou-3,ap-guangzhou-4]。 # - 通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 可获取云数据库不同地域规划的可用区信息,以便指定有效的可用区。 # - 多可用区部署节点只能部署在3个不同可用区。不支持将集群的大多数节点部署在同一个可用区。例如:3节点集群不支持2个节点部署在同一个区。 # @type AvailabilityZoneList: Array # @param MongosCpu: Mongos CPU 核数,支持1、2、4、8、16。购买分片集群时,必须填写。 # @type MongosCpu: Integer # @param MongosMemory: Mongos 内存大小。 # - 购买分片集群时,必须填写。 # - 单位:GB,支持1核2GB、2核4GB、4核8GB、8核16GB、16核32GB。 # @type MongosMemory: Integer # @param MongosNodeNum: Mongos 数量。购买分片集群时,必须填写。 # - 单可用区部署实例,其数量范围为[3,32]。 # - 多可用区部署实例,其数量范围为[6,32]。 # @type MongosNodeNum: Integer # @param ReadonlyNodeNum: 只读节点数量,取值范围[0,5]。 # @type ReadonlyNodeNum: Integer # @param ReadonlyNodeAvailabilityZoneList: 指只读节点所属可用区数组。跨可用区部署实例,参数**ReadonlyNodeNum**不为**0**时,必须配置该参数。 # @type ReadonlyNodeAvailabilityZoneList: Array # @param HiddenZone: Hidden节点所属可用区。跨可用区部署实例,必须配置该参数。 # @type HiddenZone: String # @param ParamTemplateId: 参数模板 ID。参数模板是一组 MongoDB 的参数并为预设置了参数值的集合,将一组有相同诉求的参数及值 存为模板,在创建实例时,可直接引用参数值到新实例。合理使用参数模板,可以提高MongoDB数据库的效率。模板列表从 DescribeDBInstanceParamTpl 接口获取,注意模板支持的版本及实例类型。 # @type ParamTemplateId: String attr_accessor :NodeNum, :Memory, :Volume, :MongoVersion, :GoodsNum, :Zone, :Period, :MachineCode, :ClusterType, :ReplicateSetNum, :ProjectId, :VpcId, :SubnetId, :Password, :Tags, :AutoRenewFlag, :AutoVoucher, :Clone, :Father, :SecurityGroup, :RestoreTime, :InstanceName, :AvailabilityZoneList, :MongosCpu, :MongosMemory, :MongosNodeNum, :ReadonlyNodeNum, :ReadonlyNodeAvailabilityZoneList, :HiddenZone, :ParamTemplateId def initialize(nodenum=nil, memory=nil, volume=nil, mongoversion=nil, goodsnum=nil, zone=nil, period=nil, machinecode=nil, clustertype=nil, replicatesetnum=nil, projectid=nil, vpcid=nil, subnetid=nil, password=nil, tags=nil, autorenewflag=nil, autovoucher=nil, clone=nil, father=nil, securitygroup=nil, restoretime=nil, instancename=nil, availabilityzonelist=nil, mongoscpu=nil, mongosmemory=nil, mongosnodenum=nil, readonlynodenum=nil, readonlynodeavailabilityzonelist=nil, hiddenzone=nil, paramtemplateid=nil) @NodeNum = nodenum @Memory = memory @Volume = volume @MongoVersion = mongoversion @GoodsNum = goodsnum @Zone = zone @Period = period @MachineCode = machinecode @ClusterType = clustertype @ReplicateSetNum = replicatesetnum @ProjectId = projectid @VpcId = vpcid @SubnetId = subnetid @Password = password @Tags = tags @AutoRenewFlag = autorenewflag @AutoVoucher = autovoucher @Clone = clone @Father = father @SecurityGroup = securitygroup @RestoreTime = restoretime @InstanceName = instancename @AvailabilityZoneList = availabilityzonelist @MongosCpu = mongoscpu @MongosMemory = mongosmemory @MongosNodeNum = mongosnodenum @ReadonlyNodeNum = readonlynodenum @ReadonlyNodeAvailabilityZoneList = readonlynodeavailabilityzonelist @HiddenZone = hiddenzone @ParamTemplateId = paramtemplateid end def deserialize(params) @NodeNum = params['NodeNum'] @Memory = params['Memory'] @Volume = params['Volume'] @MongoVersion = params['MongoVersion'] @GoodsNum = params['GoodsNum'] @Zone = params['Zone'] @Period = params['Period'] @MachineCode = params['MachineCode'] @ClusterType = params['ClusterType'] @ReplicateSetNum = params['ReplicateSetNum'] @ProjectId = params['ProjectId'] @VpcId = params['VpcId'] @SubnetId = params['SubnetId'] @Password = params['Password'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| taginfo_tmp = TagInfo.new taginfo_tmp.deserialize(i) @Tags << taginfo_tmp end end @AutoRenewFlag = params['AutoRenewFlag'] @AutoVoucher = params['AutoVoucher'] @Clone = params['Clone'] @Father = params['Father'] @SecurityGroup = params['SecurityGroup'] @RestoreTime = params['RestoreTime'] @InstanceName = params['InstanceName'] @AvailabilityZoneList = params['AvailabilityZoneList'] @MongosCpu = params['MongosCpu'] @MongosMemory = params['MongosMemory'] @MongosNodeNum = params['MongosNodeNum'] @ReadonlyNodeNum = params['ReadonlyNodeNum'] @ReadonlyNodeAvailabilityZoneList = params['ReadonlyNodeAvailabilityZoneList'] @HiddenZone = params['HiddenZone'] @ParamTemplateId = params['ParamTemplateId'] end end # CreateDBInstance返回参数结构体 class CreateDBInstanceResponse < TencentCloud::Common::AbstractModel # @param DealId: 订单ID # @type DealId: String # @param InstanceIds: 创建的实例ID列表 # @type InstanceIds: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :DealId, :InstanceIds, :RequestId def initialize(dealid=nil, instanceids=nil, requestid=nil) @DealId = dealid @InstanceIds = instanceids @RequestId = requestid end def deserialize(params) @DealId = params['DealId'] @InstanceIds = params['InstanceIds'] @RequestId = params['RequestId'] end end # 云数据库实例当前操作 class CurrentOp < TencentCloud::Common::AbstractModel # @param OpId: 操作序号。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type OpId: Integer # @param Ns: 操作所在的命名空间,形式如db.collection。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Ns: String # @param Query: 操作执行语句。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Query: String # @param Op: 操作类型,可能的取值:aggregate、count、delete、distinct、find、findAndModify、getMore、insert、mapReduce、update和command。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Op: String # @param ReplicaSetName: 操作所在的分片名称。 # @type ReplicaSetName: String # @param NodeName: 操作所在的节点名称。 # @type NodeName: String # @param Operation: 操作详细信息。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Operation: String # @param State: 筛选条件,节点状态,可能的取值为:Primary、Secondary。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type State: String # @param MicrosecsRunning: 操作已执行时间(ms)。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type MicrosecsRunning: Integer # @param ExecNode: 当前操作所在节点信息。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExecNode: String attr_accessor :OpId, :Ns, :Query, :Op, :ReplicaSetName, :NodeName, :Operation, :State, :MicrosecsRunning, :ExecNode def initialize(opid=nil, ns=nil, query=nil, op=nil, replicasetname=nil, nodename=nil, operation=nil, state=nil, microsecsrunning=nil, execnode=nil) @OpId = opid @Ns = ns @Query = query @Op = op @ReplicaSetName = replicasetname @NodeName = nodename @Operation = operation @State = state @MicrosecsRunning = microsecsrunning @ExecNode = execnode end def deserialize(params) @OpId = params['OpId'] @Ns = params['Ns'] @Query = params['Query'] @Op = params['Op'] @ReplicaSetName = params['ReplicaSetName'] @NodeName = params['NodeName'] @Operation = params['Operation'] @State = params['State'] @MicrosecsRunning = params['MicrosecsRunning'] @ExecNode = params['ExecNode'] end end # 实例信息 class DBInstanceInfo < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID # @type InstanceId: String # @param Region: 地域信息 # @type Region: String attr_accessor :InstanceId, :Region def initialize(instanceid=nil, region=nil) @InstanceId = instanceid @Region = region end def deserialize(params) @InstanceId = params['InstanceId'] @Region = params['Region'] end end # 数据库实例价格 class DBInstancePrice < TencentCloud::Common::AbstractModel # @param UnitPrice: 单价 # 注意:此字段可能返回 null,表示取不到有效值。 # @type UnitPrice: Float # @param OriginalPrice: 原价 # @type OriginalPrice: Float # @param DiscountPrice: 折扣价 # @type DiscountPrice: Float attr_accessor :UnitPrice, :OriginalPrice, :DiscountPrice def initialize(unitprice=nil, originalprice=nil, discountprice=nil) @UnitPrice = unitprice @OriginalPrice = originalprice @DiscountPrice = discountprice end def deserialize(params) @UnitPrice = params['UnitPrice'] @OriginalPrice = params['OriginalPrice'] @DiscountPrice = params['DiscountPrice'] end end # DeleteAccountUser请求参数结构体 class DeleteAccountUserRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定待删除账号的实例 ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param UserName: 配置待删除的账号名。 # @type UserName: String # @param MongoUserPassword: 配置 mongouser 对应的密码。mongouser为系统默认账号,输入其对应的密码。 # @type MongoUserPassword: String attr_accessor :InstanceId, :UserName, :MongoUserPassword def initialize(instanceid=nil, username=nil, mongouserpassword=nil) @InstanceId = instanceid @UserName = username @MongoUserPassword = mongouserpassword end def deserialize(params) @InstanceId = params['InstanceId'] @UserName = params['UserName'] @MongoUserPassword = params['MongoUserPassword'] end end # DeleteAccountUser返回参数结构体 class DeleteAccountUserResponse < TencentCloud::Common::AbstractModel # @param FlowId: 账户删除任务ID。 # @type FlowId: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :FlowId, :RequestId def initialize(flowid=nil, requestid=nil) @FlowId = flowid @RequestId = requestid end def deserialize(params) @FlowId = params['FlowId'] @RequestId = params['RequestId'] end end # DescribeAccountUsers请求参数结构体 class DescribeAccountUsersRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定待获取账号的实例ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String attr_accessor :InstanceId def initialize(instanceid=nil) @InstanceId = instanceid end def deserialize(params) @InstanceId = params['InstanceId'] end end # DescribeAccountUsers返回参数结构体 class DescribeAccountUsersResponse < TencentCloud::Common::AbstractModel # @param Users: 实例账号列表。 # @type Users: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Users, :RequestId def initialize(users=nil, requestid=nil) @Users = users @RequestId = requestid end def deserialize(params) unless params['Users'].nil? @Users = [] params['Users'].each do |i| userinfo_tmp = UserInfo.new userinfo_tmp.deserialize(i) @Users << userinfo_tmp end end @RequestId = params['RequestId'] end end # DescribeAsyncRequestInfo请求参数结构体 class DescribeAsyncRequestInfoRequest < TencentCloud::Common::AbstractModel # @param AsyncRequestId: 异步请求Id,涉及到异步流程的接口返回,如CreateBackupDBInstance # @type AsyncRequestId: String attr_accessor :AsyncRequestId def initialize(asyncrequestid=nil) @AsyncRequestId = asyncrequestid end def deserialize(params) @AsyncRequestId = params['AsyncRequestId'] end end # DescribeAsyncRequestInfo返回参数结构体 class DescribeAsyncRequestInfoResponse < TencentCloud::Common::AbstractModel # @param Status: 状态。返回参数有:initial-初始化、running-运行中、paused-任务执行失败,已暂停、undoed-任务执行失败,已回滚、failed-任务执行失败, 已终止、success-成功 # @type Status: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Status, :RequestId def initialize(status=nil, requestid=nil) @Status = status @RequestId = requestid end def deserialize(params) @Status = params['Status'] @RequestId = params['RequestId'] end end # DescribeBackupDownloadTask请求参数结构体 class DescribeBackupDownloadTaskRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同 # @type InstanceId: String # @param BackupName: 备份文件名,用来过滤指定文件的下载任务 # @type BackupName: String # @param StartTime: 指定查询时间范围内的任务,StartTime指定开始时间,不填默认不限制开始时间 # @type StartTime: String # @param EndTime: 指定查询时间范围内的任务,EndTime指定截止时间,不填默认不限制截止时间 # @type EndTime: String # @param Limit: 此次查询返回的条数,取值范围为1-100,默认为20 # @type Limit: Integer # @param Offset: 指定此次查询返回的页数,默认为0 # @type Offset: Integer # @param OrderBy: 排序字段,取值为createTime,finishTime两种,默认为createTime # @type OrderBy: String # @param OrderByType: 排序方式,取值为asc,desc两种,默认desc # @type OrderByType: String # @param Status: 根据任务状态过滤。0-等待执行,1-正在下载,2-下载完成,3-下载失败,4-等待重试。不填默认返回所有类型 # @type Status: Array attr_accessor :InstanceId, :BackupName, :StartTime, :EndTime, :Limit, :Offset, :OrderBy, :OrderByType, :Status def initialize(instanceid=nil, backupname=nil, starttime=nil, endtime=nil, limit=nil, offset=nil, orderby=nil, orderbytype=nil, status=nil) @InstanceId = instanceid @BackupName = backupname @StartTime = starttime @EndTime = endtime @Limit = limit @Offset = offset @OrderBy = orderby @OrderByType = orderbytype @Status = status end def deserialize(params) @InstanceId = params['InstanceId'] @BackupName = params['BackupName'] @StartTime = params['StartTime'] @EndTime = params['EndTime'] @Limit = params['Limit'] @Offset = params['Offset'] @OrderBy = params['OrderBy'] @OrderByType = params['OrderByType'] @Status = params['Status'] end end # DescribeBackupDownloadTask返回参数结构体 class DescribeBackupDownloadTaskResponse < TencentCloud::Common::AbstractModel # @param TotalCount: 满足查询条件的所有条数 # @type TotalCount: Integer # @param Tasks: 下载任务列表 # @type Tasks: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TotalCount, :Tasks, :RequestId def initialize(totalcount=nil, tasks=nil, requestid=nil) @TotalCount = totalcount @Tasks = tasks @RequestId = requestid end def deserialize(params) @TotalCount = params['TotalCount'] unless params['Tasks'].nil? @Tasks = [] params['Tasks'].each do |i| backupdownloadtask_tmp = BackupDownloadTask.new backupdownloadtask_tmp.deserialize(i) @Tasks << backupdownloadtask_tmp end end @RequestId = params['RequestId'] end end # DescribeBackupRules请求参数结构体 class DescribeBackupRulesRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定实例ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String attr_accessor :InstanceId def initialize(instanceid=nil) @InstanceId = instanceid end def deserialize(params) @InstanceId = params['InstanceId'] end end # DescribeBackupRules返回参数结构体 class DescribeBackupRulesResponse < TencentCloud::Common::AbstractModel # @param BackupSaveTime: 备份数据保留期限。单位为:天。 # @type BackupSaveTime: Integer # @param BackupTime: 自动备份开始时间。 # @type BackupTime: Integer # @param BackupMethod: 备份方式。 # - 0:逻辑备份。 # - 1:物理备份。 # @type BackupMethod: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :BackupSaveTime, :BackupTime, :BackupMethod, :RequestId def initialize(backupsavetime=nil, backuptime=nil, backupmethod=nil, requestid=nil) @BackupSaveTime = backupsavetime @BackupTime = backuptime @BackupMethod = backupmethod @RequestId = requestid end def deserialize(params) @BackupSaveTime = params['BackupSaveTime'] @BackupTime = params['BackupTime'] @BackupMethod = params['BackupMethod'] @RequestId = params['RequestId'] end end # DescribeClientConnections请求参数结构体 class DescribeClientConnectionsRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定待查询的实例ID,例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param Limit: 单次请求返回的数量。最小值为1,最大值为1000,默认值为1000。 # @type Limit: Integer # @param Offset: 偏移量,默认值为0。Offset=Limit*(页码-1)。 # @type Offset: Integer attr_accessor :InstanceId, :Limit, :Offset def initialize(instanceid=nil, limit=nil, offset=nil) @InstanceId = instanceid @Limit = limit @Offset = offset end def deserialize(params) @InstanceId = params['InstanceId'] @Limit = params['Limit'] @Offset = params['Offset'] end end # DescribeClientConnections返回参数结构体 class DescribeClientConnectionsResponse < TencentCloud::Common::AbstractModel # @param Clients: 客户端连接信息,包括客户端 IP 和对应 IP 的连接数量。 # @type Clients: Array # @param TotalCount: 满足条件的记录总条数,可用于分页查询。 # @type TotalCount: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Clients, :TotalCount, :RequestId def initialize(clients=nil, totalcount=nil, requestid=nil) @Clients = clients @TotalCount = totalcount @RequestId = requestid end def deserialize(params) unless params['Clients'].nil? @Clients = [] params['Clients'].each do |i| clientconnection_tmp = ClientConnection.new clientconnection_tmp.deserialize(i) @Clients << clientconnection_tmp end end @TotalCount = params['TotalCount'] @RequestId = params['RequestId'] end end # DescribeCurrentOp请求参数结构体 class DescribeCurrentOpRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定要查询的实例 ID,例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param Ns: 操作所属的命名空间 namespace,格式为 db.collection。 # @type Ns: String # @param MillisecondRunning: 设置查询筛选条件为操作任务已经执行的时间。 # - 默认值为0,取值范围为[0, 3600000],单位:毫秒。 # - 结果将返回超过设置时间的操作。 # @type MillisecondRunning: Integer # @param Op: 设置查询筛选条件为操作任务类型。取值包括:none、update、insert,query、command、getmore、remove 和 killcursors。 # @type Op: String # @param ReplicaSetName: 筛选条件,分片名称。 # @type ReplicaSetName: String # @param State: 设置查询筛选条件为节点角色。 # - primary:主节点。 # - secondary:从节点。 # @type State: String # @param Limit: 单次请求返回的数量,默认值为100,取值范围为[0,100] # @type Limit: Integer # @param Offset: 偏移量,默认值为0,取值范围为[0,10000] # @type Offset: Integer # @param OrderBy: 返回结果集排序的字段,目前支持:"MicrosecsRunning"/"microsecsrunning",默认为升序排序 # @type OrderBy: String # @param OrderByType: 返回结果集排序方式,可能的取值:"ASC"/"asc"或"DESC"/"desc" # @type OrderByType: String attr_accessor :InstanceId, :Ns, :MillisecondRunning, :Op, :ReplicaSetName, :State, :Limit, :Offset, :OrderBy, :OrderByType def initialize(instanceid=nil, ns=nil, millisecondrunning=nil, op=nil, replicasetname=nil, state=nil, limit=nil, offset=nil, orderby=nil, orderbytype=nil) @InstanceId = instanceid @Ns = ns @MillisecondRunning = millisecondrunning @Op = op @ReplicaSetName = replicasetname @State = state @Limit = limit @Offset = offset @OrderBy = orderby @OrderByType = orderbytype end def deserialize(params) @InstanceId = params['InstanceId'] @Ns = params['Ns'] @MillisecondRunning = params['MillisecondRunning'] @Op = params['Op'] @ReplicaSetName = params['ReplicaSetName'] @State = params['State'] @Limit = params['Limit'] @Offset = params['Offset'] @OrderBy = params['OrderBy'] @OrderByType = params['OrderByType'] end end # DescribeCurrentOp返回参数结构体 class DescribeCurrentOpResponse < TencentCloud::Common::AbstractModel # @param TotalCount: 符合查询条件的操作总数。 # @type TotalCount: Integer # @param CurrentOps: 当前操作列表。 # @type CurrentOps: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TotalCount, :CurrentOps, :RequestId def initialize(totalcount=nil, currentops=nil, requestid=nil) @TotalCount = totalcount @CurrentOps = currentops @RequestId = requestid end def deserialize(params) @TotalCount = params['TotalCount'] unless params['CurrentOps'].nil? @CurrentOps = [] params['CurrentOps'].each do |i| currentop_tmp = CurrentOp.new currentop_tmp.deserialize(i) @CurrentOps << currentop_tmp end end @RequestId = params['RequestId'] end end # DescribeDBBackups请求参数结构体 class DescribeDBBackupsRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同 # @type InstanceId: String # @param BackupMethod: 备份方式,当前支持:0-逻辑备份,1-物理备份,2-所有备份。默认为逻辑备份。 # @type BackupMethod: Integer # @param Limit: 分页大小,最大值为100,不设置默认查询所有。 # @type Limit: Integer # @param Offset: 分页偏移量,最小值为0,默认值为0。 # @type Offset: Integer attr_accessor :InstanceId, :BackupMethod, :Limit, :Offset def initialize(instanceid=nil, backupmethod=nil, limit=nil, offset=nil) @InstanceId = instanceid @BackupMethod = backupmethod @Limit = limit @Offset = offset end def deserialize(params) @InstanceId = params['InstanceId'] @BackupMethod = params['BackupMethod'] @Limit = params['Limit'] @Offset = params['Offset'] end end # DescribeDBBackups返回参数结构体 class DescribeDBBackupsResponse < TencentCloud::Common::AbstractModel # @param BackupList: 备份列表 # @type BackupList: Array # @param TotalCount: 备份总数 # @type TotalCount: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :BackupList, :TotalCount, :RequestId def initialize(backuplist=nil, totalcount=nil, requestid=nil) @BackupList = backuplist @TotalCount = totalcount @RequestId = requestid end def deserialize(params) unless params['BackupList'].nil? @BackupList = [] params['BackupList'].each do |i| backupinfo_tmp = BackupInfo.new backupinfo_tmp.deserialize(i) @BackupList << backupinfo_tmp end end @TotalCount = params['TotalCount'] @RequestId = params['RequestId'] end end # DescribeDBInstanceDeal请求参数结构体 class DescribeDBInstanceDealRequest < TencentCloud::Common::AbstractModel # @param DealId: 订单ID,通过CreateDBInstance等接口返回 # @type DealId: String attr_accessor :DealId def initialize(dealid=nil) @DealId = dealid end def deserialize(params) @DealId = params['DealId'] end end # DescribeDBInstanceDeal返回参数结构体 class DescribeDBInstanceDealResponse < TencentCloud::Common::AbstractModel # @param Status: 订单状态,1:未支付,2:已支付,3:发货中,4:发货成功,5:发货失败,6:退款,7:订单关闭,8:超时未支付关闭。 # @type Status: Integer # @param OriginalPrice: 订单原价。 # @type OriginalPrice: Float # @param DiscountPrice: 订单折扣价格。 # @type DiscountPrice: Float # @param Action: 订单行为,purchase:新购,renew:续费,upgrade:升配,downgrade:降配,refund:退货退款。 # @type Action: String # @param InstanceId: 当前订单的资源Id。 # @type InstanceId: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Status, :OriginalPrice, :DiscountPrice, :Action, :InstanceId, :RequestId def initialize(status=nil, originalprice=nil, discountprice=nil, action=nil, instanceid=nil, requestid=nil) @Status = status @OriginalPrice = originalprice @DiscountPrice = discountprice @Action = action @InstanceId = instanceid @RequestId = requestid end def deserialize(params) @Status = params['Status'] @OriginalPrice = params['OriginalPrice'] @DiscountPrice = params['DiscountPrice'] @Action = params['Action'] @InstanceId = params['InstanceId'] @RequestId = params['RequestId'] end end # DescribeDBInstanceNodeProperty请求参数结构体 class DescribeDBInstanceNodePropertyRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同。 # @type InstanceId: String # @param NodeIds: 节点ID。 # @type NodeIds: Array # @param Roles: 节点角色。可选值包括: # # @type Roles: Array # @param OnlyHidden: 该参数指定节点是否为Hidden节点,默认为false。 # @type OnlyHidden: Boolean # @param Priority: 该参数指定选举新主节点的优先级。其取值范围为[0,100],数值越高,优先级越高。 # @type Priority: Integer # @param Votes: 该参数指定节点投票权。 # # @type Votes: Integer # @param Tags: 节点标签。 # @type Tags: Array attr_accessor :InstanceId, :NodeIds, :Roles, :OnlyHidden, :Priority, :Votes, :Tags def initialize(instanceid=nil, nodeids=nil, roles=nil, onlyhidden=nil, priority=nil, votes=nil, tags=nil) @InstanceId = instanceid @NodeIds = nodeids @Roles = roles @OnlyHidden = onlyhidden @Priority = priority @Votes = votes @Tags = tags end def deserialize(params) @InstanceId = params['InstanceId'] @NodeIds = params['NodeIds'] @Roles = params['Roles'] @OnlyHidden = params['OnlyHidden'] @Priority = params['Priority'] @Votes = params['Votes'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| nodetag_tmp = NodeTag.new nodetag_tmp.deserialize(i) @Tags << nodetag_tmp end end end end # DescribeDBInstanceNodeProperty返回参数结构体 class DescribeDBInstanceNodePropertyResponse < TencentCloud::Common::AbstractModel # @param Mongos: Mongos节点属性。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Mongos: Array # @param ReplicateSets: 副本集节点信息。 # @type ReplicateSets: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Mongos, :ReplicateSets, :RequestId def initialize(mongos=nil, replicatesets=nil, requestid=nil) @Mongos = mongos @ReplicateSets = replicatesets @RequestId = requestid end def deserialize(params) unless params['Mongos'].nil? @Mongos = [] params['Mongos'].each do |i| nodeproperty_tmp = NodeProperty.new nodeproperty_tmp.deserialize(i) @Mongos << nodeproperty_tmp end end unless params['ReplicateSets'].nil? @ReplicateSets = [] params['ReplicateSets'].each do |i| replicatesetinfo_tmp = ReplicateSetInfo.new replicatesetinfo_tmp.deserialize(i) @ReplicateSets << replicatesetinfo_tmp end end @RequestId = params['RequestId'] end end # DescribeDBInstanceParamTplDetail请求参数结构体 class DescribeDBInstanceParamTplDetailRequest < TencentCloud::Common::AbstractModel # @param TplId: 参数模板 ID。 # @type TplId: String # @param ParamName: 参数名称,传入该值,则只会获取该字段的参数详情。为空时,返回全部参数。 # @type ParamName: String attr_accessor :TplId, :ParamName def initialize(tplid=nil, paramname=nil) @TplId = tplid @ParamName = paramname end def deserialize(params) @TplId = params['TplId'] @ParamName = params['ParamName'] end end # DescribeDBInstanceParamTplDetail返回参数结构体 class DescribeDBInstanceParamTplDetailResponse < TencentCloud::Common::AbstractModel # @param InstanceEnumParams: 枚举类参数详情列表。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceEnumParams: Array # @param InstanceIntegerParams: 整形参数详情列表。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceIntegerParams: Array # @param InstanceTextParams: 文本参数详情列表。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceTextParams: Array # @param InstanceMultiParams: 多值参数详情列表。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceMultiParams: Array # @param TotalCount: 参数总个数。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param MongoVersion: 模板适配实例版本。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type MongoVersion: String # @param ClusterType: 模板适配集群类型,副本集或分片。。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ClusterType: String # @param TplName: 参数模板名称。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TplName: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :InstanceEnumParams, :InstanceIntegerParams, :InstanceTextParams, :InstanceMultiParams, :TotalCount, :MongoVersion, :ClusterType, :TplName, :RequestId def initialize(instanceenumparams=nil, instanceintegerparams=nil, instancetextparams=nil, instancemultiparams=nil, totalcount=nil, mongoversion=nil, clustertype=nil, tplname=nil, requestid=nil) @InstanceEnumParams = instanceenumparams @InstanceIntegerParams = instanceintegerparams @InstanceTextParams = instancetextparams @InstanceMultiParams = instancemultiparams @TotalCount = totalcount @MongoVersion = mongoversion @ClusterType = clustertype @TplName = tplname @RequestId = requestid end def deserialize(params) unless params['InstanceEnumParams'].nil? @InstanceEnumParams = [] params['InstanceEnumParams'].each do |i| instanceenumparam_tmp = InstanceEnumParam.new instanceenumparam_tmp.deserialize(i) @InstanceEnumParams << instanceenumparam_tmp end end unless params['InstanceIntegerParams'].nil? @InstanceIntegerParams = [] params['InstanceIntegerParams'].each do |i| instanceintegerparam_tmp = InstanceIntegerParam.new instanceintegerparam_tmp.deserialize(i) @InstanceIntegerParams << instanceintegerparam_tmp end end unless params['InstanceTextParams'].nil? @InstanceTextParams = [] params['InstanceTextParams'].each do |i| instancetextparam_tmp = InstanceTextParam.new instancetextparam_tmp.deserialize(i) @InstanceTextParams << instancetextparam_tmp end end unless params['InstanceMultiParams'].nil? @InstanceMultiParams = [] params['InstanceMultiParams'].each do |i| instancemultiparam_tmp = InstanceMultiParam.new instancemultiparam_tmp.deserialize(i) @InstanceMultiParams << instancemultiparam_tmp end end @TotalCount = params['TotalCount'] @MongoVersion = params['MongoVersion'] @ClusterType = params['ClusterType'] @TplName = params['TplName'] @RequestId = params['RequestId'] end end # DescribeDBInstanceParamTpl请求参数结构体 class DescribeDBInstanceParamTplRequest < TencentCloud::Common::AbstractModel # @param TplIds: 参数模板 ID 查询条件。 # @type TplIds: Array # @param TplNames: 模板名称,查询条件。 # @type TplNames: Array # @param MongoVersion: 根据版本号插叙参数模板,具体支持的售卖版本请参照查询云数据库的售卖规格(DescribeSpecInfo)返回结果。参数与版本对应关系是:MONGO_36_WT:MongoDB 3.6 WiredTiger存储引擎版本,MONGO_40_WT:MongoDB 4.0 WiredTiger存储引擎版本,MONGO_42_WT:MongoDB 4.2 WiredTiger存储引擎版本。 # @type MongoVersion: Array # @param TplType: 根据模板类型查询参数模板,支持DEFAULT(默认模板)和CUSTOMIZE(自定义模板)两种。 # @type TplType: String attr_accessor :TplIds, :TplNames, :MongoVersion, :TplType def initialize(tplids=nil, tplnames=nil, mongoversion=nil, tpltype=nil) @TplIds = tplids @TplNames = tplnames @MongoVersion = mongoversion @TplType = tpltype end def deserialize(params) @TplIds = params['TplIds'] @TplNames = params['TplNames'] @MongoVersion = params['MongoVersion'] @TplType = params['TplType'] end end # DescribeDBInstanceParamTpl返回参数结构体 class DescribeDBInstanceParamTplResponse < TencentCloud::Common::AbstractModel # @param ParamTpls: 参数模板列表信息。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ParamTpls: Array # @param TotalCount: 参数模板总数。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :ParamTpls, :TotalCount, :RequestId def initialize(paramtpls=nil, totalcount=nil, requestid=nil) @ParamTpls = paramtpls @TotalCount = totalcount @RequestId = requestid end def deserialize(params) unless params['ParamTpls'].nil? @ParamTpls = [] params['ParamTpls'].each do |i| paramtpl_tmp = ParamTpl.new paramtpl_tmp.deserialize(i) @ParamTpls << paramtpl_tmp end end @TotalCount = params['TotalCount'] @RequestId = params['RequestId'] end end # DescribeDBInstances请求参数结构体 class DescribeDBInstancesRequest < TencentCloud::Common::AbstractModel # @param InstanceIds: 实例 ID 列表。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceIds: Array # @param InstanceType: 指定查询的实例类型。取值范围如下: # @type InstanceType: Integer # @param ClusterType: 指定所查询实例的集群类型,取值范围如下: # @type ClusterType: Integer # @param Status: 指定所查询实例的当前状态,取值范围如下所示: # @type Status: Array # @param VpcId: 私有网络的 ID。 # - 基础网络则无需配置该参数。 # - 请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表中,单击私有网络名称,在**私有网络**页面获取其 ID。 # @type VpcId: String # @param SubnetId: 私有网络的子网ID。 # - 基础网络则无需配置该参数。 # - 请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表中,单击私有网络名称,在**私有网络**页面获取其子网 ID。 # @type SubnetId: String # @param PayMode: 指定所查询实例的付费类型,取值范围如下: # @type PayMode: Integer # @param Limit: 单次请求返回的数量。默认值为20,取值范围为[1,100]。 # @type Limit: Integer # @param Offset: 偏移量,默认值为0。 # @type Offset: Integer # @param OrderBy: 配置返回结果排序依据的字段。目前支持依据"ProjectId"、"InstanceName"、"CreateTime"排序。 # @type OrderBy: String # @param OrderByType: 配置返回结果的排序方式。 # - ASC:升序。 # - DESC:降序。 # @type OrderByType: String # @param ProjectIds: 项目 ID。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb),在右上角的账户信息下拉菜单中,选择项目管理查询项目。 # @type ProjectIds: Array # @param SearchKey: 指定查询搜索的关键词。支持设置为具体的实例ID、实例名称或者内网 IP 地址。 # @type SearchKey: String # @param Tags: 标签信息,包含标签键与标签值。 # @type Tags: Array attr_accessor :InstanceIds, :InstanceType, :ClusterType, :Status, :VpcId, :SubnetId, :PayMode, :Limit, :Offset, :OrderBy, :OrderByType, :ProjectIds, :SearchKey, :Tags def initialize(instanceids=nil, instancetype=nil, clustertype=nil, status=nil, vpcid=nil, subnetid=nil, paymode=nil, limit=nil, offset=nil, orderby=nil, orderbytype=nil, projectids=nil, searchkey=nil, tags=nil) @InstanceIds = instanceids @InstanceType = instancetype @ClusterType = clustertype @Status = status @VpcId = vpcid @SubnetId = subnetid @PayMode = paymode @Limit = limit @Offset = offset @OrderBy = orderby @OrderByType = orderbytype @ProjectIds = projectids @SearchKey = searchkey @Tags = tags end def deserialize(params) @InstanceIds = params['InstanceIds'] @InstanceType = params['InstanceType'] @ClusterType = params['ClusterType'] @Status = params['Status'] @VpcId = params['VpcId'] @SubnetId = params['SubnetId'] @PayMode = params['PayMode'] @Limit = params['Limit'] @Offset = params['Offset'] @OrderBy = params['OrderBy'] @OrderByType = params['OrderByType'] @ProjectIds = params['ProjectIds'] @SearchKey = params['SearchKey'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| taginfo_tmp = TagInfo.new taginfo_tmp.deserialize(i) @Tags << taginfo_tmp end end end end # DescribeDBInstances返回参数结构体 class DescribeDBInstancesResponse < TencentCloud::Common::AbstractModel # @param TotalCount: 符合查询条件的实例总数。 # @type TotalCount: Integer # @param InstanceDetails: 实例详细信息列表。 # @type InstanceDetails: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TotalCount, :InstanceDetails, :RequestId def initialize(totalcount=nil, instancedetails=nil, requestid=nil) @TotalCount = totalcount @InstanceDetails = instancedetails @RequestId = requestid end def deserialize(params) @TotalCount = params['TotalCount'] unless params['InstanceDetails'].nil? @InstanceDetails = [] params['InstanceDetails'].each do |i| instancedetail_tmp = InstanceDetail.new instancedetail_tmp.deserialize(i) @InstanceDetails << instancedetail_tmp end end @RequestId = params['RequestId'] end end # DescribeInstanceParams请求参数结构体 class DescribeInstanceParamsRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定待查询参数列表的实例 ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String attr_accessor :InstanceId def initialize(instanceid=nil) @InstanceId = instanceid end def deserialize(params) @InstanceId = params['InstanceId'] end end # DescribeInstanceParams返回参数结构体 class DescribeInstanceParamsResponse < TencentCloud::Common::AbstractModel # @param InstanceEnumParam: 参数值为枚举类型的参数集合。 # @type InstanceEnumParam: Array # @param InstanceIntegerParam: 参数值为 Integer 类型的参数集合。 # @type InstanceIntegerParam: Array # @param InstanceTextParam: 参数值为 Text 类型的参数集合。 # @type InstanceTextParam: Array # @param InstanceMultiParam: 参数值为混合类型的参数集合。 # @type InstanceMultiParam: Array # @param TotalCount: 当前实例支持修改的参数数量。 # @type TotalCount: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :InstanceEnumParam, :InstanceIntegerParam, :InstanceTextParam, :InstanceMultiParam, :TotalCount, :RequestId def initialize(instanceenumparam=nil, instanceintegerparam=nil, instancetextparam=nil, instancemultiparam=nil, totalcount=nil, requestid=nil) @InstanceEnumParam = instanceenumparam @InstanceIntegerParam = instanceintegerparam @InstanceTextParam = instancetextparam @InstanceMultiParam = instancemultiparam @TotalCount = totalcount @RequestId = requestid end def deserialize(params) unless params['InstanceEnumParam'].nil? @InstanceEnumParam = [] params['InstanceEnumParam'].each do |i| instanceenumparam_tmp = InstanceEnumParam.new instanceenumparam_tmp.deserialize(i) @InstanceEnumParam << instanceenumparam_tmp end end unless params['InstanceIntegerParam'].nil? @InstanceIntegerParam = [] params['InstanceIntegerParam'].each do |i| instanceintegerparam_tmp = InstanceIntegerParam.new instanceintegerparam_tmp.deserialize(i) @InstanceIntegerParam << instanceintegerparam_tmp end end unless params['InstanceTextParam'].nil? @InstanceTextParam = [] params['InstanceTextParam'].each do |i| instancetextparam_tmp = InstanceTextParam.new instancetextparam_tmp.deserialize(i) @InstanceTextParam << instancetextparam_tmp end end unless params['InstanceMultiParam'].nil? @InstanceMultiParam = [] params['InstanceMultiParam'].each do |i| instancemultiparam_tmp = InstanceMultiParam.new instancemultiparam_tmp.deserialize(i) @InstanceMultiParam << instancemultiparam_tmp end end @TotalCount = params['TotalCount'] @RequestId = params['RequestId'] end end # DescribeSecurityGroup请求参数结构体 class DescribeSecurityGroupRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例 ID。例如:cmgo-p8vn****。 # @type InstanceId: String attr_accessor :InstanceId def initialize(instanceid=nil) @InstanceId = instanceid end def deserialize(params) @InstanceId = params['InstanceId'] end end # DescribeSecurityGroup返回参数结构体 class DescribeSecurityGroupResponse < TencentCloud::Common::AbstractModel # @param Groups: 实例绑定的安全组信息。 # @type Groups: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Groups, :RequestId def initialize(groups=nil, requestid=nil) @Groups = groups @RequestId = requestid end def deserialize(params) unless params['Groups'].nil? @Groups = [] params['Groups'].each do |i| securitygroup_tmp = SecurityGroup.new securitygroup_tmp.deserialize(i) @Groups << securitygroup_tmp end end @RequestId = params['RequestId'] end end # DescribeSlowLogPatterns请求参数结构体 class DescribeSlowLogPatternsRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同 # @type InstanceId: String # @param StartTime: 慢日志起始时间,格式:yyyy-mm-dd hh:mm:ss,如:2019-06-01 10:00:00。查询起止时间间隔不能超过24小时,只允许查询最近7天内慢日志。 # @type StartTime: String # @param EndTime: 慢日志终止时间,格式:yyyy-mm-dd hh:mm:ss,如:2019-06-02 12:00:00。查询起止时间间隔不能超过24小时,只允许查询最近7天内慢日志。 # @type EndTime: String # @param SlowMS: 慢日志执行时间阈值,返回执行时间超过该阈值的慢日志,单位为毫秒(ms),最小为100毫秒。 # @type SlowMS: Integer # @param Offset: 偏移量,最小值为0,最大值为10000,默认值为0。 # @type Offset: Integer # @param Limit: 分页大小,最小值为1,最大值为100,默认值为20。 # @type Limit: Integer # @param Format: 慢日志返回格式,可设置为json,不传默认返回原生慢日志格式。 # @type Format: String attr_accessor :InstanceId, :StartTime, :EndTime, :SlowMS, :Offset, :Limit, :Format def initialize(instanceid=nil, starttime=nil, endtime=nil, slowms=nil, offset=nil, limit=nil, format=nil) @InstanceId = instanceid @StartTime = starttime @EndTime = endtime @SlowMS = slowms @Offset = offset @Limit = limit @Format = format end def deserialize(params) @InstanceId = params['InstanceId'] @StartTime = params['StartTime'] @EndTime = params['EndTime'] @SlowMS = params['SlowMS'] @Offset = params['Offset'] @Limit = params['Limit'] @Format = params['Format'] end end # DescribeSlowLogPatterns返回参数结构体 class DescribeSlowLogPatternsResponse < TencentCloud::Common::AbstractModel # @param Count: 慢日志统计信息总数 # @type Count: Integer # @param SlowLogPatterns: 慢日志统计信息 # @type SlowLogPatterns: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Count, :SlowLogPatterns, :RequestId def initialize(count=nil, slowlogpatterns=nil, requestid=nil) @Count = count @SlowLogPatterns = slowlogpatterns @RequestId = requestid end def deserialize(params) @Count = params['Count'] unless params['SlowLogPatterns'].nil? @SlowLogPatterns = [] params['SlowLogPatterns'].each do |i| slowlogpattern_tmp = SlowLogPattern.new slowlogpattern_tmp.deserialize(i) @SlowLogPatterns << slowlogpattern_tmp end end @RequestId = params['RequestId'] end end # DescribeSlowLogs请求参数结构体 class DescribeSlowLogsRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同 # @type InstanceId: String # @param StartTime: 慢日志起始时间,格式:yyyy-mm-dd hh:mm:ss,如:2019-06-01 10:00:00。查询起止时间间隔不能超过24小时,只允许查询最近7天内慢日志。 # @type StartTime: String # @param EndTime: 慢日志终止时间,格式:yyyy-mm-dd hh:mm:ss,如:2019-06-02 12:00:00。查询起止时间间隔不能超过24小时,只允许查询最近7天内慢日志。 # @type EndTime: String # @param SlowMS: 慢日志执行时间阈值,返回执行时间超过该阈值的慢日志,单位为毫秒(ms),最小为100毫秒。 # @type SlowMS: Integer # @param Offset: 偏移量,最小值为0,最大值为10000,默认值为0。 # @type Offset: Integer # @param Limit: 分页大小,最小值为1,最大值为100,默认值为20。 # @type Limit: Integer # @param Format: 慢日志返回格式。默认返回原生慢日志格式,4.4及以上版本可设置为json。 # @type Format: String attr_accessor :InstanceId, :StartTime, :EndTime, :SlowMS, :Offset, :Limit, :Format def initialize(instanceid=nil, starttime=nil, endtime=nil, slowms=nil, offset=nil, limit=nil, format=nil) @InstanceId = instanceid @StartTime = starttime @EndTime = endtime @SlowMS = slowms @Offset = offset @Limit = limit @Format = format end def deserialize(params) @InstanceId = params['InstanceId'] @StartTime = params['StartTime'] @EndTime = params['EndTime'] @SlowMS = params['SlowMS'] @Offset = params['Offset'] @Limit = params['Limit'] @Format = params['Format'] end end # DescribeSlowLogs返回参数结构体 class DescribeSlowLogsResponse < TencentCloud::Common::AbstractModel # @param Count: 慢日志总数 # @type Count: Integer # @param SlowLogs: 慢日志详情 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SlowLogs: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Count, :SlowLogs, :RequestId def initialize(count=nil, slowlogs=nil, requestid=nil) @Count = count @SlowLogs = slowlogs @RequestId = requestid end def deserialize(params) @Count = params['Count'] @SlowLogs = params['SlowLogs'] @RequestId = params['RequestId'] end end # DescribeSpecInfo请求参数结构体 class DescribeSpecInfoRequest < TencentCloud::Common::AbstractModel # @param Zone: 待查询可用区 # @type Zone: String attr_accessor :Zone def initialize(zone=nil) @Zone = zone end def deserialize(params) @Zone = params['Zone'] end end # DescribeSpecInfo返回参数结构体 class DescribeSpecInfoResponse < TencentCloud::Common::AbstractModel # @param SpecInfoList: 实例售卖规格信息列表 # @type SpecInfoList: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :SpecInfoList, :RequestId def initialize(specinfolist=nil, requestid=nil) @SpecInfoList = specinfolist @RequestId = requestid end def deserialize(params) unless params['SpecInfoList'].nil? @SpecInfoList = [] params['SpecInfoList'].each do |i| specificationinfo_tmp = SpecificationInfo.new specificationinfo_tmp.deserialize(i) @SpecInfoList << specificationinfo_tmp end end @RequestId = params['RequestId'] end end # DescribeTransparentDataEncryptionStatus请求参数结构体 class DescribeTransparentDataEncryptionStatusRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定实例 ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String attr_accessor :InstanceId def initialize(instanceid=nil) @InstanceId = instanceid end def deserialize(params) @InstanceId = params['InstanceId'] end end # DescribeTransparentDataEncryptionStatus返回参数结构体 class DescribeTransparentDataEncryptionStatusResponse < TencentCloud::Common::AbstractModel # @param TransparentDataEncryptionStatus: 表示是否开启了透明加密。 # - close:未开启。 # - open:已开启。 # @type TransparentDataEncryptionStatus: String # @param KeyInfoList: 已绑定的密钥列表,如未绑定,返回null。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type KeyInfoList: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TransparentDataEncryptionStatus, :KeyInfoList, :RequestId def initialize(transparentdataencryptionstatus=nil, keyinfolist=nil, requestid=nil) @TransparentDataEncryptionStatus = transparentdataencryptionstatus @KeyInfoList = keyinfolist @RequestId = requestid end def deserialize(params) @TransparentDataEncryptionStatus = params['TransparentDataEncryptionStatus'] unless params['KeyInfoList'].nil? @KeyInfoList = [] params['KeyInfoList'].each do |i| kmsinfodetail_tmp = KMSInfoDetail.new kmsinfodetail_tmp.deserialize(i) @KeyInfoList << kmsinfodetail_tmp end end @RequestId = params['RequestId'] end end # DropDBInstanceParamTpl请求参数结构体 class DropDBInstanceParamTplRequest < TencentCloud::Common::AbstractModel # @param TplId: 参数模板 ID。 # @type TplId: String attr_accessor :TplId def initialize(tplid=nil) @TplId = tplid end def deserialize(params) @TplId = params['TplId'] end end # DropDBInstanceParamTpl返回参数结构体 class DropDBInstanceParamTplResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # EnableTransparentDataEncryption请求参数结构体 class EnableTransparentDataEncryptionRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例 ID,例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。目前支持通用版本包含:4.4、5.0,云盘版暂不支持。 # @type InstanceId: String # @param KmsRegion: [密钥管理系统(Key Management Service,KMS)](https://cloud.tencent.com/document/product/573/18809)服务所在地域,例如 ap-shanghai。 # @type KmsRegion: String # @param KeyId: 密钥 ID。若不设置该参数,不指定具体的密钥 ID,由腾讯云自动生成密钥。 # @type KeyId: String attr_accessor :InstanceId, :KmsRegion, :KeyId def initialize(instanceid=nil, kmsregion=nil, keyid=nil) @InstanceId = instanceid @KmsRegion = kmsregion @KeyId = keyid end def deserialize(params) @InstanceId = params['InstanceId'] @KmsRegion = params['KmsRegion'] @KeyId = params['KeyId'] end end # EnableTransparentDataEncryption返回参数结构体 class EnableTransparentDataEncryptionResponse < TencentCloud::Common::AbstractModel # @param FlowId: 开启透明加密的异步流程id,用于查询流程状态。 # @type FlowId: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :FlowId, :RequestId def initialize(flowid=nil, requestid=nil) @FlowId = flowid @RequestId = requestid end def deserialize(params) @FlowId = params['FlowId'] @RequestId = params['RequestId'] end end # 按key回档,用于筛选数据的键值对 class FBKeyValue < TencentCloud::Common::AbstractModel # @param Key: 用于按key回档过滤的key # @type Key: String # @param Value: 用于按key回档过滤的value # @type Value: String attr_accessor :Key, :Value def initialize(key=nil, value=nil) @Key = key @Value = value end def deserialize(params) @Key = params['Key'] @Value = params['Value'] end end # FlashBackDBInstance请求参数结构体 class FlashBackDBInstanceRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 开启按 Key 回档的实例 ID。 # @type InstanceId: String # @param TargetFlashbackTime: 源数据想恢复到的时间。 # @type TargetFlashbackTime: String # @param TargetDatabases: 源数据所在的库表信息。 # @type TargetDatabases: Array # @param TargetInstanceId: 数据最终写入的实例 ID。 # @type TargetInstanceId: String attr_accessor :InstanceId, :TargetFlashbackTime, :TargetDatabases, :TargetInstanceId def initialize(instanceid=nil, targetflashbacktime=nil, targetdatabases=nil, targetinstanceid=nil) @InstanceId = instanceid @TargetFlashbackTime = targetflashbacktime @TargetDatabases = targetdatabases @TargetInstanceId = targetinstanceid end def deserialize(params) @InstanceId = params['InstanceId'] @TargetFlashbackTime = params['TargetFlashbackTime'] unless params['TargetDatabases'].nil? @TargetDatabases = [] params['TargetDatabases'].each do |i| flashbackdatabase_tmp = FlashbackDatabase.new flashbackdatabase_tmp.deserialize(i) @TargetDatabases << flashbackdatabase_tmp end end @TargetInstanceId = params['TargetInstanceId'] end end # FlashBackDBInstance返回参数结构体 class FlashBackDBInstanceResponse < TencentCloud::Common::AbstractModel # @param FlowId: 回档数据异步任务 ID。 # @type FlowId: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :FlowId, :RequestId def initialize(flowid=nil, requestid=nil) @FlowId = flowid @RequestId = requestid end def deserialize(params) @FlowId = params['FlowId'] @RequestId = params['RequestId'] end end # 按key回档,源数据所在的表 class FlashbackCollection < TencentCloud::Common::AbstractModel # @param CollectionName: 按key回档指定的集合名 # @type CollectionName: String # @param TargetResultCollectionName: 按key回档到的目标集合名 # @type TargetResultCollectionName: String # @param FilterKey: 上传到cos的文件的value所对应的key值 # @type FilterKey: String # @param KeyValues: 用于按key回档过滤的键值对 # @type KeyValues: Array attr_accessor :CollectionName, :TargetResultCollectionName, :FilterKey, :KeyValues def initialize(collectionname=nil, targetresultcollectionname=nil, filterkey=nil, keyvalues=nil) @CollectionName = collectionname @TargetResultCollectionName = targetresultcollectionname @FilterKey = filterkey @KeyValues = keyvalues end def deserialize(params) @CollectionName = params['CollectionName'] @TargetResultCollectionName = params['TargetResultCollectionName'] @FilterKey = params['FilterKey'] unless params['KeyValues'].nil? @KeyValues = [] params['KeyValues'].each do |i| fbkeyvalue_tmp = FBKeyValue.new fbkeyvalue_tmp.deserialize(i) @KeyValues << fbkeyvalue_tmp end end end end # 按key回档,源数据所在的库表 class FlashbackDatabase < TencentCloud::Common::AbstractModel # @param DBName: 按key回档源数据所在库 # @type DBName: String # @param Collections: 按key回档的集群数组 # @type Collections: Array attr_accessor :DBName, :Collections def initialize(dbname=nil, collections=nil) @DBName = dbname @Collections = collections end def deserialize(params) @DBName = params['DBName'] unless params['Collections'].nil? @Collections = [] params['Collections'].each do |i| flashbackcollection_tmp = FlashbackCollection.new flashbackcollection_tmp.deserialize(i) @Collections << flashbackcollection_tmp end end end end # FlushInstanceRouterConfig请求参数结构体 class FlushInstanceRouterConfigRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID # @type InstanceId: String attr_accessor :InstanceId def initialize(instanceid=nil) @InstanceId = instanceid end def deserialize(params) @InstanceId = params['InstanceId'] end end # FlushInstanceRouterConfig返回参数结构体 class FlushInstanceRouterConfigResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # InquirePriceCreateDBInstances请求参数结构体 class InquirePriceCreateDBInstancesRequest < TencentCloud::Common::AbstractModel # @param Zone: 实例所属区域及可用区信息。格式:ap-guangzhou-2。 # @type Zone: String # @param NodeNum: - 创建副本集实例,指每个副本集内主从节点数量。每个副本集所支持的的最大节点数与最小节点数,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # - 创建分片集群实例,指每个分片的主从节点数量。每个分片所支持的最大节点数与最小节点数,请通过接口 [DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 获取。 # @type NodeNum: Integer # @param Memory: 实例内存大小。 # - 单位:GB。 # - 取值范围:请通过接口[DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567)查询,其返回的数据结构SpecItems中的参数CPU与Memory分别对应CPU核数与内存规格。 # @type Memory: Integer # @param Volume: 实例硬盘大小。 # - 单位:GB。 # - 取值范围:请通过接口[DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567)查询,其返回的数据结构SpecItems中的参数MinStorage与MaxStorage分别对应其最小磁盘规格与最大磁盘规格。 # @type Volume: Integer # @param MongoVersion: 实例版本信息。具体支持的版本,请通过接口[DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567)查询,其返回的数据结构SpecItems中的参数MongoVersionCode为实例所支持的版本信息。版本信息与版本号对应关系如下: # - MONGO_36_WT:MongoDB 3.6 WiredTiger存储引擎版本。 # - MONGO_40_WT:MongoDB 4.0 WiredTiger存储引擎版本。 # - MONGO_42_WT:MongoDB 4.2 WiredTiger存储引擎版本。 # - MONGO_44_WT:MongoDB 4.4 WiredTiger存储引擎版本。 # - MONGO_50_WT:MongoDB 5.0 WiredTiger存储引擎版本。 # - MONGO_60_WT:MongoDB 6.0 WiredTiger存储引擎版本。 # @type MongoVersion: String # @param MachineCode: 产品规格类型。 # - HIO10G:通用高HIO万兆型。 # - HCD:云盘版。 # @type MachineCode: String # @param GoodsNum: 实例数量,取值范围为[1,10]。 # @type GoodsNum: Integer # @param ClusterType: 实例类型。 # - REPLSET:副本集。 # - SHARD:分片集群。 # @type ClusterType: String # @param ReplicateSetNum: - 创建副本集实例,指副本集数量,该参数只能为1。 # - 创建分片集群实例,指分片的数量。请通过接口[DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567)查询分片数量的取值范围,其返回的数据结构SpecItems中的参数MinReplicateSetNum与MaxReplicateSetNum分别对应其最小值与最大值。 # @type ReplicateSetNum: Integer # @param Period: - 选择包年包月计费模式,即 InstanceChargeType 设定为PREPAID时,必须设置该参数,指定购买实例的购买时长。取值可选:[1,2,3,4,5,6,7,8,9,10,11,12,24,36];单位:月。 # -选择按量计费,即 InstanceChargeType 设定为 **POSTPAID_BY_HOUR** 时,该参数仅可配置为 1。 # @type Period: Integer # @param InstanceChargeType: 实例付费方式。 # - PREPAID:包年包月计费。 # - POSTPAID_BY_HOUR:按量计费。 # @type InstanceChargeType: String # @param MongosCpu: Mongos CPU 核数,支持1、2、4、8、16。购买分片集群时,必须填写。注意为空时取默认取值为2C。 # @type MongosCpu: Integer # @param MongosMemory: Mongos 内存大小。- 购买分片集群时,必须填写。- 单位:GB,支持1核2GB、2核4GB、4核8GB、8核16GB、16核32GB。注意为空时取默认取值为4G。 # @type MongosMemory: Integer # @param MongosNum: 指 Mongos 个数,取值范围为[3,32]。若为分片集群实例询价,则该参数必须设置。注意为空时取默认取值为3个节点。 # @type MongosNum: Integer # @param ConfigServerCpu: 指 ConfigServer CPU核数,取值为1,单位:GB。若为分片集群实例询价,该参数必须设置。 # @type ConfigServerCpu: Integer # @param ConfigServerMemory: 指 ConfigServer 内存大小,取值为2,单位:GB。若为分片集群实例询价,则该参数必须设置。 # @type ConfigServerMemory: Integer # @param ConfigServerVolume: 指 ConfigServer 磁盘大小,取值为 20,单位:GB。若为分片集群实例询价,则该参数必须设置。 # @type ConfigServerVolume: Integer attr_accessor :Zone, :NodeNum, :Memory, :Volume, :MongoVersion, :MachineCode, :GoodsNum, :ClusterType, :ReplicateSetNum, :Period, :InstanceChargeType, :MongosCpu, :MongosMemory, :MongosNum, :ConfigServerCpu, :ConfigServerMemory, :ConfigServerVolume def initialize(zone=nil, nodenum=nil, memory=nil, volume=nil, mongoversion=nil, machinecode=nil, goodsnum=nil, clustertype=nil, replicatesetnum=nil, period=nil, instancechargetype=nil, mongoscpu=nil, mongosmemory=nil, mongosnum=nil, configservercpu=nil, configservermemory=nil, configservervolume=nil) @Zone = zone @NodeNum = nodenum @Memory = memory @Volume = volume @MongoVersion = mongoversion @MachineCode = machinecode @GoodsNum = goodsnum @ClusterType = clustertype @ReplicateSetNum = replicatesetnum @Period = period @InstanceChargeType = instancechargetype @MongosCpu = mongoscpu @MongosMemory = mongosmemory @MongosNum = mongosnum @ConfigServerCpu = configservercpu @ConfigServerMemory = configservermemory @ConfigServerVolume = configservervolume end def deserialize(params) @Zone = params['Zone'] @NodeNum = params['NodeNum'] @Memory = params['Memory'] @Volume = params['Volume'] @MongoVersion = params['MongoVersion'] @MachineCode = params['MachineCode'] @GoodsNum = params['GoodsNum'] @ClusterType = params['ClusterType'] @ReplicateSetNum = params['ReplicateSetNum'] @Period = params['Period'] @InstanceChargeType = params['InstanceChargeType'] @MongosCpu = params['MongosCpu'] @MongosMemory = params['MongosMemory'] @MongosNum = params['MongosNum'] @ConfigServerCpu = params['ConfigServerCpu'] @ConfigServerMemory = params['ConfigServerMemory'] @ConfigServerVolume = params['ConfigServerVolume'] end end # InquirePriceCreateDBInstances返回参数结构体 class InquirePriceCreateDBInstancesResponse < TencentCloud::Common::AbstractModel # @param Price: 价格 # @type Price: :class:`Tencentcloud::Mongodb.v20190725.models.DBInstancePrice` # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Price, :RequestId def initialize(price=nil, requestid=nil) @Price = price @RequestId = requestid end def deserialize(params) unless params['Price'].nil? @Price = DBInstancePrice.new @Price.deserialize(params['Price']) end @RequestId = params['RequestId'] end end # InquirePriceModifyDBInstanceSpec请求参数结构体 class InquirePriceModifyDBInstanceSpecRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例 ID,格式如:cmgo-p8vn****。与云数据库控制台页面中显示的实例ID相同。 # @type InstanceId: String # @param Memory: 变更配置后实例内存大小,单位:GB。 # @type Memory: Integer # @param Volume: 变更配置后实例磁盘大小,单位:GB。 # @type Volume: Integer # @param NodeNum: 实例节点数。默认为不变更节点数,暂不支持变更。 # @type NodeNum: Integer # @param ReplicateSetNum: 实例分片数。默认为不变更分片数,暂不支持变更。 # @type ReplicateSetNum: Integer attr_accessor :InstanceId, :Memory, :Volume, :NodeNum, :ReplicateSetNum def initialize(instanceid=nil, memory=nil, volume=nil, nodenum=nil, replicatesetnum=nil) @InstanceId = instanceid @Memory = memory @Volume = volume @NodeNum = nodenum @ReplicateSetNum = replicatesetnum end def deserialize(params) @InstanceId = params['InstanceId'] @Memory = params['Memory'] @Volume = params['Volume'] @NodeNum = params['NodeNum'] @ReplicateSetNum = params['ReplicateSetNum'] end end # InquirePriceModifyDBInstanceSpec返回参数结构体 class InquirePriceModifyDBInstanceSpecResponse < TencentCloud::Common::AbstractModel # @param Price: 价格。 # @type Price: :class:`Tencentcloud::Mongodb.v20190725.models.DBInstancePrice` # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Price, :RequestId def initialize(price=nil, requestid=nil) @Price = price @RequestId = requestid end def deserialize(params) unless params['Price'].nil? @Price = DBInstancePrice.new @Price.deserialize(params['Price']) end @RequestId = params['RequestId'] end end # InquirePriceRenewDBInstances请求参数结构体 class InquirePriceRenewDBInstancesRequest < TencentCloud::Common::AbstractModel # @param InstanceIds: 实例ID,格式如:cmgo-p8vn****。与云数据库控制台页面中显示的实例ID相同,接口单次最多只支持5个实例进行操作。 # @type InstanceIds: Array # @param InstanceChargePrepaid: 预付费模式(即包年包月)相关参数设置。通过该参数可以指定包年包月实例的续费时长、是否设置自动续费等属性。 # @type InstanceChargePrepaid: :class:`Tencentcloud::Mongodb.v20190725.models.InstanceChargePrepaid` attr_accessor :InstanceIds, :InstanceChargePrepaid def initialize(instanceids=nil, instancechargeprepaid=nil) @InstanceIds = instanceids @InstanceChargePrepaid = instancechargeprepaid end def deserialize(params) @InstanceIds = params['InstanceIds'] unless params['InstanceChargePrepaid'].nil? @InstanceChargePrepaid = InstanceChargePrepaid.new @InstanceChargePrepaid.deserialize(params['InstanceChargePrepaid']) end end end # InquirePriceRenewDBInstances返回参数结构体 class InquirePriceRenewDBInstancesResponse < TencentCloud::Common::AbstractModel # @param Price: 价格 # @type Price: :class:`Tencentcloud::Mongodb.v20190725.models.DBInstancePrice` # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Price, :RequestId def initialize(price=nil, requestid=nil) @Price = price @RequestId = requestid end def deserialize(params) unless params['Price'].nil? @Price = DBInstancePrice.new @Price.deserialize(params['Price']) end @RequestId = params['RequestId'] end end # 描述了实例的计费模式 class InstanceChargePrepaid < TencentCloud::Common::AbstractModel # @param Period: 购买实例的时长,单位:月。取值范围:1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 24, 36。默认为1。 # @type Period: Integer # @param RenewFlag: 自动续费标识。取值范围: # - NOTIFY_AND_AUTO_RENEW:通知过期且自动续费。在账户余额充足的情况下,实例到期后将按月自动续费。 # - NOTIFY_AND_MANUAL_RENEW:通知过期不自动续费。默认为NOTIFY_AND_MANUAL_RENEW。 # - DISABLE_NOTIFY_AND_MANUAL_RENEW:不通知过期不自动续费。 # @type RenewFlag: String attr_accessor :Period, :RenewFlag def initialize(period=nil, renewflag=nil) @Period = period @RenewFlag = renewflag end def deserialize(params) @Period = params['Period'] @RenewFlag = params['RenewFlag'] end end # 实例详情 class InstanceDetail < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID。 # @type InstanceId: String # @param InstanceName: 实例名称。 # @type InstanceName: String # @param PayMode: 付费类型,可能的返回值:1-包年包月;0-按量计费 # @type PayMode: Integer # @param ProjectId: 项目ID。 # @type ProjectId: Integer # @param ClusterType: 集群类型,可能的返回值:0-副本集实例,1-分片实例。 # @type ClusterType: Integer # @param Region: 地域信息。 # @type Region: String # @param Zone: 可用区信息。 # @type Zone: String # @param NetType: 网络类型,可能的返回值:0-基础网络,1-私有网络 # @type NetType: Integer # @param VpcId: 私有网络的ID。 # @type VpcId: String # @param SubnetId: 私有网络的子网ID。 # @type SubnetId: String # @param Status: 实例状态,可能的返回值:0-创建中,1-流程处理中,2-运行中,-2-实例已过期。 # @type Status: Integer # @param Vip: 实例IP。 # @type Vip: String # @param Vport: 端口号。 # @type Vport: Integer # @param CreateTime: 实例创建时间。 # @type CreateTime: String # @param DeadLine: 实例到期时间。 # @type DeadLine: String # @param MongoVersion: 实例版本信息。 # @type MongoVersion: String # @param Memory: 实例内存规格,单位为MB。 # @type Memory: Integer # @param Volume: 实例磁盘规格,单位为MB。 # @type Volume: Integer # @param CpuNum: 实例CPU核心数。 # @type CpuNum: Integer # @param MachineType: 实例机器类型。 # @type MachineType: String # @param SecondaryNum: 实例从节点数。 # @type SecondaryNum: Integer # @param ReplicationSetNum: 实例分片数。 # @type ReplicationSetNum: Integer # @param AutoRenewFlag: 实例自动续费标志,可能的返回值:0-手动续费,1-自动续费,2-确认不续费。 # @type AutoRenewFlag: Integer # @param UsedVolume: 已用容量,单位MB。 # @type UsedVolume: Integer # @param MaintenanceStart: 维护窗口起始时间。 # @type MaintenanceStart: String # @param MaintenanceEnd: 维护窗口结束时间。 # @type MaintenanceEnd: String # @param ReplicaSets: 分片信息。 # @type ReplicaSets: Array # @param ReadonlyInstances: 只读实例信息。 # @type ReadonlyInstances: Array # @param StandbyInstances: 灾备实例信息。 # @type StandbyInstances: Array # @param CloneInstances: 临时实例信息。 # @type CloneInstances: Array # @param RelatedInstance: 关联实例信息,对于正式实例,该字段表示它的临时实例信息;对于临时实例,则表示它的正式实例信息;如果为只读/灾备实例,则表示他的主实例信息。 # @type RelatedInstance: :class:`Tencentcloud::Mongodb.v20190725.models.DBInstanceInfo` # @param Tags: 实例标签信息集合。 # @type Tags: Array # @param InstanceVer: 实例版本标记。 # @type InstanceVer: Integer # @param ClusterVer: 实例版本标记。 # @type ClusterVer: Integer # @param Protocol: 协议信息,可能的返回值:1-mongodb,2-dynamodb。 # @type Protocol: Integer # @param InstanceType: 实例类型,可能的返回值,1-正式实例,2-临时实例,3-只读实例,4-灾备实例 # @type InstanceType: Integer # @param InstanceStatusDesc: 实例状态描述 # @type InstanceStatusDesc: String # @param RealInstanceId: 实例对应的物理实例id,回档并替换过的实例有不同的InstanceId和RealInstanceId,从barad获取监控数据等场景下需要用物理id获取 # @type RealInstanceId: String # @param ZoneList: 实例当前可用区信息。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ZoneList: Array # @param MongosNodeNum: mongos节点个数。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type MongosNodeNum: Integer # @param MongosMemory: mongos节点内存。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type MongosMemory: Integer # @param MongosCpuNum: mongos节点CPU核数。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type MongosCpuNum: Integer # @param ConfigServerNodeNum: Config Server节点个数。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConfigServerNodeNum: Integer # @param ConfigServerMemory: Config Server节点内存。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConfigServerMemory: Integer # @param ConfigServerVolume: Config Server节点磁盘大小。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConfigServerVolume: Integer # @param ConfigServerCpuNum: Config Server节点CPU核数。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConfigServerCpuNum: Integer # @param ReadonlyNodeNum: readonly节点个数。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ReadonlyNodeNum: Integer attr_accessor :InstanceId, :InstanceName, :PayMode, :ProjectId, :ClusterType, :Region, :Zone, :NetType, :VpcId, :SubnetId, :Status, :Vip, :Vport, :CreateTime, :DeadLine, :MongoVersion, :Memory, :Volume, :CpuNum, :MachineType, :SecondaryNum, :ReplicationSetNum, :AutoRenewFlag, :UsedVolume, :MaintenanceStart, :MaintenanceEnd, :ReplicaSets, :ReadonlyInstances, :StandbyInstances, :CloneInstances, :RelatedInstance, :Tags, :InstanceVer, :ClusterVer, :Protocol, :InstanceType, :InstanceStatusDesc, :RealInstanceId, :ZoneList, :MongosNodeNum, :MongosMemory, :MongosCpuNum, :ConfigServerNodeNum, :ConfigServerMemory, :ConfigServerVolume, :ConfigServerCpuNum, :ReadonlyNodeNum def initialize(instanceid=nil, instancename=nil, paymode=nil, projectid=nil, clustertype=nil, region=nil, zone=nil, nettype=nil, vpcid=nil, subnetid=nil, status=nil, vip=nil, vport=nil, createtime=nil, deadline=nil, mongoversion=nil, memory=nil, volume=nil, cpunum=nil, machinetype=nil, secondarynum=nil, replicationsetnum=nil, autorenewflag=nil, usedvolume=nil, maintenancestart=nil, maintenanceend=nil, replicasets=nil, readonlyinstances=nil, standbyinstances=nil, cloneinstances=nil, relatedinstance=nil, tags=nil, instancever=nil, clusterver=nil, protocol=nil, instancetype=nil, instancestatusdesc=nil, realinstanceid=nil, zonelist=nil, mongosnodenum=nil, mongosmemory=nil, mongoscpunum=nil, configservernodenum=nil, configservermemory=nil, configservervolume=nil, configservercpunum=nil, readonlynodenum=nil) @InstanceId = instanceid @InstanceName = instancename @PayMode = paymode @ProjectId = projectid @ClusterType = clustertype @Region = region @Zone = zone @NetType = nettype @VpcId = vpcid @SubnetId = subnetid @Status = status @Vip = vip @Vport = vport @CreateTime = createtime @DeadLine = deadline @MongoVersion = mongoversion @Memory = memory @Volume = volume @CpuNum = cpunum @MachineType = machinetype @SecondaryNum = secondarynum @ReplicationSetNum = replicationsetnum @AutoRenewFlag = autorenewflag @UsedVolume = usedvolume @MaintenanceStart = maintenancestart @MaintenanceEnd = maintenanceend @ReplicaSets = replicasets @ReadonlyInstances = readonlyinstances @StandbyInstances = standbyinstances @CloneInstances = cloneinstances @RelatedInstance = relatedinstance @Tags = tags @InstanceVer = instancever @ClusterVer = clusterver @Protocol = protocol @InstanceType = instancetype @InstanceStatusDesc = instancestatusdesc @RealInstanceId = realinstanceid @ZoneList = zonelist @MongosNodeNum = mongosnodenum @MongosMemory = mongosmemory @MongosCpuNum = mongoscpunum @ConfigServerNodeNum = configservernodenum @ConfigServerMemory = configservermemory @ConfigServerVolume = configservervolume @ConfigServerCpuNum = configservercpunum @ReadonlyNodeNum = readonlynodenum end def deserialize(params) @InstanceId = params['InstanceId'] @InstanceName = params['InstanceName'] @PayMode = params['PayMode'] @ProjectId = params['ProjectId'] @ClusterType = params['ClusterType'] @Region = params['Region'] @Zone = params['Zone'] @NetType = params['NetType'] @VpcId = params['VpcId'] @SubnetId = params['SubnetId'] @Status = params['Status'] @Vip = params['Vip'] @Vport = params['Vport'] @CreateTime = params['CreateTime'] @DeadLine = params['DeadLine'] @MongoVersion = params['MongoVersion'] @Memory = params['Memory'] @Volume = params['Volume'] @CpuNum = params['CpuNum'] @MachineType = params['MachineType'] @SecondaryNum = params['SecondaryNum'] @ReplicationSetNum = params['ReplicationSetNum'] @AutoRenewFlag = params['AutoRenewFlag'] @UsedVolume = params['UsedVolume'] @MaintenanceStart = params['MaintenanceStart'] @MaintenanceEnd = params['MaintenanceEnd'] unless params['ReplicaSets'].nil? @ReplicaSets = [] params['ReplicaSets'].each do |i| shardinfo_tmp = ShardInfo.new shardinfo_tmp.deserialize(i) @ReplicaSets << shardinfo_tmp end end unless params['ReadonlyInstances'].nil? @ReadonlyInstances = [] params['ReadonlyInstances'].each do |i| dbinstanceinfo_tmp = DBInstanceInfo.new dbinstanceinfo_tmp.deserialize(i) @ReadonlyInstances << dbinstanceinfo_tmp end end unless params['StandbyInstances'].nil? @StandbyInstances = [] params['StandbyInstances'].each do |i| dbinstanceinfo_tmp = DBInstanceInfo.new dbinstanceinfo_tmp.deserialize(i) @StandbyInstances << dbinstanceinfo_tmp end end unless params['CloneInstances'].nil? @CloneInstances = [] params['CloneInstances'].each do |i| dbinstanceinfo_tmp = DBInstanceInfo.new dbinstanceinfo_tmp.deserialize(i) @CloneInstances << dbinstanceinfo_tmp end end unless params['RelatedInstance'].nil? @RelatedInstance = DBInstanceInfo.new @RelatedInstance.deserialize(params['RelatedInstance']) end unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| taginfo_tmp = TagInfo.new taginfo_tmp.deserialize(i) @Tags << taginfo_tmp end end @InstanceVer = params['InstanceVer'] @ClusterVer = params['ClusterVer'] @Protocol = params['Protocol'] @InstanceType = params['InstanceType'] @InstanceStatusDesc = params['InstanceStatusDesc'] @RealInstanceId = params['RealInstanceId'] @ZoneList = params['ZoneList'] @MongosNodeNum = params['MongosNodeNum'] @MongosMemory = params['MongosMemory'] @MongosCpuNum = params['MongosCpuNum'] @ConfigServerNodeNum = params['ConfigServerNodeNum'] @ConfigServerMemory = params['ConfigServerMemory'] @ConfigServerVolume = params['ConfigServerVolume'] @ConfigServerCpuNum = params['ConfigServerCpuNum'] @ReadonlyNodeNum = params['ReadonlyNodeNum'] end end # 实例可修改参数枚举类型集合。 class InstanceEnumParam < TencentCloud::Common::AbstractModel # @param CurrentValue: 参数当前值。 # @type CurrentValue: String # @param DefaultValue: 参数默认值。 # @type DefaultValue: String # @param EnumValue: 枚举值,所有支持的值。 # @type EnumValue: Array # @param NeedRestart: 参数修改之后是否需要重启生效。 # - 1:需要重启后生效。 # - 0:无需重启,设置成功即可生效。 # @type NeedRestart: String # @param ParamName: 参数名称。 # @type ParamName: String # @param Tips: 参数说明。 # @type Tips: Array # @param ValueType: 参数值类型说明。 # @type ValueType: String # @param Status: 是否为运行中参数值。 # - 1:运行中参数值。 # - 0:非运行中参数值。 # @type Status: Integer attr_accessor :CurrentValue, :DefaultValue, :EnumValue, :NeedRestart, :ParamName, :Tips, :ValueType, :Status def initialize(currentvalue=nil, defaultvalue=nil, enumvalue=nil, needrestart=nil, paramname=nil, tips=nil, valuetype=nil, status=nil) @CurrentValue = currentvalue @DefaultValue = defaultvalue @EnumValue = enumvalue @NeedRestart = needrestart @ParamName = paramname @Tips = tips @ValueType = valuetype @Status = status end def deserialize(params) @CurrentValue = params['CurrentValue'] @DefaultValue = params['DefaultValue'] @EnumValue = params['EnumValue'] @NeedRestart = params['NeedRestart'] @ParamName = params['ParamName'] @Tips = params['Tips'] @ValueType = params['ValueType'] @Status = params['Status'] end end # 实例可修改参数 Integer 类型集合。 class InstanceIntegerParam < TencentCloud::Common::AbstractModel # @param CurrentValue: 参数当前值。 # @type CurrentValue: String # @param DefaultValue: 参数默认值。 # @type DefaultValue: String # @param Max: 参数最大值。 # @type Max: String # @param Min: 最小值。 # @type Min: String # @param NeedRestart: 参数修改之后是否需要重启生效。 # - 1:需要重启后生效。 # - 0:无需重启,设置成功即可生效。 # @type NeedRestart: String # @param ParamName: 参数名称。 # @type ParamName: String # @param Tips: 参数说明。 # @type Tips: Array # @param ValueType: 参数类型。 # @type ValueType: String # @param Status: 是否为运行中参数值。 # - 1:运行中参数值。 # - 0:非运行中参数值。 # @type Status: Integer # @param Unit: 冗余字段,可忽略。 # @type Unit: String attr_accessor :CurrentValue, :DefaultValue, :Max, :Min, :NeedRestart, :ParamName, :Tips, :ValueType, :Status, :Unit def initialize(currentvalue=nil, defaultvalue=nil, max=nil, min=nil, needrestart=nil, paramname=nil, tips=nil, valuetype=nil, status=nil, unit=nil) @CurrentValue = currentvalue @DefaultValue = defaultvalue @Max = max @Min = min @NeedRestart = needrestart @ParamName = paramname @Tips = tips @ValueType = valuetype @Status = status @Unit = unit end def deserialize(params) @CurrentValue = params['CurrentValue'] @DefaultValue = params['DefaultValue'] @Max = params['Max'] @Min = params['Min'] @NeedRestart = params['NeedRestart'] @ParamName = params['ParamName'] @Tips = params['Tips'] @ValueType = params['ValueType'] @Status = params['Status'] @Unit = params['Unit'] end end # 实例可修改参数Multi类型集合。 class InstanceMultiParam < TencentCloud::Common::AbstractModel # @param CurrentValue: 参数当前值。 # @type CurrentValue: String # @param DefaultValue: 参数默认值。 # @type DefaultValue: String # @param EnumValue: 参考值范围。 # @type EnumValue: Array # @param NeedRestart: 参数修改后是否需要重启才会生效。 # - 1:需要重启后生效。 # - 0:无需重启,设置成功即可生效。 # @type NeedRestart: String # @param ParamName: 参数名称。 # @type ParamName: String # @param Status: 是否为运行中参数值。 # - 1:运行中参数值。 # - 0:非运行中参数值。 # @type Status: Integer # @param Tips: 参数说明。 # @type Tips: Array # @param ValueType: 当前值的类型描述,默认为multi。 # @type ValueType: String attr_accessor :CurrentValue, :DefaultValue, :EnumValue, :NeedRestart, :ParamName, :Status, :Tips, :ValueType def initialize(currentvalue=nil, defaultvalue=nil, enumvalue=nil, needrestart=nil, paramname=nil, status=nil, tips=nil, valuetype=nil) @CurrentValue = currentvalue @DefaultValue = defaultvalue @EnumValue = enumvalue @NeedRestart = needrestart @ParamName = paramname @Status = status @Tips = tips @ValueType = valuetype end def deserialize(params) @CurrentValue = params['CurrentValue'] @DefaultValue = params['DefaultValue'] @EnumValue = params['EnumValue'] @NeedRestart = params['NeedRestart'] @ParamName = params['ParamName'] @Status = params['Status'] @Tips = params['Tips'] @ValueType = params['ValueType'] end end # 实例可修改参数为 Text 类型的参数集合。 class InstanceTextParam < TencentCloud::Common::AbstractModel # @param CurrentValue: 参数当前值。 # @type CurrentValue: String # @param DefaultValue: 参数默认值。 # @type DefaultValue: String # @param NeedRestart: 修改参数值之后是否需要重启。 # @type NeedRestart: String # @param ParamName: 参数名称。 # @type ParamName: String # @param TextValue: Text 类型参数对应的值。 # @type TextValue: String # @param Tips: 参数说明。 # @type Tips: Array # @param ValueType: 参数值类型说明。 # @type ValueType: String # @param Status: 是否为运行中的参数值。 # - 1:运行中参数值。 # - 0:非运行中参数值。 # @type Status: String attr_accessor :CurrentValue, :DefaultValue, :NeedRestart, :ParamName, :TextValue, :Tips, :ValueType, :Status def initialize(currentvalue=nil, defaultvalue=nil, needrestart=nil, paramname=nil, textvalue=nil, tips=nil, valuetype=nil, status=nil) @CurrentValue = currentvalue @DefaultValue = defaultvalue @NeedRestart = needrestart @ParamName = paramname @TextValue = textvalue @Tips = tips @ValueType = valuetype @Status = status end def deserialize(params) @CurrentValue = params['CurrentValue'] @DefaultValue = params['DefaultValue'] @NeedRestart = params['NeedRestart'] @ParamName = params['ParamName'] @TextValue = params['TextValue'] @Tips = params['Tips'] @ValueType = params['ValueType'] @Status = params['Status'] end end # IsolateDBInstance请求参数结构体 class IsolateDBInstanceRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同 # @type InstanceId: String attr_accessor :InstanceId def initialize(instanceid=nil) @InstanceId = instanceid end def deserialize(params) @InstanceId = params['InstanceId'] end end # IsolateDBInstance返回参数结构体 class IsolateDBInstanceResponse < TencentCloud::Common::AbstractModel # @param AsyncRequestId: 异步任务的请求 ID,可使用此 ID 查询异步任务的执行结果。 # @type AsyncRequestId: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :AsyncRequestId, :RequestId def initialize(asyncrequestid=nil, requestid=nil) @AsyncRequestId = asyncrequestid @RequestId = requestid end def deserialize(params) @AsyncRequestId = params['AsyncRequestId'] @RequestId = params['RequestId'] end end # KMS密钥信息 class KMSInfoDetail < TencentCloud::Common::AbstractModel # @param KeyId: 主密钥 ID。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type KeyId: String # @param KeyName: 主密钥名称。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type KeyName: String # @param CreateTime: 实例与密钥绑定时间。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CreateTime: String # @param Status: 密钥状态。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param KeyUsage: 密钥用途。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type KeyUsage: String # @param KeyOrigin: 密钥来源。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type KeyOrigin: String # @param KmsRegion: kms所在地域。 # @type KmsRegion: String attr_accessor :KeyId, :KeyName, :CreateTime, :Status, :KeyUsage, :KeyOrigin, :KmsRegion def initialize(keyid=nil, keyname=nil, createtime=nil, status=nil, keyusage=nil, keyorigin=nil, kmsregion=nil) @KeyId = keyid @KeyName = keyname @CreateTime = createtime @Status = status @KeyUsage = keyusage @KeyOrigin = keyorigin @KmsRegion = kmsregion end def deserialize(params) @KeyId = params['KeyId'] @KeyName = params['KeyName'] @CreateTime = params['CreateTime'] @Status = params['Status'] @KeyUsage = params['KeyUsage'] @KeyOrigin = params['KeyOrigin'] @KmsRegion = params['KmsRegion'] end end # KillOps请求参数结构体 class KillOpsRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同 # @type InstanceId: String # @param Operations: 待终止的操作 # @type Operations: Array attr_accessor :InstanceId, :Operations def initialize(instanceid=nil, operations=nil) @InstanceId = instanceid @Operations = operations end def deserialize(params) @InstanceId = params['InstanceId'] unless params['Operations'].nil? @Operations = [] params['Operations'].each do |i| operation_tmp = Operation.new operation_tmp.deserialize(i) @Operations << operation_tmp end end end end # KillOps返回参数结构体 class KillOpsResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # ModifyDBInstanceNetworkAddress请求参数结构体 class ModifyDBInstanceNetworkAddressRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定需修改网络的实例 ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param OldIpExpiredTime: 原 IP 地址保留时长。 # - 单位为分钟,0表示立即回收原 IP 地址。 # - 原 IP 将在约定时间后释放,在释放前原 IP和新 IP均可访问。 # @type OldIpExpiredTime: Integer # @param NewUniqVpcId: 切换后的私有网络 ID,若实例当前为基础网络,该字段无需配置。 # @type NewUniqVpcId: String # @param NewUniqSubnetId: 切换私有网络的子网 ID。若实例当前为基础网络,该字段无需配置。 # @type NewUniqSubnetId: String # @param NetworkAddresses: IP 地址信息,包含新 IP 地址与 原 IP 地址。 # @type NetworkAddresses: Array attr_accessor :InstanceId, :OldIpExpiredTime, :NewUniqVpcId, :NewUniqSubnetId, :NetworkAddresses def initialize(instanceid=nil, oldipexpiredtime=nil, newuniqvpcid=nil, newuniqsubnetid=nil, networkaddresses=nil) @InstanceId = instanceid @OldIpExpiredTime = oldipexpiredtime @NewUniqVpcId = newuniqvpcid @NewUniqSubnetId = newuniqsubnetid @NetworkAddresses = networkaddresses end def deserialize(params) @InstanceId = params['InstanceId'] @OldIpExpiredTime = params['OldIpExpiredTime'] @NewUniqVpcId = params['NewUniqVpcId'] @NewUniqSubnetId = params['NewUniqSubnetId'] unless params['NetworkAddresses'].nil? @NetworkAddresses = [] params['NetworkAddresses'].each do |i| modifynetworkaddress_tmp = ModifyNetworkAddress.new modifynetworkaddress_tmp.deserialize(i) @NetworkAddresses << modifynetworkaddress_tmp end end end end # ModifyDBInstanceNetworkAddress返回参数结构体 class ModifyDBInstanceNetworkAddressResponse < TencentCloud::Common::AbstractModel # @param FlowId: 修改网络异步流程任务ID。 # @type FlowId: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :FlowId, :RequestId def initialize(flowid=nil, requestid=nil) @FlowId = flowid @RequestId = requestid end def deserialize(params) @FlowId = params['FlowId'] @RequestId = params['RequestId'] end end # ModifyDBInstanceParamTpl请求参数结构体 class ModifyDBInstanceParamTplRequest < TencentCloud::Common::AbstractModel # @param TplId: 待修改的参数模板 ID,示例:tpl-jglr91vew。 # @type TplId: String # @param TplName: 待修改参数模板名称,为空时,保持原有名称。 # @type TplName: String # @param TplDesc: 待修改参数模板描述,为空时,保持原有描述。 # @type TplDesc: String # @param Params: 待修改参数名及参数值,为空时,各参数保持原有值,支持单条或批量修改。 # @type Params: Array attr_accessor :TplId, :TplName, :TplDesc, :Params def initialize(tplid=nil, tplname=nil, tpldesc=nil, params=nil) @TplId = tplid @TplName = tplname @TplDesc = tpldesc @Params = params end def deserialize(params) @TplId = params['TplId'] @TplName = params['TplName'] @TplDesc = params['TplDesc'] unless params['Params'].nil? @Params = [] params['Params'].each do |i| paramtype_tmp = ParamType.new paramtype_tmp.deserialize(i) @Params << paramtype_tmp end end end end # ModifyDBInstanceParamTpl返回参数结构体 class ModifyDBInstanceParamTplResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # ModifyDBInstanceSecurityGroup请求参数结构体 class ModifyDBInstanceSecurityGroupRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例 ID。例如:cmgo-7pje****。 # @type InstanceId: String # @param SecurityGroupIds: 目标安全组 ID。请通过接口[DescribeSecurityGroup](https://cloud.tencent.com/document/product/240/55675)查看具体的安全组 ID。 # @type SecurityGroupIds: Array attr_accessor :InstanceId, :SecurityGroupIds def initialize(instanceid=nil, securitygroupids=nil) @InstanceId = instanceid @SecurityGroupIds = securitygroupids end def deserialize(params) @InstanceId = params['InstanceId'] @SecurityGroupIds = params['SecurityGroupIds'] end end # ModifyDBInstanceSecurityGroup返回参数结构体 class ModifyDBInstanceSecurityGroupResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # ModifyDBInstanceSpec请求参数结构体 class ModifyDBInstanceSpecRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例 ID,例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param Memory: 实例配置变更后的内存大小。- 单位:GB。为空时,默认取实例当前的内存大小。
注意:内存和磁盘必须同时升配或同时降配,即 Memory 与 Volume 需同时配置变更。 # @type Memory: Integer # @param Volume: 实例配置变更后的硬盘大小,单位:GB。为空时,默认取当前实例的磁盘大小。 # - 内存和磁盘必须同时升配或同时降配,即 Memory 与 Volume 需同时配置变更。 # - 降配时,变更后的磁盘容量必须大于已用磁盘容量的1.2倍。 # @type Volume: Integer # @param OplogSize: (已废弃) 请使用ResizeOplog独立接口完成。 # 实例配置变更后 Oplog 的大小。 # - 单位:GB。 # - 默认 Oplog 占用容量为磁盘空间的10%。系统允许设置的 Oplog 容量范围为磁盘空间的[10%,90%]。 # @type OplogSize: Integer # @param NodeNum: 实例变更后mongod的节点数(不包含readonly节点数)。 # - 变更mongod CPU与内存规格时,该参数可以不配置或者输入当前 mongod(不包含readonly) 节点数量。 # - 变更 mongos CPU与内存规格时,该参数可以不配置或者输入当前 mongod(不包含readonly) 节点数量。 # - 节点变更时(全部类型),该参数可不配置或输入变更后的 mongod(不包含readonl) 节点数量。 # - 副本集节点数:请确认节点数量取值范围,通过云数据库的售卖规格 [DescribeSpecInfo ](https://cloud.tencent.com/document/product/240/38565)接口返回的参数 MinNodeNum 与 MaxNodeNum 获取。 # - 分片集群每个分片节点数:请确认节点数量取值范围,通过云数据库的售卖规格 [DescribeSpecInfo ](https://cloud.tencent.com/document/product/240/38565)接口返回的参数 MinReplicateSetNodeNum 与 MaxReplicateSetNodeNum 获取。 # @type NodeNum: Integer # @param ReplicateSetNum: 实例变更后的分片数。 # - 取值范围请通过云数据库的售卖规格[DescribeSpecInfo](https://cloud.tencent.com/document/product/240/38567) 接口返回的参数**MinReplicateSetNum**与**MaxReplicateSetNum**获取。- 该参数只能增加不能减少。 # @type ReplicateSetNum: Integer # @param InMaintenance: 实例配置变更的切换时间。 # - 0:调整完成时,立即执行变配任务。默认为0。 # - 1:在维护时间窗内,执行变配任务。 # **说明**:调整节点数和分片数不支持在维护时间窗内变更。 # @type InMaintenance: Integer # @param MongosMemory: 分片实例配置变更后的mongos内存大小。单位:GB。 # @type MongosMemory: String # @param AddNodeList: 新增节点列表,节点类型及可用区信息。 # @type AddNodeList: Array # @param RemoveNodeList: 删除节点列表,注意:基于分片实例各片节点的一致性原则,删除分片实例节点时,只需指定0分片对应的节点即可,如:cmgo-9nl1czif_0-node-readonly0 将删除每个分片的第1个只读节点。 # @type RemoveNodeList: Array attr_accessor :InstanceId, :Memory, :Volume, :OplogSize, :NodeNum, :ReplicateSetNum, :InMaintenance, :MongosMemory, :AddNodeList, :RemoveNodeList def initialize(instanceid=nil, memory=nil, volume=nil, oplogsize=nil, nodenum=nil, replicatesetnum=nil, inmaintenance=nil, mongosmemory=nil, addnodelist=nil, removenodelist=nil) @InstanceId = instanceid @Memory = memory @Volume = volume @OplogSize = oplogsize @NodeNum = nodenum @ReplicateSetNum = replicatesetnum @InMaintenance = inmaintenance @MongosMemory = mongosmemory @AddNodeList = addnodelist @RemoveNodeList = removenodelist end def deserialize(params) @InstanceId = params['InstanceId'] @Memory = params['Memory'] @Volume = params['Volume'] @OplogSize = params['OplogSize'] @NodeNum = params['NodeNum'] @ReplicateSetNum = params['ReplicateSetNum'] @InMaintenance = params['InMaintenance'] @MongosMemory = params['MongosMemory'] unless params['AddNodeList'].nil? @AddNodeList = [] params['AddNodeList'].each do |i| addnodelist_tmp = AddNodeList.new addnodelist_tmp.deserialize(i) @AddNodeList << addnodelist_tmp end end unless params['RemoveNodeList'].nil? @RemoveNodeList = [] params['RemoveNodeList'].each do |i| removenodelist_tmp = RemoveNodeList.new removenodelist_tmp.deserialize(i) @RemoveNodeList << removenodelist_tmp end end end end # ModifyDBInstanceSpec返回参数结构体 class ModifyDBInstanceSpecResponse < TencentCloud::Common::AbstractModel # @param DealId: 订单 ID。 # @type DealId: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :DealId, :RequestId def initialize(dealid=nil, requestid=nil) @DealId = dealid @RequestId = requestid end def deserialize(params) @DealId = params['DealId'] @RequestId = params['RequestId'] end end # ModifyInstanceParams请求参数结构体 class ModifyInstanceParamsRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定实例 ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param InstanceParams: 指定需修改的参数名及值。当前所支持的参数名及对应取值范围,请通过 [DescribeInstanceParams ](https://cloud.tencent.com/document/product/240/65903)获取。 # @type InstanceParams: Array # @param ModifyType: 操作类型,包括: # - IMMEDIATELY:立即调整。 # - DELAY:延迟调整。可选字段,不配置该参数则默认为立即调整。 # @type ModifyType: String attr_accessor :InstanceId, :InstanceParams, :ModifyType def initialize(instanceid=nil, instanceparams=nil, modifytype=nil) @InstanceId = instanceid @InstanceParams = instanceparams @ModifyType = modifytype end def deserialize(params) @InstanceId = params['InstanceId'] unless params['InstanceParams'].nil? @InstanceParams = [] params['InstanceParams'].each do |i| modifymongodbparamtype_tmp = ModifyMongoDBParamType.new modifymongodbparamtype_tmp.deserialize(i) @InstanceParams << modifymongodbparamtype_tmp end end @ModifyType = params['ModifyType'] end end # ModifyInstanceParams返回参数结构体 class ModifyInstanceParamsResponse < TencentCloud::Common::AbstractModel # @param Changed: 修改参数配置是否生效。 # - true:参数修改后的值已生效。 # - false:执行失败。 # @type Changed: Boolean # @param TaskId: 该参数暂时无意义(兼容前端保留)。 # @type TaskId: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Changed, :TaskId, :RequestId def initialize(changed=nil, taskid=nil, requestid=nil) @Changed = changed @TaskId = taskid @RequestId = requestid end def deserialize(params) @Changed = params['Changed'] @TaskId = params['TaskId'] @RequestId = params['RequestId'] end end # 修改mongoDB实例,请求参数 class ModifyMongoDBParamType < TencentCloud::Common::AbstractModel # @param Key: 需要修改的参数名称,请严格参考通过 DescribeInstanceParams 获取的当前实例支持的参数名。 # @type Key: String # @param Value: 需要修改的参数名称对应的值,请严格参考通过 DescribeInstanceParams 获取的参数对应的值的范围。 # @type Value: String attr_accessor :Key, :Value def initialize(key=nil, value=nil) @Key = key @Value = value end def deserialize(params) @Key = params['Key'] @Value = params['Value'] end end # 修改数据库地址 class ModifyNetworkAddress < TencentCloud::Common::AbstractModel # @param NewIPAddress: 新IP地址。 # @type NewIPAddress: String # @param OldIpAddress: 原IP地址。 # @type OldIpAddress: String attr_accessor :NewIPAddress, :OldIpAddress def initialize(newipaddress=nil, oldipaddress=nil) @NewIPAddress = newipaddress @OldIpAddress = oldipaddress end def deserialize(params) @NewIPAddress = params['NewIPAddress'] @OldIpAddress = params['OldIpAddress'] end end # 节点属性 class NodeProperty < TencentCloud::Common::AbstractModel # @param Zone: 节点所在的可用区。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Zone: String # @param NodeName: 节点名称。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NodeName: String # @param Address: 节点访问地址。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Address: String # @param Role: 角色。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Role: String # @param Hidden: 是否为Hidden节点 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Hidden: Boolean # @param Status: 节点状态,包括:ORMAL/STARTUP/RECOVERING/STARTUP2/UNKNOWN/DOWN/ROLLBACK/REMOVED等。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param SlaveDelay: 主从延迟,单位秒。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SlaveDelay: Integer # @param Priority: 节点优先级。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Priority: Integer # @param Votes: 节点投票权。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Votes: Integer # @param Tags: 节点标签。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tags: Array # @param ReplicateSetId: 副本集Id。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ReplicateSetId: String attr_accessor :Zone, :NodeName, :Address, :Role, :Hidden, :Status, :SlaveDelay, :Priority, :Votes, :Tags, :ReplicateSetId def initialize(zone=nil, nodename=nil, address=nil, role=nil, hidden=nil, status=nil, slavedelay=nil, priority=nil, votes=nil, tags=nil, replicatesetid=nil) @Zone = zone @NodeName = nodename @Address = address @Role = role @Hidden = hidden @Status = status @SlaveDelay = slavedelay @Priority = priority @Votes = votes @Tags = tags @ReplicateSetId = replicatesetid end def deserialize(params) @Zone = params['Zone'] @NodeName = params['NodeName'] @Address = params['Address'] @Role = params['Role'] @Hidden = params['Hidden'] @Status = params['Status'] @SlaveDelay = params['SlaveDelay'] @Priority = params['Priority'] @Votes = params['Votes'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| nodetag_tmp = NodeTag.new nodetag_tmp.deserialize(i) @Tags << nodetag_tmp end end @ReplicateSetId = params['ReplicateSetId'] end end # 节点Tag class NodeTag < TencentCloud::Common::AbstractModel # @param TagKey: 节点Tag key # 注意:此字段可能返回 null,表示取不到有效值。 # @type TagKey: String # @param TagValue: 节点Tag Value # 注意:此字段可能返回 null,表示取不到有效值。 # @type TagValue: String attr_accessor :TagKey, :TagValue def initialize(tagkey=nil, tagvalue=nil) @TagKey = tagkey @TagValue = tagvalue end def deserialize(params) @TagKey = params['TagKey'] @TagValue = params['TagValue'] end end # OfflineIsolatedDBInstance请求参数结构体 class OfflineIsolatedDBInstanceRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同 # @type InstanceId: String attr_accessor :InstanceId def initialize(instanceid=nil) @InstanceId = instanceid end def deserialize(params) @InstanceId = params['InstanceId'] end end # OfflineIsolatedDBInstance返回参数结构体 class OfflineIsolatedDBInstanceResponse < TencentCloud::Common::AbstractModel # @param AsyncRequestId: 异步任务的请求 ID,可使用此 ID 查询异步任务的执行结果。 # @type AsyncRequestId: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :AsyncRequestId, :RequestId def initialize(asyncrequestid=nil, requestid=nil) @AsyncRequestId = asyncrequestid @RequestId = requestid end def deserialize(params) @AsyncRequestId = params['AsyncRequestId'] @RequestId = params['RequestId'] end end # 需要终止的操作 class Operation < TencentCloud::Common::AbstractModel # @param ReplicaSetName: 操作所在的分片名 # @type ReplicaSetName: String # @param NodeName: 操作所在的节点名 # @type NodeName: String # @param OpId: 操作序号 # @type OpId: Integer attr_accessor :ReplicaSetName, :NodeName, :OpId def initialize(replicasetname=nil, nodename=nil, opid=nil) @ReplicaSetName = replicasetname @NodeName = nodename @OpId = opid end def deserialize(params) @ReplicaSetName = params['ReplicaSetName'] @NodeName = params['NodeName'] @OpId = params['OpId'] end end # 数据库参数模板 class ParamTpl < TencentCloud::Common::AbstractModel # @param TplName: 参数模板名称 # @type TplName: String # @param TplId: 参数模板ID # @type TplId: String # @param MongoVersion: 适用数据库版本 # @type MongoVersion: String # @param ClusterType: 适用数据库类型 # @type ClusterType: String # @param TplDesc: 参数模板描述 # @type TplDesc: String # @param TplType: 模板类型,包括DEFAULT(默认模板)及CUSTOMIZE(定制模板)两种类型 # @type TplType: String attr_accessor :TplName, :TplId, :MongoVersion, :ClusterType, :TplDesc, :TplType def initialize(tplname=nil, tplid=nil, mongoversion=nil, clustertype=nil, tpldesc=nil, tpltype=nil) @TplName = tplname @TplId = tplid @MongoVersion = mongoversion @ClusterType = clustertype @TplDesc = tpldesc @TplType = tpltype end def deserialize(params) @TplName = params['TplName'] @TplId = params['TplId'] @MongoVersion = params['MongoVersion'] @ClusterType = params['ClusterType'] @TplDesc = params['TplDesc'] @TplType = params['TplType'] end end # 数据库参数 class ParamType < TencentCloud::Common::AbstractModel # @param Key: 参数 # @type Key: String # @param Value: 参数值 # @type Value: String attr_accessor :Key, :Value def initialize(key=nil, value=nil) @Key = key @Value = value end def deserialize(params) @Key = params['Key'] @Value = params['Value'] end end # 修改实例节点详情 class RemoveNodeList < TencentCloud::Common::AbstractModel # @param Role: 需要删除的节点角色。 # - SECONDARY:Mongod 从节点。 # - READONLY:只读节点。 # - MONGOS:Mongos 节点。 # @type Role: String # @param NodeName: 要删除的节点 ID。分片集群须指定一组分片要删除的节点名称即可,其余分片对改组对齐。 # - 获取方式:登录 [MongoDB控制台](https://console.cloud.tencent.com/),在**节点管理**页签,可获取**节点 ID**。 # - 特别说明:分片集群同一节点上的分片,仅需指定0分片节点 ID 即可。例如:cmgo-6hfk****_0-node-primary。 # @type NodeName: String # @param Zone: 节点所对应的可用区。 # - 单可用区,所有节点在同一可用区。 # - 多可用区:当前标准规格是三可用区分布,主从节点不在同一可用区,需注意配置所删除节点对应的可用区,且删除后必须满足任意2个可用区节点数大于第3个可用区原则。 # @type Zone: String attr_accessor :Role, :NodeName, :Zone def initialize(role=nil, nodename=nil, zone=nil) @Role = role @NodeName = nodename @Zone = zone end def deserialize(params) @Role = params['Role'] @NodeName = params['NodeName'] @Zone = params['Zone'] end end # RenameInstance请求参数结构体 class RenameInstanceRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同 # @type InstanceId: String # @param NewName: 自定义实例名称,名称只支持长度为60个字符的中文、英文、数字、下划线_、分隔符 - # @type NewName: String attr_accessor :InstanceId, :NewName def initialize(instanceid=nil, newname=nil) @InstanceId = instanceid @NewName = newname end def deserialize(params) @InstanceId = params['InstanceId'] @NewName = params['NewName'] end end # RenameInstance返回参数结构体 class RenameInstanceResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # RenewDBInstances请求参数结构体 class RenewDBInstancesRequest < TencentCloud::Common::AbstractModel # @param InstanceIds: 一个或多个待操作的实例ID。可通过DescribeInstances接口返回值中的InstanceId获取。每次请求批量实例的上限为100。 # @type InstanceIds: Array # @param InstanceChargePrepaid: 预付费模式,即包年包月相关参数设置。通过该参数可以指定包年包月实例的续费时长、是否设置自动续费等属性。包年包月实例该参数为必传参数。 # @type InstanceChargePrepaid: :class:`Tencentcloud::Mongodb.v20190725.models.InstanceChargePrepaid` attr_accessor :InstanceIds, :InstanceChargePrepaid def initialize(instanceids=nil, instancechargeprepaid=nil) @InstanceIds = instanceids @InstanceChargePrepaid = instancechargeprepaid end def deserialize(params) @InstanceIds = params['InstanceIds'] unless params['InstanceChargePrepaid'].nil? @InstanceChargePrepaid = InstanceChargePrepaid.new @InstanceChargePrepaid.deserialize(params['InstanceChargePrepaid']) end end end # RenewDBInstances返回参数结构体 class RenewDBInstancesResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # 分片信息 class ReplicaSetInfo < TencentCloud::Common::AbstractModel # @param ReplicaSetId: 副本集ID # @type ReplicaSetId: String attr_accessor :ReplicaSetId def initialize(replicasetid=nil) @ReplicaSetId = replicasetid end def deserialize(params) @ReplicaSetId = params['ReplicaSetId'] end end # 副本集信息 class ReplicateSetInfo < TencentCloud::Common::AbstractModel # @param Nodes: 节点属性 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Nodes: Array attr_accessor :Nodes def initialize(nodes=nil) @Nodes = nodes end def deserialize(params) unless params['Nodes'].nil? @Nodes = [] params['Nodes'].each do |i| nodeproperty_tmp = NodeProperty.new nodeproperty_tmp.deserialize(i) @Nodes << nodeproperty_tmp end end end end # ResetDBInstancePassword请求参数结构体 class ResetDBInstancePasswordRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例Id # @type InstanceId: String # @param UserName: 实例账号名 # @type UserName: String # @param Password: 新密码,新密码长度不能少于8位 # @type Password: String attr_accessor :InstanceId, :UserName, :Password def initialize(instanceid=nil, username=nil, password=nil) @InstanceId = instanceid @UserName = username @Password = password end def deserialize(params) @InstanceId = params['InstanceId'] @UserName = params['UserName'] @Password = params['Password'] end end # ResetDBInstancePassword返回参数结构体 class ResetDBInstancePasswordResponse < TencentCloud::Common::AbstractModel # @param AsyncRequestId: 异步请求Id,用户查询该流程的运行状态 # @type AsyncRequestId: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :AsyncRequestId, :RequestId def initialize(asyncrequestid=nil, requestid=nil) @AsyncRequestId = asyncrequestid @RequestId = requestid end def deserialize(params) @AsyncRequestId = params['AsyncRequestId'] @RequestId = params['RequestId'] end end # RestartNodes请求参数结构体 class RestartNodesRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID,格式如:cmgo-p8vnipr5。与云数据库控制台页面中显示的实例ID相同。 # @type InstanceId: String # @param NodeIds: 节点Id。 # @type NodeIds: Array attr_accessor :InstanceId, :NodeIds def initialize(instanceid=nil, nodeids=nil) @InstanceId = instanceid @NodeIds = nodeids end def deserialize(params) @InstanceId = params['InstanceId'] @NodeIds = params['NodeIds'] end end # RestartNodes返回参数结构体 class RestartNodesResponse < TencentCloud::Common::AbstractModel # @param FlowId: 流程Id。 # @type FlowId: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :FlowId, :RequestId def initialize(flowid=nil, requestid=nil) @FlowId = flowid @RequestId = requestid end def deserialize(params) @FlowId = params['FlowId'] @RequestId = params['RequestId'] end end # 安全组信息 class SecurityGroup < TencentCloud::Common::AbstractModel # @param ProjectId: 所属项目id # @type ProjectId: Integer # @param CreateTime: 创建时间 # @type CreateTime: String # @param Inbound: 入站规则 # @type Inbound: Array # @param Outbound: 出站规则 # @type Outbound: Array # @param SecurityGroupId: 安全组id # @type SecurityGroupId: String # @param SecurityGroupName: 安全组名称 # @type SecurityGroupName: String # @param SecurityGroupRemark: 安全组备注 # @type SecurityGroupRemark: String attr_accessor :ProjectId, :CreateTime, :Inbound, :Outbound, :SecurityGroupId, :SecurityGroupName, :SecurityGroupRemark def initialize(projectid=nil, createtime=nil, inbound=nil, outbound=nil, securitygroupid=nil, securitygroupname=nil, securitygroupremark=nil) @ProjectId = projectid @CreateTime = createtime @Inbound = inbound @Outbound = outbound @SecurityGroupId = securitygroupid @SecurityGroupName = securitygroupname @SecurityGroupRemark = securitygroupremark end def deserialize(params) @ProjectId = params['ProjectId'] @CreateTime = params['CreateTime'] unless params['Inbound'].nil? @Inbound = [] params['Inbound'].each do |i| securitygroupbound_tmp = SecurityGroupBound.new securitygroupbound_tmp.deserialize(i) @Inbound << securitygroupbound_tmp end end unless params['Outbound'].nil? @Outbound = [] params['Outbound'].each do |i| securitygroupbound_tmp = SecurityGroupBound.new securitygroupbound_tmp.deserialize(i) @Outbound << securitygroupbound_tmp end end @SecurityGroupId = params['SecurityGroupId'] @SecurityGroupName = params['SecurityGroupName'] @SecurityGroupRemark = params['SecurityGroupRemark'] end end # 安全组规则 class SecurityGroupBound < TencentCloud::Common::AbstractModel # @param Action: 执行规则。ACCEPT或DROP # @type Action: String # @param CidrIp: ip段。 # @type CidrIp: String # @param PortRange: 端口范围 # @type PortRange: String # @param IpProtocol: 传输层协议。tcp,udp或ALL # @type IpProtocol: String # @param Id: 安全组id代表的地址集合 # @type Id: String # @param AddressModule: 地址组id代表的地址集合 # @type AddressModule: String # @param ServiceModule: 服务组id代表的协议和端口集合 # @type ServiceModule: String # @param Desc: 描述 # @type Desc: String attr_accessor :Action, :CidrIp, :PortRange, :IpProtocol, :Id, :AddressModule, :ServiceModule, :Desc def initialize(action=nil, cidrip=nil, portrange=nil, ipprotocol=nil, id=nil, addressmodule=nil, servicemodule=nil, desc=nil) @Action = action @CidrIp = cidrip @PortRange = portrange @IpProtocol = ipprotocol @Id = id @AddressModule = addressmodule @ServiceModule = servicemodule @Desc = desc end def deserialize(params) @Action = params['Action'] @CidrIp = params['CidrIp'] @PortRange = params['PortRange'] @IpProtocol = params['IpProtocol'] @Id = params['Id'] @AddressModule = params['AddressModule'] @ServiceModule = params['ServiceModule'] @Desc = params['Desc'] end end # SetAccountUserPrivilege请求参数结构体 class SetAccountUserPrivilegeRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定待设置账号的实例ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param UserName: 设置账号名称。 # @type UserName: String # @param AuthRole: 设置权限信息。 # @type AuthRole: Array attr_accessor :InstanceId, :UserName, :AuthRole def initialize(instanceid=nil, username=nil, authrole=nil) @InstanceId = instanceid @UserName = username @AuthRole = authrole end def deserialize(params) @InstanceId = params['InstanceId'] @UserName = params['UserName'] unless params['AuthRole'].nil? @AuthRole = [] params['AuthRole'].each do |i| auth_tmp = Auth.new auth_tmp.deserialize(i) @AuthRole << auth_tmp end end end end # SetAccountUserPrivilege返回参数结构体 class SetAccountUserPrivilegeResponse < TencentCloud::Common::AbstractModel # @param FlowId: 任务ID。 # @type FlowId: Integer # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :FlowId, :RequestId def initialize(flowid=nil, requestid=nil) @FlowId = flowid @RequestId = requestid end def deserialize(params) @FlowId = params['FlowId'] @RequestId = params['RequestId'] end end # SetBackupRules请求参数结构体 class SetBackupRulesRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 实例 ID,例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param BackupMethod: 设置自动备份方式。- 0:逻辑备份。- 1:物理备份。-3:快照备份(仅云盘版支持)。 # @type BackupMethod: Integer # @param BackupTime: 设置自动备份开始时间。取值范围为:[0,23],例如:该参数设置为2,表示02:00开始备份。 # @type BackupTime: Integer # @param Notify: 设置自动备份发生错误时,是否发送失败告警。 # - true:发送。 # - false:不发送。 # @type Notify: Boolean # @param BackupRetentionPeriod: 指定备份数据保存天数。默认为 7 天,支持设置为7、30、90、180、365。 # @type BackupRetentionPeriod: Integer attr_accessor :InstanceId, :BackupMethod, :BackupTime, :Notify, :BackupRetentionPeriod def initialize(instanceid=nil, backupmethod=nil, backuptime=nil, notify=nil, backupretentionperiod=nil) @InstanceId = instanceid @BackupMethod = backupmethod @BackupTime = backuptime @Notify = notify @BackupRetentionPeriod = backupretentionperiod end def deserialize(params) @InstanceId = params['InstanceId'] @BackupMethod = params['BackupMethod'] @BackupTime = params['BackupTime'] @Notify = params['Notify'] @BackupRetentionPeriod = params['BackupRetentionPeriod'] end end # SetBackupRules返回参数结构体 class SetBackupRulesResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # SetInstanceMaintenance请求参数结构体 class SetInstanceMaintenanceRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定实例ID。例如:cmgo-p8vn****。请登录 [MongoDB 控制台](https://console.cloud.tencent.com/mongodb)在实例列表复制实例 ID。 # @type InstanceId: String # @param MaintenanceStart: 维护时间窗开始时间。取值范围为"00:00-23:00"的任意整点或半点,如00:00或00:30。 # @type MaintenanceStart: String # @param MaintenanceEnd: 维护时间窗结束时间。 # - 取值范围为"00:00-23:00"的任意整点或半点,维护时间持续时长最小为30分钟,最大为3小时。 # - 结束时间务必是基于开始时间向后的时间。 # @type MaintenanceEnd: String attr_accessor :InstanceId, :MaintenanceStart, :MaintenanceEnd def initialize(instanceid=nil, maintenancestart=nil, maintenanceend=nil) @InstanceId = instanceid @MaintenanceStart = maintenancestart @MaintenanceEnd = maintenanceend end def deserialize(params) @InstanceId = params['InstanceId'] @MaintenanceStart = params['MaintenanceStart'] @MaintenanceEnd = params['MaintenanceEnd'] end end # SetInstanceMaintenance返回参数结构体 class SetInstanceMaintenanceResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # 实例分片详情 class ShardInfo < TencentCloud::Common::AbstractModel # @param UsedVolume: 分片已使用容量 # @type UsedVolume: Float # @param ReplicaSetId: 分片ID # @type ReplicaSetId: String # @param ReplicaSetName: 分片名 # @type ReplicaSetName: String # @param Memory: 分片内存规格,单位为MB # @type Memory: Integer # @param Volume: 分片磁盘规格,单位为MB # @type Volume: Integer # @param OplogSize: 分片Oplog大小,单位为MB # @type OplogSize: Integer # @param SecondaryNum: 分片从节点数 # @type SecondaryNum: Integer # @param RealReplicaSetId: 分片物理id # @type RealReplicaSetId: String attr_accessor :UsedVolume, :ReplicaSetId, :ReplicaSetName, :Memory, :Volume, :OplogSize, :SecondaryNum, :RealReplicaSetId def initialize(usedvolume=nil, replicasetid=nil, replicasetname=nil, memory=nil, volume=nil, oplogsize=nil, secondarynum=nil, realreplicasetid=nil) @UsedVolume = usedvolume @ReplicaSetId = replicasetid @ReplicaSetName = replicasetname @Memory = memory @Volume = volume @OplogSize = oplogsize @SecondaryNum = secondarynum @RealReplicaSetId = realreplicasetid end def deserialize(params) @UsedVolume = params['UsedVolume'] @ReplicaSetId = params['ReplicaSetId'] @ReplicaSetName = params['ReplicaSetName'] @Memory = params['Memory'] @Volume = params['Volume'] @OplogSize = params['OplogSize'] @SecondaryNum = params['SecondaryNum'] @RealReplicaSetId = params['RealReplicaSetId'] end end # 用于描述MongoDB数据库慢日志统计信息 class SlowLogPattern < TencentCloud::Common::AbstractModel # @param Pattern: 慢日志模式 # @type Pattern: String # @param MaxTime: 最大执行时间 # @type MaxTime: Integer # @param AverageTime: 平均执行时间 # @type AverageTime: Integer # @param Total: 该模式慢日志条数 # @type Total: Integer attr_accessor :Pattern, :MaxTime, :AverageTime, :Total def initialize(pattern=nil, maxtime=nil, averagetime=nil, total=nil) @Pattern = pattern @MaxTime = maxtime @AverageTime = averagetime @Total = total end def deserialize(params) @Pattern = params['Pattern'] @MaxTime = params['MaxTime'] @AverageTime = params['AverageTime'] @Total = params['Total'] end end # mongodb售卖规格 class SpecItem < TencentCloud::Common::AbstractModel # @param SpecCode: 规格信息标识。格式如:mongo.HIO10G.128g。由节点类型、规格类型、内存规格三部分组成。 # - 节点类型,如下所示。 # - mongo:Mongod 节点。 # - mongos:Mongos 节点。 # - cfgstr:Configserver 节点。 # - 规格类型,如下所示。 # - HIO10G:通用高HIO万兆型。 # - HCD:云盘版类型。 # - 内存规格,如下所示: # - 支持4、8、16、32、64、128、240、512。 # - 单位g:表示GB。128g则表示128GB。 # @type SpecCode: String # @param Status: 售卖规格有效标志,取值范围如下: # - 0:停止售卖, # - 1:开放售卖。 # @type Status: Integer # @param Cpu: 计算资源规格,CPU核数。 # @type Cpu: Integer # @param Memory: 内存规格,单位为:MB。 # @type Memory: Integer # @param DefaultStorage: 默认磁盘规格,单位为:MB。 # @type DefaultStorage: Integer # @param MaxStorage: 最大磁盘规格,单位为:MB。 # @type MaxStorage: Integer # @param MinStorage: 最小磁盘规格,单位为:MB。 # @type MinStorage: Integer # @param Qps: 指每秒最大请求次数,单位为:次/秒。 # @type Qps: Integer # @param Conns: 规格所支持的最大连接数限制。 # @type Conns: Integer # @param MongoVersionCode: 实例存储引擎版本信息。 # - MONGO_36_WT:MongoDB 3.6 WiredTiger存储引擎版本。 # - MONGO_40_WT:MongoDB 4.0 WiredTiger存储引擎版本。 # - MONGO_42_WT:MongoDB 4.2 WiredTiger存储引擎版本。 # - MONGO_44_WT:MongoDB 4.4 WiredTiger存储引擎版本。 # - MONGO_50_WT:MongoDB 5.0 WiredTiger存储引擎版本。 # - MONGO_60_WT:MongoDB 6.0 WiredTiger存储引擎版本。 # @type MongoVersionCode: String # @param MongoVersionValue: 实例版本对应的数字版本。 # @type MongoVersionValue: Integer # @param Version: 实例版本信息。支持:3.6、4.2、4.4、5.0、6.0。 # @type Version: String # @param EngineName: 存储引擎。 # @type EngineName: String # @param ClusterType: 集群类型,取值如下: # - 1:分片集群。 # - 0:副本集集群。 # @type ClusterType: Integer # @param MinNodeNum: 每个副本集最小节点数。 # @type MinNodeNum: Integer # @param MaxNodeNum: 每个副本集最大节点数。 # @type MaxNodeNum: Integer # @param MinReplicateSetNum: 最小分片数。 # @type MinReplicateSetNum: Integer # @param MaxReplicateSetNum: 最大分片数。 # @type MaxReplicateSetNum: Integer # @param MinReplicateSetNodeNum: 每个分片最小节点数。 # @type MinReplicateSetNodeNum: Integer # @param MaxReplicateSetNodeNum: 每个分片最大节点数。 # @type MaxReplicateSetNodeNum: Integer # @param MachineType: 集群的规格类型,取值范围如下: # - HIO10G:通用高HIO万兆型。 # - HCD:云盘版类型。 # @type MachineType: String attr_accessor :SpecCode, :Status, :Cpu, :Memory, :DefaultStorage, :MaxStorage, :MinStorage, :Qps, :Conns, :MongoVersionCode, :MongoVersionValue, :Version, :EngineName, :ClusterType, :MinNodeNum, :MaxNodeNum, :MinReplicateSetNum, :MaxReplicateSetNum, :MinReplicateSetNodeNum, :MaxReplicateSetNodeNum, :MachineType def initialize(speccode=nil, status=nil, cpu=nil, memory=nil, defaultstorage=nil, maxstorage=nil, minstorage=nil, qps=nil, conns=nil, mongoversioncode=nil, mongoversionvalue=nil, version=nil, enginename=nil, clustertype=nil, minnodenum=nil, maxnodenum=nil, minreplicatesetnum=nil, maxreplicatesetnum=nil, minreplicatesetnodenum=nil, maxreplicatesetnodenum=nil, machinetype=nil) @SpecCode = speccode @Status = status @Cpu = cpu @Memory = memory @DefaultStorage = defaultstorage @MaxStorage = maxstorage @MinStorage = minstorage @Qps = qps @Conns = conns @MongoVersionCode = mongoversioncode @MongoVersionValue = mongoversionvalue @Version = version @EngineName = enginename @ClusterType = clustertype @MinNodeNum = minnodenum @MaxNodeNum = maxnodenum @MinReplicateSetNum = minreplicatesetnum @MaxReplicateSetNum = maxreplicatesetnum @MinReplicateSetNodeNum = minreplicatesetnodenum @MaxReplicateSetNodeNum = maxreplicatesetnodenum @MachineType = machinetype end def deserialize(params) @SpecCode = params['SpecCode'] @Status = params['Status'] @Cpu = params['Cpu'] @Memory = params['Memory'] @DefaultStorage = params['DefaultStorage'] @MaxStorage = params['MaxStorage'] @MinStorage = params['MinStorage'] @Qps = params['Qps'] @Conns = params['Conns'] @MongoVersionCode = params['MongoVersionCode'] @MongoVersionValue = params['MongoVersionValue'] @Version = params['Version'] @EngineName = params['EngineName'] @ClusterType = params['ClusterType'] @MinNodeNum = params['MinNodeNum'] @MaxNodeNum = params['MaxNodeNum'] @MinReplicateSetNum = params['MinReplicateSetNum'] @MaxReplicateSetNum = params['MaxReplicateSetNum'] @MinReplicateSetNodeNum = params['MinReplicateSetNodeNum'] @MaxReplicateSetNodeNum = params['MaxReplicateSetNodeNum'] @MachineType = params['MachineType'] end end # 实例规格信息 class SpecificationInfo < TencentCloud::Common::AbstractModel # @param Region: 地域信息 # @type Region: String # @param Zone: 可用区信息 # @type Zone: String # @param SpecItems: 售卖规格信息 # @type SpecItems: Array # @param SupportMultiAZ: 是否支持跨可用区部署 1-支持,0-不支持 # @type SupportMultiAZ: Integer attr_accessor :Region, :Zone, :SpecItems, :SupportMultiAZ def initialize(region=nil, zone=nil, specitems=nil, supportmultiaz=nil) @Region = region @Zone = zone @SpecItems = specitems @SupportMultiAZ = supportmultiaz end def deserialize(params) @Region = params['Region'] @Zone = params['Zone'] unless params['SpecItems'].nil? @SpecItems = [] params['SpecItems'].each do |i| specitem_tmp = SpecItem.new specitem_tmp.deserialize(i) @SpecItems << specitem_tmp end end @SupportMultiAZ = params['SupportMultiAZ'] end end # 实例标签信息 class TagInfo < TencentCloud::Common::AbstractModel # @param TagKey: 标签键 # @type TagKey: String # @param TagValue: 标签值 # @type TagValue: String attr_accessor :TagKey, :TagValue def initialize(tagkey=nil, tagvalue=nil) @TagKey = tagkey @TagValue = tagvalue end def deserialize(params) @TagKey = params['TagKey'] @TagValue = params['TagValue'] end end # TerminateDBInstances请求参数结构体 class TerminateDBInstancesRequest < TencentCloud::Common::AbstractModel # @param InstanceId: 指定预隔离实例ID。格式如:cmgo-p8vnipr5。 # @type InstanceId: String attr_accessor :InstanceId def initialize(instanceid=nil) @InstanceId = instanceid end def deserialize(params) @InstanceId = params['InstanceId'] end end # TerminateDBInstances返回参数结构体 class TerminateDBInstancesResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # 账户基本信息 class UserInfo < TencentCloud::Common::AbstractModel # @param UserName: 账号名。 # @type UserName: String # @param AuthRole: 账号权限详情。 # @type AuthRole: Array # @param CreateTime: 账号创建时间。 # @type CreateTime: String # @param UpdateTime: 账号更新时间。 # @type UpdateTime: String # @param UserDesc: 备注信息。 # @type UserDesc: String attr_accessor :UserName, :AuthRole, :CreateTime, :UpdateTime, :UserDesc def initialize(username=nil, authrole=nil, createtime=nil, updatetime=nil, userdesc=nil) @UserName = username @AuthRole = authrole @CreateTime = createtime @UpdateTime = updatetime @UserDesc = userdesc end def deserialize(params) @UserName = params['UserName'] unless params['AuthRole'].nil? @AuthRole = [] params['AuthRole'].each do |i| auth_tmp = Auth.new auth_tmp.deserialize(i) @AuthRole << auth_tmp end end @CreateTime = params['CreateTime'] @UpdateTime = params['UpdateTime'] @UserDesc = params['UserDesc'] end end end end end