# 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 Dts module V20211206 # 数据库不一致的详情,mongodb业务用到 class AdvancedObjectsItem < TencentCloud::Common::AbstractModel # @param ObjectType: 对象类型,可能得值有:account,index,shardkey,schema # 注意:此字段可能返回 null,表示取不到有效值。 # @type ObjectType: String # @param SrcChunk: 源端分块 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcChunk: String # @param DstChunk: 目标端分块 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstChunk: String # @param SrcItem: 源端值 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcItem: String # @param DstItem: 目标端值 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstItem: String attr_accessor :ObjectType, :SrcChunk, :DstChunk, :SrcItem, :DstItem def initialize(objecttype=nil, srcchunk=nil, dstchunk=nil, srcitem=nil, dstitem=nil) @ObjectType = objecttype @SrcChunk = srcchunk @DstChunk = dstchunk @SrcItem = srcitem @DstItem = dstitem end def deserialize(params) @ObjectType = params['ObjectType'] @SrcChunk = params['SrcChunk'] @DstChunk = params['DstChunk'] @SrcItem = params['SrcItem'] @DstItem = params['DstItem'] end end # 检查步骤 class CheckStep < TencentCloud::Common::AbstractModel # @param StepNo: 步骤编号 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepNo: Integer # @param StepId: 步骤Id, 如:ConnectDBCheck、VersionCheck、SrcPrivilegeCheck等,具体校验项和源目标实例相关 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepId: String # @param StepName: 步骤名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepName: String # @param StepStatus: 此检查步骤的结果,pass(校验通过)、failed(校验失败)、notStarted(校验还未开始进行)、blocked(检验阻塞)、warning(校验有告警,但仍通过) # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepStatus: String # @param StepMessage: 此检查步骤的错误消息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepMessage: String # @param DetailCheckItems: 每个检查步骤里的具体检查项 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DetailCheckItems: Array # @param HasSkipped: 是否已跳过 # 注意:此字段可能返回 null,表示取不到有效值。 # @type HasSkipped: Boolean attr_accessor :StepNo, :StepId, :StepName, :StepStatus, :StepMessage, :DetailCheckItems, :HasSkipped def initialize(stepno=nil, stepid=nil, stepname=nil, stepstatus=nil, stepmessage=nil, detailcheckitems=nil, hasskipped=nil) @StepNo = stepno @StepId = stepid @StepName = stepname @StepStatus = stepstatus @StepMessage = stepmessage @DetailCheckItems = detailcheckitems @HasSkipped = hasskipped end def deserialize(params) @StepNo = params['StepNo'] @StepId = params['StepId'] @StepName = params['StepName'] @StepStatus = params['StepStatus'] @StepMessage = params['StepMessage'] unless params['DetailCheckItems'].nil? @DetailCheckItems = [] params['DetailCheckItems'].each do |i| detailcheckitem_tmp = DetailCheckItem.new detailcheckitem_tmp.deserialize(i) @DetailCheckItems << detailcheckitem_tmp end end @HasSkipped = params['HasSkipped'] end end # 校验任务运行详情 class CheckStepInfo < TencentCloud::Common::AbstractModel # @param StartAt: 任务开始时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartAt: String # @param EndAt: 任务结束时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type EndAt: String # @param Progress: 任务步骤信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Progress: :class:`Tencentcloud::Dts.v20211206.models.ProcessProgress` attr_accessor :StartAt, :EndAt, :Progress def initialize(startat=nil, endat=nil, progress=nil) @StartAt = startat @EndAt = endat @Progress = progress end def deserialize(params) @StartAt = params['StartAt'] @EndAt = params['EndAt'] unless params['Progress'].nil? @Progress = ProcessProgress.new @Progress.deserialize(params['Progress']) end end end # 数据同步中的列信息 class Column < TencentCloud::Common::AbstractModel # @param ColumnName: 列名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ColumnName: String # @param NewColumnName: 新列名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NewColumnName: String attr_accessor :ColumnName, :NewColumnName def initialize(columnname=nil, newcolumnname=nil) @ColumnName = columnname @NewColumnName = newcolumnname end def deserialize(params) @ColumnName = params['ColumnName'] @NewColumnName = params['NewColumnName'] end end # 一致性校验摘要信息 class CompareAbstractInfo < TencentCloud::Common::AbstractModel # @param Options: 校验配置参数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Options: :class:`Tencentcloud::Dts.v20211206.models.CompareOptions` # @param Objects: 一致性校验对比对象 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Objects: :class:`Tencentcloud::Dts.v20211206.models.CompareObject` # @param Conclusion: 对比结论: same,different # 注意:此字段可能返回 null,表示取不到有效值。 # @type Conclusion: String # @param Status: 任务状态: success,failed # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param TotalTables: 总的表数量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalTables: Integer # @param CheckedTables: 已校验的表数量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CheckedTables: Integer # @param DifferentTables: 不一致的表数量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DifferentTables: Integer # @param SkippedTables: 跳过校验的表数量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SkippedTables: Integer # @param NearlyTableCount: 预估表总数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NearlyTableCount: Integer # @param DifferentRows: 不一致的数据行数量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DifferentRows: Integer # @param SrcSampleRows: 源库行数,当对比类型为**行数对比**时此项有意义 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcSampleRows: Integer # @param DstSampleRows: 目标库行数,当对比类型为**行数对比**时此项有意义 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstSampleRows: Integer # @param StartedAt: 开始时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartedAt: String # @param FinishedAt: 结束时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type FinishedAt: String attr_accessor :Options, :Objects, :Conclusion, :Status, :TotalTables, :CheckedTables, :DifferentTables, :SkippedTables, :NearlyTableCount, :DifferentRows, :SrcSampleRows, :DstSampleRows, :StartedAt, :FinishedAt def initialize(options=nil, objects=nil, conclusion=nil, status=nil, totaltables=nil, checkedtables=nil, differenttables=nil, skippedtables=nil, nearlytablecount=nil, differentrows=nil, srcsamplerows=nil, dstsamplerows=nil, startedat=nil, finishedat=nil) @Options = options @Objects = objects @Conclusion = conclusion @Status = status @TotalTables = totaltables @CheckedTables = checkedtables @DifferentTables = differenttables @SkippedTables = skippedtables @NearlyTableCount = nearlytablecount @DifferentRows = differentrows @SrcSampleRows = srcsamplerows @DstSampleRows = dstsamplerows @StartedAt = startedat @FinishedAt = finishedat end def deserialize(params) unless params['Options'].nil? @Options = CompareOptions.new @Options.deserialize(params['Options']) end unless params['Objects'].nil? @Objects = CompareObject.new @Objects.deserialize(params['Objects']) end @Conclusion = params['Conclusion'] @Status = params['Status'] @TotalTables = params['TotalTables'] @CheckedTables = params['CheckedTables'] @DifferentTables = params['DifferentTables'] @SkippedTables = params['SkippedTables'] @NearlyTableCount = params['NearlyTableCount'] @DifferentRows = params['DifferentRows'] @SrcSampleRows = params['SrcSampleRows'] @DstSampleRows = params['DstSampleRows'] @StartedAt = params['StartedAt'] @FinishedAt = params['FinishedAt'] end end # 列选项 class CompareColumnItem < TencentCloud::Common::AbstractModel # @param ColumnName: 列名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ColumnName: String attr_accessor :ColumnName def initialize(columnname=nil) @ColumnName = columnname end def deserialize(params) @ColumnName = params['ColumnName'] end end # 一致性校验详细信息 class CompareDetailInfo < TencentCloud::Common::AbstractModel # @param Difference: 数据不一致的表详情 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Difference: :class:`Tencentcloud::Dts.v20211206.models.DifferenceDetail` # @param Skipped: 跳过校验的表详情 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Skipped: :class:`Tencentcloud::Dts.v20211206.models.SkippedDetail` # @param DifferenceAdvancedObjects: 数据库不一致的详情,mongodb业务用到 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DifferenceAdvancedObjects: :class:`Tencentcloud::Dts.v20211206.models.DifferenceAdvancedObjectsDetail` # @param DifferenceData: 数据不一致的详情,mongodb业务用到 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DifferenceData: :class:`Tencentcloud::Dts.v20211206.models.DifferenceDataDetail` # @param DifferenceRow: 数据行不一致的详情,mongodb业务用到 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DifferenceRow: :class:`Tencentcloud::Dts.v20211206.models.DifferenceRowDetail` attr_accessor :Difference, :Skipped, :DifferenceAdvancedObjects, :DifferenceData, :DifferenceRow def initialize(difference=nil, skipped=nil, differenceadvancedobjects=nil, differencedata=nil, differencerow=nil) @Difference = difference @Skipped = skipped @DifferenceAdvancedObjects = differenceadvancedobjects @DifferenceData = differencedata @DifferenceRow = differencerow end def deserialize(params) unless params['Difference'].nil? @Difference = DifferenceDetail.new @Difference.deserialize(params['Difference']) end unless params['Skipped'].nil? @Skipped = SkippedDetail.new @Skipped.deserialize(params['Skipped']) end unless params['DifferenceAdvancedObjects'].nil? @DifferenceAdvancedObjects = DifferenceAdvancedObjectsDetail.new @DifferenceAdvancedObjects.deserialize(params['DifferenceAdvancedObjects']) end unless params['DifferenceData'].nil? @DifferenceData = DifferenceDataDetail.new @DifferenceData.deserialize(params['DifferenceData']) end unless params['DifferenceRow'].nil? @DifferenceRow = DifferenceRowDetail.new @DifferenceRow.deserialize(params['DifferenceRow']) end end end # 一致性对比对象配置 class CompareObject < TencentCloud::Common::AbstractModel # @param ObjectMode: 对象模式 整实例-all,部分对象-partial # 注意:此字段可能返回 null,表示取不到有效值。 # @type ObjectMode: String # @param ObjectItems: 对象列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ObjectItems: Array # @param AdvancedObjects: 高级对象类型,如account(账号),index(索引),shardkey(片键,后面可能会调整),schema(库表结构) # 注意:此字段可能返回 null,表示取不到有效值。 # @type AdvancedObjects: Array attr_accessor :ObjectMode, :ObjectItems, :AdvancedObjects def initialize(objectmode=nil, objectitems=nil, advancedobjects=nil) @ObjectMode = objectmode @ObjectItems = objectitems @AdvancedObjects = advancedobjects end def deserialize(params) @ObjectMode = params['ObjectMode'] unless params['ObjectItems'].nil? @ObjectItems = [] params['ObjectItems'].each do |i| compareobjectitem_tmp = CompareObjectItem.new compareobjectitem_tmp.deserialize(i) @ObjectItems << compareobjectitem_tmp end end @AdvancedObjects = params['AdvancedObjects'] end end # 一致性校验库表对象 class CompareObjectItem < TencentCloud::Common::AbstractModel # @param DbName: 数据库名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DbName: String # @param DbMode: 数据库选择模式: all 为当前对象下的所有对象,partial 为部分对象 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DbMode: String # @param SchemaName: schema名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SchemaName: String # @param TableMode: 表选择模式: all 为当前对象下的所有表对象,partial 为部分表对象 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TableMode: String # @param Tables: 用于一致性校验的表配置,当 TableMode 为 partial 时,需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tables: Array # @param ViewMode: 视图选择模式: all 为当前对象下的所有视图对象,partial 为部分视图对象(一致性校验不校验视图,当前参数未启作用) # 注意:此字段可能返回 null,表示取不到有效值。 # @type ViewMode: String # @param Views: 用于一致性校验的视图配置,当 ViewMode 为 partial 时, 需要填写(一致性校验不校验视图,当前参数未启作用) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Views: Array attr_accessor :DbName, :DbMode, :SchemaName, :TableMode, :Tables, :ViewMode, :Views def initialize(dbname=nil, dbmode=nil, schemaname=nil, tablemode=nil, tables=nil, viewmode=nil, views=nil) @DbName = dbname @DbMode = dbmode @SchemaName = schemaname @TableMode = tablemode @Tables = tables @ViewMode = viewmode @Views = views end def deserialize(params) @DbName = params['DbName'] @DbMode = params['DbMode'] @SchemaName = params['SchemaName'] @TableMode = params['TableMode'] unless params['Tables'].nil? @Tables = [] params['Tables'].each do |i| comparetableitem_tmp = CompareTableItem.new comparetableitem_tmp.deserialize(i) @Tables << comparetableitem_tmp end end @ViewMode = params['ViewMode'] unless params['Views'].nil? @Views = [] params['Views'].each do |i| compareviewitem_tmp = CompareViewItem.new compareviewitem_tmp.deserialize(i) @Views << compareviewitem_tmp end end end end # 一致性校验选项 class CompareOptions < TencentCloud::Common::AbstractModel # @param Method: 对比方式:dataCheck(完整数据对比)、sampleDataCheck(抽样数据对比)、rowsCount(行数对比), 默认为dataCheck # 注意:此字段可能返回 null,表示取不到有效值。 # @type Method: String # @param SampleRate: 抽样比例;范围0,100。默认为100 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SampleRate: Integer # @param ThreadCount: 线程数,取值1-5,默认为1 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ThreadCount: Integer attr_accessor :Method, :SampleRate, :ThreadCount def initialize(method=nil, samplerate=nil, threadcount=nil) @Method = method @SampleRate = samplerate @ThreadCount = threadcount end def deserialize(params) @Method = params['Method'] @SampleRate = params['SampleRate'] @ThreadCount = params['ThreadCount'] end end # 用于一致性校验的表配置 class CompareTableItem < TencentCloud::Common::AbstractModel # @param TableName: 表名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TableName: String # @param ColumnMode: column 模式,all 为全部,partial 表示部分(该参数仅对数据同步任务有效) # 注意:此字段可能返回 null,表示取不到有效值。 # @type ColumnMode: String # @param Columns: 当 ColumnMode 为 partial 时必填(该参数仅对数据同步任务有效) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Columns: Array attr_accessor :TableName, :ColumnMode, :Columns def initialize(tablename=nil, columnmode=nil, columns=nil) @TableName = tablename @ColumnMode = columnmode @Columns = columns end def deserialize(params) @TableName = params['TableName'] @ColumnMode = params['ColumnMode'] unless params['Columns'].nil? @Columns = [] params['Columns'].each do |i| comparecolumnitem_tmp = CompareColumnItem.new comparecolumnitem_tmp.deserialize(i) @Columns << comparecolumnitem_tmp end end end end # 数据一致性校验结果 class CompareTaskInfo < TencentCloud::Common::AbstractModel # @param CompareTaskId: 一致性校验任务Id # 注意:此字段可能返回 null,表示取不到有效值。 # @type CompareTaskId: String # @param Status: 一致性校验结果,包括:unstart(未启动)、running(校验中)、canceled(已终止)、failed(校验任务失败)、inconsistent(不一致)、consistent(一致)、notexist(不存在校验任务) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String attr_accessor :CompareTaskId, :Status def initialize(comparetaskid=nil, status=nil) @CompareTaskId = comparetaskid @Status = status end def deserialize(params) @CompareTaskId = params['CompareTaskId'] @Status = params['Status'] end end # 一致性校验对象信息 class CompareTaskItem < TencentCloud::Common::AbstractModel # @param JobId: 任务id # 注意:此字段可能返回 null,表示取不到有效值。 # @type JobId: String # @param CompareTaskId: 对比任务 Id # 注意:此字段可能返回 null,表示取不到有效值。 # @type CompareTaskId: String # @param TaskName: 对比任务名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TaskName: String # @param Status: 对比任务状态, 可能的值:created - 创建完成;readyRun - 等待运行;running - 运行中;success - 成功;stopping - 结束中;failed - 失败;canceled - 已终止 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param Config: 对比任务配置 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Config: :class:`Tencentcloud::Dts.v20211206.models.CompareObject` # @param CheckProcess: 对比任务校验详情 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CheckProcess: :class:`Tencentcloud::Dts.v20211206.models.ProcessProgress` # @param CompareProcess: 对比任务运行详情 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CompareProcess: :class:`Tencentcloud::Dts.v20211206.models.ProcessProgress` # @param Conclusion: 对比结果, 可能的值:same - 一致;different - 不一致;skipAll - 跳过 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Conclusion: String # @param CreatedAt: 任务创建时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CreatedAt: String # @param StartedAt: 任务启动时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartedAt: String # @param FinishedAt: 对比结束时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type FinishedAt: String # @param Method: 对比类型,dataCheck(完整数据对比)、sampleDataCheck(抽样数据对比)、rowsCount(行数对比) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Method: String # @param Options: 对比配置信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Options: :class:`Tencentcloud::Dts.v20211206.models.CompareOptions` # @param Message: 一致性校验提示信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Message: String attr_accessor :JobId, :CompareTaskId, :TaskName, :Status, :Config, :CheckProcess, :CompareProcess, :Conclusion, :CreatedAt, :StartedAt, :FinishedAt, :Method, :Options, :Message def initialize(jobid=nil, comparetaskid=nil, taskname=nil, status=nil, config=nil, checkprocess=nil, compareprocess=nil, conclusion=nil, createdat=nil, startedat=nil, finishedat=nil, method=nil, options=nil, message=nil) @JobId = jobid @CompareTaskId = comparetaskid @TaskName = taskname @Status = status @Config = config @CheckProcess = checkprocess @CompareProcess = compareprocess @Conclusion = conclusion @CreatedAt = createdat @StartedAt = startedat @FinishedAt = finishedat @Method = method @Options = options @Message = message end def deserialize(params) @JobId = params['JobId'] @CompareTaskId = params['CompareTaskId'] @TaskName = params['TaskName'] @Status = params['Status'] unless params['Config'].nil? @Config = CompareObject.new @Config.deserialize(params['Config']) end unless params['CheckProcess'].nil? @CheckProcess = ProcessProgress.new @CheckProcess.deserialize(params['CheckProcess']) end unless params['CompareProcess'].nil? @CompareProcess = ProcessProgress.new @CompareProcess.deserialize(params['CompareProcess']) end @Conclusion = params['Conclusion'] @CreatedAt = params['CreatedAt'] @StartedAt = params['StartedAt'] @FinishedAt = params['FinishedAt'] @Method = params['Method'] unless params['Options'].nil? @Options = CompareOptions.new @Options.deserialize(params['Options']) end @Message = params['Message'] end end # 用于一致性校验的视图配置 class CompareViewItem < TencentCloud::Common::AbstractModel # @param ViewName: 视图名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ViewName: String attr_accessor :ViewName def initialize(viewname=nil) @ViewName = viewname end def deserialize(params) @ViewName = params['ViewName'] end end # CompleteMigrateJob请求参数结构体 class CompleteMigrateJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # @type JobId: String # @param CompleteMode: 完成任务的方式,仅支持旧版MySQL迁移任务。waitForSync-等待主从差距为0才停止,immediately-立即完成,不会等待主从差距一致。默认为waitForSync # @type CompleteMode: String attr_accessor :JobId, :CompleteMode def initialize(jobid=nil, completemode=nil) @JobId = jobid @CompleteMode = completemode end def deserialize(params) @JobId = params['JobId'] @CompleteMode = params['CompleteMode'] end end # CompleteMigrateJob返回参数结构体 class CompleteMigrateJobResponse < 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 # ConfigureSubscribeJob请求参数结构体 class ConfigureSubscribeJobRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的 ID # @type SubscribeId: String # @param SubscribeMode: 数据订阅的类型,当 DatabaseType 不为 mongodb 时,枚举值为:all-全实例更新;dml-数据更新;ddl-结构更新;dmlAndDdl-数据更新+结构更新。当 DatabaseType 为 mongodb 时,枚举值为 all-全实例更新;database-订阅单库;collection-订阅单集合 # @type SubscribeMode: String # @param AccessType: 源数据库接入类型,如:extranet(公网)、vpncloud(vpn接入)、dcg(专线接入)、ccn(云联网)、cdb(云数据库)、cvm(云服务器自建)、intranet(自研上云)、vpc(私有网络vpc)。注意具体可选值依赖当前链路支持能力 # @type AccessType: String # @param Endpoints: 数据库节点信息 # @type Endpoints: Array # @param KafkaConfig: Kafka配置 # @type KafkaConfig: :class:`Tencentcloud::Dts.v20211206.models.SubscribeKafkaConfig` # @param SubscribeObjects: 订阅的数据库表信息,当 SubscribeMode 不为 all和ddl 时,SubscribeObjects 为必选参数 # @type SubscribeObjects: Array # @param Protocol: 订阅数据格式,如:protobuf、json、avro。注意具体可选值依赖当前链路支持能力,数据格式详情参考官网的消费demo文档 # @type Protocol: String # @param PipelineInfo: mongo选填参数:输出聚合设置。 # @type PipelineInfo: Array # @param ExtraAttr: 为业务添加的额外信息。参数名作key,参数值作value。 # mysql选填参数:ProcessXA-是否处理XA事务,填true处理,不填或填其他值不处理。 # mongo选填参数:SubscribeType-订阅类型,目前只支持changeStream,不填也是默认changeStream。 # 其他业务暂没有可选参数。 # @type ExtraAttr: Array attr_accessor :SubscribeId, :SubscribeMode, :AccessType, :Endpoints, :KafkaConfig, :SubscribeObjects, :Protocol, :PipelineInfo, :ExtraAttr def initialize(subscribeid=nil, subscribemode=nil, accesstype=nil, endpoints=nil, kafkaconfig=nil, subscribeobjects=nil, protocol=nil, pipelineinfo=nil, extraattr=nil) @SubscribeId = subscribeid @SubscribeMode = subscribemode @AccessType = accesstype @Endpoints = endpoints @KafkaConfig = kafkaconfig @SubscribeObjects = subscribeobjects @Protocol = protocol @PipelineInfo = pipelineinfo @ExtraAttr = extraattr end def deserialize(params) @SubscribeId = params['SubscribeId'] @SubscribeMode = params['SubscribeMode'] @AccessType = params['AccessType'] unless params['Endpoints'].nil? @Endpoints = [] params['Endpoints'].each do |i| endpointitem_tmp = EndpointItem.new endpointitem_tmp.deserialize(i) @Endpoints << endpointitem_tmp end end unless params['KafkaConfig'].nil? @KafkaConfig = SubscribeKafkaConfig.new @KafkaConfig.deserialize(params['KafkaConfig']) end unless params['SubscribeObjects'].nil? @SubscribeObjects = [] params['SubscribeObjects'].each do |i| subscribeobject_tmp = SubscribeObject.new subscribeobject_tmp.deserialize(i) @SubscribeObjects << subscribeobject_tmp end end @Protocol = params['Protocol'] unless params['PipelineInfo'].nil? @PipelineInfo = [] params['PipelineInfo'].each do |i| pipelineinfo_tmp = PipelineInfo.new pipelineinfo_tmp.deserialize(i) @PipelineInfo << pipelineinfo_tmp end end unless params['ExtraAttr'].nil? @ExtraAttr = [] params['ExtraAttr'].each do |i| keyvaluepairoption_tmp = KeyValuePairOption.new keyvaluepairoption_tmp.deserialize(i) @ExtraAttr << keyvaluepairoption_tmp end end end end # ConfigureSubscribeJob返回参数结构体 class ConfigureSubscribeJobResponse < 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 # ConfigureSyncJob请求参数结构体 class ConfigureSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步实例id(即标识一个同步作业),形如sync-werwfs23 # @type JobId: String # @param SrcAccessType: 源端接入类型,cdb(云数据库)、cvm(云主机自建)、vpc(私有网络)、extranet(外网)、vpncloud(vpn接入)、dcg(专线接入)、ccn(云联网)、intranet(自研上云),注意具体可选值依赖当前链路 # @type SrcAccessType: String # @param DstAccessType: 目标端接入类型,cdb(云数据库)、cvm(云主机自建)、vpc(私有网络)、extranet(外网)、vpncloud(vpn接入)、dcg(专线接入)、ccn(云联网)、intranet(自研上云)、ckafka(CKafka实例),注意具体可选值依赖当前链路 # @type DstAccessType: String # @param Objects: 同步库表对象信息 # @type Objects: :class:`Tencentcloud::Dts.v20211206.models.Objects` # @param JobName: 同步任务名称 # @type JobName: String # @param JobMode: 枚举值是 liteMode 和 fullMode ,分别对应精简模式或正常模式 # @type JobMode: String # @param RunMode: 运行模式,取值如:Immediate(表示立即运行,默认为此项值)、Timed(表示定时运行) # @type RunMode: String # @param ExpectRunTime: 期待启动时间,当RunMode取值为Timed时,此值必填,形如:"2006-01-02 15:04:05" # @type ExpectRunTime: String # @param SrcConnectType: 源端tdsql连接方式:proxy-通过tdsql proxy主机访问各个set节点,注意只有在自研上云的网络环境下才能通过这种方式连接,SrcInfos中只需要提供proxy主机信息。set-直连set节点,如选择直连set方式,需要正确填写proxy主机信息及所有set节点信息。源端是tdsqlmysql类型必填。 # @type SrcConnectType: String # @param SrcInfo: 源端信息,单机版类型数据库配置使用,且SrcNodeType传single。例如mysql、percona、mariadb等。 # @type SrcInfo: :class:`Tencentcloud::Dts.v20211206.models.Endpoint` # @param SrcInfos: 源端信息,分布式类型数据库配置使用,且SrcNodeType传cluster。例如分布式数据库tdsqlmysql等。 # @type SrcInfos: :class:`Tencentcloud::Dts.v20211206.models.SyncDBEndpointInfos` # @param SrcNodeType: 枚举值:cluster、single。源库为单节点数据库使用single,多节点使用cluster # @type SrcNodeType: String # @param DstInfo: 目标端信息,单机版类型数据库配置使用,且SrcNodeType传single。例如mysql、percona、mariadb等。 # @type DstInfo: :class:`Tencentcloud::Dts.v20211206.models.Endpoint` # @param DstInfos: 目标端信息,分布式类型数据库配置使用,且SrcNodeType传cluster。例如分布式数据库tdsqlmysql等。 # @type DstInfos: :class:`Tencentcloud::Dts.v20211206.models.SyncDBEndpointInfos` # @param DstNodeType: 枚举值:cluster、single。目标库为单节点数据库使用single,多节点使用cluster # @type DstNodeType: String # @param Options: 同步任务选项;该字段下的RateLimitOption暂时无法生效、如果需要修改限速、可通过ModifySyncRateLimit接口完成限速 # @type Options: :class:`Tencentcloud::Dts.v20211206.models.Options` # @param AutoRetryTimeRangeMinutes: 自动重试的时间段、可设置5至720分钟、0表示不重试 # @type AutoRetryTimeRangeMinutes: Integer attr_accessor :JobId, :SrcAccessType, :DstAccessType, :Objects, :JobName, :JobMode, :RunMode, :ExpectRunTime, :SrcConnectType, :SrcInfo, :SrcInfos, :SrcNodeType, :DstInfo, :DstInfos, :DstNodeType, :Options, :AutoRetryTimeRangeMinutes def initialize(jobid=nil, srcaccesstype=nil, dstaccesstype=nil, objects=nil, jobname=nil, jobmode=nil, runmode=nil, expectruntime=nil, srcconnecttype=nil, srcinfo=nil, srcinfos=nil, srcnodetype=nil, dstinfo=nil, dstinfos=nil, dstnodetype=nil, options=nil, autoretrytimerangeminutes=nil) @JobId = jobid @SrcAccessType = srcaccesstype @DstAccessType = dstaccesstype @Objects = objects @JobName = jobname @JobMode = jobmode @RunMode = runmode @ExpectRunTime = expectruntime @SrcConnectType = srcconnecttype @SrcInfo = srcinfo @SrcInfos = srcinfos @SrcNodeType = srcnodetype @DstInfo = dstinfo @DstInfos = dstinfos @DstNodeType = dstnodetype @Options = options @AutoRetryTimeRangeMinutes = autoretrytimerangeminutes end def deserialize(params) @JobId = params['JobId'] @SrcAccessType = params['SrcAccessType'] @DstAccessType = params['DstAccessType'] unless params['Objects'].nil? @Objects = Objects.new @Objects.deserialize(params['Objects']) end @JobName = params['JobName'] @JobMode = params['JobMode'] @RunMode = params['RunMode'] @ExpectRunTime = params['ExpectRunTime'] @SrcConnectType = params['SrcConnectType'] unless params['SrcInfo'].nil? @SrcInfo = Endpoint.new @SrcInfo.deserialize(params['SrcInfo']) end unless params['SrcInfos'].nil? @SrcInfos = SyncDBEndpointInfos.new @SrcInfos.deserialize(params['SrcInfos']) end @SrcNodeType = params['SrcNodeType'] unless params['DstInfo'].nil? @DstInfo = Endpoint.new @DstInfo.deserialize(params['DstInfo']) end unless params['DstInfos'].nil? @DstInfos = SyncDBEndpointInfos.new @DstInfos.deserialize(params['DstInfos']) end @DstNodeType = params['DstNodeType'] unless params['Options'].nil? @Options = Options.new @Options.deserialize(params['Options']) end @AutoRetryTimeRangeMinutes = params['AutoRetryTimeRangeMinutes'] end end # ConfigureSyncJob返回参数结构体 class ConfigureSyncJobResponse < 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 ConflictHandleOption < TencentCloud::Common::AbstractModel # @param ConditionColumn: 条件覆盖的列 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConditionColumn: String # @param ConditionOperator: 条件覆盖操作 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConditionOperator: String # @param ConditionOrderInSrcAndDst: 条件覆盖优先级处理 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConditionOrderInSrcAndDst: String attr_accessor :ConditionColumn, :ConditionOperator, :ConditionOrderInSrcAndDst def initialize(conditioncolumn=nil, conditionoperator=nil, conditionorderinsrcanddst=nil) @ConditionColumn = conditioncolumn @ConditionOperator = conditionoperator @ConditionOrderInSrcAndDst = conditionorderinsrcanddst end def deserialize(params) @ConditionColumn = params['ConditionColumn'] @ConditionOperator = params['ConditionOperator'] @ConditionOrderInSrcAndDst = params['ConditionOrderInSrcAndDst'] end end # 数据一致性校验选项, 默认为不开启一致性校验 class ConsistencyOption < TencentCloud::Common::AbstractModel # @param Mode: 一致性检测类型: full(全量检测迁移对象)、noCheck(不检测)、notConfigured(未配置) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Mode: String attr_accessor :Mode def initialize(mode=nil) @Mode = mode end def deserialize(params) @Mode = params['Mode'] end end # ContinueMigrateJob请求参数结构体 class ContinueMigrateJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # ContinueMigrateJob返回参数结构体 class ContinueMigrateJobResponse < 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 # ContinueSyncJob请求参数结构体 class ContinueSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # ContinueSyncJob返回参数结构体 class ContinueSyncJobResponse < 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 # CreateCheckSyncJob请求参数结构体 class CreateCheckSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # CreateCheckSyncJob返回参数结构体 class CreateCheckSyncJobResponse < 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 # CreateCompareTask请求参数结构体 class CreateCompareTaskRequest < TencentCloud::Common::AbstractModel # @param JobId: 任务 Id # @type JobId: String # @param TaskName: 数据对比任务名称,若为空则默认给CompareTaskId相同值 # @type TaskName: String # @param ObjectMode: 数据对比对象模式,sameAsMigrate(全部迁移对象, 默认为此项配置),custom(自定义模式) # @type ObjectMode: String # @param Objects: 数据对比对象,当ObjectMode为custom时,此项需要填写。 # @type Objects: :class:`Tencentcloud::Dts.v20211206.models.CompareObject` # @param Options: 一致性校验选项 # @type Options: :class:`Tencentcloud::Dts.v20211206.models.CompareOptions` attr_accessor :JobId, :TaskName, :ObjectMode, :Objects, :Options def initialize(jobid=nil, taskname=nil, objectmode=nil, objects=nil, options=nil) @JobId = jobid @TaskName = taskname @ObjectMode = objectmode @Objects = objects @Options = options end def deserialize(params) @JobId = params['JobId'] @TaskName = params['TaskName'] @ObjectMode = params['ObjectMode'] unless params['Objects'].nil? @Objects = CompareObject.new @Objects.deserialize(params['Objects']) end unless params['Options'].nil? @Options = CompareOptions.new @Options.deserialize(params['Options']) end end end # CreateCompareTask返回参数结构体 class CreateCompareTaskResponse < TencentCloud::Common::AbstractModel # @param CompareTaskId: 数据对比任务 ID,形如:dts-8yv4w2i1-cmp-37skmii9 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CompareTaskId: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :CompareTaskId, :RequestId def initialize(comparetaskid=nil, requestid=nil) @CompareTaskId = comparetaskid @RequestId = requestid end def deserialize(params) @CompareTaskId = params['CompareTaskId'] @RequestId = params['RequestId'] end end # CreateConsumerGroup请求参数结构体 class CreateConsumerGroupRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 订阅实例id # @type SubscribeId: String # @param ConsumerGroupName: 消费组名称,以数字、字母(大小写)或者_ - .开头,以数字、字母(大小写)结尾。实际生成的消费组全称形如:consumer-grp-#{SubscribeId}-#{ConsumerGroupName} # @type ConsumerGroupName: String # @param AccountName: 账号名称。以数字、字母(大小写)或者_ - .开头,以数字、字母(大小写)结尾。实际生成的账户全称形如:account-#{SubscribeId}-#{AccountName} # @type AccountName: String # @param Password: 消费组密码,长度必须大于3 # @type Password: String # @param Description: 消费组备注 # @type Description: String attr_accessor :SubscribeId, :ConsumerGroupName, :AccountName, :Password, :Description def initialize(subscribeid=nil, consumergroupname=nil, accountname=nil, password=nil, description=nil) @SubscribeId = subscribeid @ConsumerGroupName = consumergroupname @AccountName = accountname @Password = password @Description = description end def deserialize(params) @SubscribeId = params['SubscribeId'] @ConsumerGroupName = params['ConsumerGroupName'] @AccountName = params['AccountName'] @Password = params['Password'] @Description = params['Description'] end end # CreateConsumerGroup返回参数结构体 class CreateConsumerGroupResponse < 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 # CreateMigrateCheckJob请求参数结构体 class CreateMigrateCheckJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # CreateMigrateCheckJob返回参数结构体 class CreateMigrateCheckJobResponse < 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 # CreateMigrationService请求参数结构体 class CreateMigrationServiceRequest < TencentCloud::Common::AbstractModel # @param SrcDatabaseType: 源实例数据库类型,如mysql,redis,percona,mongodb,postgresql,sqlserver,mariadb,cynosdbmysql # @type SrcDatabaseType: String # @param DstDatabaseType: 目标实例数据库类型,如mysql,redis,percona,mongodb,postgresql,sqlserver,mariadb,cynosdbmysql # @type DstDatabaseType: String # @param SrcRegion: 源实例地域,如:ap-guangzhou # @type SrcRegion: String # @param DstRegion: 目标实例地域,如:ap-guangzhou。注意,目标地域必须和API请求地域保持一致。 # @type DstRegion: String # @param InstanceClass: 实例规格,包括:small、medium、large、xlarge、2xlarge # @type InstanceClass: String # @param Count: 购买数量,范围为[1,15],默认为1 # @type Count: Integer # @param JobName: 迁移服务名称,最大长度128 # @type JobName: String # @param Tags: 标签信息 # @type Tags: Array attr_accessor :SrcDatabaseType, :DstDatabaseType, :SrcRegion, :DstRegion, :InstanceClass, :Count, :JobName, :Tags def initialize(srcdatabasetype=nil, dstdatabasetype=nil, srcregion=nil, dstregion=nil, instanceclass=nil, count=nil, jobname=nil, tags=nil) @SrcDatabaseType = srcdatabasetype @DstDatabaseType = dstdatabasetype @SrcRegion = srcregion @DstRegion = dstregion @InstanceClass = instanceclass @Count = count @JobName = jobname @Tags = tags end def deserialize(params) @SrcDatabaseType = params['SrcDatabaseType'] @DstDatabaseType = params['DstDatabaseType'] @SrcRegion = params['SrcRegion'] @DstRegion = params['DstRegion'] @InstanceClass = params['InstanceClass'] @Count = params['Count'] @JobName = params['JobName'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| tagitem_tmp = TagItem.new tagitem_tmp.deserialize(i) @Tags << tagitem_tmp end end end end # CreateMigrationService返回参数结构体 class CreateMigrationServiceResponse < TencentCloud::Common::AbstractModel # @param JobIds: 下单成功随机生成的迁移任务id列表,形如:dts-c1f6rs21 # 注意:此字段可能返回 null,表示取不到有效值。 # @type JobIds: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :JobIds, :RequestId def initialize(jobids=nil, requestid=nil) @JobIds = jobids @RequestId = requestid end def deserialize(params) @JobIds = params['JobIds'] @RequestId = params['RequestId'] end end # CreateModifyCheckSyncJob请求参数结构体 class CreateModifyCheckSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # CreateModifyCheckSyncJob返回参数结构体 class CreateModifyCheckSyncJobResponse < 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 # CreateSubscribeCheckJob请求参数结构体 class CreateSubscribeCheckJobRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的 ID # @type SubscribeId: String attr_accessor :SubscribeId def initialize(subscribeid=nil) @SubscribeId = subscribeid end def deserialize(params) @SubscribeId = params['SubscribeId'] end end # CreateSubscribeCheckJob返回参数结构体 class CreateSubscribeCheckJobResponse < 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 # CreateSubscribe请求参数结构体 class CreateSubscribeRequest < TencentCloud::Common::AbstractModel # @param Product: 订阅的数据库类型,目前支持 cynosdbmysql(tdsql-c mysql版),mariadb,mongodb,mysql,percona,tdpg(tdsql postgresql版),tdsqlpercona(tdsql mysql版) # @type Product: String # @param PayType: 付费方式,枚举值:0-包年包月,1-按量计费 # @type PayType: Integer # @param Duration: 购买时长。当 payType 为包年包月时,该项需要填,单位为月,最小值为 1,最大值为 120。不填默认1 # @type Duration: Integer # @param AutoRenew: 是否自动续费。当 payType 为包年包月时,该项需要填。枚举值:0-不自动续费,1-自动续费。默认不自动续费。按量计费设置该标识无效。 # @type AutoRenew: Integer # @param Count: 购买数量,默认为1,最大为10 # @type Count: Integer # @param Tags: 实例资源标签 # @type Tags: Array # @param Name: 任务名,自定义 # @type Name: String attr_accessor :Product, :PayType, :Duration, :AutoRenew, :Count, :Tags, :Name def initialize(product=nil, paytype=nil, duration=nil, autorenew=nil, count=nil, tags=nil, name=nil) @Product = product @PayType = paytype @Duration = duration @AutoRenew = autorenew @Count = count @Tags = tags @Name = name end def deserialize(params) @Product = params['Product'] @PayType = params['PayType'] @Duration = params['Duration'] @AutoRenew = params['AutoRenew'] @Count = params['Count'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| tagitem_tmp = TagItem.new tagitem_tmp.deserialize(i) @Tags << tagitem_tmp end end @Name = params['Name'] end end # CreateSubscribe返回参数结构体 class CreateSubscribeResponse < TencentCloud::Common::AbstractModel # @param SubscribeIds: 数据订阅实例的ID数组 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SubscribeIds: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :SubscribeIds, :RequestId def initialize(subscribeids=nil, requestid=nil) @SubscribeIds = subscribeids @RequestId = requestid end def deserialize(params) @SubscribeIds = params['SubscribeIds'] @RequestId = params['RequestId'] end end # CreateSyncJob请求参数结构体 class CreateSyncJobRequest < TencentCloud::Common::AbstractModel # @param PayMode: 付款类型, 如:PrePay(表示包年包月)、PostPay(表示按时按量) # @type PayMode: String # @param SrcDatabaseType: 源端数据库类型,如mysql,mariadb,percona,postgresql,cynosdbmysql(表示TDSQL-C MySQL),tdpg(TDSQL PostgreSQL版),tdsqlmysql,tdstore(表示TDSQL TDStore版)等。 # @type SrcDatabaseType: String # @param SrcRegion: 源端数据库所在地域,如ap-guangzhou # @type SrcRegion: String # @param DstDatabaseType: 目标端数据库类型,如mysql,mariadb,percona,cynosdbmysql(表示TDSQL-C MySQL),tdpg(TDSQL PostgreSQL版),tdsqlmysql,kafka,tdstore(表示TDSQL TDStore版)等。 # @type DstDatabaseType: String # @param DstRegion: 目标端数据库所在地域,如ap-guangzhou # @type DstRegion: String # @param Specification: 同步任务规格,Standard:标准版 # @type Specification: String # @param TimeSpan: 购买时长(单位:月),当PayMode值为PrePay则此项配置有意义,默认为1月,取值范围为[1,100] # @type TimeSpan: Integer # @param Tags: 标签信息 # @type Tags: Array # @param Count: 一次购买的同步任务数量,取值范围为[1, 10],默认为1 # @type Count: Integer # @param AutoRenew: 自动续费标识,当PayMode值为PrePay则此项配置有意义,取值为:1(表示自动续费)、0(不自动续费,默认为此值) # @type AutoRenew: Integer # @param InstanceClass: 同步链路规格,如micro,small,medium,large,默认为medium # @type InstanceClass: String # @param JobName: 同步任务名称 # @type JobName: String # @param ExistedJobId: 创建类似任务的现有任务Id # @type ExistedJobId: String attr_accessor :PayMode, :SrcDatabaseType, :SrcRegion, :DstDatabaseType, :DstRegion, :Specification, :TimeSpan, :Tags, :Count, :AutoRenew, :InstanceClass, :JobName, :ExistedJobId def initialize(paymode=nil, srcdatabasetype=nil, srcregion=nil, dstdatabasetype=nil, dstregion=nil, specification=nil, timespan=nil, tags=nil, count=nil, autorenew=nil, instanceclass=nil, jobname=nil, existedjobid=nil) @PayMode = paymode @SrcDatabaseType = srcdatabasetype @SrcRegion = srcregion @DstDatabaseType = dstdatabasetype @DstRegion = dstregion @Specification = specification @TimeSpan = timespan @Tags = tags @Count = count @AutoRenew = autorenew @InstanceClass = instanceclass @JobName = jobname @ExistedJobId = existedjobid end def deserialize(params) @PayMode = params['PayMode'] @SrcDatabaseType = params['SrcDatabaseType'] @SrcRegion = params['SrcRegion'] @DstDatabaseType = params['DstDatabaseType'] @DstRegion = params['DstRegion'] @Specification = params['Specification'] @TimeSpan = params['TimeSpan'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| tagitem_tmp = TagItem.new tagitem_tmp.deserialize(i) @Tags << tagitem_tmp end end @Count = params['Count'] @AutoRenew = params['AutoRenew'] @InstanceClass = params['InstanceClass'] @JobName = params['JobName'] @ExistedJobId = params['ExistedJobId'] end end # CreateSyncJob返回参数结构体 class CreateSyncJobResponse < TencentCloud::Common::AbstractModel # @param JobIds: 同步任务ids # @type JobIds: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :JobIds, :RequestId def initialize(jobids=nil, requestid=nil) @JobIds = jobids @RequestId = requestid end def deserialize(params) @JobIds = params['JobIds'] @RequestId = params['RequestId'] end end # 实例信息 class DBEndpointInfo < TencentCloud::Common::AbstractModel # @param Region: 实例所在地域 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Region: String # @param AccessType: 实例网络接入类型,如:extranet(外网)、ipv6(公网ipv6)、cvm(云主机自建)、dcg(专线接入)、vpncloud(vpn接入的实例)、cdb(云数据库)、ccn(云联网)、intranet(自研上云)、vpc(私有网络)等,注意具体可选值依赖当前链路 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AccessType: String # @param DatabaseType: 实例数据库类型,如:mysql,redis,mongodb,postgresql,mariadb,percona 等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DatabaseType: String # @param NodeType: 节点类型,为空或者simple表示普通节点、cluster表示集群节点;对于mongo业务,取值为replicaset(mongodb副本集)、standalone(mongodb单节点)、cluster(mongodb集群);对于redis实例,为空或simple(单节点)、cluster(集群)、cluster-cache(cache集群)、cluster-proxy(代理集群) # 注意:此字段可能返回 null,表示取不到有效值。 # @type NodeType: String # @param Info: 数据库信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Info: Array # @param Supplier: 实例服务提供商,如:"aliyun","others" # 注意:此字段可能返回 null,表示取不到有效值。 # @type Supplier: String # @param ExtraAttr: MongoDB可定义如下的参数: ['AuthDatabase':'admin', # 'AuthFlag': "1", 'AuthMechanism':"SCRAM-SHA-1"] # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExtraAttr: Array # @param DatabaseNetEnv: 数据库所属网络环境,AccessType为云联网(ccn)时必填, UserIDC表示用户IDC、TencentVPC表示腾讯云VPC; # 注意:此字段可能返回 null,表示取不到有效值。 # @type DatabaseNetEnv: String # @param ConnectType: tdsql连接方式:proxy-通过tdsql proxy主机访问各个set节点,注意只有在自研上云的网络环境下才能通过这种方式连接,Info中只需要提供proxy主机信息。set-直连set节点,如选择直连set方式,Info中需要正确填写proxy主机信息及所有set节点信息。源端是tdsqlmysql类型必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConnectType: String attr_accessor :Region, :AccessType, :DatabaseType, :NodeType, :Info, :Supplier, :ExtraAttr, :DatabaseNetEnv, :ConnectType def initialize(region=nil, accesstype=nil, databasetype=nil, nodetype=nil, info=nil, supplier=nil, extraattr=nil, databasenetenv=nil, connecttype=nil) @Region = region @AccessType = accesstype @DatabaseType = databasetype @NodeType = nodetype @Info = info @Supplier = supplier @ExtraAttr = extraattr @DatabaseNetEnv = databasenetenv @ConnectType = connecttype end def deserialize(params) @Region = params['Region'] @AccessType = params['AccessType'] @DatabaseType = params['DatabaseType'] @NodeType = params['NodeType'] unless params['Info'].nil? @Info = [] params['Info'].each do |i| dbinfo_tmp = DBInfo.new dbinfo_tmp.deserialize(i) @Info << dbinfo_tmp end end @Supplier = params['Supplier'] unless params['ExtraAttr'].nil? @ExtraAttr = [] params['ExtraAttr'].each do |i| keyvaluepairoption_tmp = KeyValuePairOption.new keyvaluepairoption_tmp.deserialize(i) @ExtraAttr << keyvaluepairoption_tmp end end @DatabaseNetEnv = params['DatabaseNetEnv'] @ConnectType = params['ConnectType'] end end # 数据库信息 class DBInfo < TencentCloud::Common::AbstractModel # @param Role: 表示节点角色,针对分布式数据库,如mongodb中的mongos节点。tdsqlmysql的可选项:proxy表示节点类型为主机,set表示节点类型为节点。proxy类型必须填在数组第一项。tdsqlmysql类型的源/目标配置必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Role: String # @param DbKernel: 内核版本,针对mariadb的不同内核版本等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DbKernel: String # @param Host: 实例的IP地址,对于公网、专线、VPN、云联网、自研上云、VPC等接入方式此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Host: String # @param Port: 实例的端口,对于公网、云主机自建、专线、VPN、云联网、自研上云、VPC等接入方式此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Port: Integer # @param User: 实例的用户名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type User: String # @param Password: 实例的密码 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Password: String # @param CvmInstanceId: CVM实例短ID,格式如:ins-olgl39y8;与云服务器控制台页面显示的实例ID相同;如果接入类型为云主机自建的方式,此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CvmInstanceId: String # @param UniqVpnGwId: VPN网关ID,格式如:vpngw-9ghexg7q;如果接入类型为vpncloud的方式,此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type UniqVpnGwId: String # @param UniqDcgId: 专线网关ID,格式如:dcg-0rxtqqxb;如果接入类型为专线接入的方式,此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type UniqDcgId: String # @param InstanceId: 数据库实例ID,格式如:cdb-powiqx8q;如果接入类型为云数据库的方式,此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceId: String # @param CcnGwId: 云联网ID,如:ccn-afp6kltc 注意:此字段可能返回 null,表示取不到有效值。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CcnGwId: String # @param VpcId: 私有网络ID,格式如:vpc-92jblxto;如果接入类型为vpc、vpncloud、ccn、dcg的方式,此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type VpcId: String # @param SubnetId: 私有网络下的子网ID,格式如:subnet-3paxmkdz;如果接入类型为vpc、vpncloud、ccn、dcg的方式,此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SubnetId: String # @param EngineVersion: 数据库版本,当实例为RDS实例时才有效,格式如:5.6或者5.7,默认为5.6 # 注意:此字段可能返回 null,表示取不到有效值。 # @type EngineVersion: String # @param Account: 实例所属账号 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Account: String # @param AccountRole: 跨账号迁移时的角色,只允许[a-zA-Z0-9\-\_]+ # 注意:此字段可能返回 null,表示取不到有效值。 # @type AccountRole: String # @param AccountMode: 资源所属账号 为空或self(表示本账号内资源)、other(表示其他账户资源) # 注意:此字段可能返回 null,表示取不到有效值。 # @type AccountMode: String # @param TmpSecretId: 临时密钥Id,可通过申请扮演角色临时访问凭证获取临时密钥https://cloud.tencent.com/document/product/1312/48197,其中角色资源RoleArn的定义可参考DTS跨账号迁移文档(https://cloud.tencent.com/document/product/571/54117)第4节中关于角色的定义。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TmpSecretId: String # @param TmpSecretKey: 临时密钥Id,可通过申请扮演角色临时访问凭证获取临时密钥https://cloud.tencent.com/document/product/1312/48197,其中角色资源RoleArn的定义可参考DTS跨账号迁移文档(https://cloud.tencent.com/document/product/571/54117)第4节中关于角色的定义。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TmpSecretKey: String # @param TmpToken: 临时密钥Id,可通过申请扮演角色临时访问凭证获取临时密钥https://cloud.tencent.com/document/product/1312/48197,其中角色资源RoleArn的定义可参考DTS跨账号迁移文档(https://cloud.tencent.com/document/product/571/54117)第4节中关于角色的定义。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TmpToken: String # @param SetId: tdsql的分片id。如节点类型为set必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SetId: String attr_accessor :Role, :DbKernel, :Host, :Port, :User, :Password, :CvmInstanceId, :UniqVpnGwId, :UniqDcgId, :InstanceId, :CcnGwId, :VpcId, :SubnetId, :EngineVersion, :Account, :AccountRole, :AccountMode, :TmpSecretId, :TmpSecretKey, :TmpToken, :SetId def initialize(role=nil, dbkernel=nil, host=nil, port=nil, user=nil, password=nil, cvminstanceid=nil, uniqvpngwid=nil, uniqdcgid=nil, instanceid=nil, ccngwid=nil, vpcid=nil, subnetid=nil, engineversion=nil, account=nil, accountrole=nil, accountmode=nil, tmpsecretid=nil, tmpsecretkey=nil, tmptoken=nil, setid=nil) @Role = role @DbKernel = dbkernel @Host = host @Port = port @User = user @Password = password @CvmInstanceId = cvminstanceid @UniqVpnGwId = uniqvpngwid @UniqDcgId = uniqdcgid @InstanceId = instanceid @CcnGwId = ccngwid @VpcId = vpcid @SubnetId = subnetid @EngineVersion = engineversion @Account = account @AccountRole = accountrole @AccountMode = accountmode @TmpSecretId = tmpsecretid @TmpSecretKey = tmpsecretkey @TmpToken = tmptoken @SetId = setid end def deserialize(params) @Role = params['Role'] @DbKernel = params['DbKernel'] @Host = params['Host'] @Port = params['Port'] @User = params['User'] @Password = params['Password'] @CvmInstanceId = params['CvmInstanceId'] @UniqVpnGwId = params['UniqVpnGwId'] @UniqDcgId = params['UniqDcgId'] @InstanceId = params['InstanceId'] @CcnGwId = params['CcnGwId'] @VpcId = params['VpcId'] @SubnetId = params['SubnetId'] @EngineVersion = params['EngineVersion'] @Account = params['Account'] @AccountRole = params['AccountRole'] @AccountMode = params['AccountMode'] @TmpSecretId = params['TmpSecretId'] @TmpSecretKey = params['TmpSecretKey'] @TmpToken = params['TmpToken'] @SetId = params['SetId'] end end # 迁移对象信息,在配置库表视图等对象信息时大小写敏感 class DBItem < TencentCloud::Common::AbstractModel # @param DbName: 需要迁移或同步的库名,当ObjectMode为partial时,此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DbName: String # @param NewDbName: 迁移或同步后的库名,默认与源库相同 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NewDbName: String # @param SchemaName: 迁移或同步的 schema # 注意:此字段可能返回 null,表示取不到有效值。 # @type SchemaName: String # @param NewSchemaName: 迁移或同步后的 schema name # 注意:此字段可能返回 null,表示取不到有效值。 # @type NewSchemaName: String # @param DBMode: DB选择模式: all(为当前对象下的所有对象),partial(部分对象),当ObjectMode为partial时,此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DBMode: String # @param SchemaMode: schema选择模式: all(为当前对象下的所有对象),partial(部分对象) # 注意:此字段可能返回 null,表示取不到有效值。 # @type SchemaMode: String # @param TableMode: 表选择模式: all(为当前对象下的所有对象),partial(部分对象),当DBMode为partial时此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TableMode: String # @param Tables: 表图对象集合,当 TableMode 为 partial 时,此项需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tables: Array # @param ViewMode: 视图选择模式: all 为当前对象下的所有视图对象,partial 为部分视图对象 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ViewMode: String # @param Views: 视图对象集合,当 ViewMode 为 partial 时, 此项需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Views: Array # @param RoleMode: postgresql独有参数,角色选择模式: all 为当前对象下的所有角色对象,partial 为部分角色对象 # 注意:此字段可能返回 null,表示取不到有效值。 # @type RoleMode: String # @param Roles: postgresql独有参数,当 RoleMode 为 partial 时, 此项需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Roles: Array # @param FunctionMode: 选择要同步的模式,partial为部分,all为整选 # 注意:此字段可能返回 null,表示取不到有效值。 # @type FunctionMode: String # @param TriggerMode: 选择要同步的模式,partial为部分,all为整选 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TriggerMode: String # @param EventMode: 选择要同步的模式,partial为部分,all为整选 # 注意:此字段可能返回 null,表示取不到有效值。 # @type EventMode: String # @param ProcedureMode: 选择要同步的模式,partial为部分,all为整选 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ProcedureMode: String # @param Functions: FunctionMode取值为partial时需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Functions: Array # @param Procedures: ProcedureMode取值为partial时需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Procedures: Array # @param Events: EventMode取值为partial时需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Events: Array # @param Triggers: TriggerMode取值为partial时需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Triggers: Array attr_accessor :DbName, :NewDbName, :SchemaName, :NewSchemaName, :DBMode, :SchemaMode, :TableMode, :Tables, :ViewMode, :Views, :RoleMode, :Roles, :FunctionMode, :TriggerMode, :EventMode, :ProcedureMode, :Functions, :Procedures, :Events, :Triggers def initialize(dbname=nil, newdbname=nil, schemaname=nil, newschemaname=nil, dbmode=nil, schemamode=nil, tablemode=nil, tables=nil, viewmode=nil, views=nil, rolemode=nil, roles=nil, functionmode=nil, triggermode=nil, eventmode=nil, proceduremode=nil, functions=nil, procedures=nil, events=nil, triggers=nil) @DbName = dbname @NewDbName = newdbname @SchemaName = schemaname @NewSchemaName = newschemaname @DBMode = dbmode @SchemaMode = schemamode @TableMode = tablemode @Tables = tables @ViewMode = viewmode @Views = views @RoleMode = rolemode @Roles = roles @FunctionMode = functionmode @TriggerMode = triggermode @EventMode = eventmode @ProcedureMode = proceduremode @Functions = functions @Procedures = procedures @Events = events @Triggers = triggers end def deserialize(params) @DbName = params['DbName'] @NewDbName = params['NewDbName'] @SchemaName = params['SchemaName'] @NewSchemaName = params['NewSchemaName'] @DBMode = params['DBMode'] @SchemaMode = params['SchemaMode'] @TableMode = params['TableMode'] unless params['Tables'].nil? @Tables = [] params['Tables'].each do |i| tableitem_tmp = TableItem.new tableitem_tmp.deserialize(i) @Tables << tableitem_tmp end end @ViewMode = params['ViewMode'] unless params['Views'].nil? @Views = [] params['Views'].each do |i| viewitem_tmp = ViewItem.new viewitem_tmp.deserialize(i) @Views << viewitem_tmp end end @RoleMode = params['RoleMode'] unless params['Roles'].nil? @Roles = [] params['Roles'].each do |i| roleitem_tmp = RoleItem.new roleitem_tmp.deserialize(i) @Roles << roleitem_tmp end end @FunctionMode = params['FunctionMode'] @TriggerMode = params['TriggerMode'] @EventMode = params['EventMode'] @ProcedureMode = params['ProcedureMode'] @Functions = params['Functions'] @Procedures = params['Procedures'] @Events = params['Events'] @Triggers = params['Triggers'] end end # 需要同步的库表对象 class Database < TencentCloud::Common::AbstractModel # @param DbName: 需要迁移或同步的库名,当ObjectMode为Partial时,此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DbName: String # @param NewDbName: 迁移或同步后的库名,默认与源库相同 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NewDbName: String # @param DbMode: DB选择模式: All(为当前对象下的所有对象),Partial(部分对象),当Mode为Partial时,此项必填。注意,高级对象的同步不依赖此值,如果整库同步此处应该为All。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DbMode: String # @param SchemaName: 迁移或同步的 schema # 注意:此字段可能返回 null,表示取不到有效值。 # @type SchemaName: String # @param NewSchemaName: 迁移或同步后的 schema name # 注意:此字段可能返回 null,表示取不到有效值。 # @type NewSchemaName: String # @param TableMode: 表选择模式: All(为当前对象下的所有对象),Partial(部分对象),当DBMode为Partial时此项必填,如果整库同步此处应该为All。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TableMode: String # @param Tables: 表图对象集合,当 TableMode 为 Partial 时,此项需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tables: Array # @param ViewMode: 视图选择模式: All 为当前对象下的所有视图对象,Partial 为部分视图对象,如果整库同步此处应该为All。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ViewMode: String # @param Views: 视图对象集合,当 ViewMode 为 Partial 时, 此项需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Views: Array # @param FunctionMode: 选择要同步的模式,Partial为部分,All为整选,如果整库同步此处应该为All。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type FunctionMode: String # @param Functions: FunctionMode取值为Partial时需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Functions: Array # @param ProcedureMode: 选择要同步的模式,Partial为部分,All为整选,如果整库同步此处应该为All。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ProcedureMode: String # @param Procedures: ProcedureMode取值为Partial时需要填写 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Procedures: Array # @param TriggerMode: 触发器迁移模式,All(为当前对象下的所有对象),Partial(部分对象),如果整库同步此处应该为All。数据同步暂不支持此高级对象。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TriggerMode: String # @param Triggers: 当TriggerMode为partial,指定要迁移的触发器名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Triggers: Array # @param EventMode: 事件迁移模式,All(为当前对象下的所有对象),Partial(部分对象),如果整库同步此处应该为All。数据同步暂不支持此高级对象。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type EventMode: String # @param Events: 当EventMode为partial,指定要迁移的事件名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Events: Array attr_accessor :DbName, :NewDbName, :DbMode, :SchemaName, :NewSchemaName, :TableMode, :Tables, :ViewMode, :Views, :FunctionMode, :Functions, :ProcedureMode, :Procedures, :TriggerMode, :Triggers, :EventMode, :Events def initialize(dbname=nil, newdbname=nil, dbmode=nil, schemaname=nil, newschemaname=nil, tablemode=nil, tables=nil, viewmode=nil, views=nil, functionmode=nil, functions=nil, proceduremode=nil, procedures=nil, triggermode=nil, triggers=nil, eventmode=nil, events=nil) @DbName = dbname @NewDbName = newdbname @DbMode = dbmode @SchemaName = schemaname @NewSchemaName = newschemaname @TableMode = tablemode @Tables = tables @ViewMode = viewmode @Views = views @FunctionMode = functionmode @Functions = functions @ProcedureMode = proceduremode @Procedures = procedures @TriggerMode = triggermode @Triggers = triggers @EventMode = eventmode @Events = events end def deserialize(params) @DbName = params['DbName'] @NewDbName = params['NewDbName'] @DbMode = params['DbMode'] @SchemaName = params['SchemaName'] @NewSchemaName = params['NewSchemaName'] @TableMode = params['TableMode'] unless params['Tables'].nil? @Tables = [] params['Tables'].each do |i| table_tmp = Table.new table_tmp.deserialize(i) @Tables << table_tmp end end @ViewMode = params['ViewMode'] unless params['Views'].nil? @Views = [] params['Views'].each do |i| view_tmp = View.new view_tmp.deserialize(i) @Views << view_tmp end end @FunctionMode = params['FunctionMode'] @Functions = params['Functions'] @ProcedureMode = params['ProcedureMode'] @Procedures = params['Procedures'] @TriggerMode = params['TriggerMode'] @Triggers = params['Triggers'] @EventMode = params['EventMode'] @Events = params['Events'] end end # 迁移对象选项,需要告知迁移服务迁移哪些库表对象 class DatabaseTableObject < TencentCloud::Common::AbstractModel # @param ObjectMode: 迁移对象类型 all(全实例),partial(部分对象) # 注意:此字段可能返回 null,表示取不到有效值。 # @type ObjectMode: String # @param Databases: 迁移对象,当 ObjectMode 为 partial 时,不为空 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Databases: Array # @param AdvancedObjects: 高级对象类型,如trigger、function、procedure、event。注意:如果要迁移同步高级对象,此配置中应该包含对应的高级对象类型 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AdvancedObjects: Array attr_accessor :ObjectMode, :Databases, :AdvancedObjects def initialize(objectmode=nil, databases=nil, advancedobjects=nil) @ObjectMode = objectmode @Databases = databases @AdvancedObjects = advancedobjects end def deserialize(params) @ObjectMode = params['ObjectMode'] unless params['Databases'].nil? @Databases = [] params['Databases'].each do |i| dbitem_tmp = DBItem.new dbitem_tmp.deserialize(i) @Databases << dbitem_tmp end end @AdvancedObjects = params['AdvancedObjects'] end end # 数据同步中的ddl同步处理 class DdlOption < TencentCloud::Common::AbstractModel # @param DdlObject: ddl类型,如Database,Table,View,Index等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DdlObject: String # @param DdlValue: ddl具体值,对于Database可取值[Create,Drop,Alter]
对于Table可取值[Create,Drop,Alter,Truncate,Rename]
对于View可取值[Create,Drop]
对于Index可取值[Create,Drop] # 注意:此字段可能返回 null,表示取不到有效值。 # @type DdlValue: Array attr_accessor :DdlObject, :DdlValue def initialize(ddlobject=nil, ddlvalue=nil) @DdlObject = ddlobject @DdlValue = ddlvalue end def deserialize(params) @DdlObject = params['DdlObject'] @DdlValue = params['DdlValue'] end end # DeleteCompareTask请求参数结构体 class DeleteCompareTaskRequest < TencentCloud::Common::AbstractModel # @param JobId: 迁移任务 Id # @type JobId: String # @param CompareTaskId: 对比任务 ID,形如:dts-8yv4w2i1-cmp-37skmii9 # @type CompareTaskId: String attr_accessor :JobId, :CompareTaskId def initialize(jobid=nil, comparetaskid=nil) @JobId = jobid @CompareTaskId = comparetaskid end def deserialize(params) @JobId = params['JobId'] @CompareTaskId = params['CompareTaskId'] end end # DeleteCompareTask返回参数结构体 class DeleteCompareTaskResponse < 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 # DeleteConsumerGroup请求参数结构体 class DeleteConsumerGroupRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的 ID # @type SubscribeId: String # @param ConsumerGroupName: 消费组名称。实际的消费组全称形如:consumer-grp-#{SubscribeId}-#{ConsumerGroupName}。 # 请务必保证消费组名称正确。 # @type ConsumerGroupName: String # @param AccountName: 账号名称。实际的账户全称形如:account-#{SubscribeId}-#{AccountName}。 # 请务必保证账户名称正确。 # @type AccountName: String attr_accessor :SubscribeId, :ConsumerGroupName, :AccountName def initialize(subscribeid=nil, consumergroupname=nil, accountname=nil) @SubscribeId = subscribeid @ConsumerGroupName = consumergroupname @AccountName = accountname end def deserialize(params) @SubscribeId = params['SubscribeId'] @ConsumerGroupName = params['ConsumerGroupName'] @AccountName = params['AccountName'] end end # DeleteConsumerGroup返回参数结构体 class DeleteConsumerGroupResponse < 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 # DescribeCheckSyncJobResult请求参数结构体 class DescribeCheckSyncJobResultRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步实例id(即标识一个同步作业),形如sync-werwfs23,此值必填 # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # DescribeCheckSyncJobResult返回参数结构体 class DescribeCheckSyncJobResultResponse < TencentCloud::Common::AbstractModel # @param Status: 校验任务执行状态,如:notStarted(未开始)、running(校验中)、failed(校验任务失败)、success(任务成功) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param StepCount: 步骤总数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepCount: Integer # @param StepCur: 当前所在步骤 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepCur: Integer # @param Progress: 总体进度,范围为[0,100] # 注意:此字段可能返回 null,表示取不到有效值。 # @type Progress: Integer # @param StepInfos: 步骤信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepInfos: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Status, :StepCount, :StepCur, :Progress, :StepInfos, :RequestId def initialize(status=nil, stepcount=nil, stepcur=nil, progress=nil, stepinfos=nil, requestid=nil) @Status = status @StepCount = stepcount @StepCur = stepcur @Progress = progress @StepInfos = stepinfos @RequestId = requestid end def deserialize(params) @Status = params['Status'] @StepCount = params['StepCount'] @StepCur = params['StepCur'] @Progress = params['Progress'] unless params['StepInfos'].nil? @StepInfos = [] params['StepInfos'].each do |i| stepinfo_tmp = StepInfo.new stepinfo_tmp.deserialize(i) @StepInfos << stepinfo_tmp end end @RequestId = params['RequestId'] end end # DescribeCompareReport请求参数结构体 class DescribeCompareReportRequest < TencentCloud::Common::AbstractModel # @param JobId: 迁移任务 Id # @type JobId: String # @param CompareTaskId: 校验任务 Id # @type CompareTaskId: String # @param DifferenceLimit: 校验不一致结果的 limit # @type DifferenceLimit: Integer # @param DifferenceOffset: 不一致的 Offset # @type DifferenceOffset: Integer # @param DifferenceDB: 搜索条件,不一致的库名 # @type DifferenceDB: String # @param DifferenceTable: 搜索条件,不一致的表名 # @type DifferenceTable: String # @param SkippedLimit: 未校验的 Limit # @type SkippedLimit: Integer # @param SkippedOffset: 未校验的 Offset # @type SkippedOffset: Integer # @param SkippedDB: 搜索条件,未校验的库名 # @type SkippedDB: String # @param SkippedTable: 搜索条件,未校验的表名 # @type SkippedTable: String attr_accessor :JobId, :CompareTaskId, :DifferenceLimit, :DifferenceOffset, :DifferenceDB, :DifferenceTable, :SkippedLimit, :SkippedOffset, :SkippedDB, :SkippedTable def initialize(jobid=nil, comparetaskid=nil, differencelimit=nil, differenceoffset=nil, differencedb=nil, differencetable=nil, skippedlimit=nil, skippedoffset=nil, skippeddb=nil, skippedtable=nil) @JobId = jobid @CompareTaskId = comparetaskid @DifferenceLimit = differencelimit @DifferenceOffset = differenceoffset @DifferenceDB = differencedb @DifferenceTable = differencetable @SkippedLimit = skippedlimit @SkippedOffset = skippedoffset @SkippedDB = skippeddb @SkippedTable = skippedtable end def deserialize(params) @JobId = params['JobId'] @CompareTaskId = params['CompareTaskId'] @DifferenceLimit = params['DifferenceLimit'] @DifferenceOffset = params['DifferenceOffset'] @DifferenceDB = params['DifferenceDB'] @DifferenceTable = params['DifferenceTable'] @SkippedLimit = params['SkippedLimit'] @SkippedOffset = params['SkippedOffset'] @SkippedDB = params['SkippedDB'] @SkippedTable = params['SkippedTable'] end end # DescribeCompareReport返回参数结构体 class DescribeCompareReportResponse < TencentCloud::Common::AbstractModel # @param Abstract: 一致性校验摘要信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Abstract: :class:`Tencentcloud::Dts.v20211206.models.CompareAbstractInfo` # @param Detail: 一致性校验详细信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Detail: :class:`Tencentcloud::Dts.v20211206.models.CompareDetailInfo` # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Abstract, :Detail, :RequestId def initialize(abstract=nil, detail=nil, requestid=nil) @Abstract = abstract @Detail = detail @RequestId = requestid end def deserialize(params) unless params['Abstract'].nil? @Abstract = CompareAbstractInfo.new @Abstract.deserialize(params['Abstract']) end unless params['Detail'].nil? @Detail = CompareDetailInfo.new @Detail.deserialize(params['Detail']) end @RequestId = params['RequestId'] end end # DescribeCompareTasks请求参数结构体 class DescribeCompareTasksRequest < TencentCloud::Common::AbstractModel # @param JobId: 迁移任务 Id # @type JobId: String # @param Limit: 分页设置,表示每页显示多少条任务,默认为 20 # @type Limit: Integer # @param Offset: 分页偏移量 # @type Offset: Integer # @param CompareTaskId: 校验任务 ID # @type CompareTaskId: String # @param Status: 任务状态过滤,可能的值:created - 创建完成;readyRun - 等待运行;running - 运行中;success - 成功;stopping - 结束中;failed - 失败;canceled - 已终止 # @type Status: Array attr_accessor :JobId, :Limit, :Offset, :CompareTaskId, :Status def initialize(jobid=nil, limit=nil, offset=nil, comparetaskid=nil, status=nil) @JobId = jobid @Limit = limit @Offset = offset @CompareTaskId = comparetaskid @Status = status end def deserialize(params) @JobId = params['JobId'] @Limit = params['Limit'] @Offset = params['Offset'] @CompareTaskId = params['CompareTaskId'] @Status = params['Status'] end end # DescribeCompareTasks返回参数结构体 class DescribeCompareTasksResponse < TencentCloud::Common::AbstractModel # @param TotalCount: 数量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param Items: 一致性校验列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Items: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TotalCount, :Items, :RequestId def initialize(totalcount=nil, items=nil, requestid=nil) @TotalCount = totalcount @Items = items @RequestId = requestid end def deserialize(params) @TotalCount = params['TotalCount'] unless params['Items'].nil? @Items = [] params['Items'].each do |i| comparetaskitem_tmp = CompareTaskItem.new comparetaskitem_tmp.deserialize(i) @Items << comparetaskitem_tmp end end @RequestId = params['RequestId'] end end # DescribeConsumerGroups请求参数结构体 class DescribeConsumerGroupsRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 订阅实例id # @type SubscribeId: String # @param Offset: 返回记录的起始偏移量。默认0 # @type Offset: Integer # @param Limit: 单次返回的记录数量。默认10 # @type Limit: Integer attr_accessor :SubscribeId, :Offset, :Limit def initialize(subscribeid=nil, offset=nil, limit=nil) @SubscribeId = subscribeid @Offset = offset @Limit = limit end def deserialize(params) @SubscribeId = params['SubscribeId'] @Offset = params['Offset'] @Limit = params['Limit'] end end # DescribeConsumerGroups返回参数结构体 class DescribeConsumerGroupsResponse < TencentCloud::Common::AbstractModel # @param TotalCount: 指定实例下的消费者组总数 # @type TotalCount: Integer # @param Items: 消费者组列表 # @type Items: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TotalCount, :Items, :RequestId def initialize(totalcount=nil, items=nil, requestid=nil) @TotalCount = totalcount @Items = items @RequestId = requestid end def deserialize(params) @TotalCount = params['TotalCount'] unless params['Items'].nil? @Items = [] params['Items'].each do |i| groupinfo_tmp = GroupInfo.new groupinfo_tmp.deserialize(i) @Items << groupinfo_tmp end end @RequestId = params['RequestId'] end end # DescribeMigrateDBInstances请求参数结构体 class DescribeMigrateDBInstancesRequest < TencentCloud::Common::AbstractModel # @param DatabaseType: 数据库类型,如mysql,redis等 # @type DatabaseType: String # @param MigrateRole: 实例作为迁移的源还是目标,src(表示源),dst(表示目标) # @type MigrateRole: String # @param InstanceId: 云数据库实例ID # @type InstanceId: String # @param InstanceName: 云数据库名称 # @type InstanceName: String # @param Limit: 返回数量限制 # @type Limit: Integer # @param Offset: 偏移量 # @type Offset: Integer # @param AccountMode: 资源所属账号 为空值或self(表示本账号内资源)、other(表示其他账户资源) # @type AccountMode: String # @param TmpSecretId: 临时密钥Id,可通过申请扮演角色临时访问凭证获取临时密钥https://cloud.tencent.com/document/product/1312/48197,其中角色资源RoleArn的定义可参考DTS跨账号迁移文档(https://cloud.tencent.com/document/product/571/54117)第4节中关于角色的定义。 # @type TmpSecretId: String # @param TmpSecretKey: 临时密钥Id,可通过申请扮演角色临时访问凭证获取临时密钥https://cloud.tencent.com/document/product/1312/48197,其中角色资源RoleArn的定义可参考DTS跨账号迁移文档(https://cloud.tencent.com/document/product/571/54117)第4节中关于角色的定义。 # @type TmpSecretKey: String # @param TmpToken: 临时密钥Id,可通过申请扮演角色临时访问凭证获取临时密钥https://cloud.tencent.com/document/product/1312/48197,其中角色资源RoleArn的定义可参考DTS跨账号迁移文档(https://cloud.tencent.com/document/product/571/54117)第4节中关于角色的定义。 # @type TmpToken: String attr_accessor :DatabaseType, :MigrateRole, :InstanceId, :InstanceName, :Limit, :Offset, :AccountMode, :TmpSecretId, :TmpSecretKey, :TmpToken def initialize(databasetype=nil, migraterole=nil, instanceid=nil, instancename=nil, limit=nil, offset=nil, accountmode=nil, tmpsecretid=nil, tmpsecretkey=nil, tmptoken=nil) @DatabaseType = databasetype @MigrateRole = migraterole @InstanceId = instanceid @InstanceName = instancename @Limit = limit @Offset = offset @AccountMode = accountmode @TmpSecretId = tmpsecretid @TmpSecretKey = tmpsecretkey @TmpToken = tmptoken end def deserialize(params) @DatabaseType = params['DatabaseType'] @MigrateRole = params['MigrateRole'] @InstanceId = params['InstanceId'] @InstanceName = params['InstanceName'] @Limit = params['Limit'] @Offset = params['Offset'] @AccountMode = params['AccountMode'] @TmpSecretId = params['TmpSecretId'] @TmpSecretKey = params['TmpSecretKey'] @TmpToken = params['TmpToken'] end end # DescribeMigrateDBInstances返回参数结构体 class DescribeMigrateDBInstancesResponse < TencentCloud::Common::AbstractModel # @param TotalCount: 符合筛选条件的数量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param Instances: 实例列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Instances: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TotalCount, :Instances, :RequestId def initialize(totalcount=nil, instances=nil, requestid=nil) @TotalCount = totalcount @Instances = instances @RequestId = requestid end def deserialize(params) @TotalCount = params['TotalCount'] unless params['Instances'].nil? @Instances = [] params['Instances'].each do |i| migratedbitem_tmp = MigrateDBItem.new migratedbitem_tmp.deserialize(i) @Instances << migratedbitem_tmp end end @RequestId = params['RequestId'] end end # DescribeMigrationCheckJob请求参数结构体 class DescribeMigrationCheckJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # DescribeMigrationCheckJob返回参数结构体 class DescribeMigrationCheckJobResponse < TencentCloud::Common::AbstractModel # @param Status: 校验任务执行状态,如:notStarted(未开始)、running(校验中)、failed(校验任务失败)、success(任务成功) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param BriefMsg: 校验任务结果输出简要信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type BriefMsg: String # @param StepInfo: 检查步骤 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepInfo: Array # @param CheckFlag: 校验结果,如:checkPass(校验通过)、checkNotPass(校验未通过) # @type CheckFlag: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Status, :BriefMsg, :StepInfo, :CheckFlag, :RequestId def initialize(status=nil, briefmsg=nil, stepinfo=nil, checkflag=nil, requestid=nil) @Status = status @BriefMsg = briefmsg @StepInfo = stepinfo @CheckFlag = checkflag @RequestId = requestid end def deserialize(params) @Status = params['Status'] @BriefMsg = params['BriefMsg'] unless params['StepInfo'].nil? @StepInfo = [] params['StepInfo'].each do |i| checkstep_tmp = CheckStep.new checkstep_tmp.deserialize(i) @StepInfo << checkstep_tmp end end @CheckFlag = params['CheckFlag'] @RequestId = params['RequestId'] end end # DescribeMigrationDetail请求参数结构体 class DescribeMigrationDetailRequest < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # DescribeMigrationDetail返回参数结构体 class DescribeMigrationDetailResponse < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # 注意:此字段可能返回 null,表示取不到有效值。 # @type JobId: String # @param JobName: 数据迁移任务名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type JobName: String # @param CreateTime: 任务创建(提交)时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type CreateTime: String # @param UpdateTime: 任务更新时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type UpdateTime: String # @param StartTime: 任务开始执行时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartTime: String # @param EndTime: 任务执行结束时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type EndTime: String # @param BriefMsg: 迁移任务简要错误信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type BriefMsg: String # @param Status: 任务状态,取值为:created(创建完成)、checking(校验中)、checkPass(校验通过)、checkNotPass(校验不通过)、readyRun(准备运行)、running(任务运行中)、readyComplete(准备完成)、success(任务成功)、failed(任务失败)、stopping(中止中)、completing(完成中)、 # pausing(暂停中)、 # manualPaused(已暂停) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param Action: 任务操作信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Action: :class:`Tencentcloud::Dts.v20211206.models.MigrateAction` # @param StepInfo: 迁移执行过程信息,在校验阶段显示校验过程步骤信息,在迁移阶段会显示迁移步骤信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepInfo: :class:`Tencentcloud::Dts.v20211206.models.MigrateDetailInfo` # @param SrcInfo: 源实例信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcInfo: :class:`Tencentcloud::Dts.v20211206.models.DBEndpointInfo` # @param DstInfo: 目标端信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstInfo: :class:`Tencentcloud::Dts.v20211206.models.DBEndpointInfo` # @param CompareTask: 数据一致性校验结果 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CompareTask: :class:`Tencentcloud::Dts.v20211206.models.CompareTaskInfo` # @param Tags: 标签信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tags: Array # @param RunMode: 运行模式,取值如:immediate(表示立即运行)、timed(表示定时运行) # 注意:此字段可能返回 null,表示取不到有效值。 # @type RunMode: String # @param ExpectRunTime: 期待启动时间,当RunMode取值为timed时,此值必填,形如:"2006-01-02 15:04:05" # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExpectRunTime: String # @param MigrateOption: 迁移选项,描述任务如何执行迁移等一系列配置信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type MigrateOption: :class:`Tencentcloud::Dts.v20211206.models.MigrateOption` # @param CheckStepInfo: 校验任务运行详情 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CheckStepInfo: :class:`Tencentcloud::Dts.v20211206.models.CheckStepInfo` # @param TradeInfo: 描述计费相关的信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TradeInfo: :class:`Tencentcloud::Dts.v20211206.models.TradeInfo` # @param ErrorInfo: 任务错误信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ErrorInfo: Array # @param DumperResumeCtrl: 全量导出可重入标识:enum::"yes"/"no"。yes表示当前任务可重入、no表示当前任务处于全量导出且不可重入阶段;如果在该值为no时重启任务导出流程不支持断点续传 # @type DumperResumeCtrl: String # @param RateLimitOption: 任务的限速信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type RateLimitOption: :class:`Tencentcloud::Dts.v20211206.models.RateLimitOption` # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :JobId, :JobName, :CreateTime, :UpdateTime, :StartTime, :EndTime, :BriefMsg, :Status, :Action, :StepInfo, :SrcInfo, :DstInfo, :CompareTask, :Tags, :RunMode, :ExpectRunTime, :MigrateOption, :CheckStepInfo, :TradeInfo, :ErrorInfo, :DumperResumeCtrl, :RateLimitOption, :RequestId def initialize(jobid=nil, jobname=nil, createtime=nil, updatetime=nil, starttime=nil, endtime=nil, briefmsg=nil, status=nil, action=nil, stepinfo=nil, srcinfo=nil, dstinfo=nil, comparetask=nil, tags=nil, runmode=nil, expectruntime=nil, migrateoption=nil, checkstepinfo=nil, tradeinfo=nil, errorinfo=nil, dumperresumectrl=nil, ratelimitoption=nil, requestid=nil) @JobId = jobid @JobName = jobname @CreateTime = createtime @UpdateTime = updatetime @StartTime = starttime @EndTime = endtime @BriefMsg = briefmsg @Status = status @Action = action @StepInfo = stepinfo @SrcInfo = srcinfo @DstInfo = dstinfo @CompareTask = comparetask @Tags = tags @RunMode = runmode @ExpectRunTime = expectruntime @MigrateOption = migrateoption @CheckStepInfo = checkstepinfo @TradeInfo = tradeinfo @ErrorInfo = errorinfo @DumperResumeCtrl = dumperresumectrl @RateLimitOption = ratelimitoption @RequestId = requestid end def deserialize(params) @JobId = params['JobId'] @JobName = params['JobName'] @CreateTime = params['CreateTime'] @UpdateTime = params['UpdateTime'] @StartTime = params['StartTime'] @EndTime = params['EndTime'] @BriefMsg = params['BriefMsg'] @Status = params['Status'] unless params['Action'].nil? @Action = MigrateAction.new @Action.deserialize(params['Action']) end unless params['StepInfo'].nil? @StepInfo = MigrateDetailInfo.new @StepInfo.deserialize(params['StepInfo']) end unless params['SrcInfo'].nil? @SrcInfo = DBEndpointInfo.new @SrcInfo.deserialize(params['SrcInfo']) end unless params['DstInfo'].nil? @DstInfo = DBEndpointInfo.new @DstInfo.deserialize(params['DstInfo']) end unless params['CompareTask'].nil? @CompareTask = CompareTaskInfo.new @CompareTask.deserialize(params['CompareTask']) end unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| tagitem_tmp = TagItem.new tagitem_tmp.deserialize(i) @Tags << tagitem_tmp end end @RunMode = params['RunMode'] @ExpectRunTime = params['ExpectRunTime'] unless params['MigrateOption'].nil? @MigrateOption = MigrateOption.new @MigrateOption.deserialize(params['MigrateOption']) end unless params['CheckStepInfo'].nil? @CheckStepInfo = CheckStepInfo.new @CheckStepInfo.deserialize(params['CheckStepInfo']) end unless params['TradeInfo'].nil? @TradeInfo = TradeInfo.new @TradeInfo.deserialize(params['TradeInfo']) end unless params['ErrorInfo'].nil? @ErrorInfo = [] params['ErrorInfo'].each do |i| errorinfoitem_tmp = ErrorInfoItem.new errorinfoitem_tmp.deserialize(i) @ErrorInfo << errorinfoitem_tmp end end @DumperResumeCtrl = params['DumperResumeCtrl'] unless params['RateLimitOption'].nil? @RateLimitOption = RateLimitOption.new @RateLimitOption.deserialize(params['RateLimitOption']) end @RequestId = params['RequestId'] end end # DescribeMigrationJobs请求参数结构体 class DescribeMigrationJobsRequest < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID,如:dts-amm1jw5q # @type JobId: String # @param JobName: 数据迁移任务名称 # @type JobName: String # @param Status: 数据迁移任务状态,可取值包括:created(创建完成)、checking(校验中)、checkPass(校验通过)、checkNotPass(校验不通过)、readyRun(准备运行)、running(任务运行中)、readyComplete(准备完成)、success(任务成功)、failed(任务失败)、stopping(中止中)、completing(完成中) # @type Status: Array # @param SrcInstanceId: 源实例ID,格式如:cdb-c1nl9rpv # @type SrcInstanceId: String # @param SrcRegion: 源实例地域,如:ap-guangzhou # @type SrcRegion: String # @param SrcDatabaseType: 源实例数据库类型,如:sqlserver,mysql,mongodb,redis,tendis,keewidb,clickhouse,cynosdbmysql,percona,tdsqlpercona,mariadb,tdsqlmysql,postgresql # @type SrcDatabaseType: Array # @param SrcAccessType: 源实例接入类型,值包括:extranet(外网)、vpncloud(云vpn接入的实例)、dcg(专线接入的实例)、ccn(云联网接入的实例)、cdb(云上cdb实例)、cvm(cvm自建实例) # @type SrcAccessType: Array # @param DstInstanceId: 目标实例ID,格式如:cdb-c1nl9rpv # @type DstInstanceId: String # @param DstRegion: 目标实例地域,如:ap-guangzhou # @type DstRegion: String # @param DstDatabaseType: 目标源实例数据库类型,如:sqlserver,mysql,mongodb,redis,tendis,keewidb,clickhouse,cynosdbmysql,percona,tdsqlpercona,mariadb,tdsqlmysql,postgresql # @type DstDatabaseType: Array # @param DstAccessType: 目标实例接入类型,值包括:extranet(外网)、vpncloud(云vpn接入的实例)、dcg(专线接入的实例)、ccn(云联网接入的实例)、cdb(云上cdb实例)、cvm(cvm自建实例) # @type DstAccessType: Array # @param RunMode: 任务运行模式,值包括:immediate(立即运行),timed(定时运行) # @type RunMode: String # @param OrderSeq: 排序方式,可能取值为asc、desc,默认按照创建时间倒序 # @type OrderSeq: String # @param Limit: 返回实例数量,默认20,有效区间[1,100] # @type Limit: Integer # @param Offset: 偏移量,默认为0 # @type Offset: Integer # @param TagFilters: 标签过滤 # @type TagFilters: Array attr_accessor :JobId, :JobName, :Status, :SrcInstanceId, :SrcRegion, :SrcDatabaseType, :SrcAccessType, :DstInstanceId, :DstRegion, :DstDatabaseType, :DstAccessType, :RunMode, :OrderSeq, :Limit, :Offset, :TagFilters def initialize(jobid=nil, jobname=nil, status=nil, srcinstanceid=nil, srcregion=nil, srcdatabasetype=nil, srcaccesstype=nil, dstinstanceid=nil, dstregion=nil, dstdatabasetype=nil, dstaccesstype=nil, runmode=nil, orderseq=nil, limit=nil, offset=nil, tagfilters=nil) @JobId = jobid @JobName = jobname @Status = status @SrcInstanceId = srcinstanceid @SrcRegion = srcregion @SrcDatabaseType = srcdatabasetype @SrcAccessType = srcaccesstype @DstInstanceId = dstinstanceid @DstRegion = dstregion @DstDatabaseType = dstdatabasetype @DstAccessType = dstaccesstype @RunMode = runmode @OrderSeq = orderseq @Limit = limit @Offset = offset @TagFilters = tagfilters end def deserialize(params) @JobId = params['JobId'] @JobName = params['JobName'] @Status = params['Status'] @SrcInstanceId = params['SrcInstanceId'] @SrcRegion = params['SrcRegion'] @SrcDatabaseType = params['SrcDatabaseType'] @SrcAccessType = params['SrcAccessType'] @DstInstanceId = params['DstInstanceId'] @DstRegion = params['DstRegion'] @DstDatabaseType = params['DstDatabaseType'] @DstAccessType = params['DstAccessType'] @RunMode = params['RunMode'] @OrderSeq = params['OrderSeq'] @Limit = params['Limit'] @Offset = params['Offset'] unless params['TagFilters'].nil? @TagFilters = [] params['TagFilters'].each do |i| tagfilter_tmp = TagFilter.new tagfilter_tmp.deserialize(i) @TagFilters << tagfilter_tmp end end end end # DescribeMigrationJobs返回参数结构体 class DescribeMigrationJobsResponse < TencentCloud::Common::AbstractModel # @param TotalCount: 迁移任务数量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param JobList: 迁移任务列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type JobList: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TotalCount, :JobList, :RequestId def initialize(totalcount=nil, joblist=nil, requestid=nil) @TotalCount = totalcount @JobList = joblist @RequestId = requestid end def deserialize(params) @TotalCount = params['TotalCount'] unless params['JobList'].nil? @JobList = [] params['JobList'].each do |i| jobitem_tmp = JobItem.new jobitem_tmp.deserialize(i) @JobList << jobitem_tmp end end @RequestId = params['RequestId'] end end # DescribeModifyCheckSyncJobResult请求参数结构体 class DescribeModifyCheckSyncJobResultRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # DescribeModifyCheckSyncJobResult返回参数结构体 class DescribeModifyCheckSyncJobResultResponse < TencentCloud::Common::AbstractModel # @param Status: 校验任务执行状态,如:notStarted(未开始)、running(校验中)、failed(校验任务失败)、success(任务成功) # @type Status: String # @param StepCount: 校验的步骤总数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepCount: Integer # @param StepCur: 当前所在步骤 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepCur: Integer # @param Progress: 总体进度,范围为[0,100] # 注意:此字段可能返回 null,表示取不到有效值。 # @type Progress: Integer # @param StepInfos: 步骤详细信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepInfos: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Status, :StepCount, :StepCur, :Progress, :StepInfos, :RequestId def initialize(status=nil, stepcount=nil, stepcur=nil, progress=nil, stepinfos=nil, requestid=nil) @Status = status @StepCount = stepcount @StepCur = stepcur @Progress = progress @StepInfos = stepinfos @RequestId = requestid end def deserialize(params) @Status = params['Status'] @StepCount = params['StepCount'] @StepCur = params['StepCur'] @Progress = params['Progress'] unless params['StepInfos'].nil? @StepInfos = [] params['StepInfos'].each do |i| stepinfo_tmp = StepInfo.new stepinfo_tmp.deserialize(i) @StepInfos << stepinfo_tmp end end @RequestId = params['RequestId'] end end # DescribeOffsetByTime请求参数结构体 class DescribeOffsetByTimeRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的 ID # @type SubscribeId: String # @param Time: 时间点,格式为:Y-m-d h:m:s。如果输入时间比当前时间晚的多,相当于查询最新offset;如果输入时间比当前时间早的多,相当于查询最老offset;如果输入空,默认0时间,等价于查询最老offset。 # @type Time: String attr_accessor :SubscribeId, :Time def initialize(subscribeid=nil, time=nil) @SubscribeId = subscribeid @Time = time end def deserialize(params) @SubscribeId = params['SubscribeId'] @Time = params['Time'] end end # DescribeOffsetByTime返回参数结构体 class DescribeOffsetByTimeResponse < TencentCloud::Common::AbstractModel # @param Items: 时间与Offset的对应 # @type Items: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Items, :RequestId def initialize(items=nil, requestid=nil) @Items = items @RequestId = requestid end def deserialize(params) unless params['Items'].nil? @Items = [] params['Items'].each do |i| offsettimemap_tmp = OffsetTimeMap.new offsettimemap_tmp.deserialize(i) @Items << offsettimemap_tmp end end @RequestId = params['RequestId'] end end # DescribeSubscribeCheckJob请求参数结构体 class DescribeSubscribeCheckJobRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的 ID # @type SubscribeId: String attr_accessor :SubscribeId def initialize(subscribeid=nil) @SubscribeId = subscribeid end def deserialize(params) @SubscribeId = params['SubscribeId'] end end # DescribeSubscribeCheckJob返回参数结构体 class DescribeSubscribeCheckJobResponse < TencentCloud::Common::AbstractModel # @param SubscribeId: 订阅实例ID # @type SubscribeId: String # @param Message: 失败或者报错提示,成功则提示success。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Message: String # @param Status: 任务运行状态,可能值为 running,failed,success # @type Status: String # @param Progress: 当前总体进度,范围 0~100 # @type Progress: Integer # @param StepAll: 校验总步骤数 # @type StepAll: Integer # @param StepNow: 当前执行步骤 # @type StepNow: Integer # @param Steps: 各个步骤运行状态 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Steps: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :SubscribeId, :Message, :Status, :Progress, :StepAll, :StepNow, :Steps, :RequestId def initialize(subscribeid=nil, message=nil, status=nil, progress=nil, stepall=nil, stepnow=nil, steps=nil, requestid=nil) @SubscribeId = subscribeid @Message = message @Status = status @Progress = progress @StepAll = stepall @StepNow = stepnow @Steps = steps @RequestId = requestid end def deserialize(params) @SubscribeId = params['SubscribeId'] @Message = params['Message'] @Status = params['Status'] @Progress = params['Progress'] @StepAll = params['StepAll'] @StepNow = params['StepNow'] unless params['Steps'].nil? @Steps = [] params['Steps'].each do |i| subscribecheckstepinfo_tmp = SubscribeCheckStepInfo.new subscribecheckstepinfo_tmp.deserialize(i) @Steps << subscribecheckstepinfo_tmp end end @RequestId = params['RequestId'] end end # DescribeSubscribeDetail请求参数结构体 class DescribeSubscribeDetailRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 订阅实例ID # @type SubscribeId: String attr_accessor :SubscribeId def initialize(subscribeid=nil) @SubscribeId = subscribeid end def deserialize(params) @SubscribeId = params['SubscribeId'] end end # DescribeSubscribeDetail返回参数结构体 class DescribeSubscribeDetailResponse < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅的ID,形如subs-b6x64o31tm # @type SubscribeId: String # @param SubscribeName: 数据订阅实例的名称 # @type SubscribeName: String # @param Product: 订阅的数据库类型,目前支持 cynosdbmysql(tdsql-c mysql版),mariadb,mongodb,mysql,percona,tdpg(tdsql postgresql版),tdsqlpercona(tdsql mysql版) # @type Product: String # @param InstanceId: 订阅的云数据库实例ID,只有订阅云数据库该值才有意义 # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceId: String # @param InstanceStatus: 订阅的云数据库实例状态,只有订阅云数据库该值才有意义。可能值为:running, isolated, offline # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceStatus: String # @param Status: 订阅任务计费状态,可能值为:正常normal, 隔离中isolating, 已隔离isolated, 下线中offlining, 按量转包年包月中 post2PrePayIng # @type Status: String # @param SubsStatus: 订阅任务状态,可能值为:未启动notStarted, 校验中checking, 校验不通过checkNotPass, 校验通过checkPass, 启动中starting, 运行中running, 异常出错error # @type SubsStatus: String # @param ModifyTime: 修改时间,时间格式如:Y-m-d h:m:s # 注意:此字段可能返回 null,表示取不到有效值。 # @type ModifyTime: String # @param CreateTime: 创建时间,时间格式如:Y-m-d h:m:s # 注意:此字段可能返回 null,表示取不到有效值。 # @type CreateTime: String # @param IsolateTime: 隔离时间,时间格式如:Y-m-d h:m:s。默认:0000-00-00 00:00:00 # 注意:此字段可能返回 null,表示取不到有效值。 # @type IsolateTime: String # @param ExpireTime: 包年包月任务的到期时间,时间格式如:Y-m-d h:m:s。默认:0000-00-00 00:00:00 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExpireTime: String # @param OfflineTime: 下线时间,时间格式如:Y-m-d h:m:s。默认:0000-00-00 00:00:00 # 注意:此字段可能返回 null,表示取不到有效值。 # @type OfflineTime: String # @param PayType: 付费方式,可能值为:0-包年包月,1-按量计费 # @type PayType: Integer # @param AutoRenewFlag: 自动续费标识。只有当 PayType=0,该值才有意义。枚举值:0-不自动续费,1-自动续费 # @type AutoRenewFlag: Integer # @param Region: 任务所在地域 # @type Region: String # @param Topic: Kafka topic # 注意:此字段可能返回 null,表示取不到有效值。 # @type Topic: String # @param Broker: Kafka服务Broker地址 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Broker: String # @param SubscribeMode: 数据订阅的类型,当 Product 不为 mongodb 时,可能值为:all-全实例更新;dml-数据更新;ddl-结构更新;dmlAndDdl-数据更新+结构更新。当 Product 为 mongodb 时,可能值为 all-全实例更新;database-订阅单库;collection-订阅单集合 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SubscribeMode: String # @param Protocol: 订阅数据格式。如果为空则用的默认格式: mysql\cynosdbmysql\mariadb\percona\tdsqlpercona\tdpg是protobuf,mongo是json。当 DatabaseType 为 mysql和cynosdbmysql 时有三种可选协议:protobuf\avro\json。数据格式详情参考官网的消费demo文档 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Protocol: String # @param SubscribeObjects: 订阅的数据库表信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SubscribeObjects: Array # @param KafkaConfig: kafka配置信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type KafkaConfig: :class:`Tencentcloud::Dts.v20211206.models.SubscribeKafkaConfig` # @param KafkaVersion: 订阅内置kafka的版本信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type KafkaVersion: String # @param AccessType: 源数据库接入类型,如:extranet(公网)、vpncloud(vpn接入)、dcg(专线接入)、ccn(云联网)、cdb(云数据库)、cvm(云服务器自建)、intranet(自研上云)、vpc(私有网络vpc)。注意具体可选值依赖当前链路支持能力 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AccessType: String # @param Endpoints: 接入类型信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Endpoints: Array # @param PipelineInfo: mongo输出聚合设置 # 注意:此字段可能返回 null,表示取不到有效值。 # @type PipelineInfo: Array # @param Tags: 标签 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tags: Array # @param Errors: 订阅任务报错信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Errors: Array # @param ExtraAttr: 为业务添加的额外信息。参数名作key,参数值作value。 # mysql选填参数:ProcessXA-是否处理XA事务,为true处理,其他不处理。 # mongo选填参数:SubscribeType-订阅类型,目前只支持changeStream。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExtraAttr: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :SubscribeId, :SubscribeName, :Product, :InstanceId, :InstanceStatus, :Status, :SubsStatus, :ModifyTime, :CreateTime, :IsolateTime, :ExpireTime, :OfflineTime, :PayType, :AutoRenewFlag, :Region, :Topic, :Broker, :SubscribeMode, :Protocol, :SubscribeObjects, :KafkaConfig, :KafkaVersion, :AccessType, :Endpoints, :PipelineInfo, :Tags, :Errors, :ExtraAttr, :RequestId def initialize(subscribeid=nil, subscribename=nil, product=nil, instanceid=nil, instancestatus=nil, status=nil, subsstatus=nil, modifytime=nil, createtime=nil, isolatetime=nil, expiretime=nil, offlinetime=nil, paytype=nil, autorenewflag=nil, region=nil, topic=nil, broker=nil, subscribemode=nil, protocol=nil, subscribeobjects=nil, kafkaconfig=nil, kafkaversion=nil, accesstype=nil, endpoints=nil, pipelineinfo=nil, tags=nil, errors=nil, extraattr=nil, requestid=nil) @SubscribeId = subscribeid @SubscribeName = subscribename @Product = product @InstanceId = instanceid @InstanceStatus = instancestatus @Status = status @SubsStatus = subsstatus @ModifyTime = modifytime @CreateTime = createtime @IsolateTime = isolatetime @ExpireTime = expiretime @OfflineTime = offlinetime @PayType = paytype @AutoRenewFlag = autorenewflag @Region = region @Topic = topic @Broker = broker @SubscribeMode = subscribemode @Protocol = protocol @SubscribeObjects = subscribeobjects @KafkaConfig = kafkaconfig @KafkaVersion = kafkaversion @AccessType = accesstype @Endpoints = endpoints @PipelineInfo = pipelineinfo @Tags = tags @Errors = errors @ExtraAttr = extraattr @RequestId = requestid end def deserialize(params) @SubscribeId = params['SubscribeId'] @SubscribeName = params['SubscribeName'] @Product = params['Product'] @InstanceId = params['InstanceId'] @InstanceStatus = params['InstanceStatus'] @Status = params['Status'] @SubsStatus = params['SubsStatus'] @ModifyTime = params['ModifyTime'] @CreateTime = params['CreateTime'] @IsolateTime = params['IsolateTime'] @ExpireTime = params['ExpireTime'] @OfflineTime = params['OfflineTime'] @PayType = params['PayType'] @AutoRenewFlag = params['AutoRenewFlag'] @Region = params['Region'] @Topic = params['Topic'] @Broker = params['Broker'] @SubscribeMode = params['SubscribeMode'] @Protocol = params['Protocol'] unless params['SubscribeObjects'].nil? @SubscribeObjects = [] params['SubscribeObjects'].each do |i| subscribeobject_tmp = SubscribeObject.new subscribeobject_tmp.deserialize(i) @SubscribeObjects << subscribeobject_tmp end end unless params['KafkaConfig'].nil? @KafkaConfig = SubscribeKafkaConfig.new @KafkaConfig.deserialize(params['KafkaConfig']) end @KafkaVersion = params['KafkaVersion'] @AccessType = params['AccessType'] unless params['Endpoints'].nil? @Endpoints = [] params['Endpoints'].each do |i| endpointitem_tmp = EndpointItem.new endpointitem_tmp.deserialize(i) @Endpoints << endpointitem_tmp end end unless params['PipelineInfo'].nil? @PipelineInfo = [] params['PipelineInfo'].each do |i| pipelineinfo_tmp = PipelineInfo.new pipelineinfo_tmp.deserialize(i) @PipelineInfo << pipelineinfo_tmp end end unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| tagitem_tmp = TagItem.new tagitem_tmp.deserialize(i) @Tags << tagitem_tmp end end unless params['Errors'].nil? @Errors = [] params['Errors'].each do |i| subserr_tmp = SubsErr.new subserr_tmp.deserialize(i) @Errors << subserr_tmp end end unless params['ExtraAttr'].nil? @ExtraAttr = [] params['ExtraAttr'].each do |i| keyvaluepairoption_tmp = KeyValuePairOption.new keyvaluepairoption_tmp.deserialize(i) @ExtraAttr << keyvaluepairoption_tmp end end @RequestId = params['RequestId'] end end # DescribeSubscribeJobs请求参数结构体 class DescribeSubscribeJobsRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 订阅 ID 筛选,精确匹配 # @type SubscribeId: String # @param SubscribeName: 订阅名称,前缀模糊匹配 # @type SubscribeName: String # @param InstanceId: 订阅的云上数据库实例的 ID,精确匹配 # @type InstanceId: String # @param Topic: 订阅的topicName # @type Topic: String # @param PayType: 计费模式筛选,可能的值:0-包年包月,1-按量计费 # @type PayType: Integer # @param Product: 订阅的数据库产品,目前支持 cynosdbmysql,mariadb,mongodb,mysql,percona,tdpg,tdsqlpercona(tdsqlmysql) # @type Product: String # @param Status: 数据订阅生命周期状态,可能的值为:正常 normal, 隔离中 isolating, 已隔离 isolated, 下线中 offlining,按量转包年包月中 post2PrePayIng # @type Status: Array # @param SubsStatus: 数据订阅状态,可能的值为:未启动 notStarted, 校验中 checking, 校验不通过 checkNotPass, 校验通过 checkPass, 启动中 starting, 运行中 running, 异常出错 error # @type SubsStatus: Array # @param Offset: 返回记录的起始偏移量。默认0 # @type Offset: Integer # @param Limit: 单次返回的记录数量。默认20,最大100 # @type Limit: Integer # @param OrderDirection: 排序方向,可选的值为"DESC"和"ASC",默认为"DESC",按创建时间逆序排序 # @type OrderDirection: String # @param TagFilters: tag 过滤条件,多个 TagFilter 之间关系为且 # @type TagFilters: Array attr_accessor :SubscribeId, :SubscribeName, :InstanceId, :Topic, :PayType, :Product, :Status, :SubsStatus, :Offset, :Limit, :OrderDirection, :TagFilters def initialize(subscribeid=nil, subscribename=nil, instanceid=nil, topic=nil, paytype=nil, product=nil, status=nil, subsstatus=nil, offset=nil, limit=nil, orderdirection=nil, tagfilters=nil) @SubscribeId = subscribeid @SubscribeName = subscribename @InstanceId = instanceid @Topic = topic @PayType = paytype @Product = product @Status = status @SubsStatus = subsstatus @Offset = offset @Limit = limit @OrderDirection = orderdirection @TagFilters = tagfilters end def deserialize(params) @SubscribeId = params['SubscribeId'] @SubscribeName = params['SubscribeName'] @InstanceId = params['InstanceId'] @Topic = params['Topic'] @PayType = params['PayType'] @Product = params['Product'] @Status = params['Status'] @SubsStatus = params['SubsStatus'] @Offset = params['Offset'] @Limit = params['Limit'] @OrderDirection = params['OrderDirection'] unless params['TagFilters'].nil? @TagFilters = [] params['TagFilters'].each do |i| tagfilter_tmp = TagFilter.new tagfilter_tmp.deserialize(i) @TagFilters << tagfilter_tmp end end end end # DescribeSubscribeJobs返回参数结构体 class DescribeSubscribeJobsResponse < TencentCloud::Common::AbstractModel # @param TotalCount: 符合查询条件的实例总数 # @type TotalCount: Integer # @param Items: 数据订阅实例的信息列表 # @type Items: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TotalCount, :Items, :RequestId def initialize(totalcount=nil, items=nil, requestid=nil) @TotalCount = totalcount @Items = items @RequestId = requestid end def deserialize(params) @TotalCount = params['TotalCount'] unless params['Items'].nil? @Items = [] params['Items'].each do |i| subscribeinfo_tmp = SubscribeInfo.new subscribeinfo_tmp.deserialize(i) @Items << subscribeinfo_tmp end end @RequestId = params['RequestId'] end end # DescribeSubscribeReturnable请求参数结构体 class DescribeSubscribeReturnableRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的ID # @type SubscribeId: String attr_accessor :SubscribeId def initialize(subscribeid=nil) @SubscribeId = subscribeid end def deserialize(params) @SubscribeId = params['SubscribeId'] end end # DescribeSubscribeReturnable返回参数结构体 class DescribeSubscribeReturnableResponse < TencentCloud::Common::AbstractModel # @param IsReturnable: 实例是否支持退还/退货 # @type IsReturnable: Boolean # @param ReturnFailMessage: 不支持退还的原因 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ReturnFailMessage: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :IsReturnable, :ReturnFailMessage, :RequestId def initialize(isreturnable=nil, returnfailmessage=nil, requestid=nil) @IsReturnable = isreturnable @ReturnFailMessage = returnfailmessage @RequestId = requestid end def deserialize(params) @IsReturnable = params['IsReturnable'] @ReturnFailMessage = params['ReturnFailMessage'] @RequestId = params['RequestId'] end end # DescribeSyncJobs请求参数结构体 class DescribeSyncJobsRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id,如sync-werwfs23 # @type JobId: String # @param JobName: 同步任务名 # @type JobName: String # @param Order: 排序字段,可以取值为CreateTime # @type Order: String # @param OrderSeq: 排序方式,升序为ASC,降序为DESC,默认为CreateTime降序 # @type OrderSeq: String # @param Offset: 偏移量,默认为0 # @type Offset: Integer # @param Limit: 返回同步任务实例数量,默认20,有效区间[1,100] # @type Limit: Integer # @param Status: 状态集合,如Initialized,CheckPass,Running,ResumableErr,Stopped # @type Status: Array # @param RunMode: 运行模式,如Immediate:立即运行,Timed:定时运行 # @type RunMode: String # @param JobType: 任务类型,如mysql2mysql:msyql同步到mysql # @type JobType: String # @param PayMode: 付费类型,PrePay:预付费,PostPay:后付费 # @type PayMode: String # @param TagFilters: tag # @type TagFilters: Array attr_accessor :JobId, :JobName, :Order, :OrderSeq, :Offset, :Limit, :Status, :RunMode, :JobType, :PayMode, :TagFilters def initialize(jobid=nil, jobname=nil, order=nil, orderseq=nil, offset=nil, limit=nil, status=nil, runmode=nil, jobtype=nil, paymode=nil, tagfilters=nil) @JobId = jobid @JobName = jobname @Order = order @OrderSeq = orderseq @Offset = offset @Limit = limit @Status = status @RunMode = runmode @JobType = jobtype @PayMode = paymode @TagFilters = tagfilters end def deserialize(params) @JobId = params['JobId'] @JobName = params['JobName'] @Order = params['Order'] @OrderSeq = params['OrderSeq'] @Offset = params['Offset'] @Limit = params['Limit'] @Status = params['Status'] @RunMode = params['RunMode'] @JobType = params['JobType'] @PayMode = params['PayMode'] unless params['TagFilters'].nil? @TagFilters = [] params['TagFilters'].each do |i| tagfilter_tmp = TagFilter.new tagfilter_tmp.deserialize(i) @TagFilters << tagfilter_tmp end end end end # DescribeSyncJobs返回参数结构体 class DescribeSyncJobsResponse < TencentCloud::Common::AbstractModel # @param TotalCount: 任务数目 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param JobList: 任务详情数组 # 注意:此字段可能返回 null,表示取不到有效值。 # @type JobList: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :TotalCount, :JobList, :RequestId def initialize(totalcount=nil, joblist=nil, requestid=nil) @TotalCount = totalcount @JobList = joblist @RequestId = requestid end def deserialize(params) @TotalCount = params['TotalCount'] unless params['JobList'].nil? @JobList = [] params['JobList'].each do |i| syncjobinfo_tmp = SyncJobInfo.new syncjobinfo_tmp.deserialize(i) @JobList << syncjobinfo_tmp end end @RequestId = params['RequestId'] end end # DestroyIsolatedSubscribe请求参数结构体 class DestroyIsolatedSubscribeRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的ID # @type SubscribeId: String attr_accessor :SubscribeId def initialize(subscribeid=nil) @SubscribeId = subscribeid end def deserialize(params) @SubscribeId = params['SubscribeId'] end end # DestroyIsolatedSubscribe返回参数结构体 class DestroyIsolatedSubscribeResponse < 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 # DestroyMigrateJob请求参数结构体 class DestroyMigrateJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # DestroyMigrateJob返回参数结构体 class DestroyMigrateJobResponse < 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 # DestroySyncJob请求参数结构体 class DestroySyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # DestroySyncJob返回参数结构体 class DestroySyncJobResponse < 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 DetailCheckItem < TencentCloud::Common::AbstractModel # @param CheckItemName: 检查项的名称,如:源实例权限检查 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CheckItemName: String # @param Description: 检查项详细内容 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Description: String # @param CheckResult: pass(通过),failed(失败), warning(校验有警告,但仍通过) # 注意:此字段可能返回 null,表示取不到有效值。 # @type CheckResult: String # @param FailureReason: 检查项失败原因 # 注意:此字段可能返回 null,表示取不到有效值。 # @type FailureReason: String # @param Solution: 解决方案 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Solution: String # @param ErrorLog: 运行报错日志 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ErrorLog: Array # @param HelpDoc: 详细帮助的文档链接 # 注意:此字段可能返回 null,表示取不到有效值。 # @type HelpDoc: Array # @param SkipInfo: 跳过风险文案 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SkipInfo: String attr_accessor :CheckItemName, :Description, :CheckResult, :FailureReason, :Solution, :ErrorLog, :HelpDoc, :SkipInfo def initialize(checkitemname=nil, description=nil, checkresult=nil, failurereason=nil, solution=nil, errorlog=nil, helpdoc=nil, skipinfo=nil) @CheckItemName = checkitemname @Description = description @CheckResult = checkresult @FailureReason = failurereason @Solution = solution @ErrorLog = errorlog @HelpDoc = helpdoc @SkipInfo = skipinfo end def deserialize(params) @CheckItemName = params['CheckItemName'] @Description = params['Description'] @CheckResult = params['CheckResult'] @FailureReason = params['FailureReason'] @Solution = params['Solution'] @ErrorLog = params['ErrorLog'] @HelpDoc = params['HelpDoc'] @SkipInfo = params['SkipInfo'] end end # 数据库不一致的详情,mongodb业务用到 class DifferenceAdvancedObjectsDetail < TencentCloud::Common::AbstractModel # @param TotalCount: 总数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param Items: 不一致详情 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Items: Array attr_accessor :TotalCount, :Items def initialize(totalcount=nil, items=nil) @TotalCount = totalcount @Items = items end def deserialize(params) @TotalCount = params['TotalCount'] unless params['Items'].nil? @Items = [] params['Items'].each do |i| advancedobjectsitem_tmp = AdvancedObjectsItem.new advancedobjectsitem_tmp.deserialize(i) @Items << advancedobjectsitem_tmp end end end end # 数据不一致详情 class DifferenceData < TencentCloud::Common::AbstractModel # @param Db: 数据库名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Db: String # @param Table: 集合 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Table: String # @param SrcChunk: 源端ID # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcChunk: String # @param DstChunk: 目标端ID # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstChunk: String # @param SrcItem: 源端值 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcItem: String # @param DstItem: 目标端值 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstItem: String # @param UpdatedAt: 更新时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type UpdatedAt: String attr_accessor :Db, :Table, :SrcChunk, :DstChunk, :SrcItem, :DstItem, :UpdatedAt def initialize(db=nil, table=nil, srcchunk=nil, dstchunk=nil, srcitem=nil, dstitem=nil, updatedat=nil) @Db = db @Table = table @SrcChunk = srcchunk @DstChunk = dstchunk @SrcItem = srcitem @DstItem = dstitem @UpdatedAt = updatedat end def deserialize(params) @Db = params['Db'] @Table = params['Table'] @SrcChunk = params['SrcChunk'] @DstChunk = params['DstChunk'] @SrcItem = params['SrcItem'] @DstItem = params['DstItem'] @UpdatedAt = params['UpdatedAt'] end end # mongodb数据不一致性详情 class DifferenceDataDetail < TencentCloud::Common::AbstractModel # @param TotalCount: 总数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param Items: mongo数据不一致详细列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Items: Array attr_accessor :TotalCount, :Items def initialize(totalcount=nil, items=nil) @TotalCount = totalcount @Items = items end def deserialize(params) @TotalCount = params['TotalCount'] unless params['Items'].nil? @Items = [] params['Items'].each do |i| differencedata_tmp = DifferenceData.new differencedata_tmp.deserialize(i) @Items << differencedata_tmp end end end end # 数据不一致的表详情 class DifferenceDetail < TencentCloud::Common::AbstractModel # @param TotalCount: 数据不一致的表数量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param Items: 校验不一致的表详情 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Items: Array attr_accessor :TotalCount, :Items def initialize(totalcount=nil, items=nil) @TotalCount = totalcount @Items = items end def deserialize(params) @TotalCount = params['TotalCount'] unless params['Items'].nil? @Items = [] params['Items'].each do |i| differenceitem_tmp = DifferenceItem.new differenceitem_tmp.deserialize(i) @Items << differenceitem_tmp end end end end # 校验不一致的表详情 class DifferenceItem < TencentCloud::Common::AbstractModel # @param Db: 数据库名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Db: String # @param Table: 表名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Table: String # @param Chunk: 分块号 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Chunk: Integer # @param SrcItem: 源库数值 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcItem: String # @param DstItem: 目标库数值 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstItem: String # @param IndexName: 索引名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type IndexName: String # @param LowerBoundary: 索引下边界 # 注意:此字段可能返回 null,表示取不到有效值。 # @type LowerBoundary: String # @param UpperBoundary: 索引上边界 # 注意:此字段可能返回 null,表示取不到有效值。 # @type UpperBoundary: String # @param CostTime: 对比消耗时间,单位为 ms # 注意:此字段可能返回 null,表示取不到有效值。 # @type CostTime: Float # @param FinishedAt: 完成时间 # 注意:此字段可能返回 null,表示取不到有效值。 # @type FinishedAt: String attr_accessor :Db, :Table, :Chunk, :SrcItem, :DstItem, :IndexName, :LowerBoundary, :UpperBoundary, :CostTime, :FinishedAt def initialize(db=nil, table=nil, chunk=nil, srcitem=nil, dstitem=nil, indexname=nil, lowerboundary=nil, upperboundary=nil, costtime=nil, finishedat=nil) @Db = db @Table = table @Chunk = chunk @SrcItem = srcitem @DstItem = dstitem @IndexName = indexname @LowerBoundary = lowerboundary @UpperBoundary = upperboundary @CostTime = costtime @FinishedAt = finishedat end def deserialize(params) @Db = params['Db'] @Table = params['Table'] @Chunk = params['Chunk'] @SrcItem = params['SrcItem'] @DstItem = params['DstItem'] @IndexName = params['IndexName'] @LowerBoundary = params['LowerBoundary'] @UpperBoundary = params['UpperBoundary'] @CostTime = params['CostTime'] @FinishedAt = params['FinishedAt'] end end # mongodb行数校验不一致性详情结果 class DifferenceRowDetail < TencentCloud::Common::AbstractModel # @param TotalCount: 不一致总数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param Items: 不一致列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Items: Array attr_accessor :TotalCount, :Items def initialize(totalcount=nil, items=nil) @TotalCount = totalcount @Items = items end def deserialize(params) @TotalCount = params['TotalCount'] unless params['Items'].nil? @Items = [] params['Items'].each do |i| rowscountdifference_tmp = RowsCountDifference.new rowscountdifference_tmp.deserialize(i) @Items << rowscountdifference_tmp end end end end # 订阅任务的kafka分区规则。符合库名和表名正则表达式的数据将按照RuleType计算该条数据将被投递的kafka分区。如果配置了多个规则,将按照配置的顺序,第一条命中的规则生效。 class DistributeRule < TencentCloud::Common::AbstractModel # @param RuleType: 规则类型。非mongo产品的枚举值为: table-按表名分区,pk-按表名+主键分区,cols-按列名分区。mongo的枚举值为:collection-按集合名分区、collectionAndObjectId-按集合+主键分区。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type RuleType: String # @param DbPattern: 库名匹配规则,请填写正则表达式 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DbPattern: String # @param TablePattern: 表名匹配规则,如果 DatabaseType 为 mongodb,则匹配集合名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TablePattern: String # @param Columns: 列名。如果 RuleType 为 cols,此项必填。订阅任务会用该列的值计算分区。mongo没有按列分区,因此也不用传这个字段。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Columns: Array attr_accessor :RuleType, :DbPattern, :TablePattern, :Columns def initialize(ruletype=nil, dbpattern=nil, tablepattern=nil, columns=nil) @RuleType = ruletype @DbPattern = dbpattern @TablePattern = tablepattern @Columns = columns end def deserialize(params) @RuleType = params['RuleType'] @DbPattern = params['DbPattern'] @TablePattern = params['TablePattern'] @Columns = params['Columns'] end end # 数据同步中的选项 class DynamicOptions < TencentCloud::Common::AbstractModel # @param OpTypes: 所要同步的DML和DDL的选项,Insert(插入操作)、Update(更新操作)、Delete(删除操作)、DDL(结构同步),PartialDDL(自定义,和DdlOptions一起起作用 );必填、dts会用该值覆盖原有的值 # 注意:此字段可能返回 null,表示取不到有效值。 # @type OpTypes: Array # @param DdlOptions: DDL同步选项,具体描述要同步那些DDL; 当OpTypes取值PartialDDL时、字段不能为空;必填、dts会用该值覆盖原有的值 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DdlOptions: Array # @param ConflictHandleType: 冲突处理选项,ReportError(报错)、Ignore(忽略)、Cover(覆盖)、ConditionCover(条件覆盖); 目前目标端为kafka的链路不支持修改该配置 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConflictHandleType: String # @param ConflictHandleOption: 冲突处理的详细选项,如条件覆盖中的条件行和条件操作;不能部分更新该选项的内部字段;有更新时、需要全量更新该字段 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConflictHandleOption: :class:`Tencentcloud::Dts.v20211206.models.ConflictHandleOption` attr_accessor :OpTypes, :DdlOptions, :ConflictHandleType, :ConflictHandleOption def initialize(optypes=nil, ddloptions=nil, conflicthandletype=nil, conflicthandleoption=nil) @OpTypes = optypes @DdlOptions = ddloptions @ConflictHandleType = conflicthandletype @ConflictHandleOption = conflicthandleoption end def deserialize(params) @OpTypes = params['OpTypes'] unless params['DdlOptions'].nil? @DdlOptions = [] params['DdlOptions'].each do |i| ddloption_tmp = DdlOption.new ddloption_tmp.deserialize(i) @DdlOptions << ddloption_tmp end end @ConflictHandleType = params['ConflictHandleType'] unless params['ConflictHandleOption'].nil? @ConflictHandleOption = ConflictHandleOption.new @ConflictHandleOption.deserialize(params['ConflictHandleOption']) end end end # 数据同步中的描述源端和目的端的信息 class Endpoint < TencentCloud::Common::AbstractModel # @param Region: 地域英文名,如:ap-guangzhou # 注意:此字段可能返回 null,表示取不到有效值。 # @type Region: String # @param Role: 节点类型,proxy表示节点类型为主机,set表示节点类型为节点。proxy类型必须填在数组第一项。tdsqlmysql类型的源/目标配置必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Role: String # @param DbKernel: 数据库内核类型,tdsql中用于区分不同内核:percona,mariadb,mysql。注意TDSQL-C MySQL、TDSQL PostgreSQL无需填写此项值。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DbKernel: String # @param InstanceId: 数据库实例ID,格式如:cdb-powiqx8q # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceId: String # @param Ip: 实例的IP地址,接入类型为非cdb时此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Ip: String # @param Port: 实例端口,接入类型为非cdb时此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Port: Integer # @param User: 用户名,对于访问需要用户名密码认证的实例必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type User: String # @param Password: 密码,对于访问需要用户名密码认证的实例必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Password: String # @param DbName: 数据库名,数据库为cdwpg时,需要提供 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DbName: String # @param VpcId: 私有网络ID,对于私有网络、专线、VPN的接入方式此项必填,格式如:vpc-92jblxto # 注意:此字段可能返回 null,表示取不到有效值。 # @type VpcId: String # @param SubnetId: 私有网络下的子网ID,对于私有网络、专线、VPN的接入方式此项必填,格式如:subnet-3paxmkdz # 注意:此字段可能返回 null,表示取不到有效值。 # @type SubnetId: String # @param CvmInstanceId: CVM实例短ID,格式如:ins-olgl39y8,与云服务器控制台页面显示的实例ID相同。如果是CVM自建实例,需要传递此字段 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CvmInstanceId: String # @param UniqDcgId: 专线网关ID,对于专线接入类型此项必填,格式如:dcg-0rxtqqxb # 注意:此字段可能返回 null,表示取不到有效值。 # @type UniqDcgId: String # @param UniqVpnGwId: VPN网关ID,对于vpn接入类型此项必填,格式如:vpngw-9ghexg7q # 注意:此字段可能返回 null,表示取不到有效值。 # @type UniqVpnGwId: String # @param CcnId: 云联网ID,对于云联网接入类型此项必填,如:ccn-afp6kltc # 注意:此字段可能返回 null,表示取不到有效值。 # @type CcnId: String # @param Supplier: 云厂商类型,当实例为RDS实例时,填写为aliyun, 其他情况均填写others,默认为others # 注意:此字段可能返回 null,表示取不到有效值。 # @type Supplier: String # @param EngineVersion: 数据库版本,当实例为RDS实例时才有效,其他实例忽略,格式如:5.6或者5.7,默认为5.6 # 注意:此字段可能返回 null,表示取不到有效值。 # @type EngineVersion: String # @param Account: 实例所属账号,如果为跨账号实例此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Account: String # @param AccountMode: 资源所属账号 为空或self(表示本账号内资源)、other(表示跨账号资源) # 注意:此字段可能返回 null,表示取不到有效值。 # @type AccountMode: String # @param AccountRole: 跨账号同步时的角色,只允许[a-zA-Z0-9\-\_]+,如果为跨账号实例此项必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AccountRole: String # @param RoleExternalId: 外部角色id # 注意:此字段可能返回 null,表示取不到有效值。 # @type RoleExternalId: String # @param TmpSecretId: 临时密钥Id,可通过申请扮演角色临时访问凭证获取临时密钥https://cloud.tencent.com/document/product/1312/48197,其中角色资源RoleArn的定义可参考DTS跨账号同步文档(https://cloud.tencent.com/document/product/571/68729)第4节中关于角色的定义。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TmpSecretId: String # @param TmpSecretKey: 临时密钥Id,可通过申请扮演角色临时访问凭证获取临时密钥https://cloud.tencent.com/document/product/1312/48197,其中角色资源RoleArn的定义可参考DTS跨账号同步文档(https://cloud.tencent.com/document/product/571/68729)第4节中关于角色的定义。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TmpSecretKey: String # @param TmpToken: 临时密钥Id,可通过申请扮演角色临时访问凭证获取临时密钥https://cloud.tencent.com/document/product/1312/48197,其中角色资源RoleArn的定义可参考DTS跨账号同步文档(https://cloud.tencent.com/document/product/571/68729)第4节中关于角色的定义。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TmpToken: String # @param EncryptConn: 是否走加密传输、UnEncrypted表示不走加密传输,Encrypted表示走加密传输,默认UnEncrypted # 注意:此字段可能返回 null,表示取不到有效值。 # @type EncryptConn: String # @param DatabaseNetEnv: 数据库所属网络环境,AccessType为云联网(ccn)时必填, UserIDC表示用户IDC、TencentVPC表示腾讯云VPC; # 注意:此字段可能返回 null,表示取不到有效值。 # @type DatabaseNetEnv: String # @param CcnOwnerUin: 数据库为跨账号云联网下的实例时、表示云联网所属主账号 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CcnOwnerUin: String # @param ChildInstanceId: 数据库为cynos、且是cynos集群内的一个子数据库实例时、该参数为该子实例的ID # 注意:此字段可能返回 null,表示取不到有效值。 # @type ChildInstanceId: String # @param ChildInstanceType: 数据库为cynos、且是cynos集群内的一个子数据库实例时、该参数为该子实例的类型、例如:只读实例传ro、读写实例传rw # 注意:此字段可能返回 null,表示取不到有效值。 # @type ChildInstanceType: String # @param SetId: tdsql的分片id。如节点类型为set必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SetId: String attr_accessor :Region, :Role, :DbKernel, :InstanceId, :Ip, :Port, :User, :Password, :DbName, :VpcId, :SubnetId, :CvmInstanceId, :UniqDcgId, :UniqVpnGwId, :CcnId, :Supplier, :EngineVersion, :Account, :AccountMode, :AccountRole, :RoleExternalId, :TmpSecretId, :TmpSecretKey, :TmpToken, :EncryptConn, :DatabaseNetEnv, :CcnOwnerUin, :ChildInstanceId, :ChildInstanceType, :SetId def initialize(region=nil, role=nil, dbkernel=nil, instanceid=nil, ip=nil, port=nil, user=nil, password=nil, dbname=nil, vpcid=nil, subnetid=nil, cvminstanceid=nil, uniqdcgid=nil, uniqvpngwid=nil, ccnid=nil, supplier=nil, engineversion=nil, account=nil, accountmode=nil, accountrole=nil, roleexternalid=nil, tmpsecretid=nil, tmpsecretkey=nil, tmptoken=nil, encryptconn=nil, databasenetenv=nil, ccnowneruin=nil, childinstanceid=nil, childinstancetype=nil, setid=nil) @Region = region @Role = role @DbKernel = dbkernel @InstanceId = instanceid @Ip = ip @Port = port @User = user @Password = password @DbName = dbname @VpcId = vpcid @SubnetId = subnetid @CvmInstanceId = cvminstanceid @UniqDcgId = uniqdcgid @UniqVpnGwId = uniqvpngwid @CcnId = ccnid @Supplier = supplier @EngineVersion = engineversion @Account = account @AccountMode = accountmode @AccountRole = accountrole @RoleExternalId = roleexternalid @TmpSecretId = tmpsecretid @TmpSecretKey = tmpsecretkey @TmpToken = tmptoken @EncryptConn = encryptconn @DatabaseNetEnv = databasenetenv @CcnOwnerUin = ccnowneruin @ChildInstanceId = childinstanceid @ChildInstanceType = childinstancetype @SetId = setid end def deserialize(params) @Region = params['Region'] @Role = params['Role'] @DbKernel = params['DbKernel'] @InstanceId = params['InstanceId'] @Ip = params['Ip'] @Port = params['Port'] @User = params['User'] @Password = params['Password'] @DbName = params['DbName'] @VpcId = params['VpcId'] @SubnetId = params['SubnetId'] @CvmInstanceId = params['CvmInstanceId'] @UniqDcgId = params['UniqDcgId'] @UniqVpnGwId = params['UniqVpnGwId'] @CcnId = params['CcnId'] @Supplier = params['Supplier'] @EngineVersion = params['EngineVersion'] @Account = params['Account'] @AccountMode = params['AccountMode'] @AccountRole = params['AccountRole'] @RoleExternalId = params['RoleExternalId'] @TmpSecretId = params['TmpSecretId'] @TmpSecretKey = params['TmpSecretKey'] @TmpToken = params['TmpToken'] @EncryptConn = params['EncryptConn'] @DatabaseNetEnv = params['DatabaseNetEnv'] @CcnOwnerUin = params['CcnOwnerUin'] @ChildInstanceId = params['ChildInstanceId'] @ChildInstanceType = params['ChildInstanceType'] @SetId = params['SetId'] end end # 数据订阅的实例节点信息 class EndpointItem < TencentCloud::Common::AbstractModel # @param DatabaseRegion: 源库所在地域。如果 AccessType 为 ccn,请填vpc所在地域,因为此时不知道源库在哪个地域。其他接入方式,请填订阅任务所在地域,因为确保订阅任务与源库在同一地域是最优的网络方案。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DatabaseRegion: String # @param User: 用户名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type User: String # @param Password: 密码。作为入参时必填,作为出参时为空。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Password: String # @param InstanceId: 目标实例ID。如果 AccessType 为 cdb,此项必填。配置InstanceId时会查询并校验实例信息。mysql的查询接口经过了鉴权,请确保子用户有 cdb:DescribeDBInstances 的接口权限。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceId: String # @param CvmInstanceId: 云主机ID。如果 AccessType 为 cvm,此项必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CvmInstanceId: String # @param UniqDcgId: 专线网关ID。如果 AccessType 为 dcg,此项必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type UniqDcgId: String # @param CcnId: 云联网ID。如果 AccessType 为 ccn,此项必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CcnId: String # @param UniqVpnGwId: vpn网关ID。如果 AccessType 为 vpncloud,此项必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type UniqVpnGwId: String # @param VpcId: VpcID。如果 AccessType 为 dcg\ccn\vpncloud\vpc,此项必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type VpcId: String # @param SubnetId: 子网ID。如果 AccessType 为 dcg\ccn\vpncloud\vpc,此项必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SubnetId: String # @param HostName: 数据库地址,支持域名与IP。如果 AccessType 为 dcg\ccn\vpncloud\vpc\extranet\intranet,此项必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type HostName: String # @param Port: 数据库端口。如果 AccessType 为 dcg\ccn\vpncloud\vpc\extranet\intranet\cvm,此项必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Port: Integer # @param EncryptConn: 是否走加密传输,枚举值:UnEncrypted-不加密,Encrypted-加密。只有mysql支持,不填默认不加密,其他产品不填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type EncryptConn: String # @param DatabaseNetEnv: 数据库网络环境。如果 AccessType 为 ccn 此项必填。枚举值:UserIDC-自建idc,TencentVPC-腾讯云,Aws-aws,AliYun-阿里云,Others-其他。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DatabaseNetEnv: String # @param CcnOwnerUin: 云联网网关所属的主账号uin、跨账号云联网需要。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CcnOwnerUin: String # @param ExtraAttr: 为业务添加的额外信息。参数名作key,参数值作value。 tdpg必填参数:PgDatabase-订阅的库名。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExtraAttr: Array # @param ChildInstanceId: 数据库为cynos、且是cynos集群内的一个子数据库实例时、该参数为该子实例的ID # 注意:此字段可能返回 null,表示取不到有效值。 # @type ChildInstanceId: String # @param ChildInstanceType: 数据库为cynos、且是cynos集群内的一个子数据库实例时、该参数为该子实例的类型、例如:只读实例传ro、读写实例传rw # 注意:此字段可能返回 null,表示取不到有效值。 # @type ChildInstanceType: String attr_accessor :DatabaseRegion, :User, :Password, :InstanceId, :CvmInstanceId, :UniqDcgId, :CcnId, :UniqVpnGwId, :VpcId, :SubnetId, :HostName, :Port, :EncryptConn, :DatabaseNetEnv, :CcnOwnerUin, :ExtraAttr, :ChildInstanceId, :ChildInstanceType def initialize(databaseregion=nil, user=nil, password=nil, instanceid=nil, cvminstanceid=nil, uniqdcgid=nil, ccnid=nil, uniqvpngwid=nil, vpcid=nil, subnetid=nil, hostname=nil, port=nil, encryptconn=nil, databasenetenv=nil, ccnowneruin=nil, extraattr=nil, childinstanceid=nil, childinstancetype=nil) @DatabaseRegion = databaseregion @User = user @Password = password @InstanceId = instanceid @CvmInstanceId = cvminstanceid @UniqDcgId = uniqdcgid @CcnId = ccnid @UniqVpnGwId = uniqvpngwid @VpcId = vpcid @SubnetId = subnetid @HostName = hostname @Port = port @EncryptConn = encryptconn @DatabaseNetEnv = databasenetenv @CcnOwnerUin = ccnowneruin @ExtraAttr = extraattr @ChildInstanceId = childinstanceid @ChildInstanceType = childinstancetype end def deserialize(params) @DatabaseRegion = params['DatabaseRegion'] @User = params['User'] @Password = params['Password'] @InstanceId = params['InstanceId'] @CvmInstanceId = params['CvmInstanceId'] @UniqDcgId = params['UniqDcgId'] @CcnId = params['CcnId'] @UniqVpnGwId = params['UniqVpnGwId'] @VpcId = params['VpcId'] @SubnetId = params['SubnetId'] @HostName = params['HostName'] @Port = params['Port'] @EncryptConn = params['EncryptConn'] @DatabaseNetEnv = params['DatabaseNetEnv'] @CcnOwnerUin = params['CcnOwnerUin'] unless params['ExtraAttr'].nil? @ExtraAttr = [] params['ExtraAttr'].each do |i| keyvaluepairoption_tmp = KeyValuePairOption.new keyvaluepairoption_tmp.deserialize(i) @ExtraAttr << keyvaluepairoption_tmp end end @ChildInstanceId = params['ChildInstanceId'] @ChildInstanceType = params['ChildInstanceType'] end end # 错误信息及其解决方案 class ErrInfo < TencentCloud::Common::AbstractModel # @param Reason: 错误原因 # @type Reason: String # @param Message: 错误信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Message: String # @param Solution: 解决方案 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Solution: String attr_accessor :Reason, :Message, :Solution def initialize(reason=nil, message=nil, solution=nil) @Reason = reason @Message = message @Solution = solution end def deserialize(params) @Reason = params['Reason'] @Message = params['Message'] @Solution = params['Solution'] end end # 任务错误信息 class ErrorInfoItem < TencentCloud::Common::AbstractModel # @param Code: 错误码 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Code: String # @param Solution: 解决方案 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Solution: String # @param ErrorLog: 错误日志信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ErrorLog: String # @param HelpDoc: 文档提示 # 注意:此字段可能返回 null,表示取不到有效值。 # @type HelpDoc: String attr_accessor :Code, :Solution, :ErrorLog, :HelpDoc def initialize(code=nil, solution=nil, errorlog=nil, helpdoc=nil) @Code = code @Solution = solution @ErrorLog = errorlog @HelpDoc = helpdoc end def deserialize(params) @Code = params['Code'] @Solution = params['Solution'] @ErrorLog = params['ErrorLog'] @HelpDoc = params['HelpDoc'] end end # kafka消费者组详情 class GroupInfo < TencentCloud::Common::AbstractModel # @param Account: 消费者组账号 # @type Account: String # @param ConsumerGroupName: 消费者组名称 # @type ConsumerGroupName: String # @param Description: 消费者组备注 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Description: String # @param ConsumerGroupOffset: 消费组偏移量。该字段是为了兼容以前单Partition的情况,取值为最后一个分区的偏移量。各分区的偏移量详见StateOfPartition字段 # @type ConsumerGroupOffset: Integer # @param ConsumerGroupLag: 消费组未消费的数据量。该字段是为了兼容以前单Partition的情况,取值为最后一个分区未消费的数据量。各分区未消费数据量详见StateOfPartition字段 # @type ConsumerGroupLag: Integer # @param Latency: 消费延迟(单位为秒) # @type Latency: Integer # @param StateOfPartition: 各分区的消费状态 # @type StateOfPartition: Array # @param CreatedAt: 消费者组创建时间,格式为YYYY-MM-DD hh:mm:ss # @type CreatedAt: String # @param UpdatedAt: 消费者组修改时间,格式为YYYY-MM-DD hh:mm:ss # @type UpdatedAt: String # @param ConsumerGroupState: 消费者组状态,包括Dead、Empty、Stable等,只有Dead和Empty两种状态可以执行reset操作 # @type ConsumerGroupState: String # @param PartitionAssignment: 每个消费者正在消费的分区 # 注意:此字段可能返回 null,表示取不到有效值。 # @type PartitionAssignment: Array attr_accessor :Account, :ConsumerGroupName, :Description, :ConsumerGroupOffset, :ConsumerGroupLag, :Latency, :StateOfPartition, :CreatedAt, :UpdatedAt, :ConsumerGroupState, :PartitionAssignment def initialize(account=nil, consumergroupname=nil, description=nil, consumergroupoffset=nil, consumergrouplag=nil, latency=nil, stateofpartition=nil, createdat=nil, updatedat=nil, consumergroupstate=nil, partitionassignment=nil) @Account = account @ConsumerGroupName = consumergroupname @Description = description @ConsumerGroupOffset = consumergroupoffset @ConsumerGroupLag = consumergrouplag @Latency = latency @StateOfPartition = stateofpartition @CreatedAt = createdat @UpdatedAt = updatedat @ConsumerGroupState = consumergroupstate @PartitionAssignment = partitionassignment end def deserialize(params) @Account = params['Account'] @ConsumerGroupName = params['ConsumerGroupName'] @Description = params['Description'] @ConsumerGroupOffset = params['ConsumerGroupOffset'] @ConsumerGroupLag = params['ConsumerGroupLag'] @Latency = params['Latency'] unless params['StateOfPartition'].nil? @StateOfPartition = [] params['StateOfPartition'].each do |i| monitorinfo_tmp = MonitorInfo.new monitorinfo_tmp.deserialize(i) @StateOfPartition << monitorinfo_tmp end end @CreatedAt = params['CreatedAt'] @UpdatedAt = params['UpdatedAt'] @ConsumerGroupState = params['ConsumerGroupState'] unless params['PartitionAssignment'].nil? @PartitionAssignment = [] params['PartitionAssignment'].each do |i| partitionassignment_tmp = PartitionAssignment.new partitionassignment_tmp.deserialize(i) @PartitionAssignment << partitionassignment_tmp end end end end # IsolateMigrateJob请求参数结构体 class IsolateMigrateJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # IsolateMigrateJob返回参数结构体 class IsolateMigrateJobResponse < 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 # IsolateSubscribe请求参数结构体 class IsolateSubscribeRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 订阅实例ID # @type SubscribeId: String attr_accessor :SubscribeId def initialize(subscribeid=nil) @SubscribeId = subscribeid end def deserialize(params) @SubscribeId = params['SubscribeId'] end end # IsolateSubscribe返回参数结构体 class IsolateSubscribeResponse < 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 # IsolateSyncJob请求参数结构体 class IsolateSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # IsolateSyncJob返回参数结构体 class IsolateSyncJobResponse < 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 JobItem < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # 注意:此字段可能返回 null,表示取不到有效值。 # @type JobId: String # @param JobName: 数据迁移任务名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type JobName: String # @param CreateTime: 任务创建(提交)时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type CreateTime: String # @param UpdateTime: 任务更新时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type UpdateTime: String # @param StartTime: 任务开始执行时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartTime: String # @param EndTime: 任务执行结束时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type EndTime: String # @param BriefMsg: 迁移任务错误信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type BriefMsg: String # @param Status: 任务状态,取值为:creating(创建中)、created(创建完成)、checking(校验中)、checkPass(校验通过)、checkNotPass(校验不通过)、readyRun(准备运行)、running(任务运行)、readyComplete(准备完成)、success(任务成功)、failed(任务失败)、stopping(中止中)、completing(完成中)、 # pausing(暂停中)、 # manualPaused(已暂停) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param RunMode: 任务运行模式,值包括:immediate(立即运行),timed(定时运行) # 注意:此字段可能返回 null,表示取不到有效值。 # @type RunMode: String # @param ExpectRunTime: 期待启动时间,当RunMode取值为timed时,此值必填,形如:2022-07-11 16:20:49 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExpectRunTime: String # @param Action: 任务操作信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Action: :class:`Tencentcloud::Dts.v20211206.models.MigrateAction` # @param StepInfo: 迁移执行过程信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepInfo: :class:`Tencentcloud::Dts.v20211206.models.MigrateDetailInfo` # @param SrcInfo: 源实例信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcInfo: :class:`Tencentcloud::Dts.v20211206.models.DBEndpointInfo` # @param DstInfo: 目标端信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstInfo: :class:`Tencentcloud::Dts.v20211206.models.DBEndpointInfo` # @param CompareTask: 数据一致性校验结果 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CompareTask: :class:`Tencentcloud::Dts.v20211206.models.CompareTaskInfo` # @param TradeInfo: 计费状态信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TradeInfo: :class:`Tencentcloud::Dts.v20211206.models.TradeInfo` # @param Tags: 标签信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tags: Array # @param AutoRetryTimeRangeMinutes: 自动重试时间段信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AutoRetryTimeRangeMinutes: Integer # @param DumperResumeCtrl: 全量导出可重入标识:enum::"yes"/"no"。yes表示当前任务可重入、no表示当前任务处于全量导出且不可重入阶段;如果在该值为no时重启任务导出流程不支持断点续传 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DumperResumeCtrl: String attr_accessor :JobId, :JobName, :CreateTime, :UpdateTime, :StartTime, :EndTime, :BriefMsg, :Status, :RunMode, :ExpectRunTime, :Action, :StepInfo, :SrcInfo, :DstInfo, :CompareTask, :TradeInfo, :Tags, :AutoRetryTimeRangeMinutes, :DumperResumeCtrl def initialize(jobid=nil, jobname=nil, createtime=nil, updatetime=nil, starttime=nil, endtime=nil, briefmsg=nil, status=nil, runmode=nil, expectruntime=nil, action=nil, stepinfo=nil, srcinfo=nil, dstinfo=nil, comparetask=nil, tradeinfo=nil, tags=nil, autoretrytimerangeminutes=nil, dumperresumectrl=nil) @JobId = jobid @JobName = jobname @CreateTime = createtime @UpdateTime = updatetime @StartTime = starttime @EndTime = endtime @BriefMsg = briefmsg @Status = status @RunMode = runmode @ExpectRunTime = expectruntime @Action = action @StepInfo = stepinfo @SrcInfo = srcinfo @DstInfo = dstinfo @CompareTask = comparetask @TradeInfo = tradeinfo @Tags = tags @AutoRetryTimeRangeMinutes = autoretrytimerangeminutes @DumperResumeCtrl = dumperresumectrl end def deserialize(params) @JobId = params['JobId'] @JobName = params['JobName'] @CreateTime = params['CreateTime'] @UpdateTime = params['UpdateTime'] @StartTime = params['StartTime'] @EndTime = params['EndTime'] @BriefMsg = params['BriefMsg'] @Status = params['Status'] @RunMode = params['RunMode'] @ExpectRunTime = params['ExpectRunTime'] unless params['Action'].nil? @Action = MigrateAction.new @Action.deserialize(params['Action']) end unless params['StepInfo'].nil? @StepInfo = MigrateDetailInfo.new @StepInfo.deserialize(params['StepInfo']) end unless params['SrcInfo'].nil? @SrcInfo = DBEndpointInfo.new @SrcInfo.deserialize(params['SrcInfo']) end unless params['DstInfo'].nil? @DstInfo = DBEndpointInfo.new @DstInfo.deserialize(params['DstInfo']) end unless params['CompareTask'].nil? @CompareTask = CompareTaskInfo.new @CompareTask.deserialize(params['CompareTask']) end unless params['TradeInfo'].nil? @TradeInfo = TradeInfo.new @TradeInfo.deserialize(params['TradeInfo']) end unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| tagitem_tmp = TagItem.new tagitem_tmp.deserialize(i) @Tags << tagitem_tmp end end @AutoRetryTimeRangeMinutes = params['AutoRetryTimeRangeMinutes'] @DumperResumeCtrl = params['DumperResumeCtrl'] end end # 目标端为kakfa时添加的同步选项字段 class KafkaOption < TencentCloud::Common::AbstractModel # @param DataType: 投递到kafka的数据类型,如Avro,Json,canal-pb,canal-json # @type DataType: String # @param TopicType: 同步topic策略,如Single(集中投递到单topic),Multi (自定义topic名称) # @type TopicType: String # @param DDLTopicName: 用于存储ddl的topic # @type DDLTopicName: String # @param TopicRules: 单topic和自定义topic的描述 # @type TopicRules: Array attr_accessor :DataType, :TopicType, :DDLTopicName, :TopicRules def initialize(datatype=nil, topictype=nil, ddltopicname=nil, topicrules=nil) @DataType = datatype @TopicType = topictype @DDLTopicName = ddltopicname @TopicRules = topicrules end def deserialize(params) @DataType = params['DataType'] @TopicType = params['TopicType'] @DDLTopicName = params['DDLTopicName'] unless params['TopicRules'].nil? @TopicRules = [] params['TopicRules'].each do |i| topicrule_tmp = TopicRule.new topicrule_tmp.deserialize(i) @TopicRules << topicrule_tmp end end end end # 存放配置时的额外信息 class KeyValuePairOption < TencentCloud::Common::AbstractModel # @param Key: 选项key # 注意:此字段可能返回 null,表示取不到有效值。 # @type Key: String # @param Value: 选项value # 注意:此字段可能返回 null,表示取不到有效值。 # @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 MigrateAction < TencentCloud::Common::AbstractModel # @param AllAction: 任务的所有操作列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AllAction: Array # @param AllowedAction: 任务在当前状态下允许的操作列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AllowedAction: Array attr_accessor :AllAction, :AllowedAction def initialize(allaction=nil, allowedaction=nil) @AllAction = allaction @AllowedAction = allowedaction end def deserialize(params) @AllAction = params['AllAction'] @AllowedAction = params['AllowedAction'] end end # 查询迁移实例列表的实例对象 class MigrateDBItem < TencentCloud::Common::AbstractModel # @param InstanceId: 实例ID # @type InstanceId: String # @param InstanceName: 实例名称 # @type InstanceName: String # @param Vip: 实例Vip # @type Vip: String # @param Vport: 实例Vport # @type Vport: Integer # @param Usable: 是否可以作为迁移对象,1-可以,0-不可以 # @type Usable: Integer # @param Hint: 不可以作为迁移对象的原因 # @type Hint: String attr_accessor :InstanceId, :InstanceName, :Vip, :Vport, :Usable, :Hint def initialize(instanceid=nil, instancename=nil, vip=nil, vport=nil, usable=nil, hint=nil) @InstanceId = instanceid @InstanceName = instancename @Vip = vip @Vport = vport @Usable = usable @Hint = hint end def deserialize(params) @InstanceId = params['InstanceId'] @InstanceName = params['InstanceName'] @Vip = params['Vip'] @Vport = params['Vport'] @Usable = params['Usable'] @Hint = params['Hint'] end end # 迁移执行过程信息 class MigrateDetailInfo < TencentCloud::Common::AbstractModel # @param StepAll: 总步骤数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepAll: Integer # @param StepNow: 当前步骤 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepNow: Integer # @param MasterSlaveDistance: 主从差距,MB;只在任务正常,迁移或者同步的最后一步(追Binlog的阶段才有校),如果是非法值,返回-1 # 注意:此字段可能返回 null,表示取不到有效值。 # @type MasterSlaveDistance: Integer # @param SecondsBehindMaster: 主从差距,秒;只在任务正常,迁移或者同步的最后一步(追Binlog的阶段才有校),如果是非法值,返回-1 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SecondsBehindMaster: Integer # @param StepInfo: 步骤信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepInfo: Array attr_accessor :StepAll, :StepNow, :MasterSlaveDistance, :SecondsBehindMaster, :StepInfo def initialize(stepall=nil, stepnow=nil, masterslavedistance=nil, secondsbehindmaster=nil, stepinfo=nil) @StepAll = stepall @StepNow = stepnow @MasterSlaveDistance = masterslavedistance @SecondsBehindMaster = secondsbehindmaster @StepInfo = stepinfo end def deserialize(params) @StepAll = params['StepAll'] @StepNow = params['StepNow'] @MasterSlaveDistance = params['MasterSlaveDistance'] @SecondsBehindMaster = params['SecondsBehindMaster'] unless params['StepInfo'].nil? @StepInfo = [] params['StepInfo'].each do |i| stepdetailinfo_tmp = StepDetailInfo.new stepdetailinfo_tmp.deserialize(i) @StepInfo << stepdetailinfo_tmp end end end end # 迁移选项,描述任务如何执行迁移等一系列配置信息 class MigrateOption < TencentCloud::Common::AbstractModel # @param DatabaseTable: 迁移对象选项,需要告知迁移服务迁移哪些库表对象 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DatabaseTable: :class:`Tencentcloud::Dts.v20211206.models.DatabaseTableObject` # @param MigrateType: 迁移类型,full(全量迁移),structure(结构迁移),fullAndIncrement(全量加增量迁移), 默认为fullAndIncrement;注意redis,keewidb产品只支持fullAndIncrement类型。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type MigrateType: String # @param Consistency: 数据一致性校验选项, 默认为不开启一致性校验 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Consistency: :class:`Tencentcloud::Dts.v20211206.models.ConsistencyOption` # @param IsMigrateAccount: 是否迁移账号,true(迁移账号),false(不迁移账号) # 注意:此字段可能返回 null,表示取不到有效值。 # @type IsMigrateAccount: Boolean # @param IsOverrideRoot: 是否用源库Root账户覆盖目标库,值包括:false-不覆盖,true-覆盖,选择库表或者结构迁移时应该为false,注意只对旧版迁移有效 # 注意:此字段可能返回 null,表示取不到有效值。 # @type IsOverrideRoot: Boolean # @param IsDstReadOnly: 是否在迁移时设置目标库只读(仅对mysql有效),true(设置只读)、false(不设置只读,默认此值) # 注意:此字段可能返回 null,表示取不到有效值。 # @type IsDstReadOnly: Boolean # @param ExtraAttr: 其他附加信息,对于特定库可设置额外参数,Redis可定义如下的参数: # ["DstWriteMode":normal, 目标库写入模式,可取值clearData(清空目标实例数据)、overwrite(以覆盖写的方式执行任务)、normal(跟正常流程一样,不做额外动作) "IsDstReadOnly":true, 是否在迁移时设置目标库只读,true(设置只读)、false(不设置只读) "ClientOutputBufferHardLimit":512, 从机缓冲区的硬性容量限制(MB) "ClientOutputBufferSoftLimit":512, 从机缓冲区的软性容量限制(MB) "ClientOutputBufferPersistTime":60, 从机缓冲区的软性限制持续时间(秒) "ReplBacklogSize":512, 环形缓冲区容量限制(MB) "ReplTimeout":120, 复制超时时间(秒) "IsExpireKey":"true",过期key自动淘汰] # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExtraAttr: Array # @param MigrateWay: pgsql迁移分类:logical(逻辑迁移)、physical(物理迁移) # 注意:此字段可能返回 null,表示取不到有效值。 # @type MigrateWay: String attr_accessor :DatabaseTable, :MigrateType, :Consistency, :IsMigrateAccount, :IsOverrideRoot, :IsDstReadOnly, :ExtraAttr, :MigrateWay def initialize(databasetable=nil, migratetype=nil, consistency=nil, ismigrateaccount=nil, isoverrideroot=nil, isdstreadonly=nil, extraattr=nil, migrateway=nil) @DatabaseTable = databasetable @MigrateType = migratetype @Consistency = consistency @IsMigrateAccount = ismigrateaccount @IsOverrideRoot = isoverrideroot @IsDstReadOnly = isdstreadonly @ExtraAttr = extraattr @MigrateWay = migrateway end def deserialize(params) unless params['DatabaseTable'].nil? @DatabaseTable = DatabaseTableObject.new @DatabaseTable.deserialize(params['DatabaseTable']) end @MigrateType = params['MigrateType'] unless params['Consistency'].nil? @Consistency = ConsistencyOption.new @Consistency.deserialize(params['Consistency']) end @IsMigrateAccount = params['IsMigrateAccount'] @IsOverrideRoot = params['IsOverrideRoot'] @IsDstReadOnly = params['IsDstReadOnly'] unless params['ExtraAttr'].nil? @ExtraAttr = [] params['ExtraAttr'].each do |i| keyvaluepairoption_tmp = KeyValuePairOption.new keyvaluepairoption_tmp.deserialize(i) @ExtraAttr << keyvaluepairoption_tmp end end @MigrateWay = params['MigrateWay'] end end # 数据数据订阅的对象,用于修改订阅对象接口。与SubscribeObject结构类似,只是类型和参数名不同。 class ModifiedSubscribeObject < TencentCloud::Common::AbstractModel # @param ObjectsType: 订阅对象的类型,枚举值为:0-库,1-表(该值对于mongo任务来说,是集合) 。 # 注意:mongo只支持全实例、单库或者单集合订阅,因此该字段不要与SubscribeObjectType冲突。如:SubscribeObjectType=4,表示mongo单库订阅,那么该字段应该传0。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ObjectsType: Integer # @param DatabaseName: 订阅数据库的名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DatabaseName: String # @param TableNames: 订阅数据库中表(或集合)的名称。如果 ObjectsType 为 1,那么此字段为必填,且不为空; # 注意:此字段可能返回 null,表示取不到有效值。 # @type TableNames: Array attr_accessor :ObjectsType, :DatabaseName, :TableNames def initialize(objectstype=nil, databasename=nil, tablenames=nil) @ObjectsType = objectstype @DatabaseName = databasename @TableNames = tablenames end def deserialize(params) @ObjectsType = params['ObjectsType'] @DatabaseName = params['DatabaseName'] @TableNames = params['TableNames'] end end # ModifyCompareTaskName请求参数结构体 class ModifyCompareTaskNameRequest < TencentCloud::Common::AbstractModel # @param JobId: 迁移任务 Id # @type JobId: String # @param CompareTaskId: 对比任务 ID,形如:dts-8yv4w2i1-cmp-37skmii9 # @type CompareTaskId: String # @param TaskName: 一致性校验任务名称 # @type TaskName: String attr_accessor :JobId, :CompareTaskId, :TaskName def initialize(jobid=nil, comparetaskid=nil, taskname=nil) @JobId = jobid @CompareTaskId = comparetaskid @TaskName = taskname end def deserialize(params) @JobId = params['JobId'] @CompareTaskId = params['CompareTaskId'] @TaskName = params['TaskName'] end end # ModifyCompareTaskName返回参数结构体 class ModifyCompareTaskNameResponse < 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 # ModifyCompareTask请求参数结构体 class ModifyCompareTaskRequest < TencentCloud::Common::AbstractModel # @param JobId: 任务 Id # @type JobId: String # @param CompareTaskId: 对比任务 ID,形如:dts-8yv4w2i1-cmp-37skmii9 # @type CompareTaskId: String # @param TaskName: 任务名称 # @type TaskName: String # @param ObjectMode: 数据对比对象模式,sameAsMigrate(全部迁移对象, 默认为此项配置)、custom(自定义),注意自定义对比对象必须是迁移对象的子集 # @type ObjectMode: String # @param Objects: 对比对象,若CompareObjectMode取值为custom,则此项必填 # @type Objects: :class:`Tencentcloud::Dts.v20211206.models.CompareObject` # @param Options: 一致性校验选项 # @type Options: :class:`Tencentcloud::Dts.v20211206.models.CompareOptions` attr_accessor :JobId, :CompareTaskId, :TaskName, :ObjectMode, :Objects, :Options def initialize(jobid=nil, comparetaskid=nil, taskname=nil, objectmode=nil, objects=nil, options=nil) @JobId = jobid @CompareTaskId = comparetaskid @TaskName = taskname @ObjectMode = objectmode @Objects = objects @Options = options end def deserialize(params) @JobId = params['JobId'] @CompareTaskId = params['CompareTaskId'] @TaskName = params['TaskName'] @ObjectMode = params['ObjectMode'] unless params['Objects'].nil? @Objects = CompareObject.new @Objects.deserialize(params['Objects']) end unless params['Options'].nil? @Options = CompareOptions.new @Options.deserialize(params['Options']) end end end # ModifyCompareTask返回参数结构体 class ModifyCompareTaskResponse < 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 # ModifyConsumerGroupDescription请求参数结构体 class ModifyConsumerGroupDescriptionRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的 ID # @type SubscribeId: String # @param ConsumerGroupName: 消费组名称。实际的消费组全称形如:consumer-grp-#{SubscribeId}-#{ConsumerGroupName}。 # 请务必保证消费组名称正确。 # @type ConsumerGroupName: String # @param AccountName: 账户名称。实际的账户全称形如:account-#{SubscribeId}-#{AccountName}。 # 请务必保证账户名称正确。 # @type AccountName: String # @param Description: 修改之后的消费组描述 # @type Description: String attr_accessor :SubscribeId, :ConsumerGroupName, :AccountName, :Description def initialize(subscribeid=nil, consumergroupname=nil, accountname=nil, description=nil) @SubscribeId = subscribeid @ConsumerGroupName = consumergroupname @AccountName = accountname @Description = description end def deserialize(params) @SubscribeId = params['SubscribeId'] @ConsumerGroupName = params['ConsumerGroupName'] @AccountName = params['AccountName'] @Description = params['Description'] end end # ModifyConsumerGroupDescription返回参数结构体 class ModifyConsumerGroupDescriptionResponse < 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 # ModifyConsumerGroupPassword请求参数结构体 class ModifyConsumerGroupPasswordRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的 ID # @type SubscribeId: String # @param AccountName: 账号名称。实际的账户全称形如:account-#{SubscribeId}-#{AccountName} # @type AccountName: String # @param ConsumerGroupName: 消费组名称。实际的消费组全称形如:consumer-grp-#{SubscribeId}-#{ConsumerGroupName} # @type ConsumerGroupName: String # @param NewPassword: 新密码。字符长度不小于3,不大于32 # @type NewPassword: String # @param OldPassword: 旧密码,非必选 # @type OldPassword: String attr_accessor :SubscribeId, :AccountName, :ConsumerGroupName, :NewPassword, :OldPassword def initialize(subscribeid=nil, accountname=nil, consumergroupname=nil, newpassword=nil, oldpassword=nil) @SubscribeId = subscribeid @AccountName = accountname @ConsumerGroupName = consumergroupname @NewPassword = newpassword @OldPassword = oldpassword end def deserialize(params) @SubscribeId = params['SubscribeId'] @AccountName = params['AccountName'] @ConsumerGroupName = params['ConsumerGroupName'] @NewPassword = params['NewPassword'] @OldPassword = params['OldPassword'] end end # ModifyConsumerGroupPassword返回参数结构体 class ModifyConsumerGroupPasswordResponse < 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 # ModifyMigrateJobSpec请求参数结构体 class ModifyMigrateJobSpecRequest < TencentCloud::Common::AbstractModel # @param JobId: 任务id # @type JobId: String # @param NewInstanceClass: 新实例规格大小,包括:micro、small、medium、large、xlarge、2xlarge # @type NewInstanceClass: String attr_accessor :JobId, :NewInstanceClass def initialize(jobid=nil, newinstanceclass=nil) @JobId = jobid @NewInstanceClass = newinstanceclass end def deserialize(params) @JobId = params['JobId'] @NewInstanceClass = params['NewInstanceClass'] end end # ModifyMigrateJobSpec返回参数结构体 class ModifyMigrateJobSpecResponse < 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 # ModifyMigrateName请求参数结构体 class ModifyMigrateNameRequest < TencentCloud::Common::AbstractModel # @param JobId: 迁移任务id # @type JobId: String # @param JobName: 修改后的迁移任务名 # @type JobName: String attr_accessor :JobId, :JobName def initialize(jobid=nil, jobname=nil) @JobId = jobid @JobName = jobname end def deserialize(params) @JobId = params['JobId'] @JobName = params['JobName'] end end # ModifyMigrateName返回参数结构体 class ModifyMigrateNameResponse < 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 # ModifyMigrateRateLimit请求参数结构体 class ModifyMigrateRateLimitRequest < TencentCloud::Common::AbstractModel # @param JobId: 迁移任务ID # @type JobId: String # @param DumpThread: 迁移任务全量导出线程数、有效值为 1-16 # @type DumpThread: Integer # @param DumpRps: 迁移全量导出的 Rps 限制、需要大于 0 # @type DumpRps: Integer # @param LoadThread: 迁移任务全量导入线程数、有效值为 1-16 # @type LoadThread: Integer # @param SinkerThread: 迁移任务增量导入线程数、有效值为 1-128 # @type SinkerThread: Integer # @param LoadRps: 全量导入Rps限制 # @type LoadRps: Integer attr_accessor :JobId, :DumpThread, :DumpRps, :LoadThread, :SinkerThread, :LoadRps def initialize(jobid=nil, dumpthread=nil, dumprps=nil, loadthread=nil, sinkerthread=nil, loadrps=nil) @JobId = jobid @DumpThread = dumpthread @DumpRps = dumprps @LoadThread = loadthread @SinkerThread = sinkerthread @LoadRps = loadrps end def deserialize(params) @JobId = params['JobId'] @DumpThread = params['DumpThread'] @DumpRps = params['DumpRps'] @LoadThread = params['LoadThread'] @SinkerThread = params['SinkerThread'] @LoadRps = params['LoadRps'] end end # ModifyMigrateRateLimit返回参数结构体 class ModifyMigrateRateLimitResponse < 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 # ModifyMigrateRuntimeAttribute请求参数结构体 class ModifyMigrateRuntimeAttributeRequest < TencentCloud::Common::AbstractModel # @param JobId: 迁移任务id,如:dts-2rgv0f09 # @type JobId: String # @param OtherOptions: 需要修改的属性,此结构设计为通用结构,用于屏蔽多个业务的定制属性。
例如对于Redis:
{
"Key": "DstWriteMode", //目标库写入模式
"Value": "normal" //clearData(清空目标实例数据)、overwrite(以覆盖写的方式执行任务)、normal(跟正常流程一样,不做额外动作,默认为此值)
},
{
"Key": "IsDstReadOnly", //是否在迁移时设置目标库只读
"Value": "true" //true(设置只读)、false(不设置只读)
} # @type OtherOptions: Array attr_accessor :JobId, :OtherOptions def initialize(jobid=nil, otheroptions=nil) @JobId = jobid @OtherOptions = otheroptions end def deserialize(params) @JobId = params['JobId'] unless params['OtherOptions'].nil? @OtherOptions = [] params['OtherOptions'].each do |i| keyvaluepairoption_tmp = KeyValuePairOption.new keyvaluepairoption_tmp.deserialize(i) @OtherOptions << keyvaluepairoption_tmp end end end end # ModifyMigrateRuntimeAttribute返回参数结构体 class ModifyMigrateRuntimeAttributeResponse < 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 # ModifyMigrationJob请求参数结构体 class ModifyMigrationJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 任务id # @type JobId: String # @param RunMode: 运行模式,取值如:immediate(表示立即运行)、timed(表示定时运行) # @type RunMode: String # @param MigrateOption: 迁移任务配置选项,描述任务如何执行迁移等一系列配置信息;字段下的RateLimitOption不可配置、如果需要修改任务的限速信息、请在任务运行后通过ModifyMigrateRateLimit接口修改 # @type MigrateOption: :class:`Tencentcloud::Dts.v20211206.models.MigrateOption` # @param SrcInfo: 源实例信息 # @type SrcInfo: :class:`Tencentcloud::Dts.v20211206.models.DBEndpointInfo` # @param DstInfo: 目标实例信息 # @type DstInfo: :class:`Tencentcloud::Dts.v20211206.models.DBEndpointInfo` # @param JobName: 迁移任务名称,最大长度128 # @type JobName: String # @param ExpectRunTime: 期待启动时间,当RunMode取值为timed时,此值必填,形如:"2006-01-02 15:04:05" # @type ExpectRunTime: String # @param Tags: 标签信息 # @type Tags: Array # @param AutoRetryTimeRangeMinutes: 自动重试的时间段、可设置5至720分钟、0表示不重试 # @type AutoRetryTimeRangeMinutes: Integer attr_accessor :JobId, :RunMode, :MigrateOption, :SrcInfo, :DstInfo, :JobName, :ExpectRunTime, :Tags, :AutoRetryTimeRangeMinutes def initialize(jobid=nil, runmode=nil, migrateoption=nil, srcinfo=nil, dstinfo=nil, jobname=nil, expectruntime=nil, tags=nil, autoretrytimerangeminutes=nil) @JobId = jobid @RunMode = runmode @MigrateOption = migrateoption @SrcInfo = srcinfo @DstInfo = dstinfo @JobName = jobname @ExpectRunTime = expectruntime @Tags = tags @AutoRetryTimeRangeMinutes = autoretrytimerangeminutes end def deserialize(params) @JobId = params['JobId'] @RunMode = params['RunMode'] unless params['MigrateOption'].nil? @MigrateOption = MigrateOption.new @MigrateOption.deserialize(params['MigrateOption']) end unless params['SrcInfo'].nil? @SrcInfo = DBEndpointInfo.new @SrcInfo.deserialize(params['SrcInfo']) end unless params['DstInfo'].nil? @DstInfo = DBEndpointInfo.new @DstInfo.deserialize(params['DstInfo']) end @JobName = params['JobName'] @ExpectRunTime = params['ExpectRunTime'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| tagitem_tmp = TagItem.new tagitem_tmp.deserialize(i) @Tags << tagitem_tmp end end @AutoRetryTimeRangeMinutes = params['AutoRetryTimeRangeMinutes'] end end # ModifyMigrationJob返回参数结构体 class ModifyMigrationJobResponse < 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 # ModifySubscribeAutoRenewFlag请求参数结构体 class ModifySubscribeAutoRenewFlagRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 订阅实例ID # @type SubscribeId: String # @param AutoRenewFlag: 自动续费标识。1-自动续费,0-不自动续费 # @type AutoRenewFlag: Integer attr_accessor :SubscribeId, :AutoRenewFlag def initialize(subscribeid=nil, autorenewflag=nil) @SubscribeId = subscribeid @AutoRenewFlag = autorenewflag end def deserialize(params) @SubscribeId = params['SubscribeId'] @AutoRenewFlag = params['AutoRenewFlag'] end end # ModifySubscribeAutoRenewFlag返回参数结构体 class ModifySubscribeAutoRenewFlagResponse < 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 # ModifySubscribeName请求参数结构体 class ModifySubscribeNameRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的ID # @type SubscribeId: String # @param SubscribeName: 修改后的数据订阅实例的名称,长度限制为[1,60] # @type SubscribeName: String attr_accessor :SubscribeId, :SubscribeName def initialize(subscribeid=nil, subscribename=nil) @SubscribeId = subscribeid @SubscribeName = subscribename end def deserialize(params) @SubscribeId = params['SubscribeId'] @SubscribeName = params['SubscribeName'] end end # ModifySubscribeName返回参数结构体 class ModifySubscribeNameResponse < 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 # ModifySubscribeObjects请求参数结构体 class ModifySubscribeObjectsRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的ID # @type SubscribeId: String # @param SubscribeObjectType: 数据订阅的类型,非mongo任务的枚举值:0-全实例更新;1-数据更新;2-结构更新;3-数据更新+结构更新。mongo任务的枚举值:0-全实例更新;4-订阅单库;5-订阅单集合 # @type SubscribeObjectType: Integer # @param Objects: 修改后的订阅数据库表信息。会覆盖原来的订阅对象,所以除非 SubscribeObjectType = 0或2,否则改字段必填。 # @type Objects: Array # @param DistributeRules: kafka分区策略。如果不填,默认不修改。如果填了,会覆盖原来的策略。 # @type DistributeRules: Array # @param DefaultRuleType: 默认分区策略。不满足DistributeRules中正则表达式的数据,将按照默认分区策略计算分区。 # 非mongo产品支持的默认策略: table-按表名分区,pk-按表名+主键分区。mongo的默认策略仅支持:collection-按集合名分区。 # 该字段与DistributeRules搭配使用。如果配置了DistributeRules,该字段也必填。如果配置了该字段,视为配置了一条DistributeRules,原来的分区策略也会被覆盖。 # @type DefaultRuleType: String # @param PipelineInfo: mongo输出聚合设置,mongo任务可选。如果不填,默认不修改。 # @type PipelineInfo: Array attr_accessor :SubscribeId, :SubscribeObjectType, :Objects, :DistributeRules, :DefaultRuleType, :PipelineInfo def initialize(subscribeid=nil, subscribeobjecttype=nil, objects=nil, distributerules=nil, defaultruletype=nil, pipelineinfo=nil) @SubscribeId = subscribeid @SubscribeObjectType = subscribeobjecttype @Objects = objects @DistributeRules = distributerules @DefaultRuleType = defaultruletype @PipelineInfo = pipelineinfo end def deserialize(params) @SubscribeId = params['SubscribeId'] @SubscribeObjectType = params['SubscribeObjectType'] unless params['Objects'].nil? @Objects = [] params['Objects'].each do |i| modifiedsubscribeobject_tmp = ModifiedSubscribeObject.new modifiedsubscribeobject_tmp.deserialize(i) @Objects << modifiedsubscribeobject_tmp end end unless params['DistributeRules'].nil? @DistributeRules = [] params['DistributeRules'].each do |i| distributerule_tmp = DistributeRule.new distributerule_tmp.deserialize(i) @DistributeRules << distributerule_tmp end end @DefaultRuleType = params['DefaultRuleType'] unless params['PipelineInfo'].nil? @PipelineInfo = [] params['PipelineInfo'].each do |i| pipelineinfo_tmp = PipelineInfo.new pipelineinfo_tmp.deserialize(i) @PipelineInfo << pipelineinfo_tmp end end end end # ModifySubscribeObjects返回参数结构体 class ModifySubscribeObjectsResponse < 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 # ModifySyncJobConfig请求参数结构体 class ModifySyncJobConfigRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String # @param DynamicObjects: 修改后的同步对象 # @type DynamicObjects: :class:`Tencentcloud::Dts.v20211206.models.Objects` # @param DynamicOptions: 修改后的同步任务选项 # @type DynamicOptions: :class:`Tencentcloud::Dts.v20211206.models.DynamicOptions` attr_accessor :JobId, :DynamicObjects, :DynamicOptions def initialize(jobid=nil, dynamicobjects=nil, dynamicoptions=nil) @JobId = jobid @DynamicObjects = dynamicobjects @DynamicOptions = dynamicoptions end def deserialize(params) @JobId = params['JobId'] unless params['DynamicObjects'].nil? @DynamicObjects = Objects.new @DynamicObjects.deserialize(params['DynamicObjects']) end unless params['DynamicOptions'].nil? @DynamicOptions = DynamicOptions.new @DynamicOptions.deserialize(params['DynamicOptions']) end end end # ModifySyncJobConfig返回参数结构体 class ModifySyncJobConfigResponse < 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 # ModifySyncRateLimit请求参数结构体 class ModifySyncRateLimitRequest < TencentCloud::Common::AbstractModel # @param JobId: 迁移任务ID # @type JobId: String # @param DumpThread: 同步任务全量导出线程数、有效值为 1-16 # @type DumpThread: Integer # @param DumpRps: 同步任务全量导出的 Rps 限制、需要大于 0 # @type DumpRps: Integer # @param LoadThread: 同步任务全量导入线程数、有效值为 1-16 # @type LoadThread: Integer # @param SinkerThread: 同步任务增量导入线程数、有效值为 1-128 # @type SinkerThread: Integer # @param LoadRps: 同步任务全量导入的Rps # @type LoadRps: Integer attr_accessor :JobId, :DumpThread, :DumpRps, :LoadThread, :SinkerThread, :LoadRps def initialize(jobid=nil, dumpthread=nil, dumprps=nil, loadthread=nil, sinkerthread=nil, loadrps=nil) @JobId = jobid @DumpThread = dumpthread @DumpRps = dumprps @LoadThread = loadthread @SinkerThread = sinkerthread @LoadRps = loadrps end def deserialize(params) @JobId = params['JobId'] @DumpThread = params['DumpThread'] @DumpRps = params['DumpRps'] @LoadThread = params['LoadThread'] @SinkerThread = params['SinkerThread'] @LoadRps = params['LoadRps'] end end # ModifySyncRateLimit返回参数结构体 class ModifySyncRateLimitResponse < 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 # kafka消费者组的分区详情 class MonitorInfo < TencentCloud::Common::AbstractModel # @param PartitionNo: 当前分区的编号,从0开始 # @type PartitionNo: Integer # @param ConsumerGroupOffset: 当前分区的偏移量 # @type ConsumerGroupOffset: Integer # @param ConsumerGroupLag: 当前分区未消费的数据量 # @type ConsumerGroupLag: Integer # @param Latency: 当前分区的消费延迟(单位为秒) # @type Latency: Integer attr_accessor :PartitionNo, :ConsumerGroupOffset, :ConsumerGroupLag, :Latency def initialize(partitionno=nil, consumergroupoffset=nil, consumergrouplag=nil, latency=nil) @PartitionNo = partitionno @ConsumerGroupOffset = consumergroupoffset @ConsumerGroupLag = consumergrouplag @Latency = latency end def deserialize(params) @PartitionNo = params['PartitionNo'] @ConsumerGroupOffset = params['ConsumerGroupOffset'] @ConsumerGroupLag = params['ConsumerGroupLag'] @Latency = params['Latency'] end end # 同步的数据库对对象描述 class Objects < TencentCloud::Common::AbstractModel # @param Mode: 同步对象类型 Partial(部分对象) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Mode: String # @param Databases: 同步对象,当 Mode 为 Partial 时,不为空 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Databases: Array # @param AdvancedObjects: 高级对象类型,如function、procedure。注意:如果要迁移同步高级对象,此配置中应该包含对应的高级对象类型。当需要同步高级对象时,初始化类型必须包含结构初始化类型,即任务的Options.InitType字段值为Structure或Full # 注意:此字段可能返回 null,表示取不到有效值。 # @type AdvancedObjects: Array # @param OnlineDDL: OnlineDDL类型,冗余字段不做配置用途 # 注意:此字段可能返回 null,表示取不到有效值。 # @type OnlineDDL: :class:`Tencentcloud::Dts.v20211206.models.OnlineDDL` attr_accessor :Mode, :Databases, :AdvancedObjects, :OnlineDDL def initialize(mode=nil, databases=nil, advancedobjects=nil, onlineddl=nil) @Mode = mode @Databases = databases @AdvancedObjects = advancedobjects @OnlineDDL = onlineddl end def deserialize(params) @Mode = params['Mode'] unless params['Databases'].nil? @Databases = [] params['Databases'].each do |i| database_tmp = Database.new database_tmp.deserialize(i) @Databases << database_tmp end end @AdvancedObjects = params['AdvancedObjects'] unless params['OnlineDDL'].nil? @OnlineDDL = OnlineDDL.new @OnlineDDL.deserialize(params['OnlineDDL']) end end end # 数据订阅kafka分区中checkpoint信息 class OffsetTimeMap < TencentCloud::Common::AbstractModel # @param PartitionNo: kafka分区编号 # 注意:此字段可能返回 null,表示取不到有效值。 # @type PartitionNo: Integer # @param Offset: kafka offset # 注意:此字段可能返回 null,表示取不到有效值。 # @type Offset: Integer attr_accessor :PartitionNo, :Offset def initialize(partitionno=nil, offset=nil) @PartitionNo = partitionno @Offset = offset end def deserialize(params) @PartitionNo = params['PartitionNo'] @Offset = params['Offset'] end end # OnlineDDL类型 class OnlineDDL < TencentCloud::Common::AbstractModel # @param Status: 状态 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String attr_accessor :Status def initialize(status=nil) @Status = status end def deserialize(params) @Status = params['Status'] end end # 数据同步中的选项 class Options < TencentCloud::Common::AbstractModel # @param InitType: 同步初始化选项,Data(全量数据初始化)、Structure(结构初始化)、Full(全量数据且结构初始化,默认)、None(仅增量) # 注意:此字段可能返回 null,表示取不到有效值。 # @type InitType: String # @param DealOfExistSameTable: 同名表的处理,ReportErrorAfterCheck(前置校验并报错,默认)、ExecuteAfterIgnore(忽略并继续执行) # 注意:此字段可能返回 null,表示取不到有效值。 # @type DealOfExistSameTable: String # @param ConflictHandleType: 冲突处理选项,ReportError(报错,默认为该值)、Ignore(忽略)、Cover(覆盖)、ConditionCover(条件覆盖) # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConflictHandleType: String # @param AddAdditionalColumn: 是否添加附加列 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AddAdditionalColumn: Boolean # @param OpTypes: 所要同步的DML和DDL的选项,Insert(插入操作)、Update(更新操作)、Delete(删除操作)、DDL(结构同步), 不填(不选),PartialDDL(自定义,和DdlOptions一起起作用 ) # 注意:此字段可能返回 null,表示取不到有效值。 # @type OpTypes: Array # @param ConflictHandleOption: 冲突处理的详细选项,如条件覆盖中的条件行和条件操作 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ConflictHandleOption: :class:`Tencentcloud::Dts.v20211206.models.ConflictHandleOption` # @param DdlOptions: DDL同步选项,具体描述要同步那些DDL # 注意:此字段可能返回 null,表示取不到有效值。 # @type DdlOptions: Array # @param KafkaOption: kafka同步选项 # 注意:此字段可能返回 null,表示取不到有效值。 # @type KafkaOption: :class:`Tencentcloud::Dts.v20211206.models.KafkaOption` # @param RateLimitOption: 任务限速信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type RateLimitOption: :class:`Tencentcloud::Dts.v20211206.models.RateLimitOption` # @param AutoRetryTimeRangeMinutes: 自动重试的时间窗口设置 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AutoRetryTimeRangeMinutes: Integer # @param StartPosition: 同步到kafka链路指定位点。目前只支持时间格式:2023-12-20T19:24:23+08:00。如果没有指定位点,为空。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartPosition: String # @param FilterBeginCommit: 同步到kafka链路是否过滤掉begin和commit消息。目前仅mysql2kafka链路支持 # 注意:此字段可能返回 null,表示取不到有效值。 # @type FilterBeginCommit: Boolean # @param FilterCheckpoint: 同步到kafka链路是否过滤掉checkpoint消息。目前仅mysql2kafka链路支持 # 注意:此字段可能返回 null,表示取不到有效值。 # @type FilterCheckpoint: Boolean attr_accessor :InitType, :DealOfExistSameTable, :ConflictHandleType, :AddAdditionalColumn, :OpTypes, :ConflictHandleOption, :DdlOptions, :KafkaOption, :RateLimitOption, :AutoRetryTimeRangeMinutes, :StartPosition, :FilterBeginCommit, :FilterCheckpoint def initialize(inittype=nil, dealofexistsametable=nil, conflicthandletype=nil, addadditionalcolumn=nil, optypes=nil, conflicthandleoption=nil, ddloptions=nil, kafkaoption=nil, ratelimitoption=nil, autoretrytimerangeminutes=nil, startposition=nil, filterbegincommit=nil, filtercheckpoint=nil) @InitType = inittype @DealOfExistSameTable = dealofexistsametable @ConflictHandleType = conflicthandletype @AddAdditionalColumn = addadditionalcolumn @OpTypes = optypes @ConflictHandleOption = conflicthandleoption @DdlOptions = ddloptions @KafkaOption = kafkaoption @RateLimitOption = ratelimitoption @AutoRetryTimeRangeMinutes = autoretrytimerangeminutes @StartPosition = startposition @FilterBeginCommit = filterbegincommit @FilterCheckpoint = filtercheckpoint end def deserialize(params) @InitType = params['InitType'] @DealOfExistSameTable = params['DealOfExistSameTable'] @ConflictHandleType = params['ConflictHandleType'] @AddAdditionalColumn = params['AddAdditionalColumn'] @OpTypes = params['OpTypes'] unless params['ConflictHandleOption'].nil? @ConflictHandleOption = ConflictHandleOption.new @ConflictHandleOption.deserialize(params['ConflictHandleOption']) end unless params['DdlOptions'].nil? @DdlOptions = [] params['DdlOptions'].each do |i| ddloption_tmp = DdlOption.new ddloption_tmp.deserialize(i) @DdlOptions << ddloption_tmp end end unless params['KafkaOption'].nil? @KafkaOption = KafkaOption.new @KafkaOption.deserialize(params['KafkaOption']) end unless params['RateLimitOption'].nil? @RateLimitOption = RateLimitOption.new @RateLimitOption.deserialize(params['RateLimitOption']) end @AutoRetryTimeRangeMinutes = params['AutoRetryTimeRangeMinutes'] @StartPosition = params['StartPosition'] @FilterBeginCommit = params['FilterBeginCommit'] @FilterCheckpoint = params['FilterCheckpoint'] end end # 数据订阅中kafka消费者组的分区分配情况。该数据是实时查询的,如果需要最新数据,需重新掉接口查询。 class PartitionAssignment < TencentCloud::Common::AbstractModel # @param ClientId: 消费者的clientId # @type ClientId: String # @param PartitionNo: 该消费者正在消费的分区 # 注意:此字段可能返回 null,表示取不到有效值。 # @type PartitionNo: Array attr_accessor :ClientId, :PartitionNo def initialize(clientid=nil, partitionno=nil) @ClientId = clientid @PartitionNo = partitionno end def deserialize(params) @ClientId = params['ClientId'] @PartitionNo = params['PartitionNo'] end end # PauseMigrateJob请求参数结构体 class PauseMigrateJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # PauseMigrateJob返回参数结构体 class PauseMigrateJobResponse < 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 # PauseSyncJob请求参数结构体 class PauseSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # PauseSyncJob返回参数结构体 class PauseSyncJobResponse < 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 # mongo输出聚合设置。输出默认 Change Event class PipelineInfo < TencentCloud::Common::AbstractModel # @param AggOp: 聚合运算符:$addFields、$match、$project、$replaceRoot、$redact、$replaceWith、$set、$unset。其中 $replaceWith、$set、$unset 只有当订阅实例是4.2及以上版本可选。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AggOp: String # @param AggCmd: 聚合表达式。必须是json格式 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AggCmd: String attr_accessor :AggOp, :AggCmd def initialize(aggop=nil, aggcmd=nil) @AggOp = aggop @AggCmd = aggcmd end def deserialize(params) @AggOp = params['AggOp'] @AggCmd = params['AggCmd'] end end # 任务步骤信息 class ProcessProgress < TencentCloud::Common::AbstractModel # @param Status: 步骤的状态, 包括:notStarted(未开始)、running(运行中)、success(成功)、failed(失败)等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param Percent: 进度信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Percent: Integer # @param StepAll: 总的步骤数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepAll: Integer # @param StepNow: 当前进行的步骤 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepNow: Integer # @param Message: 当前步骤输出提示信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Message: String # @param Steps: 步骤信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Steps: Array attr_accessor :Status, :Percent, :StepAll, :StepNow, :Message, :Steps def initialize(status=nil, percent=nil, stepall=nil, stepnow=nil, message=nil, steps=nil) @Status = status @Percent = percent @StepAll = stepall @StepNow = stepnow @Message = message @Steps = steps end def deserialize(params) @Status = params['Status'] @Percent = params['Percent'] @StepAll = params['StepAll'] @StepNow = params['StepNow'] @Message = params['Message'] unless params['Steps'].nil? @Steps = [] params['Steps'].each do |i| stepdetailinfo_tmp = StepDetailInfo.new stepdetailinfo_tmp.deserialize(i) @Steps << stepdetailinfo_tmp end end end end # 错误信息及告警信息对象 class ProcessStepTip < TencentCloud::Common::AbstractModel # @param Message: 提示信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Message: String # @param Solution: 解决方案 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Solution: String # @param HelpDoc: 文档提示 # 注意:此字段可能返回 null,表示取不到有效值。 # @type HelpDoc: String attr_accessor :Message, :Solution, :HelpDoc def initialize(message=nil, solution=nil, helpdoc=nil) @Message = message @Solution = solution @HelpDoc = helpdoc end def deserialize(params) @Message = params['Message'] @Solution = params['Solution'] @HelpDoc = params['HelpDoc'] end end # 迁移和同步任务限速的详细信息 class RateLimitOption < TencentCloud::Common::AbstractModel # @param CurrentDumpThread: 当前生效的全量导出线程数,配置任务时可调整该字段值,注意:如果不设置或设置为0则表示保持当前值,最大值为16 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CurrentDumpThread: Integer # @param DefaultDumpThread: 默认的全量导出线程数,该字段仅在出参有意义 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DefaultDumpThread: Integer # @param CurrentDumpRps: 当前生效的全量导出Rps,配置任务时可调整该字段值,注意:如果不设置或设置为0则表示保持当前值,最大值为50000000 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CurrentDumpRps: Integer # @param DefaultDumpRps: 默认的全量导出Rps,该字段仅在出参有意义 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DefaultDumpRps: Integer # @param CurrentLoadThread: 当前生效的全量导入线程数,配置任务时可调整该字段值,注意:如果不设置或设置为0则表示保持当前值,最大值为16 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CurrentLoadThread: Integer # @param DefaultLoadThread: 默认的全量导入线程数,该字段仅在出参有意义 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DefaultLoadThread: Integer # @param CurrentLoadRps: 当前生效的全量导入Rps,配置任务时可调整该字段值,注意:如果不设置或设置为0则表示保持当前值,最大值为50000000 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CurrentLoadRps: Integer # @param DefaultLoadRps: 默认的全量导入Rps,该字段仅在出参有意义 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DefaultLoadRps: Integer # @param CurrentSinkerThread: 当前生效的增量导入线程数,配置任务时可调整该字段值,注意:如果不设置或设置为0则表示保持当前值,最大值为128 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CurrentSinkerThread: Integer # @param DefaultSinkerThread: 默认的增量导入线程数,该字段仅在出参有意义 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DefaultSinkerThread: Integer # @param HasUserSetRateLimit: enum:"no"/"yes"、no表示用户未设置过限速、yes表示设置过限速,该字段仅在出参有意义 # 注意:此字段可能返回 null,表示取不到有效值。 # @type HasUserSetRateLimit: String attr_accessor :CurrentDumpThread, :DefaultDumpThread, :CurrentDumpRps, :DefaultDumpRps, :CurrentLoadThread, :DefaultLoadThread, :CurrentLoadRps, :DefaultLoadRps, :CurrentSinkerThread, :DefaultSinkerThread, :HasUserSetRateLimit def initialize(currentdumpthread=nil, defaultdumpthread=nil, currentdumprps=nil, defaultdumprps=nil, currentloadthread=nil, defaultloadthread=nil, currentloadrps=nil, defaultloadrps=nil, currentsinkerthread=nil, defaultsinkerthread=nil, hasusersetratelimit=nil) @CurrentDumpThread = currentdumpthread @DefaultDumpThread = defaultdumpthread @CurrentDumpRps = currentdumprps @DefaultDumpRps = defaultdumprps @CurrentLoadThread = currentloadthread @DefaultLoadThread = defaultloadthread @CurrentLoadRps = currentloadrps @DefaultLoadRps = defaultloadrps @CurrentSinkerThread = currentsinkerthread @DefaultSinkerThread = defaultsinkerthread @HasUserSetRateLimit = hasusersetratelimit end def deserialize(params) @CurrentDumpThread = params['CurrentDumpThread'] @DefaultDumpThread = params['DefaultDumpThread'] @CurrentDumpRps = params['CurrentDumpRps'] @DefaultDumpRps = params['DefaultDumpRps'] @CurrentLoadThread = params['CurrentLoadThread'] @DefaultLoadThread = params['DefaultLoadThread'] @CurrentLoadRps = params['CurrentLoadRps'] @DefaultLoadRps = params['DefaultLoadRps'] @CurrentSinkerThread = params['CurrentSinkerThread'] @DefaultSinkerThread = params['DefaultSinkerThread'] @HasUserSetRateLimit = params['HasUserSetRateLimit'] end end # RecoverMigrateJob请求参数结构体 class RecoverMigrateJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # RecoverMigrateJob返回参数结构体 class RecoverMigrateJobResponse < 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 # RecoverSyncJob请求参数结构体 class RecoverSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步实例id(即标识一个同步作业),形如sync-werwfs23 # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # RecoverSyncJob返回参数结构体 class RecoverSyncJobResponse < 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 # ResetConsumerGroupOffset请求参数结构体 class ResetConsumerGroupOffsetRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 订阅实例id # @type SubscribeId: String # @param TopicName: 订阅的kafka topic # @type TopicName: String # @param ConsumerGroupName: 消费组名称。实际的消费组全称形如:consumer-grp-#{SubscribeId}-#{ConsumerGroupName} # @type ConsumerGroupName: String # @param PartitionNos: 需要修改offset的分区编号 # @type PartitionNos: Array # @param ResetMode: 重置方式。枚举值为 earliest-从最开始位置开始消费;latest-从最新位置开始消费;datetime-从指定时间前最近的checkpoint开始消费 # @type ResetMode: String # @param ResetDatetime: 当 ResetMode 为 datetime 时,该项需要填,格式为:Y-m-d h:m:s。如果不填,默认用0时间,效果与earliest相同。 # @type ResetDatetime: String attr_accessor :SubscribeId, :TopicName, :ConsumerGroupName, :PartitionNos, :ResetMode, :ResetDatetime def initialize(subscribeid=nil, topicname=nil, consumergroupname=nil, partitionnos=nil, resetmode=nil, resetdatetime=nil) @SubscribeId = subscribeid @TopicName = topicname @ConsumerGroupName = consumergroupname @PartitionNos = partitionnos @ResetMode = resetmode @ResetDatetime = resetdatetime end def deserialize(params) @SubscribeId = params['SubscribeId'] @TopicName = params['TopicName'] @ConsumerGroupName = params['ConsumerGroupName'] @PartitionNos = params['PartitionNos'] @ResetMode = params['ResetMode'] @ResetDatetime = params['ResetDatetime'] end end # ResetConsumerGroupOffset返回参数结构体 class ResetConsumerGroupOffsetResponse < 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 # ResetSubscribe请求参数结构体 class ResetSubscribeRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的ID # @type SubscribeId: String attr_accessor :SubscribeId def initialize(subscribeid=nil) @SubscribeId = subscribeid end def deserialize(params) @SubscribeId = params['SubscribeId'] end end # ResetSubscribe返回参数结构体 class ResetSubscribeResponse < 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 # ResizeSyncJob请求参数结构体 class ResizeSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String # @param NewInstanceClass: 任务规格 # @type NewInstanceClass: String attr_accessor :JobId, :NewInstanceClass def initialize(jobid=nil, newinstanceclass=nil) @JobId = jobid @NewInstanceClass = newinstanceclass end def deserialize(params) @JobId = params['JobId'] @NewInstanceClass = params['NewInstanceClass'] end end # ResizeSyncJob返回参数结构体 class ResizeSyncJobResponse < 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 # ResumeMigrateJob请求参数结构体 class ResumeMigrateJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # @type JobId: String # @param ResumeOption: 恢复任务的模式,目前的取值有:clearData 清空目标实例数据,overwrite 以覆盖写的方式执行任务,normal 跟正常流程一样,不做额外动作;注意,clearData、overwrite仅对redis生效,normal仅针对非redis链路生效 # @type ResumeOption: String attr_accessor :JobId, :ResumeOption def initialize(jobid=nil, resumeoption=nil) @JobId = jobid @ResumeOption = resumeoption end def deserialize(params) @JobId = params['JobId'] @ResumeOption = params['ResumeOption'] end end # ResumeMigrateJob返回参数结构体 class ResumeMigrateJobResponse < 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 # ResumeSubscribe请求参数结构体 class ResumeSubscribeRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的 ID # @type SubscribeId: String attr_accessor :SubscribeId def initialize(subscribeid=nil) @SubscribeId = subscribeid end def deserialize(params) @SubscribeId = params['SubscribeId'] end end # ResumeSubscribe返回参数结构体 class ResumeSubscribeResponse < 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 # ResumeSyncJob请求参数结构体 class ResumeSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # ResumeSyncJob返回参数结构体 class ResumeSyncJobResponse < 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 # 角色对象,postgresql独有参数 class RoleItem < TencentCloud::Common::AbstractModel # @param RoleName: 角色名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type RoleName: String # @param NewRoleName: 迁移后的角色名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NewRoleName: String attr_accessor :RoleName, :NewRoleName def initialize(rolename=nil, newrolename=nil) @RoleName = rolename @NewRoleName = newrolename end def deserialize(params) @RoleName = params['RoleName'] @NewRoleName = params['NewRoleName'] end end # mongodb行校验不一致详细信息 class RowsCountDifference < TencentCloud::Common::AbstractModel # @param Db: 数据库名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Db: String # @param Table: 集合 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Table: String # @param SrcCount: 源端行数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcCount: Integer # @param DstCount: 目标端行数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstCount: Integer attr_accessor :Db, :Table, :SrcCount, :DstCount def initialize(db=nil, table=nil, srccount=nil, dstcount=nil) @Db = db @Table = table @SrcCount = srccount @DstCount = dstcount end def deserialize(params) @Db = params['Db'] @Table = params['Table'] @SrcCount = params['SrcCount'] @DstCount = params['DstCount'] end end # SkipCheckItem请求参数结构体 class SkipCheckItemRequest < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # @type JobId: String # @param StepIds: 需要跳过校验项的步骤id,需要通过DescribeMigrationCheckJob接口返回StepInfo[i].StepId字段获取,例如:["OptimizeCheck"] # @type StepIds: Array # @param ForeignKeyFlag: 当出现外键依赖检查导致校验不通过时、可以通过该字段选择是否迁移外键依赖,当StepIds包含ConstraintCheck且该字段值为shield时表示不迁移外键依赖、当StepIds包含ConstraintCheck且值为migrate时表示迁移外键依赖 # @type ForeignKeyFlag: String attr_accessor :JobId, :StepIds, :ForeignKeyFlag def initialize(jobid=nil, stepids=nil, foreignkeyflag=nil) @JobId = jobid @StepIds = stepids @ForeignKeyFlag = foreignkeyflag end def deserialize(params) @JobId = params['JobId'] @StepIds = params['StepIds'] @ForeignKeyFlag = params['ForeignKeyFlag'] end end # SkipCheckItem返回参数结构体 class SkipCheckItemResponse < TencentCloud::Common::AbstractModel # @param Message: 跳过的提示信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Message: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Message, :RequestId def initialize(message=nil, requestid=nil) @Message = message @RequestId = requestid end def deserialize(params) @Message = params['Message'] @RequestId = params['RequestId'] end end # SkipSyncCheckItem请求参数结构体 class SkipSyncCheckItemRequest < TencentCloud::Common::AbstractModel # @param JobId: 任务id,如:sync-4ddgid2 # @type JobId: String # @param StepIds: 需要跳过校验项的步骤id,需要通过`DescribeCheckSyncJobResult`接口返回StepInfos[i].StepId字段获取,例如:["OptimizeCheck"] # @type StepIds: Array attr_accessor :JobId, :StepIds def initialize(jobid=nil, stepids=nil) @JobId = jobid @StepIds = stepids end def deserialize(params) @JobId = params['JobId'] @StepIds = params['StepIds'] end end # SkipSyncCheckItem返回参数结构体 class SkipSyncCheckItemResponse < 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 SkippedDetail < TencentCloud::Common::AbstractModel # @param TotalCount: 跳过的表数量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param Items: 跳过校验的表详情 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Items: Array attr_accessor :TotalCount, :Items def initialize(totalcount=nil, items=nil) @TotalCount = totalcount @Items = items end def deserialize(params) @TotalCount = params['TotalCount'] unless params['Items'].nil? @Items = [] params['Items'].each do |i| skippeditem_tmp = SkippedItem.new skippeditem_tmp.deserialize(i) @Items << skippeditem_tmp end end end end # 跳过校验的表详情 class SkippedItem < TencentCloud::Common::AbstractModel # @param Db: 数据库名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Db: String # @param Table: 表名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Table: String # @param Reason: 未发起检查的原因 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Reason: String attr_accessor :Db, :Table, :Reason def initialize(db=nil, table=nil, reason=nil) @Db = db @Table = table @Reason = reason end def deserialize(params) @Db = params['Db'] @Table = params['Table'] @Reason = params['Reason'] end end # StartCompare请求参数结构体 class StartCompareRequest < TencentCloud::Common::AbstractModel # @param JobId: 迁移任务 Id # @type JobId: String # @param CompareTaskId: 对比任务 ID,形如:dts-8yv4w2i1-cmp-37skmii9 # @type CompareTaskId: String attr_accessor :JobId, :CompareTaskId def initialize(jobid=nil, comparetaskid=nil) @JobId = jobid @CompareTaskId = comparetaskid end def deserialize(params) @JobId = params['JobId'] @CompareTaskId = params['CompareTaskId'] end end # StartCompare返回参数结构体 class StartCompareResponse < 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 # StartMigrateJob请求参数结构体 class StartMigrateJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # StartMigrateJob返回参数结构体 class StartMigrateJobResponse < 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 # StartModifySyncJob请求参数结构体 class StartModifySyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # StartModifySyncJob返回参数结构体 class StartModifySyncJobResponse < 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 # StartSubscribe请求参数结构体 class StartSubscribeRequest < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅实例的 ID # @type SubscribeId: String attr_accessor :SubscribeId def initialize(subscribeid=nil) @SubscribeId = subscribeid end def deserialize(params) @SubscribeId = params['SubscribeId'] end end # StartSubscribe返回参数结构体 class StartSubscribeResponse < 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 # StartSyncJob请求参数结构体 class StartSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # StartSyncJob返回参数结构体 class StartSyncJobResponse < 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 StepDetailInfo < TencentCloud::Common::AbstractModel # @param StepNo: 步骤序列 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepNo: Integer # @param StepName: 步骤展现名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepName: String # @param StepId: 步骤英文标识 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepId: String # @param Status: 步骤状态:success(成功)、failed(失败)、running(执行中)、notStarted(未执行)、默认为notStarted # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param StartTime: 当前步骤开始的时间,格式为"yyyy-mm-dd hh:mm:ss",该字段不存在或者为空是无意义 注意:此字段可能返回 null,表示取不到有效值。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartTime: String # @param StepMessage: 步骤错误信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepMessage: String # @param Percent: 执行进度 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Percent: Integer # @param Errors: 错误信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Errors: Array # @param Warnings: 告警提示 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Warnings: Array attr_accessor :StepNo, :StepName, :StepId, :Status, :StartTime, :StepMessage, :Percent, :Errors, :Warnings def initialize(stepno=nil, stepname=nil, stepid=nil, status=nil, starttime=nil, stepmessage=nil, percent=nil, errors=nil, warnings=nil) @StepNo = stepno @StepName = stepname @StepId = stepid @Status = status @StartTime = starttime @StepMessage = stepmessage @Percent = percent @Errors = errors @Warnings = warnings end def deserialize(params) @StepNo = params['StepNo'] @StepName = params['StepName'] @StepId = params['StepId'] @Status = params['Status'] @StartTime = params['StartTime'] @StepMessage = params['StepMessage'] @Percent = params['Percent'] unless params['Errors'].nil? @Errors = [] params['Errors'].each do |i| processsteptip_tmp = ProcessStepTip.new processsteptip_tmp.deserialize(i) @Errors << processsteptip_tmp end end unless params['Warnings'].nil? @Warnings = [] params['Warnings'].each do |i| processsteptip_tmp = ProcessStepTip.new processsteptip_tmp.deserialize(i) @Warnings << processsteptip_tmp end end end end # 单个步骤的详细信息 class StepInfo < TencentCloud::Common::AbstractModel # @param StepNo: 步骤编号 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepNo: Integer # @param StepName: 步骤名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepName: String # @param StepId: 步骤标号 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepId: String # @param Status: 当前步骤状态,可能返回有 notStarted(未开始)、running(校验中)、failed(校验任务失败)、finished(完成)、skipped(跳过)、paused(暂停) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param StartTime: 步骤开始时间,可能为空 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartTime: String # @param Errors: 错误信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Errors: Array # @param Warnings: 警告信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Warnings: Array # @param Progress: 当前步骤进度,范围为[0-100],若为-1表示当前步骤不支持查看进度 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Progress: Integer attr_accessor :StepNo, :StepName, :StepId, :Status, :StartTime, :Errors, :Warnings, :Progress def initialize(stepno=nil, stepname=nil, stepid=nil, status=nil, starttime=nil, errors=nil, warnings=nil, progress=nil) @StepNo = stepno @StepName = stepname @StepId = stepid @Status = status @StartTime = starttime @Errors = errors @Warnings = warnings @Progress = progress end def deserialize(params) @StepNo = params['StepNo'] @StepName = params['StepName'] @StepId = params['StepId'] @Status = params['Status'] @StartTime = params['StartTime'] unless params['Errors'].nil? @Errors = [] params['Errors'].each do |i| steptip_tmp = StepTip.new steptip_tmp.deserialize(i) @Errors << steptip_tmp end end unless params['Warnings'].nil? @Warnings = [] params['Warnings'].each do |i| steptip_tmp = StepTip.new steptip_tmp.deserialize(i) @Warnings << steptip_tmp end end @Progress = params['Progress'] end end # 当前步骤错误信息或者警告信息 class StepTip < TencentCloud::Common::AbstractModel # @param Code: 错误码 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Code: String # @param Message: 错误信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Message: String # @param Solution: 解决方式 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Solution: String # @param HelpDoc: 帮助文档 # 注意:此字段可能返回 null,表示取不到有效值。 # @type HelpDoc: String # @param SkipInfo: 当前步骤跳过信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SkipInfo: String attr_accessor :Code, :Message, :Solution, :HelpDoc, :SkipInfo def initialize(code=nil, message=nil, solution=nil, helpdoc=nil, skipinfo=nil) @Code = code @Message = message @Solution = solution @HelpDoc = helpdoc @SkipInfo = skipinfo end def deserialize(params) @Code = params['Code'] @Message = params['Message'] @Solution = params['Solution'] @HelpDoc = params['HelpDoc'] @SkipInfo = params['SkipInfo'] end end # StopCompare请求参数结构体 class StopCompareRequest < TencentCloud::Common::AbstractModel # @param JobId: 迁移任务 Id # @type JobId: String # @param CompareTaskId: 对比任务 ID,形如:dts-8yv4w2i1-cmp-37skmii9 # @type CompareTaskId: String # @param ForceStop: 是否强制停止。如果填true,同步任务增量阶段会跳过一致性校验产生的binlog,达到快速恢复任务的效果 # @type ForceStop: Boolean attr_accessor :JobId, :CompareTaskId, :ForceStop def initialize(jobid=nil, comparetaskid=nil, forcestop=nil) @JobId = jobid @CompareTaskId = comparetaskid @ForceStop = forcestop end def deserialize(params) @JobId = params['JobId'] @CompareTaskId = params['CompareTaskId'] @ForceStop = params['ForceStop'] end end # StopCompare返回参数结构体 class StopCompareResponse < 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 # StopMigrateJob请求参数结构体 class StopMigrateJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 数据迁移任务ID # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # StopMigrateJob返回参数结构体 class StopMigrateJobResponse < 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 # StopSyncJob请求参数结构体 class StopSyncJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # StopSyncJob返回参数结构体 class StopSyncJobResponse < 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 SubsErr < TencentCloud::Common::AbstractModel # @param Message: 报错信息 # @type Message: String # @param Reason: 报错原因 # @type Reason: String # @param Solution: 建议的修复方案 # @type Solution: String attr_accessor :Message, :Reason, :Solution def initialize(message=nil, reason=nil, solution=nil) @Message = message @Reason = reason @Solution = solution end def deserialize(params) @Message = params['Message'] @Reason = params['Reason'] @Solution = params['Solution'] end end # 订阅校验任务的各步骤信息。 class SubscribeCheckStepInfo < TencentCloud::Common::AbstractModel # @param StepName: 步骤名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepName: String # @param StepId: 步骤Id # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepId: String # @param StepNo: 步骤编号,从 1 开始 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepNo: Integer # @param Status: 当前步骤状态,可能值为 notStarted,running,finished,failed # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param Percent: 当前步骤进度 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Percent: Integer # @param Errors: 错误提示 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Errors: Array # @param Warnings: 告警提示 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Warnings: Array attr_accessor :StepName, :StepId, :StepNo, :Status, :Percent, :Errors, :Warnings def initialize(stepname=nil, stepid=nil, stepno=nil, status=nil, percent=nil, errors=nil, warnings=nil) @StepName = stepname @StepId = stepid @StepNo = stepno @Status = status @Percent = percent @Errors = errors @Warnings = warnings end def deserialize(params) @StepName = params['StepName'] @StepId = params['StepId'] @StepNo = params['StepNo'] @Status = params['Status'] @Percent = params['Percent'] unless params['Errors'].nil? @Errors = [] params['Errors'].each do |i| subscribechecksteptip_tmp = SubscribeCheckStepTip.new subscribechecksteptip_tmp.deserialize(i) @Errors << subscribechecksteptip_tmp end end unless params['Warnings'].nil? @Warnings = [] params['Warnings'].each do |i| subscribechecksteptip_tmp = SubscribeCheckStepTip.new subscribechecksteptip_tmp.deserialize(i) @Warnings << subscribechecksteptip_tmp end end end end # 订阅校验任务的提示信息 class SubscribeCheckStepTip < TencentCloud::Common::AbstractModel # @param Message: 错误或告警的详细信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Message: String # @param HelpDoc: 帮助文档 # 注意:此字段可能返回 null,表示取不到有效值。 # @type HelpDoc: String attr_accessor :Message, :HelpDoc def initialize(message=nil, helpdoc=nil) @Message = message @HelpDoc = helpdoc end def deserialize(params) @Message = params['Message'] @HelpDoc = params['HelpDoc'] end end # 订阅实例信息 class SubscribeInfo < TencentCloud::Common::AbstractModel # @param SubscribeId: 数据订阅的实例ID # @type SubscribeId: String # @param SubscribeName: 数据订阅实例的名称 # @type SubscribeName: String # @param Topic: 订阅实例发送数据的kafka topic # 注意:此字段可能返回 null,表示取不到有效值。 # @type Topic: String # @param Product: 订阅实例的类型,目前支持 cynosdbmysql,mariadb,mongodb,mysql,percona,tdpg,tdsqlpercona(tdsqlmysql) # @type Product: String # @param InstanceId: 订阅的数据库实例ID(如果订阅的是云数据库)如果实例不是腾讯云上的,此值为空。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceId: String # @param InstanceStatus: 云数据库状态:running 运行中,isolated 已隔离,offline 已下线。如果不是云上,此值为空 # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceStatus: String # @param Status: 数据订阅生命周期状态,可能的值为:正常 normal, 隔离中 isolating, 已隔离 isolated, 下线中 offlining, 按量转包年包月中 post2PrePayIng # @type Status: String # @param SubsStatus: 数据订阅状态,可能的值为:未启动 notStarted, 校验中 checking, 校验不通过 checkNotPass, 校验通过 checkPass, 启动中 starting, 运行中 running, 异常出错 error # @type SubsStatus: String # @param ModifyTime: 上次修改时间,时间格式如:Y-m-d h:m:s # 注意:此字段可能返回 null,表示取不到有效值。 # @type ModifyTime: String # @param CreateTime: 创建时间,时间格式如:Y-m-d h:m:s # 注意:此字段可能返回 null,表示取不到有效值。 # @type CreateTime: String # @param IsolateTime: 隔离时间,时间格式如:Y-m-d h:m:s。默认:0000-00-00 00:00:00 # 注意:此字段可能返回 null,表示取不到有效值。 # @type IsolateTime: String # @param ExpireTime: 包年包月任务的到期时间,时间格式如:Y-m-d h:m:s。默认:0000-00-00 00:00:00 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExpireTime: String # @param OfflineTime: 下线时间,时间格式如:Y-m-d h:m:s。默认:0000-00-00 00:00:00 # 注意:此字段可能返回 null,表示取不到有效值。 # @type OfflineTime: String # @param PayType: 计费方式,0 - 包年包月,1 - 按量计费 # @type PayType: Integer # @param AutoRenewFlag: 自动续费标识。只有当 PayType=0,该值才有意义。枚举值:0-不自动续费,1-自动续费 # @type AutoRenewFlag: Integer # @param Region: 数据订阅实例所属地域 # @type Region: String # @param AccessType: 接入方式。枚举值:extranet(公网) vpncloud(vpn接入) dcg(专线接入) ccn(云联网) cdb(云数据库) cvm(云主机自建) intranet(自研上云) vpc(私有网络vpc) # 注意:此字段可能返回 null,表示取不到有效值。 # @type AccessType: String # @param Endpoints: 数据库节点信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Endpoints: Array # @param SubscribeVersion: 数据订阅版本, 当前只支持 kafka 版本。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SubscribeVersion: String # @param Tags: 标签 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tags: Array # @param Errors: 任务报错信息,如果有的话。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Errors: Array attr_accessor :SubscribeId, :SubscribeName, :Topic, :Product, :InstanceId, :InstanceStatus, :Status, :SubsStatus, :ModifyTime, :CreateTime, :IsolateTime, :ExpireTime, :OfflineTime, :PayType, :AutoRenewFlag, :Region, :AccessType, :Endpoints, :SubscribeVersion, :Tags, :Errors def initialize(subscribeid=nil, subscribename=nil, topic=nil, product=nil, instanceid=nil, instancestatus=nil, status=nil, subsstatus=nil, modifytime=nil, createtime=nil, isolatetime=nil, expiretime=nil, offlinetime=nil, paytype=nil, autorenewflag=nil, region=nil, accesstype=nil, endpoints=nil, subscribeversion=nil, tags=nil, errors=nil) @SubscribeId = subscribeid @SubscribeName = subscribename @Topic = topic @Product = product @InstanceId = instanceid @InstanceStatus = instancestatus @Status = status @SubsStatus = subsstatus @ModifyTime = modifytime @CreateTime = createtime @IsolateTime = isolatetime @ExpireTime = expiretime @OfflineTime = offlinetime @PayType = paytype @AutoRenewFlag = autorenewflag @Region = region @AccessType = accesstype @Endpoints = endpoints @SubscribeVersion = subscribeversion @Tags = tags @Errors = errors end def deserialize(params) @SubscribeId = params['SubscribeId'] @SubscribeName = params['SubscribeName'] @Topic = params['Topic'] @Product = params['Product'] @InstanceId = params['InstanceId'] @InstanceStatus = params['InstanceStatus'] @Status = params['Status'] @SubsStatus = params['SubsStatus'] @ModifyTime = params['ModifyTime'] @CreateTime = params['CreateTime'] @IsolateTime = params['IsolateTime'] @ExpireTime = params['ExpireTime'] @OfflineTime = params['OfflineTime'] @PayType = params['PayType'] @AutoRenewFlag = params['AutoRenewFlag'] @Region = params['Region'] @AccessType = params['AccessType'] unless params['Endpoints'].nil? @Endpoints = [] params['Endpoints'].each do |i| endpointitem_tmp = EndpointItem.new endpointitem_tmp.deserialize(i) @Endpoints << endpointitem_tmp end end @SubscribeVersion = params['SubscribeVersion'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| tagitem_tmp = TagItem.new tagitem_tmp.deserialize(i) @Tags << tagitem_tmp end end unless params['Errors'].nil? @Errors = [] params['Errors'].each do |i| subserr_tmp = SubsErr.new subserr_tmp.deserialize(i) @Errors << subserr_tmp end end end end # 订阅的kafka分区数和分区规则。mariadb,percona,tdsqlmysql,tdpg不支持自定义分区,所以DistributeRules和DefaultRuleType可以不填,但是NumberOfPartitions是必填。 class SubscribeKafkaConfig < TencentCloud::Common::AbstractModel # @param NumberOfPartitions: kafka分区数量,枚举值为1,4,8 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NumberOfPartitions: Integer # @param DistributeRules: 分区规则。当NumberOfPartitions > 1时,该项必填。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DistributeRules: Array # @param DefaultRuleType: 默认分区策略。当NumberOfPartitions > 1时,该项必填。不满足DistributeRules中正则表达式的数据,将按照默认分区策略计算分区。 # 非mongo产品的枚举值为: table-按表名分区,pk-按表名+主键分区。mongo的枚举值为:collection-按集合名分区。 # 该字段与DistributeRules搭配使用,如果配置了该字段,视为配置了一条DistributeRules。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DefaultRuleType: String attr_accessor :NumberOfPartitions, :DistributeRules, :DefaultRuleType def initialize(numberofpartitions=nil, distributerules=nil, defaultruletype=nil) @NumberOfPartitions = numberofpartitions @DistributeRules = distributerules @DefaultRuleType = defaultruletype end def deserialize(params) @NumberOfPartitions = params['NumberOfPartitions'] unless params['DistributeRules'].nil? @DistributeRules = [] params['DistributeRules'].each do |i| distributerule_tmp = DistributeRule.new distributerule_tmp.deserialize(i) @DistributeRules << distributerule_tmp end end @DefaultRuleType = params['DefaultRuleType'] end end # 订阅的数据库表信息,用于配置和查询订阅任务接口。 class SubscribeObject < TencentCloud::Common::AbstractModel # @param ObjectType: 订阅数据的类型,枚举值:database-数据库,table-数据库的表(如果 DatabaseType 为 mongodb,则表示集合) # 注意:此字段可能返回 null,表示取不到有效值。 # @type ObjectType: String # @param Database: 订阅的数据库名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Database: String # @param Tables: 订阅数据库中表的名称。如果 DatabaseType 为 mongodb,填集合名。mongodb只支持订阅单库或者单集合。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tables: Array attr_accessor :ObjectType, :Database, :Tables def initialize(objecttype=nil, database=nil, tables=nil) @ObjectType = objecttype @Database = database @Tables = tables end def deserialize(params) @ObjectType = params['ObjectType'] @Database = params['Database'] @Tables = params['Tables'] end end # 数据同步配置多节点数据库的节点信息。多节点数据库,如tdsqlmysql使用该结构;单节点数据库,如mysql使用Endpoint。 class SyncDBEndpointInfos < TencentCloud::Common::AbstractModel # @param Region: 数据库所在地域 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Region: String # @param AccessType: 实例网络接入类型,如:extranet(外网)、ipv6(公网ipv6)、cvm(云主机自建)、dcg(专线接入)、vpncloud(vpn接入的实例)、cdb(云数据库)、ccn(云联网)、intranet(自研上云)、vpc(私有网络)等,注意具体可选值依赖当前链路 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AccessType: String # @param DatabaseType: 实例数据库类型,如:mysql,redis,mongodb,postgresql,mariadb,percona 等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DatabaseType: String # @param Info: 数据库信息。注意:如果数据库类型为tdsqlmysql,此处Endpoint数组的顺序应满足规则:proxy节点放在set节点之前。如果SrcConnectType选择proxy接入则只需要填写proxy节点即可。如果选择set接入,数组中第一个set节点必须是shardkey范围起始为0的分片 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Info: Array attr_accessor :Region, :AccessType, :DatabaseType, :Info def initialize(region=nil, accesstype=nil, databasetype=nil, info=nil) @Region = region @AccessType = accesstype @DatabaseType = databasetype @Info = info end def deserialize(params) @Region = params['Region'] @AccessType = params['AccessType'] @DatabaseType = params['DatabaseType'] unless params['Info'].nil? @Info = [] params['Info'].each do |i| endpoint_tmp = Endpoint.new endpoint_tmp.deserialize(i) @Info << endpoint_tmp end end end end # 同步任务的步骤信息 class SyncDetailInfo < TencentCloud::Common::AbstractModel # @param StepAll: 总步骤数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepAll: Integer # @param StepNow: 当前步骤 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepNow: Integer # @param Progress: 总体进度 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Progress: Integer # @param CurrentStepProgress: 当前步骤进度,范围为[0-100],若为-1表示当前步骤不支持查看进度 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CurrentStepProgress: Integer # @param MasterSlaveDistance: 同步两端数据量差距 # 注意:此字段可能返回 null,表示取不到有效值。 # @type MasterSlaveDistance: Integer # @param SecondsBehindMaster: 同步两端时间差距 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SecondsBehindMaster: Integer # @param Message: 总体描述信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Message: String # @param StepInfos: 详细步骤信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type StepInfos: Array # @param CauseOfCompareDisable: 不能发起一致性校验的原因 # 注意:此字段可能返回 null,表示取不到有效值。 # @type CauseOfCompareDisable: String # @param ErrInfo: 任务的错误和解决方案信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ErrInfo: :class:`Tencentcloud::Dts.v20211206.models.ErrInfo` attr_accessor :StepAll, :StepNow, :Progress, :CurrentStepProgress, :MasterSlaveDistance, :SecondsBehindMaster, :Message, :StepInfos, :CauseOfCompareDisable, :ErrInfo def initialize(stepall=nil, stepnow=nil, progress=nil, currentstepprogress=nil, masterslavedistance=nil, secondsbehindmaster=nil, message=nil, stepinfos=nil, causeofcomparedisable=nil, errinfo=nil) @StepAll = stepall @StepNow = stepnow @Progress = progress @CurrentStepProgress = currentstepprogress @MasterSlaveDistance = masterslavedistance @SecondsBehindMaster = secondsbehindmaster @Message = message @StepInfos = stepinfos @CauseOfCompareDisable = causeofcomparedisable @ErrInfo = errinfo end def deserialize(params) @StepAll = params['StepAll'] @StepNow = params['StepNow'] @Progress = params['Progress'] @CurrentStepProgress = params['CurrentStepProgress'] @MasterSlaveDistance = params['MasterSlaveDistance'] @SecondsBehindMaster = params['SecondsBehindMaster'] @Message = params['Message'] unless params['StepInfos'].nil? @StepInfos = [] params['StepInfos'].each do |i| stepinfo_tmp = StepInfo.new stepinfo_tmp.deserialize(i) @StepInfos << stepinfo_tmp end end @CauseOfCompareDisable = params['CauseOfCompareDisable'] unless params['ErrInfo'].nil? @ErrInfo = ErrInfo.new @ErrInfo.deserialize(params['ErrInfo']) end end end # 同步任务信息 class SyncJobInfo < TencentCloud::Common::AbstractModel # @param JobId: 同步任务id,如:sync-btso140 # 注意:此字段可能返回 null,表示取不到有效值。 # @type JobId: String # @param JobName: 同步任务名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type JobName: String # @param PayMode: 付款方式,PostPay(按量付费)、PrePay(包年包月) # 注意:此字段可能返回 null,表示取不到有效值。 # @type PayMode: String # @param RunMode: 运行模式,Immediate(表示立即运行,默认为此项值)、Timed(表示定时运行) # 注意:此字段可能返回 null,表示取不到有效值。 # @type RunMode: String # @param ExpectRunTime: 期待运行时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExpectRunTime: String # @param AllActions: 支持的所有操作 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AllActions: Array # @param Actions: 当前状态能进行的操作 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Actions: Array # @param Options: 同步选项 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Options: :class:`Tencentcloud::Dts.v20211206.models.Options` # @param Objects: 同步库表对象 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Objects: :class:`Tencentcloud::Dts.v20211206.models.Objects` # @param Specification: 任务规格 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Specification: String # @param ExpireTime: 过期时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExpireTime: String # @param SrcRegion: 源端地域,如:ap-guangzhou等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcRegion: String # @param SrcDatabaseType: 源端数据库类型,mysql,cynosdbmysql,tdapg,tdpg,tdsqlmysql等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcDatabaseType: String # @param SrcAccessType: 源端接入类型,cdb(云数据库)、cvm(云主机自建)、vpc(私有网络)、extranet(外网)、vpncloud(vpn接入)、dcg(专线接入)、ccn(云联网)、intranet(自研上云) # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcAccessType: String # @param SrcInfo: 源端信息,单节点数据库使用 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcInfo: :class:`Tencentcloud::Dts.v20211206.models.Endpoint` # @param SrcNodeType: 枚举值:cluster、single。源库为单节点数据库使用single,多节点使用cluster # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcNodeType: String # @param SrcInfos: 源端信息,多节点数据库使用 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SrcInfos: :class:`Tencentcloud::Dts.v20211206.models.SyncDBEndpointInfos` # @param DstRegion: 目标端地域,如:ap-guangzhou等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstRegion: String # @param DstDatabaseType: 目标端数据库类型,mysql,cynosdbmysql,tdapg,tdpg,tdsqlmysql等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstDatabaseType: String # @param DstAccessType: 目标端接入类型,cdb(云数据库)、cvm(云主机自建)、vpc(私有网络)、extranet(外网)、vpncloud(vpn接入)、dcg(专线接入)、ccn(云联网)、intranet(自研上云) # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstAccessType: String # @param DstInfo: 目标端信息,单节点数据库使用 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstInfo: :class:`Tencentcloud::Dts.v20211206.models.Endpoint` # @param DstNodeType: 枚举值:cluster、single。目标库为单节点数据库使用single,多节点使用cluster # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstNodeType: String # @param DstInfos: 目标端信息,多节点数据库使用 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DstInfos: :class:`Tencentcloud::Dts.v20211206.models.SyncDBEndpointInfos` # @param CreateTime: 创建时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type CreateTime: String # @param StartTime: 开始时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartTime: String # @param Status: 任务状态,UnInitialized(未初始化)、Initialized(已初始化)、Checking(校验中)、CheckPass(校验通过)、CheckNotPass(校验不通过)、ReadyRunning(准备运行)、Running(运行中)、Pausing(暂停中)、Paused(已暂停)、Stopping(停止中)、Stopped(已结束)、ResumableErr(任务错误)、Resuming(恢复中)、Failed(失败)、Released(已释放)、Resetting(重置中)、Unknown(未知) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Status: String # @param EndTime: 结束时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type EndTime: String # @param Tags: 标签相关信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tags: Array # @param Detail: 同步任务运行步骤信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Detail: :class:`Tencentcloud::Dts.v20211206.models.SyncDetailInfo` # @param TradeStatus: 用于计费的状态,可能取值有:Normal(正常状态)、Resizing(变配中)、Renewing(续费中)、Isolating(隔离中)、Isolated(已隔离)、Offlining(下线中)、Offlined(已下线)、NotBilled(未计费)、Recovering(解隔离)、PostPay2Prepaying(按量计费转包年包月中)、PrePay2Postpaying(包年包月转按量计费中) # 注意:此字段可能返回 null,表示取不到有效值。 # @type TradeStatus: String # @param InstanceClass: 同步链路规格,如micro,small,medium,large # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceClass: String # @param AutoRenew: 自动续费标识,当PayMode值为PrePay则此项配置有意义,取值为:1(表示自动续费)、0(不自动续费) # 注意:此字段可能返回 null,表示取不到有效值。 # @type AutoRenew: Integer # @param OfflineTime: 下线时间,格式为 yyyy-mm-dd hh:mm:ss # 注意:此字段可能返回 null,表示取不到有效值。 # @type OfflineTime: String # @param OptObjStatus: 动态修改对象,修改任务的状态等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type OptObjStatus: String # @param AutoRetryTimeRangeMinutes: 自动重试时间段设置 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AutoRetryTimeRangeMinutes: Integer # @param DumperResumeCtrl: 全量导出可重入标识:enum::"yes"/"no"。yes表示当前任务可重入、no表示当前任务处于全量导出且不可重入阶段;如果在该值为no时重启任务导出流程不支持断点续传 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DumperResumeCtrl: String attr_accessor :JobId, :JobName, :PayMode, :RunMode, :ExpectRunTime, :AllActions, :Actions, :Options, :Objects, :Specification, :ExpireTime, :SrcRegion, :SrcDatabaseType, :SrcAccessType, :SrcInfo, :SrcNodeType, :SrcInfos, :DstRegion, :DstDatabaseType, :DstAccessType, :DstInfo, :DstNodeType, :DstInfos, :CreateTime, :StartTime, :Status, :EndTime, :Tags, :Detail, :TradeStatus, :InstanceClass, :AutoRenew, :OfflineTime, :OptObjStatus, :AutoRetryTimeRangeMinutes, :DumperResumeCtrl def initialize(jobid=nil, jobname=nil, paymode=nil, runmode=nil, expectruntime=nil, allactions=nil, actions=nil, options=nil, objects=nil, specification=nil, expiretime=nil, srcregion=nil, srcdatabasetype=nil, srcaccesstype=nil, srcinfo=nil, srcnodetype=nil, srcinfos=nil, dstregion=nil, dstdatabasetype=nil, dstaccesstype=nil, dstinfo=nil, dstnodetype=nil, dstinfos=nil, createtime=nil, starttime=nil, status=nil, endtime=nil, tags=nil, detail=nil, tradestatus=nil, instanceclass=nil, autorenew=nil, offlinetime=nil, optobjstatus=nil, autoretrytimerangeminutes=nil, dumperresumectrl=nil) @JobId = jobid @JobName = jobname @PayMode = paymode @RunMode = runmode @ExpectRunTime = expectruntime @AllActions = allactions @Actions = actions @Options = options @Objects = objects @Specification = specification @ExpireTime = expiretime @SrcRegion = srcregion @SrcDatabaseType = srcdatabasetype @SrcAccessType = srcaccesstype @SrcInfo = srcinfo @SrcNodeType = srcnodetype @SrcInfos = srcinfos @DstRegion = dstregion @DstDatabaseType = dstdatabasetype @DstAccessType = dstaccesstype @DstInfo = dstinfo @DstNodeType = dstnodetype @DstInfos = dstinfos @CreateTime = createtime @StartTime = starttime @Status = status @EndTime = endtime @Tags = tags @Detail = detail @TradeStatus = tradestatus @InstanceClass = instanceclass @AutoRenew = autorenew @OfflineTime = offlinetime @OptObjStatus = optobjstatus @AutoRetryTimeRangeMinutes = autoretrytimerangeminutes @DumperResumeCtrl = dumperresumectrl end def deserialize(params) @JobId = params['JobId'] @JobName = params['JobName'] @PayMode = params['PayMode'] @RunMode = params['RunMode'] @ExpectRunTime = params['ExpectRunTime'] @AllActions = params['AllActions'] @Actions = params['Actions'] unless params['Options'].nil? @Options = Options.new @Options.deserialize(params['Options']) end unless params['Objects'].nil? @Objects = Objects.new @Objects.deserialize(params['Objects']) end @Specification = params['Specification'] @ExpireTime = params['ExpireTime'] @SrcRegion = params['SrcRegion'] @SrcDatabaseType = params['SrcDatabaseType'] @SrcAccessType = params['SrcAccessType'] unless params['SrcInfo'].nil? @SrcInfo = Endpoint.new @SrcInfo.deserialize(params['SrcInfo']) end @SrcNodeType = params['SrcNodeType'] unless params['SrcInfos'].nil? @SrcInfos = SyncDBEndpointInfos.new @SrcInfos.deserialize(params['SrcInfos']) end @DstRegion = params['DstRegion'] @DstDatabaseType = params['DstDatabaseType'] @DstAccessType = params['DstAccessType'] unless params['DstInfo'].nil? @DstInfo = Endpoint.new @DstInfo.deserialize(params['DstInfo']) end @DstNodeType = params['DstNodeType'] unless params['DstInfos'].nil? @DstInfos = SyncDBEndpointInfos.new @DstInfos.deserialize(params['DstInfos']) end @CreateTime = params['CreateTime'] @StartTime = params['StartTime'] @Status = params['Status'] @EndTime = params['EndTime'] unless params['Tags'].nil? @Tags = [] params['Tags'].each do |i| tagitem_tmp = TagItem.new tagitem_tmp.deserialize(i) @Tags << tagitem_tmp end end unless params['Detail'].nil? @Detail = SyncDetailInfo.new @Detail.deserialize(params['Detail']) end @TradeStatus = params['TradeStatus'] @InstanceClass = params['InstanceClass'] @AutoRenew = params['AutoRenew'] @OfflineTime = params['OfflineTime'] @OptObjStatus = params['OptObjStatus'] @AutoRetryTimeRangeMinutes = params['AutoRetryTimeRangeMinutes'] @DumperResumeCtrl = params['DumperResumeCtrl'] end end # 数据同步库表信息描述 class Table < TencentCloud::Common::AbstractModel # @param TableName: 表名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TableName: String # @param NewTableName: 新表名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NewTableName: String # @param FilterCondition: 过滤条件 # 注意:此字段可能返回 null,表示取不到有效值。 # @type FilterCondition: String # @param ColumnMode: 是否同步表中所有列,All:当前表下的所有列,Partial(ModifySyncJobConfig接口里的对应字段ColumnMode暂不支持Partial):当前表下的部分列,通过填充Columns字段详细表信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ColumnMode: String # @param Columns: 同步的列信息,当ColumnMode为Partial时,必填 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Columns: Array # @param TmpTables: 同步临时表,注意此配置与NewTableName互斥,只能使用其中一种。当配置的同步对象为表级别且TableEditMode为pt时此项有意义,针对pt-osc等工具在同步过程中产生的临时表进行同步,需要提前将可能的临时表配置在这里,否则不会同步任何临时表。示例,如要对t1进行pt-osc操作,此项配置应该为["\_t1\_new","\_t1\_old"];如要对t1进行gh-ost操作,此项配置应该为["\_t1\_ghc","\_t1\_gho","\_t1\_del"],pt-osc与gh-ost产生的临时表可同时配置。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TmpTables: Array # @param TableEditMode: 编辑表类型,rename(表映射),pt(同步附加表) # 注意:此字段可能返回 null,表示取不到有效值。 # @type TableEditMode: String attr_accessor :TableName, :NewTableName, :FilterCondition, :ColumnMode, :Columns, :TmpTables, :TableEditMode def initialize(tablename=nil, newtablename=nil, filtercondition=nil, columnmode=nil, columns=nil, tmptables=nil, tableeditmode=nil) @TableName = tablename @NewTableName = newtablename @FilterCondition = filtercondition @ColumnMode = columnmode @Columns = columns @TmpTables = tmptables @TableEditMode = tableeditmode end def deserialize(params) @TableName = params['TableName'] @NewTableName = params['NewTableName'] @FilterCondition = params['FilterCondition'] @ColumnMode = params['ColumnMode'] unless params['Columns'].nil? @Columns = [] params['Columns'].each do |i| column_tmp = Column.new column_tmp.deserialize(i) @Columns << column_tmp end end @TmpTables = params['TmpTables'] @TableEditMode = params['TableEditMode'] end end # 表对象集合,当 TableMode 为 partial 时,此项需要填写 class TableItem < TencentCloud::Common::AbstractModel # @param TableName: 迁移的表名,大小写敏感 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TableName: String # @param NewTableName: 迁移后的表名,当TableEditMode为rename时此项必填,注意此配置与TmpTables互斥,只能使用其中一种 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NewTableName: String # @param TmpTables: 迁移临时表,注意此配置与NewTableName互斥,只能使用其中一种。当配置的同步对象为表级别且TableEditMode为pt时此项有意义,针对pt-osc等工具在迁移过程中产生的临时表进行同步,需要提前将可能的临时表配置在这里,否则不会同步任何临时表。示例,如要对t1进行pt-osc操作,此项配置应该为["\_t1\_new","\_t1\_old"];如要对t1进行gh-ost操作,此项配置应该为["\_t1\_ghc","\_t1\_gho","\_t1\_del"],pt-osc与gh-ost产生的临时表可同时配置。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TmpTables: Array # @param TableEditMode: 编辑表类型,rename(表映射),pt(同步附加表) # 注意:此字段可能返回 null,表示取不到有效值。 # @type TableEditMode: String attr_accessor :TableName, :NewTableName, :TmpTables, :TableEditMode def initialize(tablename=nil, newtablename=nil, tmptables=nil, tableeditmode=nil) @TableName = tablename @NewTableName = newtablename @TmpTables = tmptables @TableEditMode = tableeditmode end def deserialize(params) @TableName = params['TableName'] @NewTableName = params['NewTableName'] @TmpTables = params['TmpTables'] @TableEditMode = params['TableEditMode'] end end # 标签过滤 class TagFilter < TencentCloud::Common::AbstractModel # @param TagKey: 标签键值 # @type TagKey: String # @param TagValue: 标签值 # @type TagValue: Array 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 # 标签 class TagItem < TencentCloud::Common::AbstractModel # @param TagKey: 标签键 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TagKey: String # @param TagValue: 标签值 # 注意:此字段可能返回 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 # 单topic和自定义topic的描述。投递到单topic时,该数组的最后一项会被视为默认分区策略,所有未匹配到的数据都会按该策略投递,默认策略只支持 投递至partition0、按表名、表名+主键三种。 class TopicRule < TencentCloud::Common::AbstractModel # @param TopicName: topic名。单topic时,所有的TopicName必须相同 # @type TopicName: String # @param PartitionType: topic分区策略,自定义topic时支持:Random(随机投递),集中投递到单Topic时支持:AllInPartitionZero(全部投递至partition0)、PartitionByTable(按表名分区)、PartitionByTableAndKey(按表名加主键分区)、PartitionByCols(按列分区) # @type PartitionType: String # @param DbMatchMode: 库名匹配规则,如Regular(正则匹配), Default(不符合匹配规则的剩余库),数组中最后一项必须为‘Default’ # @type DbMatchMode: String # @param DbName: 库名,DbMatchMode=Regular时生效 # @type DbName: String # @param TableMatchMode: 表名匹配规则,如Regular(正则匹配), Default(不符合匹配规则的剩余表),数组中最后一项必须为‘Default’ # @type TableMatchMode: String # @param TableName: 表名,仅TableMatchMode=Regular时生效 # @type TableName: String # @param Columns: 按列分区时需要选择配置列名,可以选择多列 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Columns: Array attr_accessor :TopicName, :PartitionType, :DbMatchMode, :DbName, :TableMatchMode, :TableName, :Columns def initialize(topicname=nil, partitiontype=nil, dbmatchmode=nil, dbname=nil, tablematchmode=nil, tablename=nil, columns=nil) @TopicName = topicname @PartitionType = partitiontype @DbMatchMode = dbmatchmode @DbName = dbname @TableMatchMode = tablematchmode @TableName = tablename @Columns = columns end def deserialize(params) @TopicName = params['TopicName'] @PartitionType = params['PartitionType'] @DbMatchMode = params['DbMatchMode'] @DbName = params['DbName'] @TableMatchMode = params['TableMatchMode'] @TableName = params['TableName'] @Columns = params['Columns'] end end # 计费状态信息 class TradeInfo < TencentCloud::Common::AbstractModel # @param DealName: 交易订单号 # 注意:此字段可能返回 null,表示取不到有效值。 # @type DealName: String # @param LastDealName: 上一次交易订单号 # 注意:此字段可能返回 null,表示取不到有效值。 # @type LastDealName: String # @param InstanceClass: 实例规格,包括:micro、small、medium、large、xlarge、2xlarge等 # 注意:此字段可能返回 null,表示取不到有效值。 # @type InstanceClass: String # @param TradeStatus: 计费任务状态, normal(计费或待计费)、resizing(变配中)、reversing(冲正中,比较短暂的状态)、isolating(隔离中,比较短暂的状态)、isolated(已隔离)、offlining(下线中)、offlined(已下线)、notBilled(未计费) # 注意:此字段可能返回 null,表示取不到有效值。 # @type TradeStatus: String # @param ExpireTime: 到期时间,格式为"yyyy-mm-dd hh:mm:ss" # 注意:此字段可能返回 null,表示取不到有效值。 # @type ExpireTime: String # @param OfflineTime: 下线时间,格式为"yyyy-mm-dd hh:mm:ss" # 注意:此字段可能返回 null,表示取不到有效值。 # @type OfflineTime: String # @param IsolateTime: 隔离时间,格式为"yyyy-mm-dd hh:mm:ss" # 注意:此字段可能返回 null,表示取不到有效值。 # @type IsolateTime: String # @param OfflineReason: 下线原因 # 注意:此字段可能返回 null,表示取不到有效值。 # @type OfflineReason: String # @param IsolateReason: 隔离原因 # 注意:此字段可能返回 null,表示取不到有效值。 # @type IsolateReason: String # @param PayType: 付费类型,包括:postpay(后付费)、prepay(预付费) # 注意:此字段可能返回 null,表示取不到有效值。 # @type PayType: String # @param BillingType: 任务计费类型,包括:billing(计费)、notBilling(不计费)、 promotions(促销活动中) # 注意:此字段可能返回 null,表示取不到有效值。 # @type BillingType: String attr_accessor :DealName, :LastDealName, :InstanceClass, :TradeStatus, :ExpireTime, :OfflineTime, :IsolateTime, :OfflineReason, :IsolateReason, :PayType, :BillingType def initialize(dealname=nil, lastdealname=nil, instanceclass=nil, tradestatus=nil, expiretime=nil, offlinetime=nil, isolatetime=nil, offlinereason=nil, isolatereason=nil, paytype=nil, billingtype=nil) @DealName = dealname @LastDealName = lastdealname @InstanceClass = instanceclass @TradeStatus = tradestatus @ExpireTime = expiretime @OfflineTime = offlinetime @IsolateTime = isolatetime @OfflineReason = offlinereason @IsolateReason = isolatereason @PayType = paytype @BillingType = billingtype end def deserialize(params) @DealName = params['DealName'] @LastDealName = params['LastDealName'] @InstanceClass = params['InstanceClass'] @TradeStatus = params['TradeStatus'] @ExpireTime = params['ExpireTime'] @OfflineTime = params['OfflineTime'] @IsolateTime = params['IsolateTime'] @OfflineReason = params['OfflineReason'] @IsolateReason = params['IsolateReason'] @PayType = params['PayType'] @BillingType = params['BillingType'] end end # 数据同步view的描述 class View < TencentCloud::Common::AbstractModel # @param ViewName: view名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ViewName: String # @param NewViewName: 预留字段、目前暂时不支持view的重命名 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NewViewName: String attr_accessor :ViewName, :NewViewName def initialize(viewname=nil, newviewname=nil) @ViewName = viewname @NewViewName = newviewname end def deserialize(params) @ViewName = params['ViewName'] @NewViewName = params['NewViewName'] end end # 视图对象 class ViewItem < TencentCloud::Common::AbstractModel # @param ViewName: 视图名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type ViewName: String # @param NewViewName: 迁移后的视图名称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type NewViewName: String attr_accessor :ViewName, :NewViewName def initialize(viewname=nil, newviewname=nil) @ViewName = viewname @NewViewName = newviewname end def deserialize(params) @ViewName = params['ViewName'] @NewViewName = params['NewViewName'] end end end end end