# 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 Monitor
module V20180724
# 策略过滤条件
class AlarmConditionFilter < TencentCloud::Common::AbstractModel
# @param Type: 类型
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param Expression: 表达式
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Expression: String
# @param Dimensions: 过滤条件
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Dimensions: String
attr_accessor :Type, :Expression, :Dimensions
def initialize(type=nil, expression=nil, dimensions=nil)
@Type = type
@Expression = expression
@Dimensions = dimensions
end
def deserialize(params)
@Type = params['Type']
@Expression = params['Expression']
@Dimensions = params['Dimensions']
end
end
# 告警事件
class AlarmEvent < TencentCloud::Common::AbstractModel
# @param EventName: 事件名
# @type EventName: String
# @param Description: 展示的事件名
# @type Description: String
# @param Namespace: 告警策略类型
# @type Namespace: String
attr_accessor :EventName, :Description, :Namespace
def initialize(eventname=nil, description=nil, namespace=nil)
@EventName = eventname
@Description = description
@Namespace = namespace
end
def deserialize(params)
@EventName = params['EventName']
@Description = params['Description']
@Namespace = params['Namespace']
end
end
# 聚合条件
class AlarmGroupByItem < TencentCloud::Common::AbstractModel
# @param Id: Item Id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Id: String
# @param Name: 名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
attr_accessor :Id, :Name
def initialize(id=nil, name=nil)
@Id = id
@Name = name
end
def deserialize(params)
@Id = params['Id']
@Name = params['Name']
end
end
# 通知模板ID及通知等级列表,["Remind","Serious"]表示该通知模板仅接收提醒和严重类别的告警
class AlarmHierarchicalNotice < TencentCloud::Common::AbstractModel
# @param NoticeId: 通知模板ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NoticeId: String
# @param Classification: 通知等级列表,["Remind","Serious"]表示该通知模板仅接收提醒和严重类别的告警
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Classification: Array
# @param PolicyId: 模板对应的策略id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PolicyId: String
attr_accessor :NoticeId, :Classification, :PolicyId
def initialize(noticeid=nil, classification=nil, policyid=nil)
@NoticeId = noticeid
@Classification = classification
@PolicyId = policyid
end
def deserialize(params)
@NoticeId = params['NoticeId']
@Classification = params['Classification']
@PolicyId = params['PolicyId']
end
end
# 告警分级阈值配置
class AlarmHierarchicalValue < TencentCloud::Common::AbstractModel
# @param Remind: 提醒等级阈值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Remind: String
# @param Warn: 警告等级阈值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Warn: String
# @param Serious: 严重等级阈值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Serious: String
attr_accessor :Remind, :Warn, :Serious
def initialize(remind=nil, warn=nil, serious=nil)
@Remind = remind
@Warn = warn
@Serious = serious
end
def deserialize(params)
@Remind = params['Remind']
@Warn = params['Warn']
@Serious = params['Serious']
end
end
# 告警历史数据
class AlarmHistory < TencentCloud::Common::AbstractModel
# @param AlarmId: 告警历史Id
# @type AlarmId: String
# @param MonitorType: 监控类型
# @type MonitorType: String
# @param Namespace: 策略类型
# @type Namespace: String
# @param AlarmObject: 告警对象
# @type AlarmObject: String
# @param Content: 告警内容
# @type Content: String
# @param FirstOccurTime: 时间戳,首次出现时间
# @type FirstOccurTime: Integer
# @param LastOccurTime: 时间戳,最后出现时间
# @type LastOccurTime: Integer
# @param AlarmStatus: 告警状态,ALARM=未恢复 OK=已恢复 NO_CONF=已失效 NO_DATA=数据不足
# @type AlarmStatus: String
# @param PolicyId: 告警策略 Id
# @type PolicyId: String
# @param PolicyName: 策略名称
# @type PolicyName: String
# @param VPC: 基础产品告警的告警对象所属网络
# @type VPC: String
# @param ProjectId: 项目 Id
# @type ProjectId: Integer
# @param ProjectName: 项目名字
# @type ProjectName: String
# @param InstanceGroup: 告警对象所属实例组
# @type InstanceGroup: Array
# @param ReceiverUids: 接收人列表
# @type ReceiverUids: Array
# @param ReceiverGroups: 接收组列表
# @type ReceiverGroups: Array
# @param NoticeWays: 告警渠道列表 SMS=短信 EMAIL=邮件 CALL=电话 WECHAT=微信
# @type NoticeWays: Array
# @param OriginId: 可用于实例、实例组的绑定和解绑接口([BindingPolicyObject](https://cloud.tencent.com/document/product/248/40421)、[UnBindingAllPolicyObject](https://cloud.tencent.com/document/product/248/40568)、[UnBindingPolicyObject](https://cloud.tencent.com/document/product/248/40567))的策略 ID
# @type OriginId: String
# @param AlarmType: 告警类型
# @type AlarmType: String
# @param EventId: 事件Id
# @type EventId: Integer
# @param Region: 地域
# @type Region: String
# @param PolicyExists: 策略是否存在 0=不存在 1=存在
# @type PolicyExists: Integer
# @param MetricsInfo: 指标信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MetricsInfo: Array
# @param Dimensions: 告警实例的维度信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Dimensions: String
# @param AlarmLevel: 告警等级
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlarmLevel: String
# @param ShieldFlag: 是否有配置告警屏蔽规则
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ShieldFlag: Integer
# @param AlarmShieldingType: 屏蔽类型(英文)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlarmShieldingType: String
# @param AlarmShieldingTime: 屏蔽时间(英文)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlarmShieldingTime: String
# @param AlarmShieldingShowType: 屏蔽类型(中文)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlarmShieldingShowType: String
# @param AlarmShieldingShowTime: 屏蔽时间(中文)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlarmShieldingShowTime: String
# @param AlarmShieldReason: 屏蔽原因
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlarmShieldReason: String
# @param InternalDimensions: 告警实例的维度信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InternalDimensions: String
# @param MetricName: 指标名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MetricName: String
# @param PolicyPermissions: 策略是否有权限
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PolicyPermissions: Integer
attr_accessor :AlarmId, :MonitorType, :Namespace, :AlarmObject, :Content, :FirstOccurTime, :LastOccurTime, :AlarmStatus, :PolicyId, :PolicyName, :VPC, :ProjectId, :ProjectName, :InstanceGroup, :ReceiverUids, :ReceiverGroups, :NoticeWays, :OriginId, :AlarmType, :EventId, :Region, :PolicyExists, :MetricsInfo, :Dimensions, :AlarmLevel, :ShieldFlag, :AlarmShieldingType, :AlarmShieldingTime, :AlarmShieldingShowType, :AlarmShieldingShowTime, :AlarmShieldReason, :InternalDimensions, :MetricName, :PolicyPermissions
def initialize(alarmid=nil, monitortype=nil, namespace=nil, alarmobject=nil, content=nil, firstoccurtime=nil, lastoccurtime=nil, alarmstatus=nil, policyid=nil, policyname=nil, vpc=nil, projectid=nil, projectname=nil, instancegroup=nil, receiveruids=nil, receivergroups=nil, noticeways=nil, originid=nil, alarmtype=nil, eventid=nil, region=nil, policyexists=nil, metricsinfo=nil, dimensions=nil, alarmlevel=nil, shieldflag=nil, alarmshieldingtype=nil, alarmshieldingtime=nil, alarmshieldingshowtype=nil, alarmshieldingshowtime=nil, alarmshieldreason=nil, internaldimensions=nil, metricname=nil, policypermissions=nil)
@AlarmId = alarmid
@MonitorType = monitortype
@Namespace = namespace
@AlarmObject = alarmobject
@Content = content
@FirstOccurTime = firstoccurtime
@LastOccurTime = lastoccurtime
@AlarmStatus = alarmstatus
@PolicyId = policyid
@PolicyName = policyname
@VPC = vpc
@ProjectId = projectid
@ProjectName = projectname
@InstanceGroup = instancegroup
@ReceiverUids = receiveruids
@ReceiverGroups = receivergroups
@NoticeWays = noticeways
@OriginId = originid
@AlarmType = alarmtype
@EventId = eventid
@Region = region
@PolicyExists = policyexists
@MetricsInfo = metricsinfo
@Dimensions = dimensions
@AlarmLevel = alarmlevel
@ShieldFlag = shieldflag
@AlarmShieldingType = alarmshieldingtype
@AlarmShieldingTime = alarmshieldingtime
@AlarmShieldingShowType = alarmshieldingshowtype
@AlarmShieldingShowTime = alarmshieldingshowtime
@AlarmShieldReason = alarmshieldreason
@InternalDimensions = internaldimensions
@MetricName = metricname
@PolicyPermissions = policypermissions
end
def deserialize(params)
@AlarmId = params['AlarmId']
@MonitorType = params['MonitorType']
@Namespace = params['Namespace']
@AlarmObject = params['AlarmObject']
@Content = params['Content']
@FirstOccurTime = params['FirstOccurTime']
@LastOccurTime = params['LastOccurTime']
@AlarmStatus = params['AlarmStatus']
@PolicyId = params['PolicyId']
@PolicyName = params['PolicyName']
@VPC = params['VPC']
@ProjectId = params['ProjectId']
@ProjectName = params['ProjectName']
unless params['InstanceGroup'].nil?
@InstanceGroup = []
params['InstanceGroup'].each do |i|
instancegroups_tmp = InstanceGroups.new
instancegroups_tmp.deserialize(i)
@InstanceGroup << instancegroups_tmp
end
end
@ReceiverUids = params['ReceiverUids']
@ReceiverGroups = params['ReceiverGroups']
@NoticeWays = params['NoticeWays']
@OriginId = params['OriginId']
@AlarmType = params['AlarmType']
@EventId = params['EventId']
@Region = params['Region']
@PolicyExists = params['PolicyExists']
unless params['MetricsInfo'].nil?
@MetricsInfo = []
params['MetricsInfo'].each do |i|
alarmhistorymetric_tmp = AlarmHistoryMetric.new
alarmhistorymetric_tmp.deserialize(i)
@MetricsInfo << alarmhistorymetric_tmp
end
end
@Dimensions = params['Dimensions']
@AlarmLevel = params['AlarmLevel']
@ShieldFlag = params['ShieldFlag']
@AlarmShieldingType = params['AlarmShieldingType']
@AlarmShieldingTime = params['AlarmShieldingTime']
@AlarmShieldingShowType = params['AlarmShieldingShowType']
@AlarmShieldingShowTime = params['AlarmShieldingShowTime']
@AlarmShieldReason = params['AlarmShieldReason']
@InternalDimensions = params['InternalDimensions']
@MetricName = params['MetricName']
@PolicyPermissions = params['PolicyPermissions']
end
end
# 告警历史的指标信息
class AlarmHistoryMetric < TencentCloud::Common::AbstractModel
# @param QceNamespace: 云产品监控类型查询数据使用的命名空间
# @type QceNamespace: String
# @param MetricName: 指标名
# @type MetricName: String
# @param Period: 统计周期
# @type Period: Integer
# @param Value: 触发告警的数值
# @type Value: String
# @param Description: 指标的展示名
# @type Description: String
attr_accessor :QceNamespace, :MetricName, :Period, :Value, :Description
def initialize(qcenamespace=nil, metricname=nil, period=nil, value=nil, description=nil)
@QceNamespace = qcenamespace
@MetricName = metricname
@Period = period
@Value = value
@Description = description
end
def deserialize(params)
@QceNamespace = params['QceNamespace']
@MetricName = params['MetricName']
@Period = params['Period']
@Value = params['Value']
@Description = params['Description']
end
end
# 告警通知模板详情
class AlarmNotice < TencentCloud::Common::AbstractModel
# @param Id: 告警通知模板 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Id: String
# @param Name: 告警通知模板名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param UpdatedAt: 上次修改时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdatedAt: String
# @param UpdatedBy: 上次修改人
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdatedBy: String
# @param NoticeType: 告警通知类型 ALARM=未恢复通知 OK=已恢复通知 ALL=全部通知
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NoticeType: String
# @param UserNotices: 用户通知列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UserNotices: Array
# @param URLNotices: 回调通知列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type URLNotices: Array
# @param IsPreset: 是否是系统预设通知模板 0=否 1=是
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsPreset: Integer
# @param NoticeLanguage: 通知语言 zh-CN=中文 en-US=英文
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NoticeLanguage: String
# @param PolicyIds: 告警通知模板绑定的告警策略ID列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PolicyIds: Array
# @param AMPConsumerId: 后台 amp consumer id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AMPConsumerId: String
# @param CLSNotices: 推送cls渠道
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CLSNotices: Array
# @param Tags: 通知模板绑定的标签
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Tags: Array
attr_accessor :Id, :Name, :UpdatedAt, :UpdatedBy, :NoticeType, :UserNotices, :URLNotices, :IsPreset, :NoticeLanguage, :PolicyIds, :AMPConsumerId, :CLSNotices, :Tags
def initialize(id=nil, name=nil, updatedat=nil, updatedby=nil, noticetype=nil, usernotices=nil, urlnotices=nil, ispreset=nil, noticelanguage=nil, policyids=nil, ampconsumerid=nil, clsnotices=nil, tags=nil)
@Id = id
@Name = name
@UpdatedAt = updatedat
@UpdatedBy = updatedby
@NoticeType = noticetype
@UserNotices = usernotices
@URLNotices = urlnotices
@IsPreset = ispreset
@NoticeLanguage = noticelanguage
@PolicyIds = policyids
@AMPConsumerId = ampconsumerid
@CLSNotices = clsnotices
@Tags = tags
end
def deserialize(params)
@Id = params['Id']
@Name = params['Name']
@UpdatedAt = params['UpdatedAt']
@UpdatedBy = params['UpdatedBy']
@NoticeType = params['NoticeType']
unless params['UserNotices'].nil?
@UserNotices = []
params['UserNotices'].each do |i|
usernotice_tmp = UserNotice.new
usernotice_tmp.deserialize(i)
@UserNotices << usernotice_tmp
end
end
unless params['URLNotices'].nil?
@URLNotices = []
params['URLNotices'].each do |i|
urlnotice_tmp = URLNotice.new
urlnotice_tmp.deserialize(i)
@URLNotices << urlnotice_tmp
end
end
@IsPreset = params['IsPreset']
@NoticeLanguage = params['NoticeLanguage']
@PolicyIds = params['PolicyIds']
@AMPConsumerId = params['AMPConsumerId']
unless params['CLSNotices'].nil?
@CLSNotices = []
params['CLSNotices'].each do |i|
clsnotice_tmp = CLSNotice.new
clsnotice_tmp.deserialize(i)
@CLSNotices << clsnotice_tmp
end
end
unless params['Tags'].nil?
@Tags = []
params['Tags'].each do |i|
tag_tmp = Tag.new
tag_tmp.deserialize(i)
@Tags << tag_tmp
end
end
end
end
# 告警策略详情
class AlarmPolicy < TencentCloud::Common::AbstractModel
# @param PolicyId: 告警策略 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PolicyId: String
# @param PolicyName: 告警策略名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PolicyName: String
# @param Remark: 备注信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Remark: String
# @param MonitorType: 监控类型 MT_QCE=云产品监控
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MonitorType: String
# @param Enable: 启停状态 0=停用 1=启用
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Enable: Integer
# @param UseSum: 策略组绑定的实例数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UseSum: Integer
# @param ProjectId: 项目 Id -1=无项目 0=默认项目
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProjectId: Integer
# @param ProjectName: 项目名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProjectName: String
# @param Namespace: 告警策略类型
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Namespace: String
# @param ConditionTemplateId: 触发条件模板 Id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ConditionTemplateId: String
# @param Condition: 指标触发条件
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Condition: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyCondition`
# @param EventCondition: 事件触发条件
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventCondition: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyEventCondition`
# @param NoticeIds: 通知规则 id 列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NoticeIds: Array
# @param Notices: 通知规则 列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Notices: Array
# @param TriggerTasks: 触发任务列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TriggerTasks: Array
# @param ConditionsTemp: 模板策略组
# 注意:此字段可能返回 null,表示取不到有效值。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ConditionsTemp: :class:`Tencentcloud::Monitor.v20180724.models.ConditionsTemp`
# @param LastEditUin: 最后编辑的用户uin
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LastEditUin: String
# @param UpdateTime: 更新时间
# 注意:此字段可能返回 null,表示取不到有效值。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdateTime: Integer
# @param InsertTime: 创建时间
# 注意:此字段可能返回 null,表示取不到有效值。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InsertTime: Integer
# @param Region: 地域
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Region: Array
# @param NamespaceShowName: namespace显示名字
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NamespaceShowName: String
# @param IsDefault: 是否默认策略,1是,0否
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsDefault: Integer
# @param CanSetDefault: 能否设置默认策略,1是,0否
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CanSetDefault: Integer
# @param InstanceGroupId: 实例分组ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceGroupId: Integer
# @param InstanceSum: 实例分组总实例数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceSum: Integer
# @param InstanceGroupName: 实例分组名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceGroupName: String
# @param RuleType: 触发条件类型 STATIC=静态阈值 DYNAMIC=动态类型
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleType: String
# @param OriginId: 用于实例、实例组绑定和解绑接口(BindingPolicyObject、UnBindingAllPolicyObject、UnBindingPolicyObject)的策略 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OriginId: String
# @param TagInstances: 标签
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TagInstances: Array
# @param Filter: 过滤条件
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Filter: :class:`Tencentcloud::Monitor.v20180724.models.AlarmConditionFilter`
# @param GroupBy: 聚合条件
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GroupBy: Array
# @param FilterDimensionsParam: 策略关联的过滤维度信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FilterDimensionsParam: String
# @param IsOneClick: 是否为一键告警策略
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsOneClick: Integer
# @param OneClickStatus: 一键告警策略是否开启
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OneClickStatus: Integer
# @param AdvancedMetricNumber: 高级指标数量
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AdvancedMetricNumber: Integer
# @param IsBindAll: 策略是否是全部对象策略
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsBindAll: Integer
# @param Tags: 策略标签
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Tags: Array
# @param IsSupportAlarmTag: 是否支持告警标签
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsSupportAlarmTag: Integer
# @param TagOperation: 多标签交/并集关系
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TagOperation: String
attr_accessor :PolicyId, :PolicyName, :Remark, :MonitorType, :Enable, :UseSum, :ProjectId, :ProjectName, :Namespace, :ConditionTemplateId, :Condition, :EventCondition, :NoticeIds, :Notices, :TriggerTasks, :ConditionsTemp, :LastEditUin, :UpdateTime, :InsertTime, :Region, :NamespaceShowName, :IsDefault, :CanSetDefault, :InstanceGroupId, :InstanceSum, :InstanceGroupName, :RuleType, :OriginId, :TagInstances, :Filter, :GroupBy, :FilterDimensionsParam, :IsOneClick, :OneClickStatus, :AdvancedMetricNumber, :IsBindAll, :Tags, :IsSupportAlarmTag, :TagOperation
def initialize(policyid=nil, policyname=nil, remark=nil, monitortype=nil, enable=nil, usesum=nil, projectid=nil, projectname=nil, namespace=nil, conditiontemplateid=nil, condition=nil, eventcondition=nil, noticeids=nil, notices=nil, triggertasks=nil, conditionstemp=nil, lastedituin=nil, updatetime=nil, inserttime=nil, region=nil, namespaceshowname=nil, isdefault=nil, cansetdefault=nil, instancegroupid=nil, instancesum=nil, instancegroupname=nil, ruletype=nil, originid=nil, taginstances=nil, filter=nil, groupby=nil, filterdimensionsparam=nil, isoneclick=nil, oneclickstatus=nil, advancedmetricnumber=nil, isbindall=nil, tags=nil, issupportalarmtag=nil, tagoperation=nil)
@PolicyId = policyid
@PolicyName = policyname
@Remark = remark
@MonitorType = monitortype
@Enable = enable
@UseSum = usesum
@ProjectId = projectid
@ProjectName = projectname
@Namespace = namespace
@ConditionTemplateId = conditiontemplateid
@Condition = condition
@EventCondition = eventcondition
@NoticeIds = noticeids
@Notices = notices
@TriggerTasks = triggertasks
@ConditionsTemp = conditionstemp
@LastEditUin = lastedituin
@UpdateTime = updatetime
@InsertTime = inserttime
@Region = region
@NamespaceShowName = namespaceshowname
@IsDefault = isdefault
@CanSetDefault = cansetdefault
@InstanceGroupId = instancegroupid
@InstanceSum = instancesum
@InstanceGroupName = instancegroupname
@RuleType = ruletype
@OriginId = originid
@TagInstances = taginstances
@Filter = filter
@GroupBy = groupby
@FilterDimensionsParam = filterdimensionsparam
@IsOneClick = isoneclick
@OneClickStatus = oneclickstatus
@AdvancedMetricNumber = advancedmetricnumber
@IsBindAll = isbindall
@Tags = tags
@IsSupportAlarmTag = issupportalarmtag
@TagOperation = tagoperation
end
def deserialize(params)
@PolicyId = params['PolicyId']
@PolicyName = params['PolicyName']
@Remark = params['Remark']
@MonitorType = params['MonitorType']
@Enable = params['Enable']
@UseSum = params['UseSum']
@ProjectId = params['ProjectId']
@ProjectName = params['ProjectName']
@Namespace = params['Namespace']
@ConditionTemplateId = params['ConditionTemplateId']
unless params['Condition'].nil?
@Condition = AlarmPolicyCondition.new
@Condition.deserialize(params['Condition'])
end
unless params['EventCondition'].nil?
@EventCondition = AlarmPolicyEventCondition.new
@EventCondition.deserialize(params['EventCondition'])
end
@NoticeIds = params['NoticeIds']
unless params['Notices'].nil?
@Notices = []
params['Notices'].each do |i|
alarmnotice_tmp = AlarmNotice.new
alarmnotice_tmp.deserialize(i)
@Notices << alarmnotice_tmp
end
end
unless params['TriggerTasks'].nil?
@TriggerTasks = []
params['TriggerTasks'].each do |i|
alarmpolicytriggertask_tmp = AlarmPolicyTriggerTask.new
alarmpolicytriggertask_tmp.deserialize(i)
@TriggerTasks << alarmpolicytriggertask_tmp
end
end
unless params['ConditionsTemp'].nil?
@ConditionsTemp = ConditionsTemp.new
@ConditionsTemp.deserialize(params['ConditionsTemp'])
end
@LastEditUin = params['LastEditUin']
@UpdateTime = params['UpdateTime']
@InsertTime = params['InsertTime']
@Region = params['Region']
@NamespaceShowName = params['NamespaceShowName']
@IsDefault = params['IsDefault']
@CanSetDefault = params['CanSetDefault']
@InstanceGroupId = params['InstanceGroupId']
@InstanceSum = params['InstanceSum']
@InstanceGroupName = params['InstanceGroupName']
@RuleType = params['RuleType']
@OriginId = params['OriginId']
unless params['TagInstances'].nil?
@TagInstances = []
params['TagInstances'].each do |i|
taginstance_tmp = TagInstance.new
taginstance_tmp.deserialize(i)
@TagInstances << taginstance_tmp
end
end
unless params['Filter'].nil?
@Filter = AlarmConditionFilter.new
@Filter.deserialize(params['Filter'])
end
unless params['GroupBy'].nil?
@GroupBy = []
params['GroupBy'].each do |i|
alarmgroupbyitem_tmp = AlarmGroupByItem.new
alarmgroupbyitem_tmp.deserialize(i)
@GroupBy << alarmgroupbyitem_tmp
end
end
@FilterDimensionsParam = params['FilterDimensionsParam']
@IsOneClick = params['IsOneClick']
@OneClickStatus = params['OneClickStatus']
@AdvancedMetricNumber = params['AdvancedMetricNumber']
@IsBindAll = params['IsBindAll']
unless params['Tags'].nil?
@Tags = []
params['Tags'].each do |i|
tag_tmp = Tag.new
tag_tmp.deserialize(i)
@Tags << tag_tmp
end
end
@IsSupportAlarmTag = params['IsSupportAlarmTag']
@TagOperation = params['TagOperation']
end
end
# 告警策略指标触发条件
class AlarmPolicyCondition < TencentCloud::Common::AbstractModel
# @param IsUnionRule: 告警触发条件的判断方式. 0: 任意; 1: 全部; 2: 复合. 当取值为2的时候为复合告警,与参数 ComplexExpression 配合使用.
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsUnionRule: Integer
# @param Rules: 告警触发条件列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Rules: Array
# @param ComplexExpression: 复合告警触发条件的判断表达式,当 IsUnionRule 取值为2的时候有效. 其作用是描述多个触发条件需要满足表达式求值为True时才算是满足告警条件.
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ComplexExpression: String
attr_accessor :IsUnionRule, :Rules, :ComplexExpression
def initialize(isunionrule=nil, rules=nil, complexexpression=nil)
@IsUnionRule = isunionrule
@Rules = rules
@ComplexExpression = complexexpression
end
def deserialize(params)
@IsUnionRule = params['IsUnionRule']
unless params['Rules'].nil?
@Rules = []
params['Rules'].each do |i|
alarmpolicyrule_tmp = AlarmPolicyRule.new
alarmpolicyrule_tmp.deserialize(i)
@Rules << alarmpolicyrule_tmp
end
end
@ComplexExpression = params['ComplexExpression']
end
end
# 告警策略事件触发条件
class AlarmPolicyEventCondition < TencentCloud::Common::AbstractModel
# @param Rules: 告警触发条件列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Rules: Array
attr_accessor :Rules
def initialize(rules=nil)
@Rules = rules
end
def deserialize(params)
unless params['Rules'].nil?
@Rules = []
params['Rules'].each do |i|
alarmpolicyrule_tmp = AlarmPolicyRule.new
alarmpolicyrule_tmp.deserialize(i)
@Rules << alarmpolicyrule_tmp
end
end
end
end
# 告警策略过滤条件
class AlarmPolicyFilter < TencentCloud::Common::AbstractModel
# @param Type: 过滤条件类型 DIMENSION=使用 Dimensions 做过滤
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param Dimensions: AlarmPolicyDimension 二维数组序列化后的json字符串,一维数组之间互为或关系,一维数组内的元素互为与关系
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Dimensions: String
attr_accessor :Type, :Dimensions
def initialize(type=nil, dimensions=nil)
@Type = type
@Dimensions = dimensions
end
def deserialize(params)
@Type = params['Type']
@Dimensions = params['Dimensions']
end
end
# 告警策略触发条件
class AlarmPolicyRule < TencentCloud::Common::AbstractModel
# @param MetricName: 指标名或事件名,支持的指标可以从 [DescribeAlarmMetrics](https://cloud.tencent.com/document/product/248/51283) 查询,支持的事件可以从 [DescribeAlarmEvents](https://cloud.tencent.com/document/product/248/51284) 查询 。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MetricName: String
# @param Period: 秒数 统计周期,支持的值可以从 [DescribeAlarmMetrics](https://cloud.tencent.com/document/product/248/51283) 查询。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Period: Integer
# @param Operator: 英文运算符
# intelligent=无阈值智能检测
# eq=等于
# ge=大于等于
# gt=大于
# le=小于等于
# lt=小于
# ne=不等于
# day_increase=天同比增长
# day_decrease=天同比下降
# day_wave=天同比波动
# week_increase=周同比增长
# week_decrease=周同比下降
# week_wave=周同比波动
# cycle_increase=环比增长
# cycle_decrease=环比下降
# cycle_wave=环比波动
# re=正则匹配
# 支持的值可以从 [DescribeAlarmMetrics](https://cloud.tencent.com/document/product/248/51283) 查询。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Operator: String
# @param Value: 阈值,支持的范围可以从 [DescribeAlarmMetrics](https://cloud.tencent.com/document/product/248/51283) 查询。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Value: String
# @param ContinuePeriod: 周期数 持续通知周期 1=持续1个周期 2=持续2个周期...,支持的值可以从 [DescribeAlarmMetrics](https://cloud.tencent.com/document/product/248/51283) 查询
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ContinuePeriod: Integer
# @param NoticeFrequency: 秒数 告警间隔 0=不重复 300=每5分钟告警一次 600=每10分钟告警一次 900=每15分钟告警一次 1800=每30分钟告警一次 3600=每1小时告警一次 7200=每2小时告警一次 10800=每3小时告警一次 21600=每6小时告警一次 43200=每12小时告警一次 86400=每1天告警一次
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NoticeFrequency: Integer
# @param IsPowerNotice: 告警频率是否指数增长 0=否 1=是
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsPowerNotice: Integer
# @param Filter: 对于单个触发规则的过滤条件
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Filter: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyFilter`
# @param Description: 指标展示名,用于出参
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Description: String
# @param Unit: 单位,用于出参
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Unit: String
# @param RuleType: 触发条件类型 STATIC=静态阈值 DYNAMIC=动态阈值。创建或编辑策略时,如不填则默认为 STATIC。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleType: String
# @param IsAdvanced: 是否为高级指标,0否,1是
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsAdvanced: Integer
# @param IsOpen: 高级指标是否开通,0否,1是
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsOpen: Integer
# @param ProductId: 集成中心产品ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProductId: String
# @param ValueMax: 最大值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ValueMax: Float
# @param ValueMin: 最小值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ValueMin: Float
# @param HierarchicalValue: 告警分级阈值配置
# 注意:此字段可能返回 null,表示取不到有效值。
# @type HierarchicalValue: :class:`Tencentcloud::Monitor.v20180724.models.AlarmHierarchicalValue`
# @param IsLatenessMetric: 是否延迟指标
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsLatenessMetric: Integer
attr_accessor :MetricName, :Period, :Operator, :Value, :ContinuePeriod, :NoticeFrequency, :IsPowerNotice, :Filter, :Description, :Unit, :RuleType, :IsAdvanced, :IsOpen, :ProductId, :ValueMax, :ValueMin, :HierarchicalValue, :IsLatenessMetric
def initialize(metricname=nil, period=nil, operator=nil, value=nil, continueperiod=nil, noticefrequency=nil, ispowernotice=nil, filter=nil, description=nil, unit=nil, ruletype=nil, isadvanced=nil, isopen=nil, productid=nil, valuemax=nil, valuemin=nil, hierarchicalvalue=nil, islatenessmetric=nil)
@MetricName = metricname
@Period = period
@Operator = operator
@Value = value
@ContinuePeriod = continueperiod
@NoticeFrequency = noticefrequency
@IsPowerNotice = ispowernotice
@Filter = filter
@Description = description
@Unit = unit
@RuleType = ruletype
@IsAdvanced = isadvanced
@IsOpen = isopen
@ProductId = productid
@ValueMax = valuemax
@ValueMin = valuemin
@HierarchicalValue = hierarchicalvalue
@IsLatenessMetric = islatenessmetric
end
def deserialize(params)
@MetricName = params['MetricName']
@Period = params['Period']
@Operator = params['Operator']
@Value = params['Value']
@ContinuePeriod = params['ContinuePeriod']
@NoticeFrequency = params['NoticeFrequency']
@IsPowerNotice = params['IsPowerNotice']
unless params['Filter'].nil?
@Filter = AlarmPolicyFilter.new
@Filter.deserialize(params['Filter'])
end
@Description = params['Description']
@Unit = params['Unit']
@RuleType = params['RuleType']
@IsAdvanced = params['IsAdvanced']
@IsOpen = params['IsOpen']
@ProductId = params['ProductId']
@ValueMax = params['ValueMax']
@ValueMin = params['ValueMin']
unless params['HierarchicalValue'].nil?
@HierarchicalValue = AlarmHierarchicalValue.new
@HierarchicalValue.deserialize(params['HierarchicalValue'])
end
@IsLatenessMetric = params['IsLatenessMetric']
end
end
# 告警策略触发任务
class AlarmPolicyTriggerTask < TencentCloud::Common::AbstractModel
# @param Type: 触发任务类型 AS=弹性伸缩
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param TaskConfig: 用 json 表示配置信息 {"Key1":"Value1","Key2":"Value2"}
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TaskConfig: String
attr_accessor :Type, :TaskConfig
def initialize(type=nil, taskconfig=nil)
@Type = type
@TaskConfig = taskconfig
end
def deserialize(params)
@Type = params['Type']
@TaskConfig = params['TaskConfig']
end
end
# BindPrometheusManagedGrafana请求参数结构体
class BindPrometheusManagedGrafanaRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param GrafanaId: Grafana 可视化服务实例 ID
# @type GrafanaId: String
attr_accessor :InstanceId, :GrafanaId
def initialize(instanceid=nil, grafanaid=nil)
@InstanceId = instanceid
@GrafanaId = grafanaid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@GrafanaId = params['GrafanaId']
end
end
# BindPrometheusManagedGrafana返回参数结构体
class BindPrometheusManagedGrafanaResponse < 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 BindingPolicyObjectDimension < TencentCloud::Common::AbstractModel
# @param Region: 地域名
# @type Region: String
# @param RegionId: 地域ID
# @type RegionId: Integer
# @param Dimensions: 实例的维度信息,格式为
# {"unInstanceId":"ins-00jvv9mo"}。不同云产品的维度信息不同,详见
# [指标维度信息Dimensions列表](https://cloud.tencent.com/document/product/248/50397)
# @type Dimensions: String
# @param EventDimensions: 事件维度信息
# @type EventDimensions: String
attr_accessor :Region, :RegionId, :Dimensions, :EventDimensions
def initialize(region=nil, regionid=nil, dimensions=nil, eventdimensions=nil)
@Region = region
@RegionId = regionid
@Dimensions = dimensions
@EventDimensions = eventdimensions
end
def deserialize(params)
@Region = params['Region']
@RegionId = params['RegionId']
@Dimensions = params['Dimensions']
@EventDimensions = params['EventDimensions']
end
end
# BindingPolicyObject请求参数结构体
class BindingPolicyObjectRequest < TencentCloud::Common::AbstractModel
# @param Module: 必填。固定值"monitor"
# @type Module: String
# @param GroupId: 策略组id,例如 4739573。逐渐弃用,建议使用 PolicyId 参数
# @type GroupId: Integer
# @param PolicyId: 告警策略ID,例如“policy-gh892hg0”。PolicyId 参数与 GroupId 参数至少要填一个,否则会报参数错误,建议使用该参数。若两者同时存在则以该参数为准
# @type PolicyId: String
# @param InstanceGroupId: 实例分组ID
# @type InstanceGroupId: Integer
# @param Dimensions: 需要绑定的对象维度信息
# @type Dimensions: Array
# @param EbSubject: 事件配置的告警
# @type EbSubject: String
# @param EbEventFlag: 是否配置了事件告警
# @type EbEventFlag: Integer
attr_accessor :Module, :GroupId, :PolicyId, :InstanceGroupId, :Dimensions, :EbSubject, :EbEventFlag
def initialize(_module=nil, groupid=nil, policyid=nil, instancegroupid=nil, dimensions=nil, ebsubject=nil, ebeventflag=nil)
@Module = _module
@GroupId = groupid
@PolicyId = policyid
@InstanceGroupId = instancegroupid
@Dimensions = dimensions
@EbSubject = ebsubject
@EbEventFlag = ebeventflag
end
def deserialize(params)
@Module = params['Module']
@GroupId = params['GroupId']
@PolicyId = params['PolicyId']
@InstanceGroupId = params['InstanceGroupId']
unless params['Dimensions'].nil?
@Dimensions = []
params['Dimensions'].each do |i|
bindingpolicyobjectdimension_tmp = BindingPolicyObjectDimension.new
bindingpolicyobjectdimension_tmp.deserialize(i)
@Dimensions << bindingpolicyobjectdimension_tmp
end
end
@EbSubject = params['EbSubject']
@EbEventFlag = params['EbEventFlag']
end
end
# BindingPolicyObject返回参数结构体
class BindingPolicyObjectResponse < 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
# BindingPolicyTag请求参数结构体
class BindingPolicyTagRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定取值 monitor
# @type Module: String
# @param PolicyId: 策略ID
# @type PolicyId: String
# @param GroupId: 用于实例、实例组绑定和解绑接口(BindingPolicyObject、UnBindingAllPolicyObject、UnBindingPolicyObject)的策略 ID
# @type GroupId: String
# @param ServiceType: 产品类型
# @type ServiceType: String
# @param Tag: 策略标签
# @type Tag: :class:`Tencentcloud::Monitor.v20180724.models.PolicyTag`
# @param InstanceGroupId: 实例分组ID
# @type InstanceGroupId: Integer
# @param BatchTag: 批量绑定标签
# @type BatchTag: Array
# @param EbEventFlag: 是否同步eb
# @type EbEventFlag: Integer
# @param EbSubject: 事件配置的告警
# @type EbSubject: String
# @param TagOperation: 标识标签取交/并集关系
# @type TagOperation: String
attr_accessor :Module, :PolicyId, :GroupId, :ServiceType, :Tag, :InstanceGroupId, :BatchTag, :EbEventFlag, :EbSubject, :TagOperation
def initialize(_module=nil, policyid=nil, groupid=nil, servicetype=nil, tag=nil, instancegroupid=nil, batchtag=nil, ebeventflag=nil, ebsubject=nil, tagoperation=nil)
@Module = _module
@PolicyId = policyid
@GroupId = groupid
@ServiceType = servicetype
@Tag = tag
@InstanceGroupId = instancegroupid
@BatchTag = batchtag
@EbEventFlag = ebeventflag
@EbSubject = ebsubject
@TagOperation = tagoperation
end
def deserialize(params)
@Module = params['Module']
@PolicyId = params['PolicyId']
@GroupId = params['GroupId']
@ServiceType = params['ServiceType']
unless params['Tag'].nil?
@Tag = PolicyTag.new
@Tag.deserialize(params['Tag'])
end
@InstanceGroupId = params['InstanceGroupId']
unless params['BatchTag'].nil?
@BatchTag = []
params['BatchTag'].each do |i|
policytag_tmp = PolicyTag.new
policytag_tmp.deserialize(i)
@BatchTag << policytag_tmp
end
end
@EbEventFlag = params['EbEventFlag']
@EbSubject = params['EbSubject']
@TagOperation = params['TagOperation']
end
end
# BindingPolicyTag返回参数结构体
class BindingPolicyTagResponse < 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
# 告警通知中的推送CLS操作
class CLSNotice < TencentCloud::Common::AbstractModel
# @param Region: 地域
# @type Region: String
# @param LogSetId: 日志集Id
# @type LogSetId: String
# @param TopicId: 主题Id
# @type TopicId: String
# @param Enable: 启停状态,可不传,默认启用。0=停用,1=启用
# @type Enable: Integer
attr_accessor :Region, :LogSetId, :TopicId, :Enable
def initialize(region=nil, logsetid=nil, topicid=nil, enable=nil)
@Region = region
@LogSetId = logsetid
@TopicId = topicid
@Enable = enable
end
def deserialize(params)
@Region = params['Region']
@LogSetId = params['LogSetId']
@TopicId = params['TopicId']
@Enable = params['Enable']
end
end
# CleanGrafanaInstance请求参数结构体
class CleanGrafanaInstanceRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
attr_accessor :InstanceId
def initialize(instanceid=nil)
@InstanceId = instanceid
end
def deserialize(params)
@InstanceId = params['InstanceId']
end
end
# CleanGrafanaInstance返回参数结构体
class CleanGrafanaInstanceResponse < 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 CommonNamespace < TencentCloud::Common::AbstractModel
# @param Id: 命名空间标示
# @type Id: String
# @param Name: 命名空间名称
# @type Name: String
# @param Value: 命名空间值
# @type Value: String
# @param ProductName: 产品名称
# @type ProductName: String
# @param Config: 配置信息
# @type Config: String
# @param AvailableRegions: 支持地域列表
# @type AvailableRegions: Array
# @param SortId: 排序Id
# @type SortId: Integer
# @param DashboardId: Dashboard中的唯一表示
# @type DashboardId: String
attr_accessor :Id, :Name, :Value, :ProductName, :Config, :AvailableRegions, :SortId, :DashboardId
def initialize(id=nil, name=nil, value=nil, productname=nil, config=nil, availableregions=nil, sortid=nil, dashboardid=nil)
@Id = id
@Name = name
@Value = value
@ProductName = productname
@Config = config
@AvailableRegions = availableregions
@SortId = sortid
@DashboardId = dashboardid
end
def deserialize(params)
@Id = params['Id']
@Name = params['Name']
@Value = params['Value']
@ProductName = params['ProductName']
@Config = params['Config']
@AvailableRegions = params['AvailableRegions']
@SortId = params['SortId']
@DashboardId = params['DashboardId']
end
end
# 策略类型信息
class CommonNamespaceNew < TencentCloud::Common::AbstractModel
# @param Id: 命名空间标示
# @type Id: String
# @param Name: 命名空间名称
# @type Name: String
# @param MonitorType: 监控类型
# @type MonitorType: String
# @param Dimensions: 维度信息
# @type Dimensions: Array
attr_accessor :Id, :Name, :MonitorType, :Dimensions
def initialize(id=nil, name=nil, monitortype=nil, dimensions=nil)
@Id = id
@Name = name
@MonitorType = monitortype
@Dimensions = dimensions
end
def deserialize(params)
@Id = params['Id']
@Name = params['Name']
@MonitorType = params['MonitorType']
unless params['Dimensions'].nil?
@Dimensions = []
params['Dimensions'].each do |i|
dimensionnew_tmp = DimensionNew.new
dimensionnew_tmp.deserialize(i)
@Dimensions << dimensionnew_tmp
end
end
end
end
# 告警条件
class Condition < TencentCloud::Common::AbstractModel
# @param AlarmNotifyPeriod: 告警通知频率
# @type AlarmNotifyPeriod: Integer
# @param AlarmNotifyType: 重复通知策略预定义(0 - 只告警一次, 1 - 指数告警,2 - 连接告警)
# @type AlarmNotifyType: Integer
# @param CalcType: 检测方式
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CalcType: String
# @param CalcValue: 检测值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CalcValue: String
# @param ContinueTime: 持续时间,单位秒
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ContinueTime: String
# @param MetricID: 指标ID
# @type MetricID: Integer
# @param MetricDisplayName: 指标展示名称(对外)
# @type MetricDisplayName: String
# @param Period: 周期
# @type Period: Integer
# @param RuleID: 规则ID
# @type RuleID: Integer
# @param Unit: 指标单位
# @type Unit: String
# @param IsAdvanced: 是否为高级指标,0:否;1:是
# @type IsAdvanced: Integer
# @param IsOpen: 是否开通高级指标,0:否;1:是
# @type IsOpen: Integer
# @param ProductId: 产品ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProductId: String
# @param HierarchicalValue: 告警分级阈值配置
# 注意:此字段可能返回 null,表示取不到有效值。
# @type HierarchicalValue: :class:`Tencentcloud::Monitor.v20180724.models.AlarmHierarchicalValue`
attr_accessor :AlarmNotifyPeriod, :AlarmNotifyType, :CalcType, :CalcValue, :ContinueTime, :MetricID, :MetricDisplayName, :Period, :RuleID, :Unit, :IsAdvanced, :IsOpen, :ProductId, :HierarchicalValue
def initialize(alarmnotifyperiod=nil, alarmnotifytype=nil, calctype=nil, calcvalue=nil, continuetime=nil, metricid=nil, metricdisplayname=nil, period=nil, ruleid=nil, unit=nil, isadvanced=nil, isopen=nil, productid=nil, hierarchicalvalue=nil)
@AlarmNotifyPeriod = alarmnotifyperiod
@AlarmNotifyType = alarmnotifytype
@CalcType = calctype
@CalcValue = calcvalue
@ContinueTime = continuetime
@MetricID = metricid
@MetricDisplayName = metricdisplayname
@Period = period
@RuleID = ruleid
@Unit = unit
@IsAdvanced = isadvanced
@IsOpen = isopen
@ProductId = productid
@HierarchicalValue = hierarchicalvalue
end
def deserialize(params)
@AlarmNotifyPeriod = params['AlarmNotifyPeriod']
@AlarmNotifyType = params['AlarmNotifyType']
@CalcType = params['CalcType']
@CalcValue = params['CalcValue']
@ContinueTime = params['ContinueTime']
@MetricID = params['MetricID']
@MetricDisplayName = params['MetricDisplayName']
@Period = params['Period']
@RuleID = params['RuleID']
@Unit = params['Unit']
@IsAdvanced = params['IsAdvanced']
@IsOpen = params['IsOpen']
@ProductId = params['ProductId']
unless params['HierarchicalValue'].nil?
@HierarchicalValue = AlarmHierarchicalValue.new
@HierarchicalValue.deserialize(params['HierarchicalValue'])
end
end
end
# 告警条件模板
class ConditionsTemp < TencentCloud::Common::AbstractModel
# @param TemplateName: 模板名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TemplateName: String
# @param Condition: 指标触发条件
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Condition: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyCondition`
# @param EventCondition: 事件触发条件
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventCondition: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyEventCondition`
attr_accessor :TemplateName, :Condition, :EventCondition
def initialize(templatename=nil, condition=nil, eventcondition=nil)
@TemplateName = templatename
@Condition = condition
@EventCondition = eventcondition
end
def deserialize(params)
@TemplateName = params['TemplateName']
unless params['Condition'].nil?
@Condition = AlarmPolicyCondition.new
@Condition.deserialize(params['Condition'])
end
unless params['EventCondition'].nil?
@EventCondition = AlarmPolicyEventCondition.new
@EventCondition.deserialize(params['EventCondition'])
end
end
end
# CreateAlarmNotice请求参数结构体
class CreateAlarmNoticeRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,这里填“monitor”
# @type Module: String
# @param Name: 通知模板名称 60字符以内
# @type Name: String
# @param NoticeType: 通知类型 ALARM=未恢复通知 OK=已恢复通知 ALL=都通知
# @type NoticeType: String
# @param NoticeLanguage: 通知语言 zh-CN=中文 en-US=英文
# @type NoticeLanguage: String
# @param UserNotices: 用户通知 最多5个
# @type UserNotices: Array
# @param URLNotices: 回调通知 最多6个
# @type URLNotices: Array
# @param CLSNotices: 推送CLS日志服务的操作 最多1个
# @type CLSNotices: Array
# @param Tags: 模板绑定的标签
# @type Tags: Array
attr_accessor :Module, :Name, :NoticeType, :NoticeLanguage, :UserNotices, :URLNotices, :CLSNotices, :Tags
def initialize(_module=nil, name=nil, noticetype=nil, noticelanguage=nil, usernotices=nil, urlnotices=nil, clsnotices=nil, tags=nil)
@Module = _module
@Name = name
@NoticeType = noticetype
@NoticeLanguage = noticelanguage
@UserNotices = usernotices
@URLNotices = urlnotices
@CLSNotices = clsnotices
@Tags = tags
end
def deserialize(params)
@Module = params['Module']
@Name = params['Name']
@NoticeType = params['NoticeType']
@NoticeLanguage = params['NoticeLanguage']
unless params['UserNotices'].nil?
@UserNotices = []
params['UserNotices'].each do |i|
usernotice_tmp = UserNotice.new
usernotice_tmp.deserialize(i)
@UserNotices << usernotice_tmp
end
end
unless params['URLNotices'].nil?
@URLNotices = []
params['URLNotices'].each do |i|
urlnotice_tmp = URLNotice.new
urlnotice_tmp.deserialize(i)
@URLNotices << urlnotice_tmp
end
end
unless params['CLSNotices'].nil?
@CLSNotices = []
params['CLSNotices'].each do |i|
clsnotice_tmp = CLSNotice.new
clsnotice_tmp.deserialize(i)
@CLSNotices << clsnotice_tmp
end
end
unless params['Tags'].nil?
@Tags = []
params['Tags'].each do |i|
tag_tmp = Tag.new
tag_tmp.deserialize(i)
@Tags << tag_tmp
end
end
end
end
# CreateAlarmNotice返回参数结构体
class CreateAlarmNoticeResponse < TencentCloud::Common::AbstractModel
# @param NoticeId: 告警通知模板ID
# @type NoticeId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :NoticeId, :RequestId
def initialize(noticeid=nil, requestid=nil)
@NoticeId = noticeid
@RequestId = requestid
end
def deserialize(params)
@NoticeId = params['NoticeId']
@RequestId = params['RequestId']
end
end
# CreateAlarmPolicy请求参数结构体
class CreateAlarmPolicyRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param PolicyName: 策略名称,不超过60字符
# @type PolicyName: String
# @param MonitorType: 监控类型 MT_QCE=云产品监控
# @type MonitorType: String
# @param Namespace: 告警策略类型,由 [DescribeAllNamespaces](https://cloud.tencent.com/document/product/248/48683) 获得。对于云产品监控,取接口出参的 QceNamespacesNew.N.Id,例如 cvm_device
# @type Namespace: String
# @param Remark: 备注,不超过100字符,仅支持中英文、数字、下划线、-
# @type Remark: String
# @param Enable: 是否启用 0=停用 1=启用,可不传 默认为1
# @type Enable: Integer
# @param ProjectId: 项目 Id,对于区分项目的产品必须传入非 -1 的值。 -1=无项目 0=默认项目,如不传 默认为 -1。支持的项目 Id 可以在控制台 [账号中心-项目管理](https://console.cloud.tencent.com/project) 中查看。
# @type ProjectId: Integer
# @param ConditionTemplateId: 触发条件模板 Id,该参数与 Condition 参数二选一。如果策略绑定触发条件模板,则传该参数;否则不传该参数,而是传 Condition 参数。触发条件模板 Id 可以从 [DescribeConditionsTemplateList](https://cloud.tencent.com/document/api/248/70250) 接口获取。
# @type ConditionTemplateId: Integer
# @param Condition: 指标触发条件,支持的指标可以从 [DescribeAlarmMetrics](https://cloud.tencent.com/document/product/248/51283) 查询。
# @type Condition: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyCondition`
# @param EventCondition: 事件触发条件,支持的事件可以从 [DescribeAlarmEvents](https://cloud.tencent.com/document/product/248/51284) 查询。
# @type EventCondition: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyEventCondition`
# @param NoticeIds: 通知规则 Id 列表,由 [DescribeAlarmNotices](https://cloud.tencent.com/document/product/248/51280) 获得
# @type NoticeIds: Array
# @param TriggerTasks: 触发任务列表
# @type TriggerTasks: Array
# @param Filter: 全局过滤条件
# @type Filter: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyFilter`
# @param GroupBy: 聚合维度列表,指定按哪些维度 key 来做 group by
# @type GroupBy: Array
# @param Tags: 模板绑定的标签
# @type Tags: Array
# @param LogAlarmReqInfo: 日志告警信息
# @type LogAlarmReqInfo: :class:`Tencentcloud::Monitor.v20180724.models.LogAlarmReq`
# @param HierarchicalNotices: 告警分级通知规则配置
# @type HierarchicalNotices: Array
# @param MigrateFlag: 迁移策略专用字段,0-走鉴权逻辑,1-跳过鉴权逻辑
# @type MigrateFlag: Integer
# @param EbSubject: 事件配置的告警
# @type EbSubject: String
attr_accessor :Module, :PolicyName, :MonitorType, :Namespace, :Remark, :Enable, :ProjectId, :ConditionTemplateId, :Condition, :EventCondition, :NoticeIds, :TriggerTasks, :Filter, :GroupBy, :Tags, :LogAlarmReqInfo, :HierarchicalNotices, :MigrateFlag, :EbSubject
def initialize(_module=nil, policyname=nil, monitortype=nil, namespace=nil, remark=nil, enable=nil, projectid=nil, conditiontemplateid=nil, condition=nil, eventcondition=nil, noticeids=nil, triggertasks=nil, filter=nil, groupby=nil, tags=nil, logalarmreqinfo=nil, hierarchicalnotices=nil, migrateflag=nil, ebsubject=nil)
@Module = _module
@PolicyName = policyname
@MonitorType = monitortype
@Namespace = namespace
@Remark = remark
@Enable = enable
@ProjectId = projectid
@ConditionTemplateId = conditiontemplateid
@Condition = condition
@EventCondition = eventcondition
@NoticeIds = noticeids
@TriggerTasks = triggertasks
@Filter = filter
@GroupBy = groupby
@Tags = tags
@LogAlarmReqInfo = logalarmreqinfo
@HierarchicalNotices = hierarchicalnotices
@MigrateFlag = migrateflag
@EbSubject = ebsubject
end
def deserialize(params)
@Module = params['Module']
@PolicyName = params['PolicyName']
@MonitorType = params['MonitorType']
@Namespace = params['Namespace']
@Remark = params['Remark']
@Enable = params['Enable']
@ProjectId = params['ProjectId']
@ConditionTemplateId = params['ConditionTemplateId']
unless params['Condition'].nil?
@Condition = AlarmPolicyCondition.new
@Condition.deserialize(params['Condition'])
end
unless params['EventCondition'].nil?
@EventCondition = AlarmPolicyEventCondition.new
@EventCondition.deserialize(params['EventCondition'])
end
@NoticeIds = params['NoticeIds']
unless params['TriggerTasks'].nil?
@TriggerTasks = []
params['TriggerTasks'].each do |i|
alarmpolicytriggertask_tmp = AlarmPolicyTriggerTask.new
alarmpolicytriggertask_tmp.deserialize(i)
@TriggerTasks << alarmpolicytriggertask_tmp
end
end
unless params['Filter'].nil?
@Filter = AlarmPolicyFilter.new
@Filter.deserialize(params['Filter'])
end
@GroupBy = params['GroupBy']
unless params['Tags'].nil?
@Tags = []
params['Tags'].each do |i|
tag_tmp = Tag.new
tag_tmp.deserialize(i)
@Tags << tag_tmp
end
end
unless params['LogAlarmReqInfo'].nil?
@LogAlarmReqInfo = LogAlarmReq.new
@LogAlarmReqInfo.deserialize(params['LogAlarmReqInfo'])
end
unless params['HierarchicalNotices'].nil?
@HierarchicalNotices = []
params['HierarchicalNotices'].each do |i|
alarmhierarchicalnotice_tmp = AlarmHierarchicalNotice.new
alarmhierarchicalnotice_tmp.deserialize(i)
@HierarchicalNotices << alarmhierarchicalnotice_tmp
end
end
@MigrateFlag = params['MigrateFlag']
@EbSubject = params['EbSubject']
end
end
# CreateAlarmPolicy返回参数结构体
class CreateAlarmPolicyResponse < TencentCloud::Common::AbstractModel
# @param PolicyId: 告警策略 ID
# @type PolicyId: String
# @param OriginId: 可用于实例、实例组的绑定和解绑接口([BindingPolicyObject](https://cloud.tencent.com/document/product/248/40421)、[UnBindingAllPolicyObject](https://cloud.tencent.com/document/product/248/40568)、[UnBindingPolicyObject](https://cloud.tencent.com/document/product/248/40567))的策略 ID
# @type OriginId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PolicyId, :OriginId, :RequestId
def initialize(policyid=nil, originid=nil, requestid=nil)
@PolicyId = policyid
@OriginId = originid
@RequestId = requestid
end
def deserialize(params)
@PolicyId = params['PolicyId']
@OriginId = params['OriginId']
@RequestId = params['RequestId']
end
end
# CreateAlertRule请求参数结构体
class CreateAlertRuleRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID,例如:prom-abcd1234
# @type InstanceId: String
# @param RuleName: 规则名称
# @type RuleName: String
# @param Expr: 规则表达式,可参考告警规则说明
# @type Expr: String
# @param Receivers: 告警通知模板 ID 列表
# @type Receivers: Array
# @param RuleState: 规则状态码,取值如下:
#
2=RuleEnabled
# 3=RuleDisabled
# @type RuleState: Integer
# @param Duration: 规则报警持续时间
# @type Duration: String
# @param Labels: 标签列表
# @type Labels: Array
# @param Annotations: 注释列表。
# 告警对象和告警消息是 Prometheus Rule Annotations 的特殊字段,需要通过 annotations 来传递,对应的 Key 分别为summary/description。
# @type Annotations: Array
# @param Type: 报警策略模板分类
# @type Type: String
attr_accessor :InstanceId, :RuleName, :Expr, :Receivers, :RuleState, :Duration, :Labels, :Annotations, :Type
def initialize(instanceid=nil, rulename=nil, expr=nil, receivers=nil, rulestate=nil, duration=nil, labels=nil, annotations=nil, type=nil)
@InstanceId = instanceid
@RuleName = rulename
@Expr = expr
@Receivers = receivers
@RuleState = rulestate
@Duration = duration
@Labels = labels
@Annotations = annotations
@Type = type
end
def deserialize(params)
@InstanceId = params['InstanceId']
@RuleName = params['RuleName']
@Expr = params['Expr']
@Receivers = params['Receivers']
@RuleState = params['RuleState']
@Duration = params['Duration']
unless params['Labels'].nil?
@Labels = []
params['Labels'].each do |i|
prometheusrulekv_tmp = PrometheusRuleKV.new
prometheusrulekv_tmp.deserialize(i)
@Labels << prometheusrulekv_tmp
end
end
unless params['Annotations'].nil?
@Annotations = []
params['Annotations'].each do |i|
prometheusrulekv_tmp = PrometheusRuleKV.new
prometheusrulekv_tmp.deserialize(i)
@Annotations << prometheusrulekv_tmp
end
end
@Type = params['Type']
end
end
# CreateAlertRule返回参数结构体
class CreateAlertRuleResponse < TencentCloud::Common::AbstractModel
# @param RuleId: 规则 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RuleId, :RequestId
def initialize(ruleid=nil, requestid=nil)
@RuleId = ruleid
@RequestId = requestid
end
def deserialize(params)
@RuleId = params['RuleId']
@RequestId = params['RequestId']
end
end
# CreateExporterIntegration请求参数结构体
class CreateExporterIntegrationRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param Kind: 类型(可通过 DescribePrometheusIntegrations 接口获取,取每一项中的 ExporterType 字段)
# @type Kind: String
# @param Content: 集成配置
# @type Content: String
# @param KubeType: Kubernetes 集群类型,可不填,取值如下:
# 1= 容器集群(TKE)
# 2=弹性集群(EKS)
# 3= Prometheus管理的弹性集群(MEKS)
# @type KubeType: Integer
# @param ClusterId: 集群 ID,可不填
# @type ClusterId: String
attr_accessor :InstanceId, :Kind, :Content, :KubeType, :ClusterId
def initialize(instanceid=nil, kind=nil, content=nil, kubetype=nil, clusterid=nil)
@InstanceId = instanceid
@Kind = kind
@Content = content
@KubeType = kubetype
@ClusterId = clusterid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Kind = params['Kind']
@Content = params['Content']
@KubeType = params['KubeType']
@ClusterId = params['ClusterId']
end
end
# CreateExporterIntegration返回参数结构体
class CreateExporterIntegrationResponse < TencentCloud::Common::AbstractModel
# @param Names: 返回创建成功的集成名称列表
# @type Names: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Names, :RequestId
def initialize(names=nil, requestid=nil)
@Names = names
@RequestId = requestid
end
def deserialize(params)
@Names = params['Names']
@RequestId = params['RequestId']
end
end
# CreateGrafanaInstance请求参数结构体
class CreateGrafanaInstanceRequest < TencentCloud::Common::AbstractModel
# @param InstanceName: 实例名
# @type InstanceName: String
# @param VpcId: VPC ID (私有网络 ID)
# @type VpcId: String
# @param SubnetIds: 子网 ID 数组(VPC ID下的子网 ID,只取第一个)
# @type SubnetIds: Array
# @param EnableInternet: 是否启用外网
# @type EnableInternet: Boolean
# @param GrafanaInitPassword: Grafana 初始密码(国际站用户必填,国内站用户可不填,不填时会生成随机密码并给主账号发送通知)
# @type GrafanaInitPassword: String
# @param TagSpecification: 标签
# @type TagSpecification: Array
# @param AutoVoucher: 是否自动选择代金券,默认为 false
# @type AutoVoucher: Boolean
attr_accessor :InstanceName, :VpcId, :SubnetIds, :EnableInternet, :GrafanaInitPassword, :TagSpecification, :AutoVoucher
def initialize(instancename=nil, vpcid=nil, subnetids=nil, enableinternet=nil, grafanainitpassword=nil, tagspecification=nil, autovoucher=nil)
@InstanceName = instancename
@VpcId = vpcid
@SubnetIds = subnetids
@EnableInternet = enableinternet
@GrafanaInitPassword = grafanainitpassword
@TagSpecification = tagspecification
@AutoVoucher = autovoucher
end
def deserialize(params)
@InstanceName = params['InstanceName']
@VpcId = params['VpcId']
@SubnetIds = params['SubnetIds']
@EnableInternet = params['EnableInternet']
@GrafanaInitPassword = params['GrafanaInitPassword']
unless params['TagSpecification'].nil?
@TagSpecification = []
params['TagSpecification'].each do |i|
prometheustag_tmp = PrometheusTag.new
prometheustag_tmp.deserialize(i)
@TagSpecification << prometheustag_tmp
end
end
@AutoVoucher = params['AutoVoucher']
end
end
# CreateGrafanaInstance返回参数结构体
class CreateGrafanaInstanceResponse < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例名
# @type InstanceId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :InstanceId, :RequestId
def initialize(instanceid=nil, requestid=nil)
@InstanceId = instanceid
@RequestId = requestid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@RequestId = params['RequestId']
end
end
# CreateGrafanaIntegration请求参数结构体
class CreateGrafanaIntegrationRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
# @param Kind: 集成类型(接口DescribeGrafanaIntegrationOverviews返回的集成信息中的Code字段)
# @type Kind: String
# @param Content: 集成配置
# @type Content: String
attr_accessor :InstanceId, :Kind, :Content
def initialize(instanceid=nil, kind=nil, content=nil)
@InstanceId = instanceid
@Kind = kind
@Content = content
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Kind = params['Kind']
@Content = params['Content']
end
end
# CreateGrafanaIntegration返回参数结构体
class CreateGrafanaIntegrationResponse < TencentCloud::Common::AbstractModel
# @param IntegrationId: 集成 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IntegrationId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :IntegrationId, :RequestId
def initialize(integrationid=nil, requestid=nil)
@IntegrationId = integrationid
@RequestId = requestid
end
def deserialize(params)
@IntegrationId = params['IntegrationId']
@RequestId = params['RequestId']
end
end
# CreateGrafanaNotificationChannel请求参数结构体
class CreateGrafanaNotificationChannelRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
# @param ChannelName: 告警通道名称,例如:test
# @type ChannelName: String
# @param Receivers: 接受告警通道 ID 数组,值为告警管理/基础配置/通知模板中的模板 ID
# @type Receivers: Array
# @param OrgId: 默认为1,建议使用 OrganizationIds
# @type OrgId: Integer
# @param ExtraOrgIds: 额外组织 ID 数组,已废弃,请使用 OrganizationIds
# @type ExtraOrgIds: Array
# @param OrganizationIds: 生效的所有组织 ID 数组,默认为 ["1"]
# @type OrganizationIds: Array
attr_accessor :InstanceId, :ChannelName, :Receivers, :OrgId, :ExtraOrgIds, :OrganizationIds
def initialize(instanceid=nil, channelname=nil, receivers=nil, orgid=nil, extraorgids=nil, organizationids=nil)
@InstanceId = instanceid
@ChannelName = channelname
@Receivers = receivers
@OrgId = orgid
@ExtraOrgIds = extraorgids
@OrganizationIds = organizationids
end
def deserialize(params)
@InstanceId = params['InstanceId']
@ChannelName = params['ChannelName']
@Receivers = params['Receivers']
@OrgId = params['OrgId']
@ExtraOrgIds = params['ExtraOrgIds']
@OrganizationIds = params['OrganizationIds']
end
end
# CreateGrafanaNotificationChannel返回参数结构体
class CreateGrafanaNotificationChannelResponse < TencentCloud::Common::AbstractModel
# @param ChannelId: 通道 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ChannelId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ChannelId, :RequestId
def initialize(channelid=nil, requestid=nil)
@ChannelId = channelid
@RequestId = requestid
end
def deserialize(params)
@ChannelId = params['ChannelId']
@RequestId = params['RequestId']
end
end
# 创建策略传入的阈值告警条件
class CreatePolicyGroupCondition < TencentCloud::Common::AbstractModel
# @param MetricId: 指标Id
# @type MetricId: Integer
# @param AlarmNotifyType: 告警发送收敛类型。0连续告警,1指数告警
# @type AlarmNotifyType: Integer
# @param AlarmNotifyPeriod: 告警发送周期单位秒。<0 不触发, 0 只触发一次, >0 每隔triggerTime秒触发一次
# @type AlarmNotifyPeriod: Integer
# @param CalcType: 比较类型,1表示大于,2表示大于等于,3表示小于,4表示小于等于,5表示相等,6表示不相等。如果指标有配置默认比较类型值可以不填。
# @type CalcType: Integer
# @param CalcValue: 比较的值,如果指标不必须CalcValue可不填
# @type CalcValue: Float
# @param CalcPeriod: 数据聚合周期(单位秒),若指标有默认值可不填
# @type CalcPeriod: Integer
# @param ContinuePeriod: 持续几个检测周期触发规则会告警
# @type ContinuePeriod: Integer
# @param RuleId: 如果通过模板创建,需要传入模板中该指标的对应RuleId
# @type RuleId: Integer
attr_accessor :MetricId, :AlarmNotifyType, :AlarmNotifyPeriod, :CalcType, :CalcValue, :CalcPeriod, :ContinuePeriod, :RuleId
def initialize(metricid=nil, alarmnotifytype=nil, alarmnotifyperiod=nil, calctype=nil, calcvalue=nil, calcperiod=nil, continueperiod=nil, ruleid=nil)
@MetricId = metricid
@AlarmNotifyType = alarmnotifytype
@AlarmNotifyPeriod = alarmnotifyperiod
@CalcType = calctype
@CalcValue = calcvalue
@CalcPeriod = calcperiod
@ContinuePeriod = continueperiod
@RuleId = ruleid
end
def deserialize(params)
@MetricId = params['MetricId']
@AlarmNotifyType = params['AlarmNotifyType']
@AlarmNotifyPeriod = params['AlarmNotifyPeriod']
@CalcType = params['CalcType']
@CalcValue = params['CalcValue']
@CalcPeriod = params['CalcPeriod']
@ContinuePeriod = params['ContinuePeriod']
@RuleId = params['RuleId']
end
end
# 创建策略传入的事件告警条件
class CreatePolicyGroupEventCondition < TencentCloud::Common::AbstractModel
# @param EventId: 告警事件的Id
# @type EventId: Integer
# @param AlarmNotifyType: 告警发送收敛类型。0连续告警,1指数告警
# @type AlarmNotifyType: Integer
# @param AlarmNotifyPeriod: 告警发送周期单位秒。<0 不触发, 0 只触发一次, >0 每隔triggerTime秒触发一次
# @type AlarmNotifyPeriod: Integer
# @param RuleId: 如果通过模板创建,需要传入模板中该指标的对应RuleId
# @type RuleId: Integer
attr_accessor :EventId, :AlarmNotifyType, :AlarmNotifyPeriod, :RuleId
def initialize(eventid=nil, alarmnotifytype=nil, alarmnotifyperiod=nil, ruleid=nil)
@EventId = eventid
@AlarmNotifyType = alarmnotifytype
@AlarmNotifyPeriod = alarmnotifyperiod
@RuleId = ruleid
end
def deserialize(params)
@EventId = params['EventId']
@AlarmNotifyType = params['AlarmNotifyType']
@AlarmNotifyPeriod = params['AlarmNotifyPeriod']
@RuleId = params['RuleId']
end
end
# CreatePolicyGroup请求参数结构体
class CreatePolicyGroupRequest < TencentCloud::Common::AbstractModel
# @param GroupName: 组策略名称
# @type GroupName: String
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param ViewName: 策略组所属视图的名称,若通过模板创建,可不传入
# @type ViewName: String
# @param ProjectId: 策略组所属项目Id,会进行鉴权操作
# @type ProjectId: Integer
# @param ConditionTempGroupId: 模板策略组Id, 通过模板创建时才需要传
# @type ConditionTempGroupId: Integer
# @param IsShielded: 是否屏蔽策略组,0表示不屏蔽,1表示屏蔽。不填默认为0
# @type IsShielded: Integer
# @param Remark: 策略组的备注信息
# @type Remark: String
# @param InsertTime: 插入时间,戳格式为Unix时间戳,不填则按后台处理时间填充
# @type InsertTime: Integer
# @param Conditions: 策略组中的阈值告警规则
# @type Conditions: Array
# @param EventConditions: 策略组中的事件告警规则
# @type EventConditions: Array
# @param BackEndCall: 是否为后端调用。当且仅当值为1时,后台拉取策略模板中的规则填充入Conditions以及EventConditions字段
# @type BackEndCall: Integer
# @param IsUnionRule: 指标告警规则的且或关系,0表示或规则(满足任意规则就告警),1表示且规则(满足所有规则才告警)
# @type IsUnionRule: Integer
attr_accessor :GroupName, :Module, :ViewName, :ProjectId, :ConditionTempGroupId, :IsShielded, :Remark, :InsertTime, :Conditions, :EventConditions, :BackEndCall, :IsUnionRule
def initialize(groupname=nil, _module=nil, viewname=nil, projectid=nil, conditiontempgroupid=nil, isshielded=nil, remark=nil, inserttime=nil, conditions=nil, eventconditions=nil, backendcall=nil, isunionrule=nil)
@GroupName = groupname
@Module = _module
@ViewName = viewname
@ProjectId = projectid
@ConditionTempGroupId = conditiontempgroupid
@IsShielded = isshielded
@Remark = remark
@InsertTime = inserttime
@Conditions = conditions
@EventConditions = eventconditions
@BackEndCall = backendcall
@IsUnionRule = isunionrule
end
def deserialize(params)
@GroupName = params['GroupName']
@Module = params['Module']
@ViewName = params['ViewName']
@ProjectId = params['ProjectId']
@ConditionTempGroupId = params['ConditionTempGroupId']
@IsShielded = params['IsShielded']
@Remark = params['Remark']
@InsertTime = params['InsertTime']
unless params['Conditions'].nil?
@Conditions = []
params['Conditions'].each do |i|
createpolicygroupcondition_tmp = CreatePolicyGroupCondition.new
createpolicygroupcondition_tmp.deserialize(i)
@Conditions << createpolicygroupcondition_tmp
end
end
unless params['EventConditions'].nil?
@EventConditions = []
params['EventConditions'].each do |i|
createpolicygroupeventcondition_tmp = CreatePolicyGroupEventCondition.new
createpolicygroupeventcondition_tmp.deserialize(i)
@EventConditions << createpolicygroupeventcondition_tmp
end
end
@BackEndCall = params['BackEndCall']
@IsUnionRule = params['IsUnionRule']
end
end
# CreatePolicyGroup返回参数结构体
class CreatePolicyGroupResponse < TencentCloud::Common::AbstractModel
# @param GroupId: 创建成功的策略组Id
# @type GroupId: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :GroupId, :RequestId
def initialize(groupid=nil, requestid=nil)
@GroupId = groupid
@RequestId = requestid
end
def deserialize(params)
@GroupId = params['GroupId']
@RequestId = params['RequestId']
end
end
# CreatePrometheusAgent请求参数结构体
class CreatePrometheusAgentRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param Name: Agent 名称
# @type Name: String
attr_accessor :InstanceId, :Name
def initialize(instanceid=nil, name=nil)
@InstanceId = instanceid
@Name = name
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Name = params['Name']
end
end
# CreatePrometheusAgent返回参数结构体
class CreatePrometheusAgentResponse < TencentCloud::Common::AbstractModel
# @param AgentId: 创建成功的 Agent Id
# @type AgentId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :AgentId, :RequestId
def initialize(agentid=nil, requestid=nil)
@AgentId = agentid
@RequestId = requestid
end
def deserialize(params)
@AgentId = params['AgentId']
@RequestId = params['RequestId']
end
end
# CreatePrometheusAlertGroup请求参数结构体
class CreatePrometheusAlertGroupRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: prometheus实例ID
# @type InstanceId: String
# @param GroupName: 告警分组名称,不能与其他告警分组重名
# @type GroupName: String
# @param GroupState: 告警分组状态:
# 2 -- 启用
# 3 -- 禁用
# 不为空时会覆盖 `Rules`字段下所有告警规则状态
# @type GroupState: Integer
# @param AMPReceivers: 云监控告警通知模板ID列表,形如Consumer-xxxx或notice-xxxx
# @type AMPReceivers: Array
# @param CustomReceiver: 自定义告警通知模板
# @type CustomReceiver: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusAlertCustomReceiver`
# @param RepeatInterval: 告警通知周期(收敛时间),为空默认1h
# @type RepeatInterval: String
# @param Rules: 要创建的告警规则列表
# @type Rules: Array
attr_accessor :InstanceId, :GroupName, :GroupState, :AMPReceivers, :CustomReceiver, :RepeatInterval, :Rules
def initialize(instanceid=nil, groupname=nil, groupstate=nil, ampreceivers=nil, customreceiver=nil, repeatinterval=nil, rules=nil)
@InstanceId = instanceid
@GroupName = groupname
@GroupState = groupstate
@AMPReceivers = ampreceivers
@CustomReceiver = customreceiver
@RepeatInterval = repeatinterval
@Rules = rules
end
def deserialize(params)
@InstanceId = params['InstanceId']
@GroupName = params['GroupName']
@GroupState = params['GroupState']
@AMPReceivers = params['AMPReceivers']
unless params['CustomReceiver'].nil?
@CustomReceiver = PrometheusAlertCustomReceiver.new
@CustomReceiver.deserialize(params['CustomReceiver'])
end
@RepeatInterval = params['RepeatInterval']
unless params['Rules'].nil?
@Rules = []
params['Rules'].each do |i|
prometheusalertgroupruleset_tmp = PrometheusAlertGroupRuleSet.new
prometheusalertgroupruleset_tmp.deserialize(i)
@Rules << prometheusalertgroupruleset_tmp
end
end
end
end
# CreatePrometheusAlertGroup返回参数结构体
class CreatePrometheusAlertGroupResponse < TencentCloud::Common::AbstractModel
# @param GroupId: 创建的告警分组ID,满足正则表达式`alert-[a-z0-9]{8}`
# @type GroupId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :GroupId, :RequestId
def initialize(groupid=nil, requestid=nil)
@GroupId = groupid
@RequestId = requestid
end
def deserialize(params)
@GroupId = params['GroupId']
@RequestId = params['RequestId']
end
end
# CreatePrometheusAlertPolicy请求参数结构体
class CreatePrometheusAlertPolicyRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param AlertRule: 告警配置
# @type AlertRule: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusAlertPolicyItem`
attr_accessor :InstanceId, :AlertRule
def initialize(instanceid=nil, alertrule=nil)
@InstanceId = instanceid
@AlertRule = alertrule
end
def deserialize(params)
@InstanceId = params['InstanceId']
unless params['AlertRule'].nil?
@AlertRule = PrometheusAlertPolicyItem.new
@AlertRule.deserialize(params['AlertRule'])
end
end
end
# CreatePrometheusAlertPolicy返回参数结构体
class CreatePrometheusAlertPolicyResponse < TencentCloud::Common::AbstractModel
# @param Id: 告警id
# @type Id: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Id, :RequestId
def initialize(id=nil, requestid=nil)
@Id = id
@RequestId = requestid
end
def deserialize(params)
@Id = params['Id']
@RequestId = params['RequestId']
end
end
# CreatePrometheusClusterAgent请求参数结构体
class CreatePrometheusClusterAgentRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
# @param Agents: agent列表
# @type Agents: Array
attr_accessor :InstanceId, :Agents
def initialize(instanceid=nil, agents=nil)
@InstanceId = instanceid
@Agents = agents
end
def deserialize(params)
@InstanceId = params['InstanceId']
unless params['Agents'].nil?
@Agents = []
params['Agents'].each do |i|
prometheusclusteragentbasic_tmp = PrometheusClusterAgentBasic.new
prometheusclusteragentbasic_tmp.deserialize(i)
@Agents << prometheusclusteragentbasic_tmp
end
end
end
end
# CreatePrometheusClusterAgent返回参数结构体
class CreatePrometheusClusterAgentResponse < 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
# CreatePrometheusConfig请求参数结构体
class CreatePrometheusConfigRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param ClusterType: 集群类型
# @type ClusterType: String
# @param ClusterId: 集群id
# @type ClusterId: String
# @param ServiceMonitors: ServiceMonitors配置
# @type ServiceMonitors: Array
# @param PodMonitors: PodMonitors配置
# @type PodMonitors: Array
# @param RawJobs: prometheus原生Job配置
# @type RawJobs: Array
attr_accessor :InstanceId, :ClusterType, :ClusterId, :ServiceMonitors, :PodMonitors, :RawJobs
def initialize(instanceid=nil, clustertype=nil, clusterid=nil, servicemonitors=nil, podmonitors=nil, rawjobs=nil)
@InstanceId = instanceid
@ClusterType = clustertype
@ClusterId = clusterid
@ServiceMonitors = servicemonitors
@PodMonitors = podmonitors
@RawJobs = rawjobs
end
def deserialize(params)
@InstanceId = params['InstanceId']
@ClusterType = params['ClusterType']
@ClusterId = params['ClusterId']
unless params['ServiceMonitors'].nil?
@ServiceMonitors = []
params['ServiceMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@ServiceMonitors << prometheusconfigitem_tmp
end
end
unless params['PodMonitors'].nil?
@PodMonitors = []
params['PodMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@PodMonitors << prometheusconfigitem_tmp
end
end
unless params['RawJobs'].nil?
@RawJobs = []
params['RawJobs'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@RawJobs << prometheusconfigitem_tmp
end
end
end
end
# CreatePrometheusConfig返回参数结构体
class CreatePrometheusConfigResponse < 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
# CreatePrometheusGlobalNotification请求参数结构体
class CreatePrometheusGlobalNotificationRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID(可通过 DescribePrometheusInstances 接口获取)
# @type InstanceId: String
# @param Notification: 告警通知渠道
# @type Notification: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusNotificationItem`
attr_accessor :InstanceId, :Notification
def initialize(instanceid=nil, notification=nil)
@InstanceId = instanceid
@Notification = notification
end
def deserialize(params)
@InstanceId = params['InstanceId']
unless params['Notification'].nil?
@Notification = PrometheusNotificationItem.new
@Notification.deserialize(params['Notification'])
end
end
end
# CreatePrometheusGlobalNotification返回参数结构体
class CreatePrometheusGlobalNotificationResponse < TencentCloud::Common::AbstractModel
# @param Id: 全局告警通知渠道ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Id: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Id, :RequestId
def initialize(id=nil, requestid=nil)
@Id = id
@RequestId = requestid
end
def deserialize(params)
@Id = params['Id']
@RequestId = params['RequestId']
end
end
# CreatePrometheusMultiTenantInstancePostPayMode请求参数结构体
class CreatePrometheusMultiTenantInstancePostPayModeRequest < TencentCloud::Common::AbstractModel
# @param InstanceName: 实例名
# @type InstanceName: String
# @param VpcId: VPC ID(可通过 vpc:DescribeVpcs 接口获取,与实例同地域)
# @type VpcId: String
# @param SubnetId: 子网 ID(可通过 vpc:DescribeSubnets 接口获取)
# @type SubnetId: String
# @param DataRetentionTime: 数据存储时间(单位天),限制值为15, 30, 45, 90, 180, 365, 730之一
# @type DataRetentionTime: Integer
# @param Zone: 可用区(与子网同可用区)
# @type Zone: String
# @param TagSpecification: 实例的标签
# @type TagSpecification: Array
# @param GrafanaInstanceId: 需要关联的 Grafana 实例
# @type GrafanaInstanceId: String
attr_accessor :InstanceName, :VpcId, :SubnetId, :DataRetentionTime, :Zone, :TagSpecification, :GrafanaInstanceId
def initialize(instancename=nil, vpcid=nil, subnetid=nil, dataretentiontime=nil, zone=nil, tagspecification=nil, grafanainstanceid=nil)
@InstanceName = instancename
@VpcId = vpcid
@SubnetId = subnetid
@DataRetentionTime = dataretentiontime
@Zone = zone
@TagSpecification = tagspecification
@GrafanaInstanceId = grafanainstanceid
end
def deserialize(params)
@InstanceName = params['InstanceName']
@VpcId = params['VpcId']
@SubnetId = params['SubnetId']
@DataRetentionTime = params['DataRetentionTime']
@Zone = params['Zone']
unless params['TagSpecification'].nil?
@TagSpecification = []
params['TagSpecification'].each do |i|
prometheustag_tmp = PrometheusTag.new
prometheustag_tmp.deserialize(i)
@TagSpecification << prometheustag_tmp
end
end
@GrafanaInstanceId = params['GrafanaInstanceId']
end
end
# CreatePrometheusMultiTenantInstancePostPayMode返回参数结构体
class CreatePrometheusMultiTenantInstancePostPayModeResponse < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :InstanceId, :RequestId
def initialize(instanceid=nil, requestid=nil)
@InstanceId = instanceid
@RequestId = requestid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@RequestId = params['RequestId']
end
end
# CreatePrometheusRecordRuleYaml请求参数结构体
class CreatePrometheusRecordRuleYamlRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param Content: yaml的内容
# @type Content: String
# @param Name: 规则名称
# @type Name: String
attr_accessor :InstanceId, :Content, :Name
def initialize(instanceid=nil, content=nil, name=nil)
@InstanceId = instanceid
@Content = content
@Name = name
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Content = params['Content']
@Name = params['Name']
end
end
# CreatePrometheusRecordRuleYaml返回参数结构体
class CreatePrometheusRecordRuleYamlResponse < 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
# CreatePrometheusScrapeJob请求参数结构体
class CreatePrometheusScrapeJobRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param AgentId: Agent ID(可通过DescribePrometheusAgents 接口获取)
# @type AgentId: String
# @param Config: 抓取任务配置
# @type Config: String
attr_accessor :InstanceId, :AgentId, :Config
def initialize(instanceid=nil, agentid=nil, config=nil)
@InstanceId = instanceid
@AgentId = agentid
@Config = config
end
def deserialize(params)
@InstanceId = params['InstanceId']
@AgentId = params['AgentId']
@Config = params['Config']
end
end
# CreatePrometheusScrapeJob返回参数结构体
class CreatePrometheusScrapeJobResponse < TencentCloud::Common::AbstractModel
# @param JobId: 成功创建抓取任务 Id
# @type JobId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :JobId, :RequestId
def initialize(jobid=nil, requestid=nil)
@JobId = jobid
@RequestId = requestid
end
def deserialize(params)
@JobId = params['JobId']
@RequestId = params['RequestId']
end
end
# CreatePrometheusTemp请求参数结构体
class CreatePrometheusTempRequest < TencentCloud::Common::AbstractModel
# @param Template: 模板设置
# @type Template: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusTemp`
attr_accessor :Template
def initialize(template=nil)
@Template = template
end
def deserialize(params)
unless params['Template'].nil?
@Template = PrometheusTemp.new
@Template.deserialize(params['Template'])
end
end
end
# CreatePrometheusTemp返回参数结构体
class CreatePrometheusTempResponse < TencentCloud::Common::AbstractModel
# @param TemplateId: 模板Id
# @type TemplateId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TemplateId, :RequestId
def initialize(templateid=nil, requestid=nil)
@TemplateId = templateid
@RequestId = requestid
end
def deserialize(params)
@TemplateId = params['TemplateId']
@RequestId = params['RequestId']
end
end
# CreateRecordingRule请求参数结构体
class CreateRecordingRuleRequest < TencentCloud::Common::AbstractModel
# @param Name: 聚合规则名称
# @type Name: String
# @param Group: 聚合规则组内容,格式为 yaml,通过 base64 进行编码。
# @type Group: String
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param RuleState: 规则状态码,取值如下:
# 1=RuleDeleted
# 2=RuleEnabled
# 3=RuleDisabled
# 默认状态码为 2 启用。
# @type RuleState: Integer
attr_accessor :Name, :Group, :InstanceId, :RuleState
def initialize(name=nil, group=nil, instanceid=nil, rulestate=nil)
@Name = name
@Group = group
@InstanceId = instanceid
@RuleState = rulestate
end
def deserialize(params)
@Name = params['Name']
@Group = params['Group']
@InstanceId = params['InstanceId']
@RuleState = params['RuleState']
end
end
# CreateRecordingRule返回参数结构体
class CreateRecordingRuleResponse < TencentCloud::Common::AbstractModel
# @param RuleId: 规则 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RuleId, :RequestId
def initialize(ruleid=nil, requestid=nil)
@RuleId = ruleid
@RequestId = requestid
end
def deserialize(params)
@RuleId = params['RuleId']
@RequestId = params['RequestId']
end
end
# CreateSSOAccount请求参数结构体
class CreateSSOAccountRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
# @param UserId: 用户账号 ID ,例如:10000000
# @type UserId: String
# @param Role: 权限(只取数组中的第一个,其中 Organization 暂未使用,可不填)
# @type Role: Array
# @param Notes: 备注
# @type Notes: String
attr_accessor :InstanceId, :UserId, :Role, :Notes
def initialize(instanceid=nil, userid=nil, role=nil, notes=nil)
@InstanceId = instanceid
@UserId = userid
@Role = role
@Notes = notes
end
def deserialize(params)
@InstanceId = params['InstanceId']
@UserId = params['UserId']
unless params['Role'].nil?
@Role = []
params['Role'].each do |i|
grafanaaccountrole_tmp = GrafanaAccountRole.new
grafanaaccountrole_tmp.deserialize(i)
@Role << grafanaaccountrole_tmp
end
end
@Notes = params['Notes']
end
end
# CreateSSOAccount返回参数结构体
class CreateSSOAccountResponse < TencentCloud::Common::AbstractModel
# @param UserId: 已添加的用户 UIN
# @type UserId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :UserId, :RequestId
def initialize(userid=nil, requestid=nil)
@UserId = userid
@RequestId = requestid
end
def deserialize(params)
@UserId = params['UserId']
@RequestId = params['RequestId']
end
end
# CreateServiceDiscovery请求参数结构体
class CreateServiceDiscoveryRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param KubeClusterId: 类型为TKE:对应集成的腾讯云容器服务集群 ID
# @type KubeClusterId: String
# @param KubeType: 用户 Kubernetes 集群类型:
# 1 = 容器服务集群(TKE)
# @type KubeType: Integer
# @param Type: 服务发现类型,取值如下:
# 1 = ServiceMonitor
# 2 = PodMonitor
# 3 = JobMonitor
# @type Type: Integer
# @param Yaml: 服务发现配置信息,YAML 格式,[具体YAML参数内容请参考](https://cloud.tencent.com/document/product/1416/55995#service-monitor)
# @type Yaml: String
attr_accessor :InstanceId, :KubeClusterId, :KubeType, :Type, :Yaml
def initialize(instanceid=nil, kubeclusterid=nil, kubetype=nil, type=nil, yaml=nil)
@InstanceId = instanceid
@KubeClusterId = kubeclusterid
@KubeType = kubetype
@Type = type
@Yaml = yaml
end
def deserialize(params)
@InstanceId = params['InstanceId']
@KubeClusterId = params['KubeClusterId']
@KubeType = params['KubeType']
@Type = params['Type']
@Yaml = params['Yaml']
end
end
# CreateServiceDiscovery返回参数结构体
class CreateServiceDiscoveryResponse < TencentCloud::Common::AbstractModel
# @param ServiceDiscovery: 创建成功之后,返回对应服务发现信息
# @type ServiceDiscovery: :class:`Tencentcloud::Monitor.v20180724.models.ServiceDiscoveryItem`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ServiceDiscovery, :RequestId
def initialize(servicediscovery=nil, requestid=nil)
@ServiceDiscovery = servicediscovery
@RequestId = requestid
end
def deserialize(params)
unless params['ServiceDiscovery'].nil?
@ServiceDiscovery = ServiceDiscoveryItem.new
@ServiceDiscovery.deserialize(params['ServiceDiscovery'])
end
@RequestId = params['RequestId']
end
end
# 监控数据点
class DataPoint < TencentCloud::Common::AbstractModel
# @param Dimensions: 实例对象维度组合
# @type Dimensions: Array
# @param Timestamps: 时间戳数组,表示那些时间点有数据,缺失的时间戳,没有数据点,可以理解为掉点了
# @type Timestamps: Array
# @param Values: 监控值数组,该数组和Timestamps一一对应
# @type Values: Array
# @param MaxValues: 监控值数组,该数组和Timestamps一一对应
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MaxValues: Array
# @param MinValues: 监控值数组,该数组和Timestamps一一对应
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MinValues: Array
# @param AvgValues: 监控值数组,该数组和Timestamps一一对应
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AvgValues: Array
attr_accessor :Dimensions, :Timestamps, :Values, :MaxValues, :MinValues, :AvgValues
def initialize(dimensions=nil, timestamps=nil, values=nil, maxvalues=nil, minvalues=nil, avgvalues=nil)
@Dimensions = dimensions
@Timestamps = timestamps
@Values = values
@MaxValues = maxvalues
@MinValues = minvalues
@AvgValues = avgvalues
end
def deserialize(params)
unless params['Dimensions'].nil?
@Dimensions = []
params['Dimensions'].each do |i|
dimension_tmp = Dimension.new
dimension_tmp.deserialize(i)
@Dimensions << dimension_tmp
end
end
@Timestamps = params['Timestamps']
@Values = params['Values']
@MaxValues = params['MaxValues']
@MinValues = params['MinValues']
@AvgValues = params['AvgValues']
end
end
# DeleteAlarmNotices请求参数结构体
class DeleteAlarmNoticesRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,这里填“monitor”
# @type Module: String
# @param NoticeIds: 告警通知模板id列表
# @type NoticeIds: Array
# @param NoticeBindPolicys: 通知模板与策略绑定关系
# @type NoticeBindPolicys: Array
attr_accessor :Module, :NoticeIds, :NoticeBindPolicys
def initialize(_module=nil, noticeids=nil, noticebindpolicys=nil)
@Module = _module
@NoticeIds = noticeids
@NoticeBindPolicys = noticebindpolicys
end
def deserialize(params)
@Module = params['Module']
@NoticeIds = params['NoticeIds']
unless params['NoticeBindPolicys'].nil?
@NoticeBindPolicys = []
params['NoticeBindPolicys'].each do |i|
noticebindpolicys_tmp = NoticeBindPolicys.new
noticebindpolicys_tmp.deserialize(i)
@NoticeBindPolicys << noticebindpolicys_tmp
end
end
end
end
# DeleteAlarmNotices返回参数结构体
class DeleteAlarmNoticesResponse < 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
# DeleteAlarmPolicy请求参数结构体
class DeleteAlarmPolicyRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,固定值 monitor
# @type Module: String
# @param PolicyIds: 告警策略 ID 列表
# @type PolicyIds: Array
# @param PromInsIds: prom的实例id
# @type PromInsIds: Array
attr_accessor :Module, :PolicyIds, :PromInsIds
def initialize(_module=nil, policyids=nil, prominsids=nil)
@Module = _module
@PolicyIds = policyids
@PromInsIds = prominsids
end
def deserialize(params)
@Module = params['Module']
@PolicyIds = params['PolicyIds']
@PromInsIds = params['PromInsIds']
end
end
# DeleteAlarmPolicy返回参数结构体
class DeleteAlarmPolicyResponse < 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
# DeleteAlertRules请求参数结构体
class DeleteAlertRulesRequest < TencentCloud::Common::AbstractModel
# @param RuleIds: 规则 ID 列表
# @type RuleIds: Array
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
attr_accessor :RuleIds, :InstanceId
def initialize(ruleids=nil, instanceid=nil)
@RuleIds = ruleids
@InstanceId = instanceid
end
def deserialize(params)
@RuleIds = params['RuleIds']
@InstanceId = params['InstanceId']
end
end
# DeleteAlertRules返回参数结构体
class DeleteAlertRulesResponse < 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
# DeleteExporterIntegration请求参数结构体
class DeleteExporterIntegrationRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param Kind: 类型(可通过 DescribeExporterIntegrations获取)
# @type Kind: String
# @param Name: 名字
# @type Name: String
# @param KubeType: Kubernetes 集群类型,取值如下:
# 1= 容器集群(TKE)
# 2=弹性集群(EKS)
# 3= Prometheus管理的弹性集群(MEKS)
# @type KubeType: Integer
# @param ClusterId: 集群 ID,可不填
# @type ClusterId: String
attr_accessor :InstanceId, :Kind, :Name, :KubeType, :ClusterId
def initialize(instanceid=nil, kind=nil, name=nil, kubetype=nil, clusterid=nil)
@InstanceId = instanceid
@Kind = kind
@Name = name
@KubeType = kubetype
@ClusterId = clusterid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Kind = params['Kind']
@Name = params['Name']
@KubeType = params['KubeType']
@ClusterId = params['ClusterId']
end
end
# DeleteExporterIntegration返回参数结构体
class DeleteExporterIntegrationResponse < 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
# DeleteGrafanaInstance请求参数结构体
class DeleteGrafanaInstanceRequest < TencentCloud::Common::AbstractModel
# @param InstanceIDs: 实例ID数组
# @type InstanceIDs: Array
attr_accessor :InstanceIDs
def initialize(instanceids=nil)
@InstanceIDs = instanceids
end
def deserialize(params)
@InstanceIDs = params['InstanceIDs']
end
end
# DeleteGrafanaInstance返回参数结构体
class DeleteGrafanaInstanceResponse < 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
# DeleteGrafanaIntegration请求参数结构体
class DeleteGrafanaIntegrationRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-12345678
# @type InstanceId: String
# @param IntegrationId: 集成 ID,可在实例详情-云产品集成-集成列表查看。例如:integration-abcd1234
# @type IntegrationId: String
attr_accessor :InstanceId, :IntegrationId
def initialize(instanceid=nil, integrationid=nil)
@InstanceId = instanceid
@IntegrationId = integrationid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@IntegrationId = params['IntegrationId']
end
end
# DeleteGrafanaIntegration返回参数结构体
class DeleteGrafanaIntegrationResponse < 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
# DeleteGrafanaNotificationChannel请求参数结构体
class DeleteGrafanaNotificationChannelRequest < TencentCloud::Common::AbstractModel
# @param ChannelIDs: 通道 ID 数组。例如:nchannel-abcd1234,通过 DescribeGrafanaChannels 获取
# @type ChannelIDs: Array
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
attr_accessor :ChannelIDs, :InstanceId
def initialize(channelids=nil, instanceid=nil)
@ChannelIDs = channelids
@InstanceId = instanceid
end
def deserialize(params)
@ChannelIDs = params['ChannelIDs']
@InstanceId = params['InstanceId']
end
end
# DeleteGrafanaNotificationChannel返回参数结构体
class DeleteGrafanaNotificationChannelResponse < 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
# DeletePolicyGroup请求参数结构体
class DeletePolicyGroupRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param GroupId: 策略组id,即1.0的告警策略id,可以从策略详情获取
# @type GroupId: Array
attr_accessor :Module, :GroupId
def initialize(_module=nil, groupid=nil)
@Module = _module
@GroupId = groupid
end
def deserialize(params)
@Module = params['Module']
@GroupId = params['GroupId']
end
end
# DeletePolicyGroup返回参数结构体
class DeletePolicyGroupResponse < 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
# DeletePrometheusAlertGroups请求参数结构体
class DeletePrometheusAlertGroupsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: prometheus实例id
# @type InstanceId: String
# @param GroupIds: 需要删除的告警分组ID,形如alert-xxxxx
# @type GroupIds: Array
attr_accessor :InstanceId, :GroupIds
def initialize(instanceid=nil, groupids=nil)
@InstanceId = instanceid
@GroupIds = groupids
end
def deserialize(params)
@InstanceId = params['InstanceId']
@GroupIds = params['GroupIds']
end
end
# DeletePrometheusAlertGroups返回参数结构体
class DeletePrometheusAlertGroupsResponse < 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
# DeletePrometheusAlertPolicy请求参数结构体
class DeletePrometheusAlertPolicyRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID(可通过 DescribePrometheusInstances 接口获取)
# @type InstanceId: String
# @param AlertIds: 告警策略ID列表(可通过 DescribePrometheusAlertPolicy 接口获取)
# @type AlertIds: Array
# @param Names: 告警策略名称(可通过 DescribePrometheusAlertPolicy 接口获取),名称完全相同的告警策略才会删除
# @type Names: Array
attr_accessor :InstanceId, :AlertIds, :Names
def initialize(instanceid=nil, alertids=nil, names=nil)
@InstanceId = instanceid
@AlertIds = alertids
@Names = names
end
def deserialize(params)
@InstanceId = params['InstanceId']
@AlertIds = params['AlertIds']
@Names = params['Names']
end
end
# DeletePrometheusAlertPolicy返回参数结构体
class DeletePrometheusAlertPolicyResponse < 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
# DeletePrometheusClusterAgent请求参数结构体
class DeletePrometheusClusterAgentRequest < TencentCloud::Common::AbstractModel
# @param Agents: agent列表
# @type Agents: Array
# @param InstanceId: 实例id
# @type InstanceId: String
attr_accessor :Agents, :InstanceId
def initialize(agents=nil, instanceid=nil)
@Agents = agents
@InstanceId = instanceid
end
def deserialize(params)
unless params['Agents'].nil?
@Agents = []
params['Agents'].each do |i|
prometheusagentinfo_tmp = PrometheusAgentInfo.new
prometheusagentinfo_tmp.deserialize(i)
@Agents << prometheusagentinfo_tmp
end
end
@InstanceId = params['InstanceId']
end
end
# DeletePrometheusClusterAgent返回参数结构体
class DeletePrometheusClusterAgentResponse < 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
# DeletePrometheusConfig请求参数结构体
class DeletePrometheusConfigRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param ClusterType: 集群类型
# @type ClusterType: String
# @param ClusterId: 集群id
# @type ClusterId: String
# @param ServiceMonitors: 要删除的ServiceMonitor名字列表
# @type ServiceMonitors: Array
# @param PodMonitors: 要删除的PodMonitor名字列表
# @type PodMonitors: Array
# @param RawJobs: 要删除的RawJobs名字列表
# @type RawJobs: Array
attr_accessor :InstanceId, :ClusterType, :ClusterId, :ServiceMonitors, :PodMonitors, :RawJobs
def initialize(instanceid=nil, clustertype=nil, clusterid=nil, servicemonitors=nil, podmonitors=nil, rawjobs=nil)
@InstanceId = instanceid
@ClusterType = clustertype
@ClusterId = clusterid
@ServiceMonitors = servicemonitors
@PodMonitors = podmonitors
@RawJobs = rawjobs
end
def deserialize(params)
@InstanceId = params['InstanceId']
@ClusterType = params['ClusterType']
@ClusterId = params['ClusterId']
@ServiceMonitors = params['ServiceMonitors']
@PodMonitors = params['PodMonitors']
@RawJobs = params['RawJobs']
end
end
# DeletePrometheusConfig返回参数结构体
class DeletePrometheusConfigResponse < 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
# DeletePrometheusRecordRuleYaml请求参数结构体
class DeletePrometheusRecordRuleYamlRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param Names: 聚合规则列表
# @type Names: Array
attr_accessor :InstanceId, :Names
def initialize(instanceid=nil, names=nil)
@InstanceId = instanceid
@Names = names
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Names = params['Names']
end
end
# DeletePrometheusRecordRuleYaml返回参数结构体
class DeletePrometheusRecordRuleYamlResponse < 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
# DeletePrometheusScrapeJobs请求参数结构体
class DeletePrometheusScrapeJobsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param AgentId: Agent ID(可通过 DescribePrometheusAgents 接口获取)
# @type AgentId: String
# @param JobIds: 任务 ID 列表(可通过 DescribePrometheusScrapeJobs 接口获取)
# @type JobIds: Array
attr_accessor :InstanceId, :AgentId, :JobIds
def initialize(instanceid=nil, agentid=nil, jobids=nil)
@InstanceId = instanceid
@AgentId = agentid
@JobIds = jobids
end
def deserialize(params)
@InstanceId = params['InstanceId']
@AgentId = params['AgentId']
@JobIds = params['JobIds']
end
end
# DeletePrometheusScrapeJobs返回参数结构体
class DeletePrometheusScrapeJobsResponse < 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
# DeletePrometheusTemp请求参数结构体
class DeletePrometheusTempRequest < TencentCloud::Common::AbstractModel
# @param TemplateId: 模板id
# @type TemplateId: String
attr_accessor :TemplateId
def initialize(templateid=nil)
@TemplateId = templateid
end
def deserialize(params)
@TemplateId = params['TemplateId']
end
end
# DeletePrometheusTemp返回参数结构体
class DeletePrometheusTempResponse < 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
# DeletePrometheusTempSync请求参数结构体
class DeletePrometheusTempSyncRequest < TencentCloud::Common::AbstractModel
# @param TemplateId: 模板id
# @type TemplateId: String
# @param Targets: 取消同步的对象列表
# @type Targets: Array
attr_accessor :TemplateId, :Targets
def initialize(templateid=nil, targets=nil)
@TemplateId = templateid
@Targets = targets
end
def deserialize(params)
@TemplateId = params['TemplateId']
unless params['Targets'].nil?
@Targets = []
params['Targets'].each do |i|
prometheustemplatesynctarget_tmp = PrometheusTemplateSyncTarget.new
prometheustemplatesynctarget_tmp.deserialize(i)
@Targets << prometheustemplatesynctarget_tmp
end
end
end
end
# DeletePrometheusTempSync返回参数结构体
class DeletePrometheusTempSyncResponse < 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
# DeleteRecordingRules请求参数结构体
class DeleteRecordingRulesRequest < TencentCloud::Common::AbstractModel
# @param RuleIds: 规则 ID 列表(规则 ID 可通过 DescribeRecordingRules 接口获取)
# @type RuleIds: Array
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
attr_accessor :RuleIds, :InstanceId
def initialize(ruleids=nil, instanceid=nil)
@RuleIds = ruleids
@InstanceId = instanceid
end
def deserialize(params)
@RuleIds = params['RuleIds']
@InstanceId = params['InstanceId']
end
end
# DeleteRecordingRules返回参数结构体
class DeleteRecordingRulesResponse < 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
# DeleteSSOAccount请求参数结构体
class DeleteSSOAccountRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
# @param UserId: 用户账号 ID ,例如:10000000
# @type UserId: String
attr_accessor :InstanceId, :UserId
def initialize(instanceid=nil, userid=nil)
@InstanceId = instanceid
@UserId = userid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@UserId = params['UserId']
end
end
# DeleteSSOAccount返回参数结构体
class DeleteSSOAccountResponse < 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
# DeleteServiceDiscovery请求参数结构体
class DeleteServiceDiscoveryRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID,例如:prom-sdfk2342a
# @type InstanceId: String
# @param KubeClusterId: 类型是 TKE,为对应的腾讯云容器服务集群 ID
# @type KubeClusterId: String
# @param KubeType: 用户 Kubernetes 集群类型:
# 1 = 容器服务集群(TKE)
# @type KubeType: Integer
# @param Type: 服务发现类型,取值如下:
# 1 = ServiceMonitor
# 2 = PodMonitor
# 3 = PodMonitor
# @type Type: Integer
# @param Yaml: 服务发现配置信息,YAML 格式,[具体YAML参数内容请参考](https://cloud.tencent.com/document/product/1416/55995#service-monitor)
# @type Yaml: String
attr_accessor :InstanceId, :KubeClusterId, :KubeType, :Type, :Yaml
def initialize(instanceid=nil, kubeclusterid=nil, kubetype=nil, type=nil, yaml=nil)
@InstanceId = instanceid
@KubeClusterId = kubeclusterid
@KubeType = kubetype
@Type = type
@Yaml = yaml
end
def deserialize(params)
@InstanceId = params['InstanceId']
@KubeClusterId = params['KubeClusterId']
@KubeType = params['KubeType']
@Type = params['Type']
@Yaml = params['Yaml']
end
end
# DeleteServiceDiscovery返回参数结构体
class DeleteServiceDiscoveryResponse < 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
# DescribeAccidentEventList接口的出参类型
class DescribeAccidentEventListAlarms < TencentCloud::Common::AbstractModel
# @param BusinessTypeDesc: 事件分类
# 注意:此字段可能返回 null,表示取不到有效值。
# @type BusinessTypeDesc: String
# @param AccidentTypeDesc: 事件类型
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AccidentTypeDesc: String
# @param BusinessID: 事件分类的ID,1表示服务问题,2表示其他订阅
# 注意:此字段可能返回 null,表示取不到有效值。
# @type BusinessID: Integer
# @param EventStatus: 事件状态的ID,0表示已恢复,1表示未恢复
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventStatus: Integer
# @param AffectResource: 影响的对象
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AffectResource: String
# @param Region: 事件的地域
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Region: String
# @param OccurTime: 事件发生的时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OccurTime: String
# @param UpdateTime: 更新时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdateTime: String
attr_accessor :BusinessTypeDesc, :AccidentTypeDesc, :BusinessID, :EventStatus, :AffectResource, :Region, :OccurTime, :UpdateTime
def initialize(businesstypedesc=nil, accidenttypedesc=nil, businessid=nil, eventstatus=nil, affectresource=nil, region=nil, occurtime=nil, updatetime=nil)
@BusinessTypeDesc = businesstypedesc
@AccidentTypeDesc = accidenttypedesc
@BusinessID = businessid
@EventStatus = eventstatus
@AffectResource = affectresource
@Region = region
@OccurTime = occurtime
@UpdateTime = updatetime
end
def deserialize(params)
@BusinessTypeDesc = params['BusinessTypeDesc']
@AccidentTypeDesc = params['AccidentTypeDesc']
@BusinessID = params['BusinessID']
@EventStatus = params['EventStatus']
@AffectResource = params['AffectResource']
@Region = params['Region']
@OccurTime = params['OccurTime']
@UpdateTime = params['UpdateTime']
end
end
# DescribeAccidentEventList请求参数结构体
class DescribeAccidentEventListRequest < TencentCloud::Common::AbstractModel
# @param Module: 接口模块名,当前接口取值monitor
# @type Module: String
# @param StartTime: 起始时间,默认一天前的时间戳
# @type StartTime: Integer
# @param EndTime: 结束时间,默认当前时间戳
# @type EndTime: Integer
# @param Limit: 分页参数,每页返回的数量,取值1~100,默认20
# @type Limit: Integer
# @param Offset: 分页参数,页偏移量,从0开始计数,默认0
# @type Offset: Integer
# @param UpdateTimeOrder: 根据UpdateTime排序的规则,取值asc或desc
# @type UpdateTimeOrder: String
# @param OccurTimeOrder: 根据OccurTime排序的规则,取值asc或desc(优先根据UpdateTimeOrder排序)
# @type OccurTimeOrder: String
# @param AccidentType: 根据事件类型过滤,1表示服务问题,2表示其他订阅
# @type AccidentType: Array
# @param AccidentEvent: 根据事件过滤,1表示云服务器存储问题,2表示云服务器网络连接问题,3表示云服务器运行异常,202表示运营商网络抖动
# @type AccidentEvent: Array
# @param AccidentStatus: 根据事件状态过滤,0表示已恢复,1表示未恢复
# @type AccidentStatus: Array
# @param AccidentRegion: 根据事件地域过滤,gz表示广州,sh表示上海等
# @type AccidentRegion: Array
# @param AffectResource: 根据影响资源过滤,比如ins-19a06bka
# @type AffectResource: String
attr_accessor :Module, :StartTime, :EndTime, :Limit, :Offset, :UpdateTimeOrder, :OccurTimeOrder, :AccidentType, :AccidentEvent, :AccidentStatus, :AccidentRegion, :AffectResource
def initialize(_module=nil, starttime=nil, endtime=nil, limit=nil, offset=nil, updatetimeorder=nil, occurtimeorder=nil, accidenttype=nil, accidentevent=nil, accidentstatus=nil, accidentregion=nil, affectresource=nil)
@Module = _module
@StartTime = starttime
@EndTime = endtime
@Limit = limit
@Offset = offset
@UpdateTimeOrder = updatetimeorder
@OccurTimeOrder = occurtimeorder
@AccidentType = accidenttype
@AccidentEvent = accidentevent
@AccidentStatus = accidentstatus
@AccidentRegion = accidentregion
@AffectResource = affectresource
end
def deserialize(params)
@Module = params['Module']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@Limit = params['Limit']
@Offset = params['Offset']
@UpdateTimeOrder = params['UpdateTimeOrder']
@OccurTimeOrder = params['OccurTimeOrder']
@AccidentType = params['AccidentType']
@AccidentEvent = params['AccidentEvent']
@AccidentStatus = params['AccidentStatus']
@AccidentRegion = params['AccidentRegion']
@AffectResource = params['AffectResource']
end
end
# DescribeAccidentEventList返回参数结构体
class DescribeAccidentEventListResponse < TencentCloud::Common::AbstractModel
# @param Alarms: 平台事件列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Alarms: Array
# @param Total: 平台事件的总数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Total: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Alarms, :Total, :RequestId
def initialize(alarms=nil, total=nil, requestid=nil)
@Alarms = alarms
@Total = total
@RequestId = requestid
end
def deserialize(params)
unless params['Alarms'].nil?
@Alarms = []
params['Alarms'].each do |i|
describeaccidenteventlistalarms_tmp = DescribeAccidentEventListAlarms.new
describeaccidenteventlistalarms_tmp.deserialize(i)
@Alarms << describeaccidenteventlistalarms_tmp
end
end
@Total = params['Total']
@RequestId = params['RequestId']
end
end
# DescribeAlarmEvents请求参数结构体
class DescribeAlarmEventsRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,固定值 monitor
# @type Module: String
# @param Namespace: 告警策略类型,由 DescribeAllNamespaces 获得,例如 cvm_device
# @type Namespace: String
# @param MonitorType: 监控类型,如 MT_QCE。如果不填默认为 MT_QCE。
# @type MonitorType: String
attr_accessor :Module, :Namespace, :MonitorType
def initialize(_module=nil, namespace=nil, monitortype=nil)
@Module = _module
@Namespace = namespace
@MonitorType = monitortype
end
def deserialize(params)
@Module = params['Module']
@Namespace = params['Namespace']
@MonitorType = params['MonitorType']
end
end
# DescribeAlarmEvents返回参数结构体
class DescribeAlarmEventsResponse < TencentCloud::Common::AbstractModel
# @param Events: 告警事件列表
# @type Events: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Events, :RequestId
def initialize(events=nil, requestid=nil)
@Events = events
@RequestId = requestid
end
def deserialize(params)
unless params['Events'].nil?
@Events = []
params['Events'].each do |i|
alarmevent_tmp = AlarmEvent.new
alarmevent_tmp.deserialize(i)
@Events << alarmevent_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeAlarmHistories请求参数结构体
class DescribeAlarmHistoriesRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param PageNumber: 页数,从 1 开始计数,默认 1
# @type PageNumber: Integer
# @param PageSize: 每页的数量,取值1~100,默认20
# @type PageSize: Integer
# @param Order: 默认按首次出现时间倒序排列 "ASC"=正序 "DESC"=逆序
# @type Order: String
# @param StartTime: 起始时间,默认一天前的时间戳。对应 `FirstOccurTime` 告警首次出现时间,告警历史的 `FirstOccurTime` 晚于 `StartTime` 才可能被搜索到。
# @type StartTime: Integer
# @param EndTime: 结束时间,默认当前时间戳。对应 `FirstOccurTime` 告警首次出现时间,告警历史的 `FirstOccurTime` 早于 `EndTime` 才可能被搜索到。
# @type EndTime: Integer
# @param MonitorTypes: 根据监控类型过滤,不选默认查所有类型。"MT_QCE"=云产品监控,支持的枚举值有:"MT_QCE"=云产品监控;"MT_TAW"=应用性能监控;"MT_RUM"=前端性能监控;"MT_PROBE"=云拨测,"MT_TRTC"=实时音视频,
# "MT_RUMAPP"=终端性能监控
# @type MonitorTypes: Array
# @param AlarmObject: 根据告警对象过滤 字符串模糊搜索
# @type AlarmObject: String
# @param AlarmStatus: 根据告警状态过滤 ALARM=未恢复 OK=已恢复 NO_CONF=已失效 NO_DATA=数据不足,不选默认查所有
# @type AlarmStatus: Array
# @param ProjectIds: 根据项目ID过滤,-1=无项目 0=默认项目
# 可在此页面查询 [项目管理](https://console.cloud.tencent.com/project)
# @type ProjectIds: Array
# @param InstanceGroupIds: 根据实例组ID过滤
# @type InstanceGroupIds: Array
# @param Namespaces: 根据策略类型过滤,策略类型是监控类型之下的概念,在这里两者都需要传入,例如 `[{"MonitorType": "MT_QCE", "Namespace": "cvm_device"}]`
# 可使用 [查询所有名字空间 DescribeAllNamespaces](https://cloud.tencent.com/document/product/248/48683) 接口查询
# @type Namespaces: Array
# @param MetricNames: 根据指标名过滤
# @type MetricNames: Array
# @param PolicyName: 根据策略名称模糊搜索,不支持大小写区分
# @type PolicyName: String
# @param Content: 根据告警内容模糊搜索
# @type Content: String
# @param ReceiverUids: 根据接收人搜索,可以使用“访问管理”的 [拉取子用户 ListUsers](https://cloud.tencent.com/document/product/598/34587) 接口获取用户列表 或 [查询子用户 GetUser](https://cloud.tencent.com/document/product/598/34590) 接口查询子用户详情,此处填入返回结果中的 `Uid` 字段
# @type ReceiverUids: Array
# @param ReceiverGroups: 根据接收组搜索,可以使用“访问管理”的 [查询用户组列表 ListGroups](https://cloud.tencent.com/document/product/598/34589) 接口获取用户组列表 或 [列出用户关联的用户组 ListGroupsForUser](https://cloud.tencent.com/document/product/598/34588) 查询某个子用户所在的用户组列表 ,此处填入返回结果中的 `GroupId ` 字段
# @type ReceiverGroups: Array
# @param PolicyIds: 根据告警策略 Id 列表搜索
# @type PolicyIds: Array
# @param AlarmLevels: 告警等级,取值范围:Remind、Serious、Warn
# @type AlarmLevels: Array
# @param ConvergenceHistoryIDs: 收敛历史的唯一id
# @type ConvergenceHistoryIDs: Array
# @param AlarmTypes: 告警类型
# @type AlarmTypes: Array
attr_accessor :Module, :PageNumber, :PageSize, :Order, :StartTime, :EndTime, :MonitorTypes, :AlarmObject, :AlarmStatus, :ProjectIds, :InstanceGroupIds, :Namespaces, :MetricNames, :PolicyName, :Content, :ReceiverUids, :ReceiverGroups, :PolicyIds, :AlarmLevels, :ConvergenceHistoryIDs, :AlarmTypes
def initialize(_module=nil, pagenumber=nil, pagesize=nil, order=nil, starttime=nil, endtime=nil, monitortypes=nil, alarmobject=nil, alarmstatus=nil, projectids=nil, instancegroupids=nil, namespaces=nil, metricnames=nil, policyname=nil, content=nil, receiveruids=nil, receivergroups=nil, policyids=nil, alarmlevels=nil, convergencehistoryids=nil, alarmtypes=nil)
@Module = _module
@PageNumber = pagenumber
@PageSize = pagesize
@Order = order
@StartTime = starttime
@EndTime = endtime
@MonitorTypes = monitortypes
@AlarmObject = alarmobject
@AlarmStatus = alarmstatus
@ProjectIds = projectids
@InstanceGroupIds = instancegroupids
@Namespaces = namespaces
@MetricNames = metricnames
@PolicyName = policyname
@Content = content
@ReceiverUids = receiveruids
@ReceiverGroups = receivergroups
@PolicyIds = policyids
@AlarmLevels = alarmlevels
@ConvergenceHistoryIDs = convergencehistoryids
@AlarmTypes = alarmtypes
end
def deserialize(params)
@Module = params['Module']
@PageNumber = params['PageNumber']
@PageSize = params['PageSize']
@Order = params['Order']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@MonitorTypes = params['MonitorTypes']
@AlarmObject = params['AlarmObject']
@AlarmStatus = params['AlarmStatus']
@ProjectIds = params['ProjectIds']
@InstanceGroupIds = params['InstanceGroupIds']
unless params['Namespaces'].nil?
@Namespaces = []
params['Namespaces'].each do |i|
monitortypenamespace_tmp = MonitorTypeNamespace.new
monitortypenamespace_tmp.deserialize(i)
@Namespaces << monitortypenamespace_tmp
end
end
@MetricNames = params['MetricNames']
@PolicyName = params['PolicyName']
@Content = params['Content']
@ReceiverUids = params['ReceiverUids']
@ReceiverGroups = params['ReceiverGroups']
@PolicyIds = params['PolicyIds']
@AlarmLevels = params['AlarmLevels']
@ConvergenceHistoryIDs = params['ConvergenceHistoryIDs']
@AlarmTypes = params['AlarmTypes']
end
end
# DescribeAlarmHistories返回参数结构体
class DescribeAlarmHistoriesResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 总数
# @type TotalCount: Integer
# @param Histories: 告警历史列表
# @type Histories: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Histories, :RequestId
def initialize(totalcount=nil, histories=nil, requestid=nil)
@TotalCount = totalcount
@Histories = histories
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Histories'].nil?
@Histories = []
params['Histories'].each do |i|
alarmhistory_tmp = AlarmHistory.new
alarmhistory_tmp.deserialize(i)
@Histories << alarmhistory_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeAlarmMetrics请求参数结构体
class DescribeAlarmMetricsRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param MonitorType: 监控类型过滤 "MT_QCE"=云产品监控
# @type MonitorType: String
# @param Namespace: 告警策略类型,由 DescribeAllNamespaces 获得,例如 cvm_device
# @type Namespace: String
attr_accessor :Module, :MonitorType, :Namespace
def initialize(_module=nil, monitortype=nil, namespace=nil)
@Module = _module
@MonitorType = monitortype
@Namespace = namespace
end
def deserialize(params)
@Module = params['Module']
@MonitorType = params['MonitorType']
@Namespace = params['Namespace']
end
end
# DescribeAlarmMetrics返回参数结构体
class DescribeAlarmMetricsResponse < TencentCloud::Common::AbstractModel
# @param Metrics: 告警指标列表
# @type Metrics: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Metrics, :RequestId
def initialize(metrics=nil, requestid=nil)
@Metrics = metrics
@RequestId = requestid
end
def deserialize(params)
unless params['Metrics'].nil?
@Metrics = []
params['Metrics'].each do |i|
metric_tmp = Metric.new
metric_tmp.deserialize(i)
@Metrics << metric_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeAlarmNoticeCallbacks请求参数结构体
class DescribeAlarmNoticeCallbacksRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,这里填“monitor”
# @type Module: String
attr_accessor :Module
def initialize(_module=nil)
@Module = _module
end
def deserialize(params)
@Module = params['Module']
end
end
# DescribeAlarmNoticeCallbacks返回参数结构体
class DescribeAlarmNoticeCallbacksResponse < TencentCloud::Common::AbstractModel
# @param URLNotices: 告警回调通知
# 注意:此字段可能返回 null,表示取不到有效值。
# @type URLNotices: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :URLNotices, :RequestId
def initialize(urlnotices=nil, requestid=nil)
@URLNotices = urlnotices
@RequestId = requestid
end
def deserialize(params)
unless params['URLNotices'].nil?
@URLNotices = []
params['URLNotices'].each do |i|
urlnotice_tmp = URLNotice.new
urlnotice_tmp.deserialize(i)
@URLNotices << urlnotice_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeAlarmNotice请求参数结构体
class DescribeAlarmNoticeRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,这里填“monitor”
# @type Module: String
# @param NoticeId: 告警通知模板 id
# @type NoticeId: String
attr_accessor :Module, :NoticeId
def initialize(_module=nil, noticeid=nil)
@Module = _module
@NoticeId = noticeid
end
def deserialize(params)
@Module = params['Module']
@NoticeId = params['NoticeId']
end
end
# DescribeAlarmNotice返回参数结构体
class DescribeAlarmNoticeResponse < TencentCloud::Common::AbstractModel
# @param Notice: 告警通知模板详细信息
# @type Notice: :class:`Tencentcloud::Monitor.v20180724.models.AlarmNotice`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Notice, :RequestId
def initialize(notice=nil, requestid=nil)
@Notice = notice
@RequestId = requestid
end
def deserialize(params)
unless params['Notice'].nil?
@Notice = AlarmNotice.new
@Notice.deserialize(params['Notice'])
end
@RequestId = params['RequestId']
end
end
# DescribeAlarmNotices请求参数结构体
class DescribeAlarmNoticesRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,这里填“monitor”
# @type Module: String
# @param PageNumber: 页码 最小为1
# @type PageNumber: Integer
# @param PageSize: 分页大小 1~200
# @type PageSize: Integer
# @param Order: 按更新时间排序方式 ASC=正序 DESC=倒序
# @type Order: String
# @param OwnerUid: 主账号 uid 用于创建预设通知
# @type OwnerUid: Integer
# @param Name: 告警通知模板名称 用来模糊搜索
# @type Name: String
# @param ReceiverType: 根据接收人过滤告警通知模板需要选定通知用户类型 USER=用户 GROUP=用户组 传空=不按接收人过滤
# @type ReceiverType: String
# @param UserIds: 接收对象列表
# @type UserIds: Array
# @param GroupIds: 接收组列表
# @type GroupIds: Array
# @param NoticeIds: 根据通知模板 id 过滤,空数组/不传则不过滤
# @type NoticeIds: Array
# @param Tags: 模板根据标签过滤
# @type Tags: Array
# @param OnCallFormIDs: 值班列表
# @type OnCallFormIDs: Array
attr_accessor :Module, :PageNumber, :PageSize, :Order, :OwnerUid, :Name, :ReceiverType, :UserIds, :GroupIds, :NoticeIds, :Tags, :OnCallFormIDs
def initialize(_module=nil, pagenumber=nil, pagesize=nil, order=nil, owneruid=nil, name=nil, receivertype=nil, userids=nil, groupids=nil, noticeids=nil, tags=nil, oncallformids=nil)
@Module = _module
@PageNumber = pagenumber
@PageSize = pagesize
@Order = order
@OwnerUid = owneruid
@Name = name
@ReceiverType = receivertype
@UserIds = userids
@GroupIds = groupids
@NoticeIds = noticeids
@Tags = tags
@OnCallFormIDs = oncallformids
end
def deserialize(params)
@Module = params['Module']
@PageNumber = params['PageNumber']
@PageSize = params['PageSize']
@Order = params['Order']
@OwnerUid = params['OwnerUid']
@Name = params['Name']
@ReceiverType = params['ReceiverType']
@UserIds = params['UserIds']
@GroupIds = params['GroupIds']
@NoticeIds = params['NoticeIds']
unless params['Tags'].nil?
@Tags = []
params['Tags'].each do |i|
tag_tmp = Tag.new
tag_tmp.deserialize(i)
@Tags << tag_tmp
end
end
@OnCallFormIDs = params['OnCallFormIDs']
end
end
# DescribeAlarmNotices返回参数结构体
class DescribeAlarmNoticesResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 告警通知模板总数
# @type TotalCount: Integer
# @param Notices: 告警通知模板列表
# @type Notices: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Notices, :RequestId
def initialize(totalcount=nil, notices=nil, requestid=nil)
@TotalCount = totalcount
@Notices = notices
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Notices'].nil?
@Notices = []
params['Notices'].each do |i|
alarmnotice_tmp = AlarmNotice.new
alarmnotice_tmp.deserialize(i)
@Notices << alarmnotice_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeAlarmPolicies请求参数结构体
class DescribeAlarmPoliciesRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param PageNumber: 页数,从 1 开始计数,默认 1
# @type PageNumber: Integer
# @param PageSize: 每页的数量,取值1~100,默认20
# @type PageSize: Integer
# @param PolicyName: 按策略名称模糊搜索
# @type PolicyName: String
# @param MonitorTypes: 根据监控类型过滤 不选默认查所有类型 "MT_QCE"=云产品监控,当Dimension不为空时,该项为必填项
# @type MonitorTypes: Array
# @param Namespaces: 根据命名空间过滤,不同策略类型的值详见
# [策略类型列表](https://cloud.tencent.com/document/product/248/50397)当Dimension不为空时,该项为必填项
# @type Namespaces: Array
# @param Dimensions: 告警对象列表,JSON 字符串。外层数组,对应多个实例,内层为对象的维度。例如“云服务器-基础监控”可写为:
# `[ {"Dimensions": {"unInstanceId": "ins-qr8d555g"}}, {"Dimensions": {"unInstanceId": "ins-qr8d555h"}} ]`
# 具体也可以参考下方的示例 2。
# 不同云产品参数示例详见 [维度信息Dimensions列表](https://cloud.tencent.com/document/product/248/50397)
# 注意:如果NeedCorrespondence传入1,即需要返回策略与实例对应关系,请传入不多于20个告警对象维度,否则容易请求超时
# @type Dimensions: String
# @param ReceiverUids: 根据接收人搜索,可以使用“访问管理”的 [拉取子用户 ListUsers](https://cloud.tencent.com/document/product/598/34587) 接口获取用户列表 或 [查询子用户 GetUser](https://cloud.tencent.com/document/product/598/34590) 接口查询子用户详情,此处填入返回结果中的 `Uid` 字段
# @type ReceiverUids: Array
# @param ReceiverGroups: 根据接收组搜索,可以使用“访问管理”的 [查询用户组列表 ListGroups](https://cloud.tencent.com/document/product/598/34589) 接口获取用户组列表 或 [列出用户关联的用户组 ListGroupsForUser](https://cloud.tencent.com/document/product/598/34588) 查询某个子用户所在的用户组列表 ,此处填入返回结果中的 `GroupId ` 字段
# @type ReceiverGroups: Array
# @param PolicyType: 根据默认策略筛选 不传展示全部策略 DEFAULT=展示默认策略 NOT_DEFAULT=展示非默认策略
# @type PolicyType: Array
# @param Field: 排序字段,例如按照最后修改时间排序,Field: "UpdateTime"
# @type Field: String
# @param Order: 排序顺序:升序:ASC 降序:DESC
# @type Order: String
# @param ProjectIds: 策略所属项目的id数组,可在此页面查看
# [项目管理](https://console.cloud.tencent.com/project)
# @type ProjectIds: Array
# @param NoticeIds: 通知模板的id列表,可查询通知模板列表获取。
# 可使用 [查询通知模板列表](https://cloud.tencent.com/document/product/248/51280) 接口查询。
# @type NoticeIds: Array
# @param RuleTypes: 根据触发条件筛选 不传展示全部策略 STATIC=展示静态阈值策略 DYNAMIC=展示动态阈值策略
# @type RuleTypes: Array
# @param Enable: 告警启停筛选,[1]:启用 [0]:停止,全部[0, 1]
# @type Enable: Array
# @param NotBindingNoticeRule: 传 1 查询未配置通知规则的告警策略;不传或传其他数值,查询所有策略。
# @type NotBindingNoticeRule: Integer
# @param InstanceGroupId: 实例分组id
# @type InstanceGroupId: Integer
# @param NeedCorrespondence: 是否需要策略与入参过滤维度参数的对应关系,1:是 0:否,默认为0
# @type NeedCorrespondence: Integer
# @param TriggerTasks: 按照触发任务(例如弹性伸缩)过滤策略。最多10个
# @type TriggerTasks: Array
# @param OneClickPolicyType: 根据一键告警策略筛选 不传展示全部策略 ONECLICK=展示一键告警策略 NOT_ONECLICK=展示非一键告警策略
# @type OneClickPolicyType: Array
# @param NotBindAll: 返回结果过滤掉绑定全部对象的策略,1代表需要过滤,0则无需过滤
# @type NotBindAll: Integer
# @param NotInstanceGroup: 返回结果过滤掉关联实例为实例分组的策略,1代表需要过滤,0则无需过滤
# @type NotInstanceGroup: Integer
# @param Tags: 策略根据标签过滤
# @type Tags: Array
# @param PromInsId: prom实例id,自定义指标策略时会用到
# @type PromInsId: String
# @param ReceiverOnCallFormIDs: 根据排班表搜索
# @type ReceiverOnCallFormIDs: Array
attr_accessor :Module, :PageNumber, :PageSize, :PolicyName, :MonitorTypes, :Namespaces, :Dimensions, :ReceiverUids, :ReceiverGroups, :PolicyType, :Field, :Order, :ProjectIds, :NoticeIds, :RuleTypes, :Enable, :NotBindingNoticeRule, :InstanceGroupId, :NeedCorrespondence, :TriggerTasks, :OneClickPolicyType, :NotBindAll, :NotInstanceGroup, :Tags, :PromInsId, :ReceiverOnCallFormIDs
def initialize(_module=nil, pagenumber=nil, pagesize=nil, policyname=nil, monitortypes=nil, namespaces=nil, dimensions=nil, receiveruids=nil, receivergroups=nil, policytype=nil, field=nil, order=nil, projectids=nil, noticeids=nil, ruletypes=nil, enable=nil, notbindingnoticerule=nil, instancegroupid=nil, needcorrespondence=nil, triggertasks=nil, oneclickpolicytype=nil, notbindall=nil, notinstancegroup=nil, tags=nil, prominsid=nil, receiveroncallformids=nil)
@Module = _module
@PageNumber = pagenumber
@PageSize = pagesize
@PolicyName = policyname
@MonitorTypes = monitortypes
@Namespaces = namespaces
@Dimensions = dimensions
@ReceiverUids = receiveruids
@ReceiverGroups = receivergroups
@PolicyType = policytype
@Field = field
@Order = order
@ProjectIds = projectids
@NoticeIds = noticeids
@RuleTypes = ruletypes
@Enable = enable
@NotBindingNoticeRule = notbindingnoticerule
@InstanceGroupId = instancegroupid
@NeedCorrespondence = needcorrespondence
@TriggerTasks = triggertasks
@OneClickPolicyType = oneclickpolicytype
@NotBindAll = notbindall
@NotInstanceGroup = notinstancegroup
@Tags = tags
@PromInsId = prominsid
@ReceiverOnCallFormIDs = receiveroncallformids
end
def deserialize(params)
@Module = params['Module']
@PageNumber = params['PageNumber']
@PageSize = params['PageSize']
@PolicyName = params['PolicyName']
@MonitorTypes = params['MonitorTypes']
@Namespaces = params['Namespaces']
@Dimensions = params['Dimensions']
@ReceiverUids = params['ReceiverUids']
@ReceiverGroups = params['ReceiverGroups']
@PolicyType = params['PolicyType']
@Field = params['Field']
@Order = params['Order']
@ProjectIds = params['ProjectIds']
@NoticeIds = params['NoticeIds']
@RuleTypes = params['RuleTypes']
@Enable = params['Enable']
@NotBindingNoticeRule = params['NotBindingNoticeRule']
@InstanceGroupId = params['InstanceGroupId']
@NeedCorrespondence = params['NeedCorrespondence']
unless params['TriggerTasks'].nil?
@TriggerTasks = []
params['TriggerTasks'].each do |i|
alarmpolicytriggertask_tmp = AlarmPolicyTriggerTask.new
alarmpolicytriggertask_tmp.deserialize(i)
@TriggerTasks << alarmpolicytriggertask_tmp
end
end
@OneClickPolicyType = params['OneClickPolicyType']
@NotBindAll = params['NotBindAll']
@NotInstanceGroup = params['NotInstanceGroup']
unless params['Tags'].nil?
@Tags = []
params['Tags'].each do |i|
tag_tmp = Tag.new
tag_tmp.deserialize(i)
@Tags << tag_tmp
end
end
@PromInsId = params['PromInsId']
@ReceiverOnCallFormIDs = params['ReceiverOnCallFormIDs']
end
end
# DescribeAlarmPolicies返回参数结构体
class DescribeAlarmPoliciesResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 策略总数
# @type TotalCount: Integer
# @param Policies: 策略数组
# @type Policies: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Policies, :RequestId
def initialize(totalcount=nil, policies=nil, requestid=nil)
@TotalCount = totalcount
@Policies = policies
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Policies'].nil?
@Policies = []
params['Policies'].each do |i|
alarmpolicy_tmp = AlarmPolicy.new
alarmpolicy_tmp.deserialize(i)
@Policies << alarmpolicy_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeAlarmPolicy请求参数结构体
class DescribeAlarmPolicyRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param PolicyId: 告警策略ID
# @type PolicyId: String
attr_accessor :Module, :PolicyId
def initialize(_module=nil, policyid=nil)
@Module = _module
@PolicyId = policyid
end
def deserialize(params)
@Module = params['Module']
@PolicyId = params['PolicyId']
end
end
# DescribeAlarmPolicy返回参数结构体
class DescribeAlarmPolicyResponse < TencentCloud::Common::AbstractModel
# @param Policy: 策略详情
# @type Policy: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicy`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Policy, :RequestId
def initialize(policy=nil, requestid=nil)
@Policy = policy
@RequestId = requestid
end
def deserialize(params)
unless params['Policy'].nil?
@Policy = AlarmPolicy.new
@Policy.deserialize(params['Policy'])
end
@RequestId = params['RequestId']
end
end
# DescribeAlarmSmsQuota接口的配额信息
class DescribeAlarmSmsQuotaQuota < TencentCloud::Common::AbstractModel
# @param Type: 配额类型
# @type Type: String
# @param Name: 配额名称
# @type Name: String
# @param FreeLeft: 免费配额剩余量
# @type FreeLeft: Integer
# @param PurchaseLeft: 付费配额剩余量
# @type PurchaseLeft: Integer
# @param Used: 已使用量
# @type Used: Integer
attr_accessor :Type, :Name, :FreeLeft, :PurchaseLeft, :Used
def initialize(type=nil, name=nil, freeleft=nil, purchaseleft=nil, used=nil)
@Type = type
@Name = name
@FreeLeft = freeleft
@PurchaseLeft = purchaseleft
@Used = used
end
def deserialize(params)
@Type = params['Type']
@Name = params['Name']
@FreeLeft = params['FreeLeft']
@PurchaseLeft = params['PurchaseLeft']
@Used = params['Used']
end
end
# DescribeAlarmSmsQuota请求参数结构体
class DescribeAlarmSmsQuotaRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
attr_accessor :Module
def initialize(_module=nil)
@Module = _module
end
def deserialize(params)
@Module = params['Module']
end
end
# DescribeAlarmSmsQuota返回参数结构体
class DescribeAlarmSmsQuotaResponse < TencentCloud::Common::AbstractModel
# @param Total: 配额总数
# @type Total: Integer
# @param Used: 总使用量
# @type Used: Integer
# @param QuotaList: 短信配额信息列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type QuotaList: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Total, :Used, :QuotaList, :RequestId
def initialize(total=nil, used=nil, quotalist=nil, requestid=nil)
@Total = total
@Used = used
@QuotaList = quotalist
@RequestId = requestid
end
def deserialize(params)
@Total = params['Total']
@Used = params['Used']
unless params['QuotaList'].nil?
@QuotaList = []
params['QuotaList'].each do |i|
describealarmsmsquotaquota_tmp = DescribeAlarmSmsQuotaQuota.new
describealarmsmsquotaquota_tmp.deserialize(i)
@QuotaList << describealarmsmsquotaquota_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeAlertRules请求参数结构体
class DescribeAlertRulesRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param Limit: 返回数量,默认为 20,最大值为 100
# @type Limit: Integer
# @param Offset: 偏移量,默认为 0
# @type Offset: Integer
# @param RuleId: 规则 ID
# @type RuleId: String
# @param RuleState: 规则状态码,取值如下:
# 2=RuleEnabled
# 3=RuleDisabled
# @type RuleState: Integer
# @param RuleName: 规则名称
# @type RuleName: String
# @param Type: 报警策略模板分类
# @type Type: String
attr_accessor :InstanceId, :Limit, :Offset, :RuleId, :RuleState, :RuleName, :Type
def initialize(instanceid=nil, limit=nil, offset=nil, ruleid=nil, rulestate=nil, rulename=nil, type=nil)
@InstanceId = instanceid
@Limit = limit
@Offset = offset
@RuleId = ruleid
@RuleState = rulestate
@RuleName = rulename
@Type = type
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Limit = params['Limit']
@Offset = params['Offset']
@RuleId = params['RuleId']
@RuleState = params['RuleState']
@RuleName = params['RuleName']
@Type = params['Type']
end
end
# DescribeAlertRules返回参数结构体
class DescribeAlertRulesResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 报警规则数量
# @type TotalCount: Integer
# @param AlertRuleSet: 报警规则详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlertRuleSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :AlertRuleSet, :RequestId
def initialize(totalcount=nil, alertruleset=nil, requestid=nil)
@TotalCount = totalcount
@AlertRuleSet = alertruleset
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['AlertRuleSet'].nil?
@AlertRuleSet = []
params['AlertRuleSet'].each do |i|
prometheusruleset_tmp = PrometheusRuleSet.new
prometheusruleset_tmp.deserialize(i)
@AlertRuleSet << prometheusruleset_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeAllNamespaces请求参数结构体
class DescribeAllNamespacesRequest < TencentCloud::Common::AbstractModel
# @param SceneType: 根据使用场景过滤 目前仅有"ST_ALARM"=告警类型
# @type SceneType: String
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param MonitorTypes: 根据监控类型过滤 不填默认查所有类型 "MT_QCE"=云产品监控
# @type MonitorTypes: Array
# @param Ids: 根据namespace的Id过滤 不填默认查询所有
# @type Ids: Array
attr_accessor :SceneType, :Module, :MonitorTypes, :Ids
def initialize(scenetype=nil, _module=nil, monitortypes=nil, ids=nil)
@SceneType = scenetype
@Module = _module
@MonitorTypes = monitortypes
@Ids = ids
end
def deserialize(params)
@SceneType = params['SceneType']
@Module = params['Module']
@MonitorTypes = params['MonitorTypes']
@Ids = params['Ids']
end
end
# DescribeAllNamespaces返回参数结构体
class DescribeAllNamespacesResponse < TencentCloud::Common::AbstractModel
# @param QceNamespaces: 云产品的告警策略类型,已废弃
# @type QceNamespaces: :class:`Tencentcloud::Monitor.v20180724.models.CommonNamespace`
# @param CustomNamespaces: 其他告警策略类型,已废弃
# @type CustomNamespaces: :class:`Tencentcloud::Monitor.v20180724.models.CommonNamespace`
# @param QceNamespacesNew: 云产品的告警策略类型
# @type QceNamespacesNew: Array
# @param CustomNamespacesNew: 其他告警策略类型,暂不支持
# @type CustomNamespacesNew: Array
# @param CommonNamespaces: 通用告警策略类型(包括:应用性能监控,前端性能监控,云拨测)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CommonNamespaces: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :QceNamespaces, :CustomNamespaces, :QceNamespacesNew, :CustomNamespacesNew, :CommonNamespaces, :RequestId
def initialize(qcenamespaces=nil, customnamespaces=nil, qcenamespacesnew=nil, customnamespacesnew=nil, commonnamespaces=nil, requestid=nil)
@QceNamespaces = qcenamespaces
@CustomNamespaces = customnamespaces
@QceNamespacesNew = qcenamespacesnew
@CustomNamespacesNew = customnamespacesnew
@CommonNamespaces = commonnamespaces
@RequestId = requestid
end
def deserialize(params)
unless params['QceNamespaces'].nil?
@QceNamespaces = CommonNamespace.new
@QceNamespaces.deserialize(params['QceNamespaces'])
end
unless params['CustomNamespaces'].nil?
@CustomNamespaces = CommonNamespace.new
@CustomNamespaces.deserialize(params['CustomNamespaces'])
end
unless params['QceNamespacesNew'].nil?
@QceNamespacesNew = []
params['QceNamespacesNew'].each do |i|
commonnamespace_tmp = CommonNamespace.new
commonnamespace_tmp.deserialize(i)
@QceNamespacesNew << commonnamespace_tmp
end
end
unless params['CustomNamespacesNew'].nil?
@CustomNamespacesNew = []
params['CustomNamespacesNew'].each do |i|
commonnamespace_tmp = CommonNamespace.new
commonnamespace_tmp.deserialize(i)
@CustomNamespacesNew << commonnamespace_tmp
end
end
unless params['CommonNamespaces'].nil?
@CommonNamespaces = []
params['CommonNamespaces'].each do |i|
commonnamespacenew_tmp = CommonNamespaceNew.new
commonnamespacenew_tmp.deserialize(i)
@CommonNamespaces << commonnamespacenew_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeBaseMetrics请求参数结构体
class DescribeBaseMetricsRequest < TencentCloud::Common::AbstractModel
# @param Namespace: 业务命名空间,各个云产品的业务命名空间不同。如需获取业务命名空间,请前往各产品监控指标文档,例如云服务器的命名空间,可参见 [云服务器监控指标](https://cloud.tencent.com/document/product/248/6843)
# @type Namespace: String
# @param MetricName: 指标名,各个云产品的指标名不同。如需获取指标名,请前往各产品监控指标文档,例如云服务器的指标名,可参见 [云服务器监控指标](https://cloud.tencent.com/document/product/248/6843)
# @type MetricName: String
# @param Dimensions: 可选参数,按照维度过滤
# @type Dimensions: Array
attr_accessor :Namespace, :MetricName, :Dimensions
def initialize(namespace=nil, metricname=nil, dimensions=nil)
@Namespace = namespace
@MetricName = metricname
@Dimensions = dimensions
end
def deserialize(params)
@Namespace = params['Namespace']
@MetricName = params['MetricName']
@Dimensions = params['Dimensions']
end
end
# DescribeBaseMetrics返回参数结构体
class DescribeBaseMetricsResponse < TencentCloud::Common::AbstractModel
# @param MetricSet: 查询得到的指标描述列表
# @type MetricSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :MetricSet, :RequestId
def initialize(metricset=nil, requestid=nil)
@MetricSet = metricset
@RequestId = requestid
end
def deserialize(params)
unless params['MetricSet'].nil?
@MetricSet = []
params['MetricSet'].each do |i|
metricset_tmp = MetricSet.new
metricset_tmp.deserialize(i)
@MetricSet << metricset_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeBasicAlarmList返回的Alarms
class DescribeBasicAlarmListAlarms < TencentCloud::Common::AbstractModel
# @param Id: 该条告警的ID
# @type Id: Integer
# @param ProjectId: 项目ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProjectId: Integer
# @param ProjectName: 项目名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProjectName: String
# @param Status: 告警状态ID,0表示未恢复;1表示已恢复;2,3,5表示数据不足;4表示已失效
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Status: Integer
# @param AlarmStatus: 告警状态,ALARM表示未恢复;OK表示已恢复;NO_DATA表示数据不足;NO_CONF表示已失效
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlarmStatus: String
# @param GroupId: 策略组ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GroupId: Integer
# @param GroupName: 策略组名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GroupName: String
# @param FirstOccurTime: 发生时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FirstOccurTime: String
# @param Duration: 持续时间,单位s
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Duration: Integer
# @param LastOccurTime: 结束时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LastOccurTime: String
# @param Content: 告警内容
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Content: String
# @param ObjName: 告警对象
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ObjName: String
# @param ObjId: 告警对象ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ObjId: String
# @param ViewName: 策略类型
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ViewName: String
# @param Vpc: VPC,只有CVM有
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Vpc: String
# @param MetricId: 指标ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MetricId: Integer
# @param MetricName: 指标名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MetricName: String
# @param AlarmType: 告警类型,0表示指标告警,2表示产品事件告警,3表示平台事件告警
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlarmType: Integer
# @param Region: 地域
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Region: String
# @param Dimensions: 告警对象维度信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Dimensions: String
# @param NotifyWay: 通知方式
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NotifyWay: Array
# @param InstanceGroup: 所属实例组信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceGroup: Array
attr_accessor :Id, :ProjectId, :ProjectName, :Status, :AlarmStatus, :GroupId, :GroupName, :FirstOccurTime, :Duration, :LastOccurTime, :Content, :ObjName, :ObjId, :ViewName, :Vpc, :MetricId, :MetricName, :AlarmType, :Region, :Dimensions, :NotifyWay, :InstanceGroup
def initialize(id=nil, projectid=nil, projectname=nil, status=nil, alarmstatus=nil, groupid=nil, groupname=nil, firstoccurtime=nil, duration=nil, lastoccurtime=nil, content=nil, objname=nil, objid=nil, viewname=nil, vpc=nil, metricid=nil, metricname=nil, alarmtype=nil, region=nil, dimensions=nil, notifyway=nil, instancegroup=nil)
@Id = id
@ProjectId = projectid
@ProjectName = projectname
@Status = status
@AlarmStatus = alarmstatus
@GroupId = groupid
@GroupName = groupname
@FirstOccurTime = firstoccurtime
@Duration = duration
@LastOccurTime = lastoccurtime
@Content = content
@ObjName = objname
@ObjId = objid
@ViewName = viewname
@Vpc = vpc
@MetricId = metricid
@MetricName = metricname
@AlarmType = alarmtype
@Region = region
@Dimensions = dimensions
@NotifyWay = notifyway
@InstanceGroup = instancegroup
end
def deserialize(params)
@Id = params['Id']
@ProjectId = params['ProjectId']
@ProjectName = params['ProjectName']
@Status = params['Status']
@AlarmStatus = params['AlarmStatus']
@GroupId = params['GroupId']
@GroupName = params['GroupName']
@FirstOccurTime = params['FirstOccurTime']
@Duration = params['Duration']
@LastOccurTime = params['LastOccurTime']
@Content = params['Content']
@ObjName = params['ObjName']
@ObjId = params['ObjId']
@ViewName = params['ViewName']
@Vpc = params['Vpc']
@MetricId = params['MetricId']
@MetricName = params['MetricName']
@AlarmType = params['AlarmType']
@Region = params['Region']
@Dimensions = params['Dimensions']
@NotifyWay = params['NotifyWay']
unless params['InstanceGroup'].nil?
@InstanceGroup = []
params['InstanceGroup'].each do |i|
instancegroup_tmp = InstanceGroup.new
instancegroup_tmp.deserialize(i)
@InstanceGroup << instancegroup_tmp
end
end
end
end
# DescribeBasicAlarmList请求参数结构体
class DescribeBasicAlarmListRequest < TencentCloud::Common::AbstractModel
# @param Module: 接口模块名,当前取值monitor
# @type Module: String
# @param StartTime: 起始时间,默认一天前的时间戳
# @type StartTime: Integer
# @param EndTime: 结束时间,默认当前时间戳
# @type EndTime: Integer
# @param Limit: 分页参数,每页返回的数量,取值1~100,默认20
# @type Limit: Integer
# @param Offset: 分页参数,页偏移量,从0开始计数,默认0
# @type Offset: Integer
# @param OccurTimeOrder: 根据发生时间排序,取值ASC或DESC
# @type OccurTimeOrder: String
# @param ProjectIds: 根据项目ID过滤
# @type ProjectIds: Array
# @param ViewNames: 根据策略类型过滤
# @type ViewNames: Array
# @param AlarmStatus: 根据告警状态过滤
# @type AlarmStatus: Array
# @param ObjLike: 根据告警对象过滤
# @type ObjLike: String
# @param InstanceGroupIds: 根据实例组ID过滤
# @type InstanceGroupIds: Array
# @param MetricNames: 根据指标名过滤
# @type MetricNames: Array
attr_accessor :Module, :StartTime, :EndTime, :Limit, :Offset, :OccurTimeOrder, :ProjectIds, :ViewNames, :AlarmStatus, :ObjLike, :InstanceGroupIds, :MetricNames
def initialize(_module=nil, starttime=nil, endtime=nil, limit=nil, offset=nil, occurtimeorder=nil, projectids=nil, viewnames=nil, alarmstatus=nil, objlike=nil, instancegroupids=nil, metricnames=nil)
@Module = _module
@StartTime = starttime
@EndTime = endtime
@Limit = limit
@Offset = offset
@OccurTimeOrder = occurtimeorder
@ProjectIds = projectids
@ViewNames = viewnames
@AlarmStatus = alarmstatus
@ObjLike = objlike
@InstanceGroupIds = instancegroupids
@MetricNames = metricnames
end
def deserialize(params)
@Module = params['Module']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@Limit = params['Limit']
@Offset = params['Offset']
@OccurTimeOrder = params['OccurTimeOrder']
@ProjectIds = params['ProjectIds']
@ViewNames = params['ViewNames']
@AlarmStatus = params['AlarmStatus']
@ObjLike = params['ObjLike']
@InstanceGroupIds = params['InstanceGroupIds']
@MetricNames = params['MetricNames']
end
end
# DescribeBasicAlarmList返回参数结构体
class DescribeBasicAlarmListResponse < TencentCloud::Common::AbstractModel
# @param Alarms: 告警列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Alarms: Array
# @param Total: 总数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Total: Integer
# @param Warning: 备注信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Warning: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Alarms, :Total, :Warning, :RequestId
def initialize(alarms=nil, total=nil, warning=nil, requestid=nil)
@Alarms = alarms
@Total = total
@Warning = warning
@RequestId = requestid
end
def deserialize(params)
unless params['Alarms'].nil?
@Alarms = []
params['Alarms'].each do |i|
describebasicalarmlistalarms_tmp = DescribeBasicAlarmListAlarms.new
describebasicalarmlistalarms_tmp.deserialize(i)
@Alarms << describebasicalarmlistalarms_tmp
end
end
@Total = params['Total']
@Warning = params['Warning']
@RequestId = params['RequestId']
end
end
# DescribeBindingPolicyObjectList接口的Dimension
class DescribeBindingPolicyObjectListDimension < TencentCloud::Common::AbstractModel
# @param RegionId: 地域id
# @type RegionId: Integer
# @param Region: 地域简称
# @type Region: String
# @param Dimensions: 维度组合json字符串
# @type Dimensions: String
# @param EventDimensions: 事件维度组合json字符串
# @type EventDimensions: String
attr_accessor :RegionId, :Region, :Dimensions, :EventDimensions
def initialize(regionid=nil, region=nil, dimensions=nil, eventdimensions=nil)
@RegionId = regionid
@Region = region
@Dimensions = dimensions
@EventDimensions = eventdimensions
end
def deserialize(params)
@RegionId = params['RegionId']
@Region = params['Region']
@Dimensions = params['Dimensions']
@EventDimensions = params['EventDimensions']
end
end
# 查询策略绑定对象列表接口返回的对象实例信息
class DescribeBindingPolicyObjectListInstance < TencentCloud::Common::AbstractModel
# @param UniqueId: 对象唯一id
# @type UniqueId: String
# @param Dimensions: 表示对象实例的维度集合,jsonObj字符串
# @type Dimensions: String
# @param IsShielded: 对象是否被屏蔽,0表示未屏蔽,1表示被屏蔽
# @type IsShielded: Integer
# @param Region: 对象所在的地域
# @type Region: String
attr_accessor :UniqueId, :Dimensions, :IsShielded, :Region
def initialize(uniqueid=nil, dimensions=nil, isshielded=nil, region=nil)
@UniqueId = uniqueid
@Dimensions = dimensions
@IsShielded = isshielded
@Region = region
end
def deserialize(params)
@UniqueId = params['UniqueId']
@Dimensions = params['Dimensions']
@IsShielded = params['IsShielded']
@Region = params['Region']
end
end
# DescribeBindingPolicyObjectList返回的是实例分组信息
class DescribeBindingPolicyObjectListInstanceGroup < TencentCloud::Common::AbstractModel
# @param InstanceGroupId: 实例分组id
# @type InstanceGroupId: Integer
# @param ViewName: 告警策略类型名称
# @type ViewName: String
# @param LastEditUin: 最后编辑uin
# @type LastEditUin: String
# @param GroupName: 实例分组名称
# @type GroupName: String
# @param InstanceSum: 实例数量
# @type InstanceSum: Integer
# @param UpdateTime: 更新时间
# @type UpdateTime: Integer
# @param InsertTime: 创建时间
# @type InsertTime: Integer
# @param Regions: 实例所在的地域集合
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Regions: Array
attr_accessor :InstanceGroupId, :ViewName, :LastEditUin, :GroupName, :InstanceSum, :UpdateTime, :InsertTime, :Regions
def initialize(instancegroupid=nil, viewname=nil, lastedituin=nil, groupname=nil, instancesum=nil, updatetime=nil, inserttime=nil, regions=nil)
@InstanceGroupId = instancegroupid
@ViewName = viewname
@LastEditUin = lastedituin
@GroupName = groupname
@InstanceSum = instancesum
@UpdateTime = updatetime
@InsertTime = inserttime
@Regions = regions
end
def deserialize(params)
@InstanceGroupId = params['InstanceGroupId']
@ViewName = params['ViewName']
@LastEditUin = params['LastEditUin']
@GroupName = params['GroupName']
@InstanceSum = params['InstanceSum']
@UpdateTime = params['UpdateTime']
@InsertTime = params['InsertTime']
@Regions = params['Regions']
end
end
# DescribeBindingPolicyObjectList请求参数结构体
class DescribeBindingPolicyObjectListRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param GroupId: 策略组id,如果有形如 policy-xxxx 的 id,请填到 PolicyId 字段中,本字段填 0
# @type GroupId: Integer
# @param PolicyId: 告警策略id,形如 policy-xxxx,如果填入,则GroupId可以填0
# @type PolicyId: String
# @param Limit: 每次返回的数量,取值1~100,默认20
# @type Limit: Integer
# @param Offset: 偏移量,从0开始计数,默认0。举例来说,参数 Offset=0&Limit=20 返回第 0 到 19 项,Offset=20&Limit=20 返回第 20 到 39 项,以此类推
# @type Offset: Integer
# @param Dimensions: 筛选对象的维度信息
# @type Dimensions: Array
attr_accessor :Module, :GroupId, :PolicyId, :Limit, :Offset, :Dimensions
def initialize(_module=nil, groupid=nil, policyid=nil, limit=nil, offset=nil, dimensions=nil)
@Module = _module
@GroupId = groupid
@PolicyId = policyid
@Limit = limit
@Offset = offset
@Dimensions = dimensions
end
def deserialize(params)
@Module = params['Module']
@GroupId = params['GroupId']
@PolicyId = params['PolicyId']
@Limit = params['Limit']
@Offset = params['Offset']
unless params['Dimensions'].nil?
@Dimensions = []
params['Dimensions'].each do |i|
describebindingpolicyobjectlistdimension_tmp = DescribeBindingPolicyObjectListDimension.new
describebindingpolicyobjectlistdimension_tmp.deserialize(i)
@Dimensions << describebindingpolicyobjectlistdimension_tmp
end
end
end
end
# DescribeBindingPolicyObjectList返回参数结构体
class DescribeBindingPolicyObjectListResponse < TencentCloud::Common::AbstractModel
# @param List: 绑定的对象实例列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type List: Array
# @param Total: 绑定的对象实例总数
# @type Total: Integer
# @param NoShieldedSum: 未屏蔽的对象实例数
# @type NoShieldedSum: Integer
# @param InstanceGroup: 绑定的实例分组信息,没有绑定实例分组则为空
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceGroup: :class:`Tencentcloud::Monitor.v20180724.models.DescribeBindingPolicyObjectListInstanceGroup`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :List, :Total, :NoShieldedSum, :InstanceGroup, :RequestId
def initialize(list=nil, total=nil, noshieldedsum=nil, instancegroup=nil, requestid=nil)
@List = list
@Total = total
@NoShieldedSum = noshieldedsum
@InstanceGroup = instancegroup
@RequestId = requestid
end
def deserialize(params)
unless params['List'].nil?
@List = []
params['List'].each do |i|
describebindingpolicyobjectlistinstance_tmp = DescribeBindingPolicyObjectListInstance.new
describebindingpolicyobjectlistinstance_tmp.deserialize(i)
@List << describebindingpolicyobjectlistinstance_tmp
end
end
@Total = params['Total']
@NoShieldedSum = params['NoShieldedSum']
unless params['InstanceGroup'].nil?
@InstanceGroup = DescribeBindingPolicyObjectListInstanceGroup.new
@InstanceGroup.deserialize(params['InstanceGroup'])
end
@RequestId = params['RequestId']
end
end
# DescribeClusterAgentCreatingProgress请求参数结构体
class DescribeClusterAgentCreatingProgressRequest < TencentCloud::Common::AbstractModel
def initialize()
end
def deserialize(params)
end
end
# DescribeClusterAgentCreatingProgress返回参数结构体
class DescribeClusterAgentCreatingProgressResponse < 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
# DescribeConditionsTemplateList请求参数结构体
class DescribeConditionsTemplateListRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param ViewName: 视图名,由 [DescribeAllNamespaces](https://cloud.tencent.com/document/product/248/48683) 获得。对于云产品监控,取接口出参的 QceNamespacesNew.N.Id,例如 cvm_device
# @type ViewName: String
# @param GroupName: 根据触发条件模板名称过滤查询
# @type GroupName: String
# @param GroupID: 根据触发条件模板ID过滤查询
# @type GroupID: String
# @param Limit: 分页参数,每页返回的数量,取值1~100,默认20
# @type Limit: Integer
# @param Offset: 分页参数,页偏移量,从0开始计数,默认0
# @type Offset: Integer
# @param UpdateTimeOrder: 指定按更新时间的排序方式,asc=升序, desc=降序
# @type UpdateTimeOrder: String
# @param PolicyCountOrder: 指定按绑定策略数目的排序方式,asc=升序, desc=降序
# @type PolicyCountOrder: String
attr_accessor :Module, :ViewName, :GroupName, :GroupID, :Limit, :Offset, :UpdateTimeOrder, :PolicyCountOrder
def initialize(_module=nil, viewname=nil, groupname=nil, groupid=nil, limit=nil, offset=nil, updatetimeorder=nil, policycountorder=nil)
@Module = _module
@ViewName = viewname
@GroupName = groupname
@GroupID = groupid
@Limit = limit
@Offset = offset
@UpdateTimeOrder = updatetimeorder
@PolicyCountOrder = policycountorder
end
def deserialize(params)
@Module = params['Module']
@ViewName = params['ViewName']
@GroupName = params['GroupName']
@GroupID = params['GroupID']
@Limit = params['Limit']
@Offset = params['Offset']
@UpdateTimeOrder = params['UpdateTimeOrder']
@PolicyCountOrder = params['PolicyCountOrder']
end
end
# DescribeConditionsTemplateList返回参数结构体
class DescribeConditionsTemplateListResponse < TencentCloud::Common::AbstractModel
# @param Total: 模板总数
# @type Total: Integer
# @param TemplateGroupList: 模板列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TemplateGroupList: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Total, :TemplateGroupList, :RequestId
def initialize(total=nil, templategrouplist=nil, requestid=nil)
@Total = total
@TemplateGroupList = templategrouplist
@RequestId = requestid
end
def deserialize(params)
@Total = params['Total']
unless params['TemplateGroupList'].nil?
@TemplateGroupList = []
params['TemplateGroupList'].each do |i|
templategroup_tmp = TemplateGroup.new
templategroup_tmp.deserialize(i)
@TemplateGroupList << templategroup_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeDNSConfig请求参数结构体
class DescribeDNSConfigRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
attr_accessor :InstanceId
def initialize(instanceid=nil)
@InstanceId = instanceid
end
def deserialize(params)
@InstanceId = params['InstanceId']
end
end
# DescribeDNSConfig返回参数结构体
class DescribeDNSConfigResponse < TencentCloud::Common::AbstractModel
# @param NameServers: DNS 服务器数组
# @type NameServers: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :NameServers, :RequestId
def initialize(nameservers=nil, requestid=nil)
@NameServers = nameservers
@RequestId = requestid
end
def deserialize(params)
@NameServers = params['NameServers']
@RequestId = params['RequestId']
end
end
# DescribeExporterIntegrations请求参数结构体
class DescribeExporterIntegrationsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param KubeType: Kubernetes 集群类型,可不填。取值如下:
# 1= 容器集群(TKE)
# 2=弹性集群(EKS)
# 3= Prometheus管理的弹性集群(MEKS)
# @type KubeType: Integer
# @param ClusterId: 集群 ID,可不填
# @type ClusterId: String
# @param Kind: 类型(不填返回全部集成。可通过 DescribePrometheusIntegrations 接口获取,取每一项中的 ExporterType 字段)
# @type Kind: String
# @param Name: 名字
# @type Name: String
attr_accessor :InstanceId, :KubeType, :ClusterId, :Kind, :Name
def initialize(instanceid=nil, kubetype=nil, clusterid=nil, kind=nil, name=nil)
@InstanceId = instanceid
@KubeType = kubetype
@ClusterId = clusterid
@Kind = kind
@Name = name
end
def deserialize(params)
@InstanceId = params['InstanceId']
@KubeType = params['KubeType']
@ClusterId = params['ClusterId']
@Kind = params['Kind']
@Name = params['Name']
end
end
# DescribeExporterIntegrations返回参数结构体
class DescribeExporterIntegrationsResponse < TencentCloud::Common::AbstractModel
# @param IntegrationSet: 集成配置列表
# @type IntegrationSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :IntegrationSet, :RequestId
def initialize(integrationset=nil, requestid=nil)
@IntegrationSet = integrationset
@RequestId = requestid
end
def deserialize(params)
unless params['IntegrationSet'].nil?
@IntegrationSet = []
params['IntegrationSet'].each do |i|
integrationconfiguration_tmp = IntegrationConfiguration.new
integrationconfiguration_tmp.deserialize(i)
@IntegrationSet << integrationconfiguration_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeGrafanaChannels请求参数结构体
class DescribeGrafanaChannelsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-12345678
# @type InstanceId: String
# @param Offset: 偏移量
# @type Offset: Integer
# @param Limit: 查询数量
# @type Limit: Integer
# @param ChannelName: 告警通道名称,例如:test
# @type ChannelName: String
# @param ChannelIds: 告警通道 ID,例如:nchannel-abcd1234
# @type ChannelIds: Array
# @param ChannelState: 告警通道状态(不用填写,目前只有可用和删除状态,默认只能查询可用的告警通道)
# @type ChannelState: Integer
attr_accessor :InstanceId, :Offset, :Limit, :ChannelName, :ChannelIds, :ChannelState
def initialize(instanceid=nil, offset=nil, limit=nil, channelname=nil, channelids=nil, channelstate=nil)
@InstanceId = instanceid
@Offset = offset
@Limit = limit
@ChannelName = channelname
@ChannelIds = channelids
@ChannelState = channelstate
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Offset = params['Offset']
@Limit = params['Limit']
@ChannelName = params['ChannelName']
@ChannelIds = params['ChannelIds']
@ChannelState = params['ChannelState']
end
end
# DescribeGrafanaChannels返回参数结构体
class DescribeGrafanaChannelsResponse < TencentCloud::Common::AbstractModel
# @param NotificationChannelSet: 告警通道数组
# @type NotificationChannelSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :NotificationChannelSet, :RequestId
def initialize(notificationchannelset=nil, requestid=nil)
@NotificationChannelSet = notificationchannelset
@RequestId = requestid
end
def deserialize(params)
unless params['NotificationChannelSet'].nil?
@NotificationChannelSet = []
params['NotificationChannelSet'].each do |i|
grafanachannel_tmp = GrafanaChannel.new
grafanachannel_tmp.deserialize(i)
@NotificationChannelSet << grafanachannel_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeGrafanaConfig请求参数结构体
class DescribeGrafanaConfigRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-12345678
# @type InstanceId: String
attr_accessor :InstanceId
def initialize(instanceid=nil)
@InstanceId = instanceid
end
def deserialize(params)
@InstanceId = params['InstanceId']
end
end
# DescribeGrafanaConfig返回参数结构体
class DescribeGrafanaConfigResponse < TencentCloud::Common::AbstractModel
# @param Config: JSON 编码后的字符串
# @type Config: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Config, :RequestId
def initialize(config=nil, requestid=nil)
@Config = config
@RequestId = requestid
end
def deserialize(params)
@Config = params['Config']
@RequestId = params['RequestId']
end
end
# DescribeGrafanaEnvironments请求参数结构体
class DescribeGrafanaEnvironmentsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
attr_accessor :InstanceId
def initialize(instanceid=nil)
@InstanceId = instanceid
end
def deserialize(params)
@InstanceId = params['InstanceId']
end
end
# DescribeGrafanaEnvironments返回参数结构体
class DescribeGrafanaEnvironmentsResponse < TencentCloud::Common::AbstractModel
# @param Envs: 环境变量字符串
# @type Envs: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Envs, :RequestId
def initialize(envs=nil, requestid=nil)
@Envs = envs
@RequestId = requestid
end
def deserialize(params)
@Envs = params['Envs']
@RequestId = params['RequestId']
end
end
# DescribeGrafanaInstances请求参数结构体
class DescribeGrafanaInstancesRequest < TencentCloud::Common::AbstractModel
# @param Offset: 查询偏移量
# @type Offset: Integer
# @param Limit: 查询数量
# @type Limit: Integer
# @param InstanceIds: Grafana 实例 ID 数组
# @type InstanceIds: Array
# @param InstanceName: Grafana 实例名,支持前缀模糊搜索
# @type InstanceName: String
# @param InstanceStatus: 查询状态
# @type InstanceStatus: Array
# @param TagFilters: 标签过滤数组
# @type TagFilters: Array
attr_accessor :Offset, :Limit, :InstanceIds, :InstanceName, :InstanceStatus, :TagFilters
def initialize(offset=nil, limit=nil, instanceids=nil, instancename=nil, instancestatus=nil, tagfilters=nil)
@Offset = offset
@Limit = limit
@InstanceIds = instanceids
@InstanceName = instancename
@InstanceStatus = instancestatus
@TagFilters = tagfilters
end
def deserialize(params)
@Offset = params['Offset']
@Limit = params['Limit']
@InstanceIds = params['InstanceIds']
@InstanceName = params['InstanceName']
@InstanceStatus = params['InstanceStatus']
unless params['TagFilters'].nil?
@TagFilters = []
params['TagFilters'].each do |i|
prometheustag_tmp = PrometheusTag.new
prometheustag_tmp.deserialize(i)
@TagFilters << prometheustag_tmp
end
end
end
end
# DescribeGrafanaInstances返回参数结构体
class DescribeGrafanaInstancesResponse < TencentCloud::Common::AbstractModel
# @param InstanceSet: 已废弃,请使用 Instances
# @type InstanceSet: Array
# @param TotalCount: 符合查询条件的实例总数
# @type TotalCount: Integer
# @param Instances: 实例列表
# @type Instances: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :InstanceSet, :TotalCount, :Instances, :RequestId
def initialize(instanceset=nil, totalcount=nil, instances=nil, requestid=nil)
@InstanceSet = instanceset
@TotalCount = totalcount
@Instances = instances
@RequestId = requestid
end
def deserialize(params)
unless params['InstanceSet'].nil?
@InstanceSet = []
params['InstanceSet'].each do |i|
grafanainstanceinfo_tmp = GrafanaInstanceInfo.new
grafanainstanceinfo_tmp.deserialize(i)
@InstanceSet << grafanainstanceinfo_tmp
end
end
@TotalCount = params['TotalCount']
unless params['Instances'].nil?
@Instances = []
params['Instances'].each do |i|
grafanainstanceinfo_tmp = GrafanaInstanceInfo.new
grafanainstanceinfo_tmp.deserialize(i)
@Instances << grafanainstanceinfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeGrafanaIntegrations请求参数结构体
class DescribeGrafanaIntegrationsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param IntegrationId: 集成 ID
# @type IntegrationId: String
# @param Kind: 类型
# @type Kind: String
attr_accessor :InstanceId, :IntegrationId, :Kind
def initialize(instanceid=nil, integrationid=nil, kind=nil)
@InstanceId = instanceid
@IntegrationId = integrationid
@Kind = kind
end
def deserialize(params)
@InstanceId = params['InstanceId']
@IntegrationId = params['IntegrationId']
@Kind = params['Kind']
end
end
# DescribeGrafanaIntegrations返回参数结构体
class DescribeGrafanaIntegrationsResponse < TencentCloud::Common::AbstractModel
# @param IntegrationSet: 集成数组
# @type IntegrationSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :IntegrationSet, :RequestId
def initialize(integrationset=nil, requestid=nil)
@IntegrationSet = integrationset
@RequestId = requestid
end
def deserialize(params)
unless params['IntegrationSet'].nil?
@IntegrationSet = []
params['IntegrationSet'].each do |i|
grafanaintegrationconfig_tmp = GrafanaIntegrationConfig.new
grafanaintegrationconfig_tmp.deserialize(i)
@IntegrationSet << grafanaintegrationconfig_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeGrafanaNotificationChannels请求参数结构体
class DescribeGrafanaNotificationChannelsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-12345678
# @type InstanceId: String
# @param Offset: 偏移量
# @type Offset: Integer
# @param Limit: 查询数量
# @type Limit: Integer
# @param ChannelName: 告警通道名称,例如:test
# @type ChannelName: String
# @param ChannelIDs: 告警通道 ID,例如:nchannel-abcd1234
# @type ChannelIDs: Array
# @param ChannelState: 告警通道状态
# @type ChannelState: Integer
attr_accessor :InstanceId, :Offset, :Limit, :ChannelName, :ChannelIDs, :ChannelState
def initialize(instanceid=nil, offset=nil, limit=nil, channelname=nil, channelids=nil, channelstate=nil)
@InstanceId = instanceid
@Offset = offset
@Limit = limit
@ChannelName = channelname
@ChannelIDs = channelids
@ChannelState = channelstate
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Offset = params['Offset']
@Limit = params['Limit']
@ChannelName = params['ChannelName']
@ChannelIDs = params['ChannelIDs']
@ChannelState = params['ChannelState']
end
end
# DescribeGrafanaNotificationChannels返回参数结构体
class DescribeGrafanaNotificationChannelsResponse < TencentCloud::Common::AbstractModel
# @param NotificationChannelSet: 告警通道数组
# @type NotificationChannelSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :NotificationChannelSet, :RequestId
def initialize(notificationchannelset=nil, requestid=nil)
@NotificationChannelSet = notificationchannelset
@RequestId = requestid
end
def deserialize(params)
unless params['NotificationChannelSet'].nil?
@NotificationChannelSet = []
params['NotificationChannelSet'].each do |i|
grafananotificationchannel_tmp = GrafanaNotificationChannel.new
grafananotificationchannel_tmp.deserialize(i)
@NotificationChannelSet << grafananotificationchannel_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeGrafanaWhiteList请求参数结构体
class DescribeGrafanaWhiteListRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
attr_accessor :InstanceId
def initialize(instanceid=nil)
@InstanceId = instanceid
end
def deserialize(params)
@InstanceId = params['InstanceId']
end
end
# DescribeGrafanaWhiteList返回参数结构体
class DescribeGrafanaWhiteListResponse < TencentCloud::Common::AbstractModel
# @param WhiteList: 数组
# @type WhiteList: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :WhiteList, :RequestId
def initialize(whitelist=nil, requestid=nil)
@WhiteList = whitelist
@RequestId = requestid
end
def deserialize(params)
@WhiteList = params['WhiteList']
@RequestId = params['RequestId']
end
end
# DescribeInstalledPlugins请求参数结构体
class DescribeInstalledPluginsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-kleu3gt0
# @type InstanceId: String
# @param PluginId: 按插件 ID 过滤,例如:grafana-piechart-panel,可通过接口 DescribeInstalledPlugins 查看已安装的插件 ID
# @type PluginId: String
attr_accessor :InstanceId, :PluginId
def initialize(instanceid=nil, pluginid=nil)
@InstanceId = instanceid
@PluginId = pluginid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@PluginId = params['PluginId']
end
end
# DescribeInstalledPlugins返回参数结构体
class DescribeInstalledPluginsResponse < TencentCloud::Common::AbstractModel
# @param PluginSet: 插件列表
# @type PluginSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PluginSet, :RequestId
def initialize(pluginset=nil, requestid=nil)
@PluginSet = pluginset
@RequestId = requestid
end
def deserialize(params)
unless params['PluginSet'].nil?
@PluginSet = []
params['PluginSet'].each do |i|
grafanaplugin_tmp = GrafanaPlugin.new
grafanaplugin_tmp.deserialize(i)
@PluginSet << grafanaplugin_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeMonitorResourceInfo请求参数结构体
class DescribeMonitorResourceInfoRequest < TencentCloud::Common::AbstractModel
def initialize()
end
def deserialize(params)
end
end
# DescribeMonitorResourceInfo返回参数结构体
class DescribeMonitorResourceInfoResponse < TencentCloud::Common::AbstractModel
# @param PhoneAlarmNumber: 电话告警数量
# @type PhoneAlarmNumber: Integer
# @param AdvancedMetricNumber: 高级指标数量
# @type AdvancedMetricNumber: Integer
# @param APIUsageNumber: API调用量
# @type APIUsageNumber: Integer
# @param AlarmSMSNumber: 告警短信数量
# @type AlarmSMSNumber: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PhoneAlarmNumber, :AdvancedMetricNumber, :APIUsageNumber, :AlarmSMSNumber, :RequestId
def initialize(phonealarmnumber=nil, advancedmetricnumber=nil, apiusagenumber=nil, alarmsmsnumber=nil, requestid=nil)
@PhoneAlarmNumber = phonealarmnumber
@AdvancedMetricNumber = advancedmetricnumber
@APIUsageNumber = apiusagenumber
@AlarmSMSNumber = alarmsmsnumber
@RequestId = requestid
end
def deserialize(params)
@PhoneAlarmNumber = params['PhoneAlarmNumber']
@AdvancedMetricNumber = params['AdvancedMetricNumber']
@APIUsageNumber = params['APIUsageNumber']
@AlarmSMSNumber = params['AlarmSMSNumber']
@RequestId = params['RequestId']
end
end
# DescribeMonitorTypes请求参数结构体
class DescribeMonitorTypesRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,固定值 monitor
# @type Module: String
attr_accessor :Module
def initialize(_module=nil)
@Module = _module
end
def deserialize(params)
@Module = params['Module']
end
end
# DescribeMonitorTypes返回参数结构体
class DescribeMonitorTypesResponse < TencentCloud::Common::AbstractModel
# @param MonitorTypes: 监控类型,云产品监控为 MT_QCE
# @type MonitorTypes: Array
# @param MonitorTypeInfos: 监控类型详情
# @type MonitorTypeInfos: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :MonitorTypes, :MonitorTypeInfos, :RequestId
def initialize(monitortypes=nil, monitortypeinfos=nil, requestid=nil)
@MonitorTypes = monitortypes
@MonitorTypeInfos = monitortypeinfos
@RequestId = requestid
end
def deserialize(params)
@MonitorTypes = params['MonitorTypes']
unless params['MonitorTypeInfos'].nil?
@MonitorTypeInfos = []
params['MonitorTypeInfos'].each do |i|
monitortypeinfo_tmp = MonitorTypeInfo.new
monitortypeinfo_tmp.deserialize(i)
@MonitorTypeInfos << monitortypeinfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribePhoneAlarmFlowTotalCount请求参数结构体
class DescribePhoneAlarmFlowTotalCountRequest < TencentCloud::Common::AbstractModel
# @param Module: 默认monitor
# @type Module: String
# @param QueryTime: unix时间戳,单位:s
# @type QueryTime: Integer
attr_accessor :Module, :QueryTime
def initialize(_module=nil, querytime=nil)
@Module = _module
@QueryTime = querytime
end
def deserialize(params)
@Module = params['Module']
@QueryTime = params['QueryTime']
end
end
# DescribePhoneAlarmFlowTotalCount返回参数结构体
class DescribePhoneAlarmFlowTotalCountResponse < TencentCloud::Common::AbstractModel
# @param Count: 电话流水总数
# @type Count: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Count, :RequestId
def initialize(count=nil, requestid=nil)
@Count = count
@RequestId = requestid
end
def deserialize(params)
@Count = params['Count']
@RequestId = params['RequestId']
end
end
# DescribePluginOverviews请求参数结构体
class DescribePluginOverviewsRequest < TencentCloud::Common::AbstractModel
def initialize()
end
def deserialize(params)
end
end
# DescribePluginOverviews返回参数结构体
class DescribePluginOverviewsResponse < TencentCloud::Common::AbstractModel
# @param PluginSet: 插件列表
# @type PluginSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PluginSet, :RequestId
def initialize(pluginset=nil, requestid=nil)
@PluginSet = pluginset
@RequestId = requestid
end
def deserialize(params)
unless params['PluginSet'].nil?
@PluginSet = []
params['PluginSet'].each do |i|
grafanaplugin_tmp = GrafanaPlugin.new
grafanaplugin_tmp.deserialize(i)
@PluginSet << grafanaplugin_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribePolicyConditionList策略条件
class DescribePolicyConditionListCondition < TencentCloud::Common::AbstractModel
# @param PolicyViewName: 策略视图名称
# @type PolicyViewName: String
# @param EventMetrics: 事件告警条件
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventMetrics: Array
# @param IsSupportMultiRegion: 是否支持多地域
# @type IsSupportMultiRegion: Boolean
# @param Metrics: 指标告警条件
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Metrics: Array
# @param Name: 策略类型名称
# @type Name: String
# @param SortId: 排序id
# @type SortId: Integer
# @param SupportDefault: 是否支持默认策略
# @type SupportDefault: Boolean
# @param SupportRegions: 支持该策略类型的地域列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SupportRegions: Array
# @param DeprecatingInfo: 弃用信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DeprecatingInfo: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyConditionListResponseDeprecatingInfo`
attr_accessor :PolicyViewName, :EventMetrics, :IsSupportMultiRegion, :Metrics, :Name, :SortId, :SupportDefault, :SupportRegions, :DeprecatingInfo
def initialize(policyviewname=nil, eventmetrics=nil, issupportmultiregion=nil, metrics=nil, name=nil, sortid=nil, supportdefault=nil, supportregions=nil, deprecatinginfo=nil)
@PolicyViewName = policyviewname
@EventMetrics = eventmetrics
@IsSupportMultiRegion = issupportmultiregion
@Metrics = metrics
@Name = name
@SortId = sortid
@SupportDefault = supportdefault
@SupportRegions = supportregions
@DeprecatingInfo = deprecatinginfo
end
def deserialize(params)
@PolicyViewName = params['PolicyViewName']
unless params['EventMetrics'].nil?
@EventMetrics = []
params['EventMetrics'].each do |i|
describepolicyconditionlisteventmetric_tmp = DescribePolicyConditionListEventMetric.new
describepolicyconditionlisteventmetric_tmp.deserialize(i)
@EventMetrics << describepolicyconditionlisteventmetric_tmp
end
end
@IsSupportMultiRegion = params['IsSupportMultiRegion']
unless params['Metrics'].nil?
@Metrics = []
params['Metrics'].each do |i|
describepolicyconditionlistmetric_tmp = DescribePolicyConditionListMetric.new
describepolicyconditionlistmetric_tmp.deserialize(i)
@Metrics << describepolicyconditionlistmetric_tmp
end
end
@Name = params['Name']
@SortId = params['SortId']
@SupportDefault = params['SupportDefault']
@SupportRegions = params['SupportRegions']
unless params['DeprecatingInfo'].nil?
@DeprecatingInfo = DescribePolicyConditionListResponseDeprecatingInfo.new
@DeprecatingInfo.deserialize(params['DeprecatingInfo'])
end
end
end
# DescribePolicyConditionList.ConfigManual
class DescribePolicyConditionListConfigManual < TencentCloud::Common::AbstractModel
# @param CalcType: 检测方式
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CalcType: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyConditionListConfigManualCalcType`
# @param CalcValue: 检测阈值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CalcValue: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyConditionListConfigManualCalcValue`
# @param ContinueTime: 持续时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ContinueTime: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyConditionListConfigManualContinueTime`
# @param Period: 数据周期
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Period: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyConditionListConfigManualPeriod`
# @param PeriodNum: 持续周期个数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PeriodNum: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyConditionListConfigManualPeriodNum`
# @param StatType: 聚合方式
# 注意:此字段可能返回 null,表示取不到有效值。
# @type StatType: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyConditionListConfigManualStatType`
attr_accessor :CalcType, :CalcValue, :ContinueTime, :Period, :PeriodNum, :StatType
def initialize(calctype=nil, calcvalue=nil, continuetime=nil, period=nil, periodnum=nil, stattype=nil)
@CalcType = calctype
@CalcValue = calcvalue
@ContinueTime = continuetime
@Period = period
@PeriodNum = periodnum
@StatType = stattype
end
def deserialize(params)
unless params['CalcType'].nil?
@CalcType = DescribePolicyConditionListConfigManualCalcType.new
@CalcType.deserialize(params['CalcType'])
end
unless params['CalcValue'].nil?
@CalcValue = DescribePolicyConditionListConfigManualCalcValue.new
@CalcValue.deserialize(params['CalcValue'])
end
unless params['ContinueTime'].nil?
@ContinueTime = DescribePolicyConditionListConfigManualContinueTime.new
@ContinueTime.deserialize(params['ContinueTime'])
end
unless params['Period'].nil?
@Period = DescribePolicyConditionListConfigManualPeriod.new
@Period.deserialize(params['Period'])
end
unless params['PeriodNum'].nil?
@PeriodNum = DescribePolicyConditionListConfigManualPeriodNum.new
@PeriodNum.deserialize(params['PeriodNum'])
end
unless params['StatType'].nil?
@StatType = DescribePolicyConditionListConfigManualStatType.new
@StatType.deserialize(params['StatType'])
end
end
end
# DescribePolicyConditionList.ConfigManual.CalcType
class DescribePolicyConditionListConfigManualCalcType < TencentCloud::Common::AbstractModel
# @param Keys: CalcType 取值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Keys: Array
# @param Need: 是否必须
# @type Need: Boolean
attr_accessor :Keys, :Need
def initialize(keys=nil, need=nil)
@Keys = keys
@Need = need
end
def deserialize(params)
@Keys = params['Keys']
@Need = params['Need']
end
end
# DescribePolicyConditionList.ConfigManual.CalcValue
class DescribePolicyConditionListConfigManualCalcValue < TencentCloud::Common::AbstractModel
# @param Default: 默认值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Default: String
# @param Fixed: 固定值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Fixed: String
# @param Max: 最大值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Max: String
# @param Min: 最小值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Min: String
# @param Need: 是否必须
# @type Need: Boolean
attr_accessor :Default, :Fixed, :Max, :Min, :Need
def initialize(default=nil, fixed=nil, max=nil, min=nil, need=nil)
@Default = default
@Fixed = fixed
@Max = max
@Min = min
@Need = need
end
def deserialize(params)
@Default = params['Default']
@Fixed = params['Fixed']
@Max = params['Max']
@Min = params['Min']
@Need = params['Need']
end
end
# DescribePolicyConditionList.ConfigManual.ContinueTime
class DescribePolicyConditionListConfigManualContinueTime < TencentCloud::Common::AbstractModel
# @param Default: 默认持续时间,单位:秒
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Default: Integer
# @param Keys: 可选持续时间,单位:秒
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Keys: Array
# @param Need: 是否必须
# @type Need: Boolean
attr_accessor :Default, :Keys, :Need
def initialize(default=nil, keys=nil, need=nil)
@Default = default
@Keys = keys
@Need = need
end
def deserialize(params)
@Default = params['Default']
@Keys = params['Keys']
@Need = params['Need']
end
end
# DescribePolicyConditionList.ConfigManual.Period
class DescribePolicyConditionListConfigManualPeriod < TencentCloud::Common::AbstractModel
# @param Default: 默认周期,单位:秒
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Default: Integer
# @param Keys: 可选周期,单位:秒
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Keys: Array
# @param Need: 是否必须
# @type Need: Boolean
attr_accessor :Default, :Keys, :Need
def initialize(default=nil, keys=nil, need=nil)
@Default = default
@Keys = keys
@Need = need
end
def deserialize(params)
@Default = params['Default']
@Keys = params['Keys']
@Need = params['Need']
end
end
# DescribePolicyConditionList.ConfigManual.PeriodNum
class DescribePolicyConditionListConfigManualPeriodNum < TencentCloud::Common::AbstractModel
# @param Default: 默认周期数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Default: Integer
# @param Keys: 可选周期数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Keys: Array
# @param Need: 是否必须
# @type Need: Boolean
attr_accessor :Default, :Keys, :Need
def initialize(default=nil, keys=nil, need=nil)
@Default = default
@Keys = keys
@Need = need
end
def deserialize(params)
@Default = params['Default']
@Keys = params['Keys']
@Need = params['Need']
end
end
# DescribePolicyConditionList.ConfigManual.StatType
class DescribePolicyConditionListConfigManualStatType < TencentCloud::Common::AbstractModel
# @param P5: 数据聚合方式,周期5秒
# 注意:此字段可能返回 null,表示取不到有效值。
# @type P5: String
# @param P10: 数据聚合方式,周期10秒
# 注意:此字段可能返回 null,表示取不到有效值。
# @type P10: String
# @param P60: 数据聚合方式,周期1分钟
# 注意:此字段可能返回 null,表示取不到有效值。
# @type P60: String
# @param P300: 数据聚合方式,周期5分钟
# 注意:此字段可能返回 null,表示取不到有效值。
# @type P300: String
# @param P600: 数据聚合方式,周期10分钟
# 注意:此字段可能返回 null,表示取不到有效值。
# @type P600: String
# @param P1800: 数据聚合方式,周期30分钟
# 注意:此字段可能返回 null,表示取不到有效值。
# @type P1800: String
# @param P3600: 数据聚合方式,周期1小时
# 注意:此字段可能返回 null,表示取不到有效值。
# @type P3600: String
# @param P86400: 数据聚合方式,周期1天
# 注意:此字段可能返回 null,表示取不到有效值。
# @type P86400: String
attr_accessor :P5, :P10, :P60, :P300, :P600, :P1800, :P3600, :P86400
def initialize(p5=nil, p10=nil, p60=nil, p300=nil, p600=nil, p1800=nil, p3600=nil, p86400=nil)
@P5 = p5
@P10 = p10
@P60 = p60
@P300 = p300
@P600 = p600
@P1800 = p1800
@P3600 = p3600
@P86400 = p86400
end
def deserialize(params)
@P5 = params['P5']
@P10 = params['P10']
@P60 = params['P60']
@P300 = params['P300']
@P600 = params['P600']
@P1800 = params['P1800']
@P3600 = params['P3600']
@P86400 = params['P86400']
end
end
# DescribePolicyConditionList.EventMetric
class DescribePolicyConditionListEventMetric < TencentCloud::Common::AbstractModel
# @param EventId: 事件id
# @type EventId: Integer
# @param EventShowName: 事件名称
# @type EventShowName: String
# @param NeedRecovered: 是否需要恢复
# @type NeedRecovered: Boolean
# @param Type: 事件类型,预留字段,当前固定取值为2
# @type Type: Integer
attr_accessor :EventId, :EventShowName, :NeedRecovered, :Type
def initialize(eventid=nil, eventshowname=nil, needrecovered=nil, type=nil)
@EventId = eventid
@EventShowName = eventshowname
@NeedRecovered = needrecovered
@Type = type
end
def deserialize(params)
@EventId = params['EventId']
@EventShowName = params['EventShowName']
@NeedRecovered = params['NeedRecovered']
@Type = params['Type']
end
end
# 指标告警配置
class DescribePolicyConditionListMetric < TencentCloud::Common::AbstractModel
# @param ConfigManual: 指标配置
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ConfigManual: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyConditionListConfigManual`
# @param MetricId: 指标id
# @type MetricId: Integer
# @param MetricShowName: 指标名称
# @type MetricShowName: String
# @param MetricUnit: 指标单位
# @type MetricUnit: String
attr_accessor :ConfigManual, :MetricId, :MetricShowName, :MetricUnit
def initialize(configmanual=nil, metricid=nil, metricshowname=nil, metricunit=nil)
@ConfigManual = configmanual
@MetricId = metricid
@MetricShowName = metricshowname
@MetricUnit = metricunit
end
def deserialize(params)
unless params['ConfigManual'].nil?
@ConfigManual = DescribePolicyConditionListConfigManual.new
@ConfigManual.deserialize(params['ConfigManual'])
end
@MetricId = params['MetricId']
@MetricShowName = params['MetricShowName']
@MetricUnit = params['MetricUnit']
end
end
# DescribePolicyConditionList请求参数结构体
class DescribePolicyConditionListRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
attr_accessor :Module
def initialize(_module=nil)
@Module = _module
end
def deserialize(params)
@Module = params['Module']
end
end
# DescribePolicyConditionList返回参数结构体
class DescribePolicyConditionListResponse < TencentCloud::Common::AbstractModel
# @param Conditions: 告警策略条件列表
# @type Conditions: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Conditions, :RequestId
def initialize(conditions=nil, requestid=nil)
@Conditions = conditions
@RequestId = requestid
end
def deserialize(params)
unless params['Conditions'].nil?
@Conditions = []
params['Conditions'].each do |i|
describepolicyconditionlistcondition_tmp = DescribePolicyConditionListCondition.new
describepolicyconditionlistcondition_tmp.deserialize(i)
@Conditions << describepolicyconditionlistcondition_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribePolicyConditionListResponseDeprecatingInfo
class DescribePolicyConditionListResponseDeprecatingInfo < TencentCloud::Common::AbstractModel
# @param Hidden: 是否隐藏
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Hidden: Boolean
# @param NewViewNames: 新视图名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NewViewNames: Array
# @param Description: 描述
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Description: String
attr_accessor :Hidden, :NewViewNames, :Description
def initialize(hidden=nil, newviewnames=nil, description=nil)
@Hidden = hidden
@NewViewNames = newviewnames
@Description = description
end
def deserialize(params)
@Hidden = params['Hidden']
@NewViewNames = params['NewViewNames']
@Description = params['Description']
end
end
# 查询策略输出的用户回调信息
class DescribePolicyGroupInfoCallback < TencentCloud::Common::AbstractModel
# @param CallbackUrl: 用户回调接口地址
# @type CallbackUrl: String
# @param ValidFlag: 用户回调接口状态,0表示未验证,1表示已验证,2表示存在url但没有通过验证
# @type ValidFlag: Integer
# @param VerifyCode: 用户回调接口验证码
# @type VerifyCode: String
attr_accessor :CallbackUrl, :ValidFlag, :VerifyCode
def initialize(callbackurl=nil, validflag=nil, verifycode=nil)
@CallbackUrl = callbackurl
@ValidFlag = validflag
@VerifyCode = verifycode
end
def deserialize(params)
@CallbackUrl = params['CallbackUrl']
@ValidFlag = params['ValidFlag']
@VerifyCode = params['VerifyCode']
end
end
# 查询策略输出的阈值告警条件
class DescribePolicyGroupInfoCondition < TencentCloud::Common::AbstractModel
# @param MetricShowName: 指标名称
# @type MetricShowName: String
# @param Period: 数据聚合周期(单位秒)
# @type Period: Integer
# @param MetricId: 指标id
# @type MetricId: Integer
# @param RuleId: 阈值规则id
# @type RuleId: Integer
# @param Unit: 指标单位
# @type Unit: String
# @param AlarmNotifyType: 告警发送收敛类型。0连续告警,1指数告警
# @type AlarmNotifyType: Integer
# @param AlarmNotifyPeriod: 告警发送周期单位秒。<0 不触发, 0 只触发一次, >0 每隔triggerTime秒触发一次
# @type AlarmNotifyPeriod: Integer
# @param CalcType: 比较类型,1表示大于,2表示大于等于,3表示小于,4表示小于等于,5表示相等,6表示不相等,7表示日同比上涨,8表示日同比下降,9表示周同比上涨,10表示周同比下降,11表示周期环比上涨,12表示周期环比下降
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CalcType: Integer
# @param CalcValue: 检测阈值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CalcValue: String
# @param ContinueTime: 持续多长时间触发规则会告警(单位秒)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ContinueTime: Integer
# @param MetricName: 告警指标名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MetricName: String
attr_accessor :MetricShowName, :Period, :MetricId, :RuleId, :Unit, :AlarmNotifyType, :AlarmNotifyPeriod, :CalcType, :CalcValue, :ContinueTime, :MetricName
def initialize(metricshowname=nil, period=nil, metricid=nil, ruleid=nil, unit=nil, alarmnotifytype=nil, alarmnotifyperiod=nil, calctype=nil, calcvalue=nil, continuetime=nil, metricname=nil)
@MetricShowName = metricshowname
@Period = period
@MetricId = metricid
@RuleId = ruleid
@Unit = unit
@AlarmNotifyType = alarmnotifytype
@AlarmNotifyPeriod = alarmnotifyperiod
@CalcType = calctype
@CalcValue = calcvalue
@ContinueTime = continuetime
@MetricName = metricname
end
def deserialize(params)
@MetricShowName = params['MetricShowName']
@Period = params['Period']
@MetricId = params['MetricId']
@RuleId = params['RuleId']
@Unit = params['Unit']
@AlarmNotifyType = params['AlarmNotifyType']
@AlarmNotifyPeriod = params['AlarmNotifyPeriod']
@CalcType = params['CalcType']
@CalcValue = params['CalcValue']
@ContinueTime = params['ContinueTime']
@MetricName = params['MetricName']
end
end
# 查询策略输出的模板策略组信息
class DescribePolicyGroupInfoConditionTpl < TencentCloud::Common::AbstractModel
# @param GroupId: 策略组id
# @type GroupId: Integer
# @param GroupName: 策略组名称
# @type GroupName: String
# @param ViewName: 策略类型
# @type ViewName: String
# @param Remark: 策略组说明
# @type Remark: String
# @param LastEditUin: 最后编辑的用户uin
# @type LastEditUin: String
# @param UpdateTime: 更新时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdateTime: Integer
# @param InsertTime: 创建时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InsertTime: Integer
# @param IsUnionRule: 是否且规则
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsUnionRule: Integer
attr_accessor :GroupId, :GroupName, :ViewName, :Remark, :LastEditUin, :UpdateTime, :InsertTime, :IsUnionRule
def initialize(groupid=nil, groupname=nil, viewname=nil, remark=nil, lastedituin=nil, updatetime=nil, inserttime=nil, isunionrule=nil)
@GroupId = groupid
@GroupName = groupname
@ViewName = viewname
@Remark = remark
@LastEditUin = lastedituin
@UpdateTime = updatetime
@InsertTime = inserttime
@IsUnionRule = isunionrule
end
def deserialize(params)
@GroupId = params['GroupId']
@GroupName = params['GroupName']
@ViewName = params['ViewName']
@Remark = params['Remark']
@LastEditUin = params['LastEditUin']
@UpdateTime = params['UpdateTime']
@InsertTime = params['InsertTime']
@IsUnionRule = params['IsUnionRule']
end
end
# 查询策略输出的事件告警条件
class DescribePolicyGroupInfoEventCondition < TencentCloud::Common::AbstractModel
# @param EventId: 事件id
# @type EventId: Integer
# @param RuleId: 事件告警规则id
# @type RuleId: Integer
# @param EventShowName: 事件名称
# @type EventShowName: String
# @param AlarmNotifyPeriod: 告警发送周期单位秒。<0 不触发, 0 只触发一次, >0 每隔triggerTime秒触发一次
# @type AlarmNotifyPeriod: Integer
# @param AlarmNotifyType: 告警发送收敛类型。0连续告警,1指数告警
# @type AlarmNotifyType: Integer
attr_accessor :EventId, :RuleId, :EventShowName, :AlarmNotifyPeriod, :AlarmNotifyType
def initialize(eventid=nil, ruleid=nil, eventshowname=nil, alarmnotifyperiod=nil, alarmnotifytype=nil)
@EventId = eventid
@RuleId = ruleid
@EventShowName = eventshowname
@AlarmNotifyPeriod = alarmnotifyperiod
@AlarmNotifyType = alarmnotifytype
end
def deserialize(params)
@EventId = params['EventId']
@RuleId = params['RuleId']
@EventShowName = params['EventShowName']
@AlarmNotifyPeriod = params['AlarmNotifyPeriod']
@AlarmNotifyType = params['AlarmNotifyType']
end
end
# 查询策略输出的告警接收人信息
class DescribePolicyGroupInfoReceiverInfo < TencentCloud::Common::AbstractModel
# @param ReceiverGroupList: 告警接收组id列表
# @type ReceiverGroupList: Array
# @param ReceiverUserList: 告警接收人id列表
# @type ReceiverUserList: Array
# @param StartTime: 告警时间段开始时间。范围[0,86400),作为 UNIX 时间戳转成北京时间后去掉日期,例如7200表示"10:0:0"
# @type StartTime: Integer
# @param EndTime: 告警时间段结束时间。含义同StartTime
# @type EndTime: Integer
# @param ReceiverType: 接收类型。“group”(接收组)或“user”(接收人)
# @type ReceiverType: String
# @param NotifyWay: 告警通知方式。可选 "SMS","SITE","EMAIL","CALL","WECHAT"
# @type NotifyWay: Array
# @param UidList: 电话告警接收者uid
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UidList: Array
# @param RoundNumber: 电话告警轮数
# @type RoundNumber: Integer
# @param RoundInterval: 电话告警每轮间隔(秒)
# @type RoundInterval: Integer
# @param PersonInterval: 电话告警对个人间隔(秒)
# @type PersonInterval: Integer
# @param NeedSendNotice: 是否需要电话告警触达提示。0不需要,1需要
# @type NeedSendNotice: Integer
# @param SendFor: 电话告警通知时机。可选"OCCUR"(告警时通知),"RECOVER"(恢复时通知)
# @type SendFor: Array
# @param RecoverNotify: 恢复通知方式。可选"SMS"
# @type RecoverNotify: Array
# @param ReceiveLanguage: 告警发送语言
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ReceiveLanguage: String
attr_accessor :ReceiverGroupList, :ReceiverUserList, :StartTime, :EndTime, :ReceiverType, :NotifyWay, :UidList, :RoundNumber, :RoundInterval, :PersonInterval, :NeedSendNotice, :SendFor, :RecoverNotify, :ReceiveLanguage
def initialize(receivergrouplist=nil, receiveruserlist=nil, starttime=nil, endtime=nil, receivertype=nil, notifyway=nil, uidlist=nil, roundnumber=nil, roundinterval=nil, personinterval=nil, needsendnotice=nil, sendfor=nil, recovernotify=nil, receivelanguage=nil)
@ReceiverGroupList = receivergrouplist
@ReceiverUserList = receiveruserlist
@StartTime = starttime
@EndTime = endtime
@ReceiverType = receivertype
@NotifyWay = notifyway
@UidList = uidlist
@RoundNumber = roundnumber
@RoundInterval = roundinterval
@PersonInterval = personinterval
@NeedSendNotice = needsendnotice
@SendFor = sendfor
@RecoverNotify = recovernotify
@ReceiveLanguage = receivelanguage
end
def deserialize(params)
@ReceiverGroupList = params['ReceiverGroupList']
@ReceiverUserList = params['ReceiverUserList']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@ReceiverType = params['ReceiverType']
@NotifyWay = params['NotifyWay']
@UidList = params['UidList']
@RoundNumber = params['RoundNumber']
@RoundInterval = params['RoundInterval']
@PersonInterval = params['PersonInterval']
@NeedSendNotice = params['NeedSendNotice']
@SendFor = params['SendFor']
@RecoverNotify = params['RecoverNotify']
@ReceiveLanguage = params['ReceiveLanguage']
end
end
# DescribePolicyGroupInfo请求参数结构体
class DescribePolicyGroupInfoRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param GroupId: 策略组id
# @type GroupId: Integer
attr_accessor :Module, :GroupId
def initialize(_module=nil, groupid=nil)
@Module = _module
@GroupId = groupid
end
def deserialize(params)
@Module = params['Module']
@GroupId = params['GroupId']
end
end
# DescribePolicyGroupInfo返回参数结构体
class DescribePolicyGroupInfoResponse < TencentCloud::Common::AbstractModel
# @param GroupName: 策略组名称
# @type GroupName: String
# @param ProjectId: 策略组所属的项目id
# @type ProjectId: Integer
# @param IsDefault: 是否为默认策略,0表示非默认策略,1表示默认策略
# @type IsDefault: Integer
# @param ViewName: 策略类型
# @type ViewName: String
# @param Remark: 策略说明
# @type Remark: String
# @param ShowName: 策略类型名称
# @type ShowName: String
# @param LastEditUin: 最近编辑的用户uin
# @type LastEditUin: String
# @param UpdateTime: 最近编辑时间
# @type UpdateTime: String
# @param Region: 该策略支持的地域
# @type Region: Array
# @param DimensionGroup: 策略类型的维度列表
# @type DimensionGroup: Array
# @param ConditionsConfig: 阈值规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ConditionsConfig: Array
# @param EventConfig: 产品事件规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventConfig: Array
# @param ReceiverInfos: 用户接收人列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ReceiverInfos: Array
# @param Callback: 用户回调信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Callback: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyGroupInfoCallback`
# @param ConditionsTemp: 模板策略组
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ConditionsTemp: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyGroupInfoConditionTpl`
# @param CanSetDefault: 是否可以设置成默认策略
# @type CanSetDefault: Boolean
# @param IsUnionRule: 是否且规则
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsUnionRule: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :GroupName, :ProjectId, :IsDefault, :ViewName, :Remark, :ShowName, :LastEditUin, :UpdateTime, :Region, :DimensionGroup, :ConditionsConfig, :EventConfig, :ReceiverInfos, :Callback, :ConditionsTemp, :CanSetDefault, :IsUnionRule, :RequestId
def initialize(groupname=nil, projectid=nil, isdefault=nil, viewname=nil, remark=nil, showname=nil, lastedituin=nil, updatetime=nil, region=nil, dimensiongroup=nil, conditionsconfig=nil, eventconfig=nil, receiverinfos=nil, callback=nil, conditionstemp=nil, cansetdefault=nil, isunionrule=nil, requestid=nil)
@GroupName = groupname
@ProjectId = projectid
@IsDefault = isdefault
@ViewName = viewname
@Remark = remark
@ShowName = showname
@LastEditUin = lastedituin
@UpdateTime = updatetime
@Region = region
@DimensionGroup = dimensiongroup
@ConditionsConfig = conditionsconfig
@EventConfig = eventconfig
@ReceiverInfos = receiverinfos
@Callback = callback
@ConditionsTemp = conditionstemp
@CanSetDefault = cansetdefault
@IsUnionRule = isunionrule
@RequestId = requestid
end
def deserialize(params)
@GroupName = params['GroupName']
@ProjectId = params['ProjectId']
@IsDefault = params['IsDefault']
@ViewName = params['ViewName']
@Remark = params['Remark']
@ShowName = params['ShowName']
@LastEditUin = params['LastEditUin']
@UpdateTime = params['UpdateTime']
@Region = params['Region']
@DimensionGroup = params['DimensionGroup']
unless params['ConditionsConfig'].nil?
@ConditionsConfig = []
params['ConditionsConfig'].each do |i|
describepolicygroupinfocondition_tmp = DescribePolicyGroupInfoCondition.new
describepolicygroupinfocondition_tmp.deserialize(i)
@ConditionsConfig << describepolicygroupinfocondition_tmp
end
end
unless params['EventConfig'].nil?
@EventConfig = []
params['EventConfig'].each do |i|
describepolicygroupinfoeventcondition_tmp = DescribePolicyGroupInfoEventCondition.new
describepolicygroupinfoeventcondition_tmp.deserialize(i)
@EventConfig << describepolicygroupinfoeventcondition_tmp
end
end
unless params['ReceiverInfos'].nil?
@ReceiverInfos = []
params['ReceiverInfos'].each do |i|
describepolicygroupinforeceiverinfo_tmp = DescribePolicyGroupInfoReceiverInfo.new
describepolicygroupinforeceiverinfo_tmp.deserialize(i)
@ReceiverInfos << describepolicygroupinforeceiverinfo_tmp
end
end
unless params['Callback'].nil?
@Callback = DescribePolicyGroupInfoCallback.new
@Callback.deserialize(params['Callback'])
end
unless params['ConditionsTemp'].nil?
@ConditionsTemp = DescribePolicyGroupInfoConditionTpl.new
@ConditionsTemp.deserialize(params['ConditionsTemp'])
end
@CanSetDefault = params['CanSetDefault']
@IsUnionRule = params['IsUnionRule']
@RequestId = params['RequestId']
end
end
# DescribePolicyGroupList.Group
class DescribePolicyGroupListGroup < TencentCloud::Common::AbstractModel
# @param GroupId: 策略组id
# @type GroupId: Integer
# @param GroupName: 策略组名称
# @type GroupName: String
# @param IsOpen: 是否开启
# @type IsOpen: Boolean
# @param ViewName: 策略视图名称
# @type ViewName: String
# @param LastEditUin: 最近编辑的用户uin
# @type LastEditUin: String
# @param UpdateTime: 最后修改时间
# @type UpdateTime: Integer
# @param InsertTime: 创建时间
# @type InsertTime: Integer
# @param UseSum: 策略组绑定的实例数
# @type UseSum: Integer
# @param NoShieldedSum: 策略组绑定的未屏蔽实例数
# @type NoShieldedSum: Integer
# @param IsDefault: 是否为默认策略,0表示非默认策略,1表示默认策略
# @type IsDefault: Integer
# @param CanSetDefault: 是否可以设置成默认策略
# @type CanSetDefault: Boolean
# @param ParentGroupId: 父策略组id
# @type ParentGroupId: Integer
# @param Remark: 策略组备注
# @type Remark: String
# @param ProjectId: 策略组所属项目id
# @type ProjectId: Integer
# @param Conditions: 阈值规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Conditions: Array
# @param EventConditions: 产品事件规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventConditions: Array
# @param ReceiverInfos: 用户接收人列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ReceiverInfos: Array
# @param ConditionsTemp: 模板策略组
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ConditionsTemp: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyGroupInfoConditionTpl`
# @param InstanceGroup: 策略组绑定的实例组信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceGroup: :class:`Tencentcloud::Monitor.v20180724.models.DescribePolicyGroupListGroupInstanceGroup`
# @param IsUnionRule: 且或规则标识, 0表示或规则(任意一条规则满足阈值条件就告警), 1表示且规则(所有规则都满足阈值条件才告警)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsUnionRule: Integer
attr_accessor :GroupId, :GroupName, :IsOpen, :ViewName, :LastEditUin, :UpdateTime, :InsertTime, :UseSum, :NoShieldedSum, :IsDefault, :CanSetDefault, :ParentGroupId, :Remark, :ProjectId, :Conditions, :EventConditions, :ReceiverInfos, :ConditionsTemp, :InstanceGroup, :IsUnionRule
def initialize(groupid=nil, groupname=nil, isopen=nil, viewname=nil, lastedituin=nil, updatetime=nil, inserttime=nil, usesum=nil, noshieldedsum=nil, isdefault=nil, cansetdefault=nil, parentgroupid=nil, remark=nil, projectid=nil, conditions=nil, eventconditions=nil, receiverinfos=nil, conditionstemp=nil, instancegroup=nil, isunionrule=nil)
@GroupId = groupid
@GroupName = groupname
@IsOpen = isopen
@ViewName = viewname
@LastEditUin = lastedituin
@UpdateTime = updatetime
@InsertTime = inserttime
@UseSum = usesum
@NoShieldedSum = noshieldedsum
@IsDefault = isdefault
@CanSetDefault = cansetdefault
@ParentGroupId = parentgroupid
@Remark = remark
@ProjectId = projectid
@Conditions = conditions
@EventConditions = eventconditions
@ReceiverInfos = receiverinfos
@ConditionsTemp = conditionstemp
@InstanceGroup = instancegroup
@IsUnionRule = isunionrule
end
def deserialize(params)
@GroupId = params['GroupId']
@GroupName = params['GroupName']
@IsOpen = params['IsOpen']
@ViewName = params['ViewName']
@LastEditUin = params['LastEditUin']
@UpdateTime = params['UpdateTime']
@InsertTime = params['InsertTime']
@UseSum = params['UseSum']
@NoShieldedSum = params['NoShieldedSum']
@IsDefault = params['IsDefault']
@CanSetDefault = params['CanSetDefault']
@ParentGroupId = params['ParentGroupId']
@Remark = params['Remark']
@ProjectId = params['ProjectId']
unless params['Conditions'].nil?
@Conditions = []
params['Conditions'].each do |i|
describepolicygroupinfocondition_tmp = DescribePolicyGroupInfoCondition.new
describepolicygroupinfocondition_tmp.deserialize(i)
@Conditions << describepolicygroupinfocondition_tmp
end
end
unless params['EventConditions'].nil?
@EventConditions = []
params['EventConditions'].each do |i|
describepolicygroupinfoeventcondition_tmp = DescribePolicyGroupInfoEventCondition.new
describepolicygroupinfoeventcondition_tmp.deserialize(i)
@EventConditions << describepolicygroupinfoeventcondition_tmp
end
end
unless params['ReceiverInfos'].nil?
@ReceiverInfos = []
params['ReceiverInfos'].each do |i|
describepolicygroupinforeceiverinfo_tmp = DescribePolicyGroupInfoReceiverInfo.new
describepolicygroupinforeceiverinfo_tmp.deserialize(i)
@ReceiverInfos << describepolicygroupinforeceiverinfo_tmp
end
end
unless params['ConditionsTemp'].nil?
@ConditionsTemp = DescribePolicyGroupInfoConditionTpl.new
@ConditionsTemp.deserialize(params['ConditionsTemp'])
end
unless params['InstanceGroup'].nil?
@InstanceGroup = DescribePolicyGroupListGroupInstanceGroup.new
@InstanceGroup.deserialize(params['InstanceGroup'])
end
@IsUnionRule = params['IsUnionRule']
end
end
# DescribePolicyGroupList接口策略组绑定的实例分组信息
class DescribePolicyGroupListGroupInstanceGroup < TencentCloud::Common::AbstractModel
# @param InstanceGroupId: 实例分组名称id
# @type InstanceGroupId: Integer
# @param ViewName: 策略类型视图名称
# @type ViewName: String
# @param LastEditUin: 最近编辑的用户uin
# @type LastEditUin: String
# @param GroupName: 实例分组名称
# @type GroupName: String
# @param InstanceSum: 实例数量
# @type InstanceSum: Integer
# @param UpdateTime: 更新时间
# @type UpdateTime: Integer
# @param InsertTime: 创建时间
# @type InsertTime: Integer
attr_accessor :InstanceGroupId, :ViewName, :LastEditUin, :GroupName, :InstanceSum, :UpdateTime, :InsertTime
def initialize(instancegroupid=nil, viewname=nil, lastedituin=nil, groupname=nil, instancesum=nil, updatetime=nil, inserttime=nil)
@InstanceGroupId = instancegroupid
@ViewName = viewname
@LastEditUin = lastedituin
@GroupName = groupname
@InstanceSum = instancesum
@UpdateTime = updatetime
@InsertTime = inserttime
end
def deserialize(params)
@InstanceGroupId = params['InstanceGroupId']
@ViewName = params['ViewName']
@LastEditUin = params['LastEditUin']
@GroupName = params['GroupName']
@InstanceSum = params['InstanceSum']
@UpdateTime = params['UpdateTime']
@InsertTime = params['InsertTime']
end
end
# DescribePolicyGroupList请求参数结构体
class DescribePolicyGroupListRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param Limit: 分页参数,每页返回的数量,取值1~100
# @type Limit: Integer
# @param Offset: 分页参数,页偏移量,从0开始计数
# @type Offset: Integer
# @param Like: 按策略名搜索
# @type Like: String
# @param InstanceGroupId: 实例分组id
# @type InstanceGroupId: Integer
# @param UpdateTimeOrder: 按更新时间排序, asc 或者 desc
# @type UpdateTimeOrder: String
# @param ProjectIds: 项目id列表
# @type ProjectIds: Array
# @param ViewNames: 告警策略类型列表
# @type ViewNames: Array
# @param FilterUnuseReceiver: 是否过滤无接收人策略组, 1表示过滤, 0表示不过滤
# @type FilterUnuseReceiver: Integer
# @param Receivers: 过滤条件, 接收组列表
# @type Receivers: Array
# @param ReceiverUserList: 过滤条件, 接收人列表
# @type ReceiverUserList: Array
# @param Dimensions: 维度组合字段(json字符串), 例如[[{"name":"unInstanceId","value":"ins-6e4b2aaa"}]]
# @type Dimensions: String
# @param ConditionTempGroupId: 模板策略组id, 多个id用逗号分隔
# @type ConditionTempGroupId: String
# @param ReceiverType: 过滤条件, 接收人或者接收组, user表示接收人, group表示接收组
# @type ReceiverType: String
# @param IsOpen: 过滤条件,告警策略是否已启动或停止
# @type IsOpen: Boolean
attr_accessor :Module, :Limit, :Offset, :Like, :InstanceGroupId, :UpdateTimeOrder, :ProjectIds, :ViewNames, :FilterUnuseReceiver, :Receivers, :ReceiverUserList, :Dimensions, :ConditionTempGroupId, :ReceiverType, :IsOpen
def initialize(_module=nil, limit=nil, offset=nil, like=nil, instancegroupid=nil, updatetimeorder=nil, projectids=nil, viewnames=nil, filterunusereceiver=nil, receivers=nil, receiveruserlist=nil, dimensions=nil, conditiontempgroupid=nil, receivertype=nil, isopen=nil)
@Module = _module
@Limit = limit
@Offset = offset
@Like = like
@InstanceGroupId = instancegroupid
@UpdateTimeOrder = updatetimeorder
@ProjectIds = projectids
@ViewNames = viewnames
@FilterUnuseReceiver = filterunusereceiver
@Receivers = receivers
@ReceiverUserList = receiveruserlist
@Dimensions = dimensions
@ConditionTempGroupId = conditiontempgroupid
@ReceiverType = receivertype
@IsOpen = isopen
end
def deserialize(params)
@Module = params['Module']
@Limit = params['Limit']
@Offset = params['Offset']
@Like = params['Like']
@InstanceGroupId = params['InstanceGroupId']
@UpdateTimeOrder = params['UpdateTimeOrder']
@ProjectIds = params['ProjectIds']
@ViewNames = params['ViewNames']
@FilterUnuseReceiver = params['FilterUnuseReceiver']
@Receivers = params['Receivers']
@ReceiverUserList = params['ReceiverUserList']
@Dimensions = params['Dimensions']
@ConditionTempGroupId = params['ConditionTempGroupId']
@ReceiverType = params['ReceiverType']
@IsOpen = params['IsOpen']
end
end
# DescribePolicyGroupList返回参数结构体
class DescribePolicyGroupListResponse < TencentCloud::Common::AbstractModel
# @param GroupList: 策略组列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GroupList: Array
# @param Total: 策略组总数
# @type Total: Integer
# @param Warning: 备注信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Warning: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :GroupList, :Total, :Warning, :RequestId
def initialize(grouplist=nil, total=nil, warning=nil, requestid=nil)
@GroupList = grouplist
@Total = total
@Warning = warning
@RequestId = requestid
end
def deserialize(params)
unless params['GroupList'].nil?
@GroupList = []
params['GroupList'].each do |i|
describepolicygrouplistgroup_tmp = DescribePolicyGroupListGroup.new
describepolicygrouplistgroup_tmp.deserialize(i)
@GroupList << describepolicygrouplistgroup_tmp
end
end
@Total = params['Total']
@Warning = params['Warning']
@RequestId = params['RequestId']
end
end
# DescribeProductEventList的入参Dimensions
class DescribeProductEventListDimensions < TencentCloud::Common::AbstractModel
# @param Name: 维度名
# @type Name: String
# @param Value: 维度值
# @type Value: String
attr_accessor :Name, :Value
def initialize(name=nil, value=nil)
@Name = name
@Value = value
end
def deserialize(params)
@Name = params['Name']
@Value = params['Value']
end
end
# DescribeProductEventList返回的Events
class DescribeProductEventListEvents < TencentCloud::Common::AbstractModel
# @param EventId: 事件ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventId: Integer
# @param EventCName: 事件中文名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventCName: String
# @param EventEName: 事件英文名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventEName: String
# @param EventName: 事件简称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventName: String
# @param ProductCName: 产品中文名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProductCName: String
# @param ProductEName: 产品英文名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProductEName: String
# @param ProductName: 产品简称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProductName: String
# @param InstanceId: 实例ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceId: String
# @param InstanceName: 实例名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceName: String
# @param ProjectId: 项目ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProjectId: String
# @param Region: 地域
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Region: String
# @param Status: 状态
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Status: String
# @param SupportAlarm: 是否支持告警
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SupportAlarm: Integer
# @param Type: 事件类型
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param StartTime: 开始时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type StartTime: Integer
# @param UpdateTime: 更新时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdateTime: Integer
# @param Dimensions: 实例对象信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Dimensions: Array
# @param AdditionMsg: 实例对象附加信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AdditionMsg: Array
# @param IsAlarmConfig: 是否配置告警
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsAlarmConfig: Integer
# @param GroupInfo: 策略信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GroupInfo: Array
# @param ViewName: 显示名称ViewName
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ViewName: String
attr_accessor :EventId, :EventCName, :EventEName, :EventName, :ProductCName, :ProductEName, :ProductName, :InstanceId, :InstanceName, :ProjectId, :Region, :Status, :SupportAlarm, :Type, :StartTime, :UpdateTime, :Dimensions, :AdditionMsg, :IsAlarmConfig, :GroupInfo, :ViewName
def initialize(eventid=nil, eventcname=nil, eventename=nil, eventname=nil, productcname=nil, productename=nil, productname=nil, instanceid=nil, instancename=nil, projectid=nil, region=nil, status=nil, supportalarm=nil, type=nil, starttime=nil, updatetime=nil, dimensions=nil, additionmsg=nil, isalarmconfig=nil, groupinfo=nil, viewname=nil)
@EventId = eventid
@EventCName = eventcname
@EventEName = eventename
@EventName = eventname
@ProductCName = productcname
@ProductEName = productename
@ProductName = productname
@InstanceId = instanceid
@InstanceName = instancename
@ProjectId = projectid
@Region = region
@Status = status
@SupportAlarm = supportalarm
@Type = type
@StartTime = starttime
@UpdateTime = updatetime
@Dimensions = dimensions
@AdditionMsg = additionmsg
@IsAlarmConfig = isalarmconfig
@GroupInfo = groupinfo
@ViewName = viewname
end
def deserialize(params)
@EventId = params['EventId']
@EventCName = params['EventCName']
@EventEName = params['EventEName']
@EventName = params['EventName']
@ProductCName = params['ProductCName']
@ProductEName = params['ProductEName']
@ProductName = params['ProductName']
@InstanceId = params['InstanceId']
@InstanceName = params['InstanceName']
@ProjectId = params['ProjectId']
@Region = params['Region']
@Status = params['Status']
@SupportAlarm = params['SupportAlarm']
@Type = params['Type']
@StartTime = params['StartTime']
@UpdateTime = params['UpdateTime']
unless params['Dimensions'].nil?
@Dimensions = []
params['Dimensions'].each do |i|
describeproducteventlisteventsdimensions_tmp = DescribeProductEventListEventsDimensions.new
describeproducteventlisteventsdimensions_tmp.deserialize(i)
@Dimensions << describeproducteventlisteventsdimensions_tmp
end
end
unless params['AdditionMsg'].nil?
@AdditionMsg = []
params['AdditionMsg'].each do |i|
describeproducteventlisteventsdimensions_tmp = DescribeProductEventListEventsDimensions.new
describeproducteventlisteventsdimensions_tmp.deserialize(i)
@AdditionMsg << describeproducteventlisteventsdimensions_tmp
end
end
@IsAlarmConfig = params['IsAlarmConfig']
unless params['GroupInfo'].nil?
@GroupInfo = []
params['GroupInfo'].each do |i|
describeproducteventlisteventsgroupinfo_tmp = DescribeProductEventListEventsGroupInfo.new
describeproducteventlisteventsgroupinfo_tmp.deserialize(i)
@GroupInfo << describeproducteventlisteventsgroupinfo_tmp
end
end
@ViewName = params['ViewName']
end
end
# DescribeProductEventList返回的Events的Dimensions
class DescribeProductEventListEventsDimensions < TencentCloud::Common::AbstractModel
# @param Key: 维度名(英文)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Key: String
# @param Name: 维度名(中文)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param Value: 维度值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Value: String
attr_accessor :Key, :Name, :Value
def initialize(key=nil, name=nil, value=nil)
@Key = key
@Name = name
@Value = value
end
def deserialize(params)
@Key = params['Key']
@Name = params['Name']
@Value = params['Value']
end
end
# DescribeProductEventList返回的Events里的GroupInfo
class DescribeProductEventListEventsGroupInfo < TencentCloud::Common::AbstractModel
# @param GroupId: 策略ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GroupId: Integer
# @param GroupName: 策略名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GroupName: String
attr_accessor :GroupId, :GroupName
def initialize(groupid=nil, groupname=nil)
@GroupId = groupid
@GroupName = groupname
end
def deserialize(params)
@GroupId = params['GroupId']
@GroupName = params['GroupName']
end
end
# DescribeProductEventList返回的OverView对象
class DescribeProductEventListOverView < TencentCloud::Common::AbstractModel
# @param StatusChangeAmount: 状态变更的事件数量
# 注意:此字段可能返回 null,表示取不到有效值。
# @type StatusChangeAmount: Integer
# @param UnConfigAlarmAmount: 告警状态未配置的事件数量
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UnConfigAlarmAmount: Integer
# @param UnNormalEventAmount: 异常事件数量
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UnNormalEventAmount: Integer
# @param UnRecoverAmount: 未恢复的事件数量
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UnRecoverAmount: Integer
attr_accessor :StatusChangeAmount, :UnConfigAlarmAmount, :UnNormalEventAmount, :UnRecoverAmount
def initialize(statuschangeamount=nil, unconfigalarmamount=nil, unnormaleventamount=nil, unrecoveramount=nil)
@StatusChangeAmount = statuschangeamount
@UnConfigAlarmAmount = unconfigalarmamount
@UnNormalEventAmount = unnormaleventamount
@UnRecoverAmount = unrecoveramount
end
def deserialize(params)
@StatusChangeAmount = params['StatusChangeAmount']
@UnConfigAlarmAmount = params['UnConfigAlarmAmount']
@UnNormalEventAmount = params['UnNormalEventAmount']
@UnRecoverAmount = params['UnRecoverAmount']
end
end
# DescribeProductEventList请求参数结构体
class DescribeProductEventListRequest < TencentCloud::Common::AbstractModel
# @param Module: 接口模块名,固定值"monitor"
# @type Module: String
# @param ProductName: 产品类型过滤,例如"cvm"表示云服务器
# @type ProductName: Array
# @param EventName: 事件名称过滤,例如"guest_reboot"表示机器重启
# @type EventName: Array
# @param InstanceId: 影响对象,例如"ins-19708ino"
# @type InstanceId: Array
# @param Dimensions: 维度过滤,例如外网IP:10.0.0.1
# @type Dimensions: Array
# @param RegionList: 产品事件地域过滤参数,例如gz,各地域缩写可参见[地域列表](https://cloud.tencent.com/document/product/248/50863)
# @type RegionList: Array
# @param Type: 事件类型过滤,取值范围["status_change","abnormal"],分别表示状态变更、异常事件
# @type Type: Array
# @param Status: 事件状态过滤,取值范围["recover","alarm","-"],分别表示已恢复、未恢复、无状态
# @type Status: Array
# @param Project: 项目ID过滤
# @type Project: Array
# @param IsAlarmConfig: 告警状态配置过滤,1表示已配置,0表示未配置
# @type IsAlarmConfig: Integer
# @param TimeOrder: 按更新时间排序,ASC表示升序,DESC表示降序,默认DESC
# @type TimeOrder: String
# @param StartTime: 起始时间,默认一天前的时间戳
# @type StartTime: Integer
# @param EndTime: 结束时间,默认当前时间戳
# @type EndTime: Integer
# @param Offset: 页偏移量,默认0
# @type Offset: Integer
# @param Limit: 每页返回的数量,默认20
# @type Limit: Integer
attr_accessor :Module, :ProductName, :EventName, :InstanceId, :Dimensions, :RegionList, :Type, :Status, :Project, :IsAlarmConfig, :TimeOrder, :StartTime, :EndTime, :Offset, :Limit
def initialize(_module=nil, productname=nil, eventname=nil, instanceid=nil, dimensions=nil, regionlist=nil, type=nil, status=nil, project=nil, isalarmconfig=nil, timeorder=nil, starttime=nil, endtime=nil, offset=nil, limit=nil)
@Module = _module
@ProductName = productname
@EventName = eventname
@InstanceId = instanceid
@Dimensions = dimensions
@RegionList = regionlist
@Type = type
@Status = status
@Project = project
@IsAlarmConfig = isalarmconfig
@TimeOrder = timeorder
@StartTime = starttime
@EndTime = endtime
@Offset = offset
@Limit = limit
end
def deserialize(params)
@Module = params['Module']
@ProductName = params['ProductName']
@EventName = params['EventName']
@InstanceId = params['InstanceId']
unless params['Dimensions'].nil?
@Dimensions = []
params['Dimensions'].each do |i|
describeproducteventlistdimensions_tmp = DescribeProductEventListDimensions.new
describeproducteventlistdimensions_tmp.deserialize(i)
@Dimensions << describeproducteventlistdimensions_tmp
end
end
@RegionList = params['RegionList']
@Type = params['Type']
@Status = params['Status']
@Project = params['Project']
@IsAlarmConfig = params['IsAlarmConfig']
@TimeOrder = params['TimeOrder']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribeProductEventList返回参数结构体
class DescribeProductEventListResponse < TencentCloud::Common::AbstractModel
# @param Events: 事件列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Events: Array
# @param OverView: 事件统计
# @type OverView: :class:`Tencentcloud::Monitor.v20180724.models.DescribeProductEventListOverView`
# @param Total: 事件总数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Total: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Events, :OverView, :Total, :RequestId
def initialize(events=nil, overview=nil, total=nil, requestid=nil)
@Events = events
@OverView = overview
@Total = total
@RequestId = requestid
end
def deserialize(params)
unless params['Events'].nil?
@Events = []
params['Events'].each do |i|
describeproducteventlistevents_tmp = DescribeProductEventListEvents.new
describeproducteventlistevents_tmp.deserialize(i)
@Events << describeproducteventlistevents_tmp
end
end
unless params['OverView'].nil?
@OverView = DescribeProductEventListOverView.new
@OverView.deserialize(params['OverView'])
end
@Total = params['Total']
@RequestId = params['RequestId']
end
end
# DescribeProductList请求参数结构体
class DescribeProductListRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定传值monitor
# @type Module: String
# @param Order: 排序方式:DESC/ASC(区分大小写),默认值DESC
# @type Order: String
# @param Offset: 分页查询的偏移量,默认值0
# @type Offset: Integer
# @param Limit: 分页查询的每页数据量,默认值20
# @type Limit: Integer
attr_accessor :Module, :Order, :Offset, :Limit
def initialize(_module=nil, order=nil, offset=nil, limit=nil)
@Module = _module
@Order = order
@Offset = offset
@Limit = limit
end
def deserialize(params)
@Module = params['Module']
@Order = params['Order']
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribeProductList返回参数结构体
class DescribeProductListResponse < TencentCloud::Common::AbstractModel
# @param ProductList: 产品信息列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProductList: Array
# @param TotalCount: 产品总数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TotalCount: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ProductList, :TotalCount, :RequestId
def initialize(productlist=nil, totalcount=nil, requestid=nil)
@ProductList = productlist
@TotalCount = totalcount
@RequestId = requestid
end
def deserialize(params)
unless params['ProductList'].nil?
@ProductList = []
params['ProductList'].each do |i|
productsimple_tmp = ProductSimple.new
productsimple_tmp.deserialize(i)
@ProductList << productsimple_tmp
end
end
@TotalCount = params['TotalCount']
@RequestId = params['RequestId']
end
end
# DescribePrometheusAgentInstances请求参数结构体
class DescribePrometheusAgentInstancesRequest < TencentCloud::Common::AbstractModel
# @param ClusterId: 集群id
# 可以是tke, eks, edge的集群id
# @type ClusterId: String
attr_accessor :ClusterId
def initialize(clusterid=nil)
@ClusterId = clusterid
end
def deserialize(params)
@ClusterId = params['ClusterId']
end
end
# DescribePrometheusAgentInstances返回参数结构体
class DescribePrometheusAgentInstancesResponse < TencentCloud::Common::AbstractModel
# @param Instances: 关联该集群的实例列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Instances: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Instances, :RequestId
def initialize(instances=nil, requestid=nil)
@Instances = instances
@RequestId = requestid
end
def deserialize(params)
@Instances = params['Instances']
@RequestId = params['RequestId']
end
end
# DescribePrometheusAgents请求参数结构体
class DescribePrometheusAgentsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param Name: Agent 名称
# @type Name: String
# @param AgentIds: Agent ID 列表
# @type AgentIds: Array
# @param Offset: 偏移量,默认为0
# @type Offset: Integer
# @param Limit: 返回数量,默认为20,最大值为100
# @type Limit: Integer
attr_accessor :InstanceId, :Name, :AgentIds, :Offset, :Limit
def initialize(instanceid=nil, name=nil, agentids=nil, offset=nil, limit=nil)
@InstanceId = instanceid
@Name = name
@AgentIds = agentids
@Offset = offset
@Limit = limit
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Name = params['Name']
@AgentIds = params['AgentIds']
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribePrometheusAgents返回参数结构体
class DescribePrometheusAgentsResponse < TencentCloud::Common::AbstractModel
# @param AgentSet: Agent 列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AgentSet: Array
# @param TotalCount: Agent 总量
# @type TotalCount: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :AgentSet, :TotalCount, :RequestId
def initialize(agentset=nil, totalcount=nil, requestid=nil)
@AgentSet = agentset
@TotalCount = totalcount
@RequestId = requestid
end
def deserialize(params)
unless params['AgentSet'].nil?
@AgentSet = []
params['AgentSet'].each do |i|
prometheusagent_tmp = PrometheusAgent.new
prometheusagent_tmp.deserialize(i)
@AgentSet << prometheusagent_tmp
end
end
@TotalCount = params['TotalCount']
@RequestId = params['RequestId']
end
end
# DescribePrometheusAlertGroups请求参数结构体
class DescribePrometheusAlertGroupsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param Limit: 返回数量,默认为 20,最大值为 100
# @type Limit: Integer
# @param Offset: 偏移量,默认为 0
# @type Offset: Integer
# @param GroupId: 告警分组ID,形如alert-xxxx。
# 查询给定ID的告警分组
# @type GroupId: String
# @param GroupName: 告警分组名称。
# 查询名称中包含给定字符串的告警分组
# @type GroupName: String
attr_accessor :InstanceId, :Limit, :Offset, :GroupId, :GroupName
def initialize(instanceid=nil, limit=nil, offset=nil, groupid=nil, groupname=nil)
@InstanceId = instanceid
@Limit = limit
@Offset = offset
@GroupId = groupid
@GroupName = groupname
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Limit = params['Limit']
@Offset = params['Offset']
@GroupId = params['GroupId']
@GroupName = params['GroupName']
end
end
# DescribePrometheusAlertGroups返回参数结构体
class DescribePrometheusAlertGroupsResponse < TencentCloud::Common::AbstractModel
# @param AlertGroupSet: 告警分组信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlertGroupSet: Array
# @param TotalCount: 告警分组总数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TotalCount: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :AlertGroupSet, :TotalCount, :RequestId
def initialize(alertgroupset=nil, totalcount=nil, requestid=nil)
@AlertGroupSet = alertgroupset
@TotalCount = totalcount
@RequestId = requestid
end
def deserialize(params)
unless params['AlertGroupSet'].nil?
@AlertGroupSet = []
params['AlertGroupSet'].each do |i|
prometheusalertgroupset_tmp = PrometheusAlertGroupSet.new
prometheusalertgroupset_tmp.deserialize(i)
@AlertGroupSet << prometheusalertgroupset_tmp
end
end
@TotalCount = params['TotalCount']
@RequestId = params['RequestId']
end
end
# DescribePrometheusAlertPolicy请求参数结构体
class DescribePrometheusAlertPolicyRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
# @param Offset: 分页偏移量,默认为0。 示例值:1
# @type Offset: Integer
# @param Limit: 分页返回数量,默认为20,最大值为100
# @type Limit: Integer
# @param Filters: 仅支持按Name, Values字段过滤:
# - Name = Name
# 按照给定的告警规则名称列表匹配
# - Name = ID
# 按照给定的告警规则ID列表匹配
# @type Filters: Array
attr_accessor :InstanceId, :Offset, :Limit, :Filters
def initialize(instanceid=nil, offset=nil, limit=nil, filters=nil)
@InstanceId = instanceid
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
end
end
# DescribePrometheusAlertPolicy返回参数结构体
class DescribePrometheusAlertPolicyResponse < TencentCloud::Common::AbstractModel
# @param AlertRules: 告警详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlertRules: Array
# @param Total: 总数
# @type Total: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :AlertRules, :Total, :RequestId
def initialize(alertrules=nil, total=nil, requestid=nil)
@AlertRules = alertrules
@Total = total
@RequestId = requestid
end
def deserialize(params)
unless params['AlertRules'].nil?
@AlertRules = []
params['AlertRules'].each do |i|
prometheusalertpolicyitem_tmp = PrometheusAlertPolicyItem.new
prometheusalertpolicyitem_tmp.deserialize(i)
@AlertRules << prometheusalertpolicyitem_tmp
end
end
@Total = params['Total']
@RequestId = params['RequestId']
end
end
# DescribePrometheusClusterAgents请求参数结构体
class DescribePrometheusClusterAgentsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param Offset: 偏移量,默认为0。
# @type Offset: Integer
# @param Limit: 返回数量,默认为20,最大值为100。
# @type Limit: Integer
# @param ClusterIds: 用于通过集群id过滤被绑定集群
# @type ClusterIds: Array
# @param ClusterTypes: 用于通过集群类型过滤被绑定集群
# @type ClusterTypes: Array
# @param ClusterName: 用于通过名称搜索被绑定集群
# @type ClusterName: String
attr_accessor :InstanceId, :Offset, :Limit, :ClusterIds, :ClusterTypes, :ClusterName
def initialize(instanceid=nil, offset=nil, limit=nil, clusterids=nil, clustertypes=nil, clustername=nil)
@InstanceId = instanceid
@Offset = offset
@Limit = limit
@ClusterIds = clusterids
@ClusterTypes = clustertypes
@ClusterName = clustername
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Offset = params['Offset']
@Limit = params['Limit']
@ClusterIds = params['ClusterIds']
@ClusterTypes = params['ClusterTypes']
@ClusterName = params['ClusterName']
end
end
# DescribePrometheusClusterAgents返回参数结构体
class DescribePrometheusClusterAgentsResponse < TencentCloud::Common::AbstractModel
# @param Agents: 被关联集群信息
# @type Agents: Array
# @param Total: 被关联集群总量
# @type Total: Integer
# @param IsFirstBind: 是否为首次绑定,如果是首次绑定则需要安装预聚合规则
# @type IsFirstBind: Boolean
# @param ImageNeedUpdate: 实例组件是否需要更新镜像版本
# @type ImageNeedUpdate: Boolean
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Agents, :Total, :IsFirstBind, :ImageNeedUpdate, :RequestId
def initialize(agents=nil, total=nil, isfirstbind=nil, imageneedupdate=nil, requestid=nil)
@Agents = agents
@Total = total
@IsFirstBind = isfirstbind
@ImageNeedUpdate = imageneedupdate
@RequestId = requestid
end
def deserialize(params)
unless params['Agents'].nil?
@Agents = []
params['Agents'].each do |i|
prometheusagentoverview_tmp = PrometheusAgentOverview.new
prometheusagentoverview_tmp.deserialize(i)
@Agents << prometheusagentoverview_tmp
end
end
@Total = params['Total']
@IsFirstBind = params['IsFirstBind']
@ImageNeedUpdate = params['ImageNeedUpdate']
@RequestId = params['RequestId']
end
end
# DescribePrometheusConfig请求参数结构体
class DescribePrometheusConfigRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param ClusterId: 集群id
# @type ClusterId: String
# @param ClusterType: 集群类型
# @type ClusterType: String
attr_accessor :InstanceId, :ClusterId, :ClusterType
def initialize(instanceid=nil, clusterid=nil, clustertype=nil)
@InstanceId = instanceid
@ClusterId = clusterid
@ClusterType = clustertype
end
def deserialize(params)
@InstanceId = params['InstanceId']
@ClusterId = params['ClusterId']
@ClusterType = params['ClusterType']
end
end
# DescribePrometheusConfig返回参数结构体
class DescribePrometheusConfigResponse < TencentCloud::Common::AbstractModel
# @param Config: 全局配置
# @type Config: String
# @param ServiceMonitors: ServiceMonitor配置
# @type ServiceMonitors: Array
# @param PodMonitors: PodMonitor配置
# @type PodMonitors: Array
# @param RawJobs: 原生Job
# @type RawJobs: Array
# @param Probes: Probes
# @type Probes: Array
# @param ImageNeedUpdate: 实例组件是否需要升级
# @type ImageNeedUpdate: Boolean
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Config, :ServiceMonitors, :PodMonitors, :RawJobs, :Probes, :ImageNeedUpdate, :RequestId
def initialize(config=nil, servicemonitors=nil, podmonitors=nil, rawjobs=nil, probes=nil, imageneedupdate=nil, requestid=nil)
@Config = config
@ServiceMonitors = servicemonitors
@PodMonitors = podmonitors
@RawJobs = rawjobs
@Probes = probes
@ImageNeedUpdate = imageneedupdate
@RequestId = requestid
end
def deserialize(params)
@Config = params['Config']
unless params['ServiceMonitors'].nil?
@ServiceMonitors = []
params['ServiceMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@ServiceMonitors << prometheusconfigitem_tmp
end
end
unless params['PodMonitors'].nil?
@PodMonitors = []
params['PodMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@PodMonitors << prometheusconfigitem_tmp
end
end
unless params['RawJobs'].nil?
@RawJobs = []
params['RawJobs'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@RawJobs << prometheusconfigitem_tmp
end
end
unless params['Probes'].nil?
@Probes = []
params['Probes'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@Probes << prometheusconfigitem_tmp
end
end
@ImageNeedUpdate = params['ImageNeedUpdate']
@RequestId = params['RequestId']
end
end
# DescribePrometheusGlobalConfig请求参数结构体
class DescribePrometheusGlobalConfigRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例级别抓取配置
# @type InstanceId: String
# @param DisableStatistics: 是否禁用统计
# @type DisableStatistics: Boolean
attr_accessor :InstanceId, :DisableStatistics
def initialize(instanceid=nil, disablestatistics=nil)
@InstanceId = instanceid
@DisableStatistics = disablestatistics
end
def deserialize(params)
@InstanceId = params['InstanceId']
@DisableStatistics = params['DisableStatistics']
end
end
# DescribePrometheusGlobalConfig返回参数结构体
class DescribePrometheusGlobalConfigResponse < TencentCloud::Common::AbstractModel
# @param Config: 配置内容
# @type Config: String
# @param ServiceMonitors: ServiceMonitors列表以及对应targets信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ServiceMonitors: Array
# @param PodMonitors: PodMonitors列表以及对应targets信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PodMonitors: Array
# @param RawJobs: RawJobs列表以及对应targets信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RawJobs: Array
# @param Probes: Probes列表以及对应targets信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Probes: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Config, :ServiceMonitors, :PodMonitors, :RawJobs, :Probes, :RequestId
def initialize(config=nil, servicemonitors=nil, podmonitors=nil, rawjobs=nil, probes=nil, requestid=nil)
@Config = config
@ServiceMonitors = servicemonitors
@PodMonitors = podmonitors
@RawJobs = rawjobs
@Probes = probes
@RequestId = requestid
end
def deserialize(params)
@Config = params['Config']
unless params['ServiceMonitors'].nil?
@ServiceMonitors = []
params['ServiceMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@ServiceMonitors << prometheusconfigitem_tmp
end
end
unless params['PodMonitors'].nil?
@PodMonitors = []
params['PodMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@PodMonitors << prometheusconfigitem_tmp
end
end
unless params['RawJobs'].nil?
@RawJobs = []
params['RawJobs'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@RawJobs << prometheusconfigitem_tmp
end
end
unless params['Probes'].nil?
@Probes = []
params['Probes'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@Probes << prometheusconfigitem_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribePrometheusGlobalNotification请求参数结构体
class DescribePrometheusGlobalNotificationRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
attr_accessor :InstanceId
def initialize(instanceid=nil)
@InstanceId = instanceid
end
def deserialize(params)
@InstanceId = params['InstanceId']
end
end
# DescribePrometheusGlobalNotification返回参数结构体
class DescribePrometheusGlobalNotificationResponse < TencentCloud::Common::AbstractModel
# @param Notification: 全局告警通知渠道
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Notification: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusNotificationItem`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Notification, :RequestId
def initialize(notification=nil, requestid=nil)
@Notification = notification
@RequestId = requestid
end
def deserialize(params)
unless params['Notification'].nil?
@Notification = PrometheusNotificationItem.new
@Notification.deserialize(params['Notification'])
end
@RequestId = params['RequestId']
end
end
# DescribePrometheusInstanceDetail请求参数结构体
class DescribePrometheusInstanceDetailRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
attr_accessor :InstanceId
def initialize(instanceid=nil)
@InstanceId = instanceid
end
def deserialize(params)
@InstanceId = params['InstanceId']
end
end
# DescribePrometheusInstanceDetail返回参数结构体
class DescribePrometheusInstanceDetailResponse < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
# @param InstanceName: 实例名称
# @type InstanceName: String
# @param VpcId: VPC ID
# @type VpcId: String
# @param SubnetId: 子网 ID
# @type SubnetId: String
# @param InstanceStatus: 实例业务状态。取值范围:
# 1:正在创建
# 2:运行中
# 3:异常
# 4:重建中
# 5:销毁中
# 6:已停服
# 8:欠费停服中
# 9:欠费已停服
# @type InstanceStatus: Integer
# @param ChargeStatus: 计费状态
# 1:正常
# 2:过期
# 3:销毁
# 4:分配中
# 5:分配失败
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ChargeStatus: Integer
# @param EnableGrafana: 是否开启 Grafana
# 0:不开启
# 1:开启
# @type EnableGrafana: Integer
# @param GrafanaURL: Grafana 面板 URL
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GrafanaURL: String
# @param InstanceChargeType: 实例计费模式。取值范围:
# 2:包年包月
# 3:按量
# @type InstanceChargeType: Integer
# @param SpecName: 规格名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SpecName: String
# @param DataRetentionTime: 存储周期
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DataRetentionTime: Integer
# @param ExpireTime: 购买的实例过期时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExpireTime: String
# @param AutoRenewFlag: 自动续费标记
# 0:不自动续费
# 1:开启自动续费
# 2:禁止自动续费
# -1:无效
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AutoRenewFlag: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :InstanceId, :InstanceName, :VpcId, :SubnetId, :InstanceStatus, :ChargeStatus, :EnableGrafana, :GrafanaURL, :InstanceChargeType, :SpecName, :DataRetentionTime, :ExpireTime, :AutoRenewFlag, :RequestId
def initialize(instanceid=nil, instancename=nil, vpcid=nil, subnetid=nil, instancestatus=nil, chargestatus=nil, enablegrafana=nil, grafanaurl=nil, instancechargetype=nil, specname=nil, dataretentiontime=nil, expiretime=nil, autorenewflag=nil, requestid=nil)
@InstanceId = instanceid
@InstanceName = instancename
@VpcId = vpcid
@SubnetId = subnetid
@InstanceStatus = instancestatus
@ChargeStatus = chargestatus
@EnableGrafana = enablegrafana
@GrafanaURL = grafanaurl
@InstanceChargeType = instancechargetype
@SpecName = specname
@DataRetentionTime = dataretentiontime
@ExpireTime = expiretime
@AutoRenewFlag = autorenewflag
@RequestId = requestid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@InstanceName = params['InstanceName']
@VpcId = params['VpcId']
@SubnetId = params['SubnetId']
@InstanceStatus = params['InstanceStatus']
@ChargeStatus = params['ChargeStatus']
@EnableGrafana = params['EnableGrafana']
@GrafanaURL = params['GrafanaURL']
@InstanceChargeType = params['InstanceChargeType']
@SpecName = params['SpecName']
@DataRetentionTime = params['DataRetentionTime']
@ExpireTime = params['ExpireTime']
@AutoRenewFlag = params['AutoRenewFlag']
@RequestId = params['RequestId']
end
end
# DescribePrometheusInstanceInitStatus请求参数结构体
class DescribePrometheusInstanceInitStatusRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
attr_accessor :InstanceId
def initialize(instanceid=nil)
@InstanceId = instanceid
end
def deserialize(params)
@InstanceId = params['InstanceId']
end
end
# DescribePrometheusInstanceInitStatus返回参数结构体
class DescribePrometheusInstanceInitStatusResponse < TencentCloud::Common::AbstractModel
# @param Status: 实例初始化状态,取值:
# uninitialized 未初始化
# initializing 初始化中
# running 初始化完成,运行中
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Status: String
# @param Steps: 初始化任务步骤
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Steps: Array
# @param EksClusterId: 实例eks集群ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EksClusterId: String
# @param SecurityGroupId: eks集群内pod的安全组
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SecurityGroupId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Status, :Steps, :EksClusterId, :SecurityGroupId, :RequestId
def initialize(status=nil, steps=nil, eksclusterid=nil, securitygroupid=nil, requestid=nil)
@Status = status
@Steps = steps
@EksClusterId = eksclusterid
@SecurityGroupId = securitygroupid
@RequestId = requestid
end
def deserialize(params)
@Status = params['Status']
unless params['Steps'].nil?
@Steps = []
params['Steps'].each do |i|
taskstepinfo_tmp = TaskStepInfo.new
taskstepinfo_tmp.deserialize(i)
@Steps << taskstepinfo_tmp
end
end
@EksClusterId = params['EksClusterId']
@SecurityGroupId = params['SecurityGroupId']
@RequestId = params['RequestId']
end
end
# DescribePrometheusInstanceUsage请求参数结构体
class DescribePrometheusInstanceUsageRequest < TencentCloud::Common::AbstractModel
# @param InstanceIds: 按照一个或者多个实例ID查询。实例ID形如:prom-xxxxxxxx。
# @type InstanceIds: Array
# @param StartCalcDate: 开始时间
# @type StartCalcDate: String
# @param EndCalcDate: 结束时间
# @type EndCalcDate: String
attr_accessor :InstanceIds, :StartCalcDate, :EndCalcDate
def initialize(instanceids=nil, startcalcdate=nil, endcalcdate=nil)
@InstanceIds = instanceids
@StartCalcDate = startcalcdate
@EndCalcDate = endcalcdate
end
def deserialize(params)
@InstanceIds = params['InstanceIds']
@StartCalcDate = params['StartCalcDate']
@EndCalcDate = params['EndCalcDate']
end
end
# DescribePrometheusInstanceUsage返回参数结构体
class DescribePrometheusInstanceUsageResponse < TencentCloud::Common::AbstractModel
# @param UsageSet: 用量列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UsageSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :UsageSet, :RequestId
def initialize(usageset=nil, requestid=nil)
@UsageSet = usageset
@RequestId = requestid
end
def deserialize(params)
unless params['UsageSet'].nil?
@UsageSet = []
params['UsageSet'].each do |i|
prometheusinstancetenantusage_tmp = PrometheusInstanceTenantUsage.new
prometheusinstancetenantusage_tmp.deserialize(i)
@UsageSet << prometheusinstancetenantusage_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribePrometheusInstancesOverview请求参数结构体
class DescribePrometheusInstancesOverviewRequest < TencentCloud::Common::AbstractModel
# @param Offset: 分页偏移量,默认为0
# @type Offset: Integer
# @param Limit: 返回数量,默认为20,最大值为100
# @type Limit: Integer
# @param Filters: 过滤实例,目前支持:
# ID: 通过实例ID来过滤
# Name: 通过实例名称来过滤
# @type Filters: Array
attr_accessor :Offset, :Limit, :Filters
def initialize(offset=nil, limit=nil, filters=nil)
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
end
end
# DescribePrometheusInstancesOverview返回参数结构体
class DescribePrometheusInstancesOverviewResponse < TencentCloud::Common::AbstractModel
# @param Instances: 实例列表
# @type Instances: Array
# @param Total: 实例总数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Total: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Instances, :Total, :RequestId
def initialize(instances=nil, total=nil, requestid=nil)
@Instances = instances
@Total = total
@RequestId = requestid
end
def deserialize(params)
unless params['Instances'].nil?
@Instances = []
params['Instances'].each do |i|
prometheusinstancesoverview_tmp = PrometheusInstancesOverview.new
prometheusinstancesoverview_tmp.deserialize(i)
@Instances << prometheusinstancesoverview_tmp
end
end
@Total = params['Total']
@RequestId = params['RequestId']
end
end
# DescribePrometheusInstances请求参数结构体
class DescribePrometheusInstancesRequest < TencentCloud::Common::AbstractModel
# @param InstanceIds: 按照一个或者多个实例ID查询。实例ID形如:prom-xxxxxxxx。请求的实例的上限为100。
# @type InstanceIds: Array
# @param InstanceStatus: 按照【实例状态】进行过滤。
#
# - 1:正在创建
# - 2:运行中
# - 3:异常
# - 4:重建中
# - 5:销毁中
# - 6:已停服
# - 8:欠费停服中
# - 9:欠费已停服
#
# @type InstanceStatus: Array
# @param InstanceName: 按照【实例名称】进行过滤。
# @type InstanceName: String
# @param Zones: 按照【可用区】进行过滤。可用区形如:ap-guangzhou-1。
# @type Zones: Array
# @param TagFilters: 按照【标签键值对】进行过滤。tag-key使用具体的标签键进行替换。
# @type TagFilters: Array
# @param IPv4Address: 按照【实例的IPv4地址】进行过滤。
# @type IPv4Address: Array
# @param Limit: 返回数量,默认为20,最大值为100。
# @type Limit: Integer
# @param Offset: 偏移量,默认为0。
# @type Offset: Integer
# @param InstanceChargeType: 按照【计费类型】进行过滤。
# 2:包年包月
# 3:按量
# @type InstanceChargeType: Integer
attr_accessor :InstanceIds, :InstanceStatus, :InstanceName, :Zones, :TagFilters, :IPv4Address, :Limit, :Offset, :InstanceChargeType
def initialize(instanceids=nil, instancestatus=nil, instancename=nil, zones=nil, tagfilters=nil, ipv4address=nil, limit=nil, offset=nil, instancechargetype=nil)
@InstanceIds = instanceids
@InstanceStatus = instancestatus
@InstanceName = instancename
@Zones = zones
@TagFilters = tagfilters
@IPv4Address = ipv4address
@Limit = limit
@Offset = offset
@InstanceChargeType = instancechargetype
end
def deserialize(params)
@InstanceIds = params['InstanceIds']
@InstanceStatus = params['InstanceStatus']
@InstanceName = params['InstanceName']
@Zones = params['Zones']
unless params['TagFilters'].nil?
@TagFilters = []
params['TagFilters'].each do |i|
prometheustag_tmp = PrometheusTag.new
prometheustag_tmp.deserialize(i)
@TagFilters << prometheustag_tmp
end
end
@IPv4Address = params['IPv4Address']
@Limit = params['Limit']
@Offset = params['Offset']
@InstanceChargeType = params['InstanceChargeType']
end
end
# DescribePrometheusInstances返回参数结构体
class DescribePrometheusInstancesResponse < TencentCloud::Common::AbstractModel
# @param InstanceSet: 实例详细信息列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceSet: Array
# @param TotalCount: 符合条件的实例数量。
# @type TotalCount: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :InstanceSet, :TotalCount, :RequestId
def initialize(instanceset=nil, totalcount=nil, requestid=nil)
@InstanceSet = instanceset
@TotalCount = totalcount
@RequestId = requestid
end
def deserialize(params)
unless params['InstanceSet'].nil?
@InstanceSet = []
params['InstanceSet'].each do |i|
prometheusinstancesitem_tmp = PrometheusInstancesItem.new
prometheusinstancesitem_tmp.deserialize(i)
@InstanceSet << prometheusinstancesitem_tmp
end
end
@TotalCount = params['TotalCount']
@RequestId = params['RequestId']
end
end
# DescribePrometheusRecordRules请求参数结构体
class DescribePrometheusRecordRulesRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param Offset: 偏移量,默认为0。
# @type Offset: Integer
# @param Limit: 返回数量,默认为20,最大值为100。
# @type Limit: Integer
# @param Filters: 仅支持按Name, Values字段过滤。
# @type Filters: Array
attr_accessor :InstanceId, :Offset, :Limit, :Filters
def initialize(instanceid=nil, offset=nil, limit=nil, filters=nil)
@InstanceId = instanceid
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
end
end
# DescribePrometheusRecordRules返回参数结构体
class DescribePrometheusRecordRulesResponse < TencentCloud::Common::AbstractModel
# @param Records: 聚合规则
# @type Records: Array
# @param Total: 总数
# @type Total: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Records, :Total, :RequestId
def initialize(records=nil, total=nil, requestid=nil)
@Records = records
@Total = total
@RequestId = requestid
end
def deserialize(params)
unless params['Records'].nil?
@Records = []
params['Records'].each do |i|
prometheusrecordruleyamlitem_tmp = PrometheusRecordRuleYamlItem.new
prometheusrecordruleyamlitem_tmp.deserialize(i)
@Records << prometheusrecordruleyamlitem_tmp
end
end
@Total = params['Total']
@RequestId = params['RequestId']
end
end
# DescribePrometheusRegions请求参数结构体
class DescribePrometheusRegionsRequest < TencentCloud::Common::AbstractModel
# @param PayMode: 1-预付费,2-后付费,3-全地域(不填默认全地域)
# @type PayMode: Integer
attr_accessor :PayMode
def initialize(paymode=nil)
@PayMode = paymode
end
def deserialize(params)
@PayMode = params['PayMode']
end
end
# DescribePrometheusRegions返回参数结构体
class DescribePrometheusRegionsResponse < TencentCloud::Common::AbstractModel
# @param RegionSet: 区域列表
# @type RegionSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RegionSet, :RequestId
def initialize(regionset=nil, requestid=nil)
@RegionSet = regionset
@RequestId = requestid
end
def deserialize(params)
unless params['RegionSet'].nil?
@RegionSet = []
params['RegionSet'].each do |i|
prometheusregionitem_tmp = PrometheusRegionItem.new
prometheusregionitem_tmp.deserialize(i)
@RegionSet << prometheusregionitem_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribePrometheusScrapeJobs请求参数结构体
class DescribePrometheusScrapeJobsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param AgentId: Agent ID
# @type AgentId: String
# @param Name: 任务名
# @type Name: String
# @param JobIds: 任务 ID 列表
# @type JobIds: Array
# @param Offset: 偏移量,默认为0
# @type Offset: Integer
# @param Limit: 返回数量,默认为20,最大值为100
# @type Limit: Integer
attr_accessor :InstanceId, :AgentId, :Name, :JobIds, :Offset, :Limit
def initialize(instanceid=nil, agentid=nil, name=nil, jobids=nil, offset=nil, limit=nil)
@InstanceId = instanceid
@AgentId = agentid
@Name = name
@JobIds = jobids
@Offset = offset
@Limit = limit
end
def deserialize(params)
@InstanceId = params['InstanceId']
@AgentId = params['AgentId']
@Name = params['Name']
@JobIds = params['JobIds']
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribePrometheusScrapeJobs返回参数结构体
class DescribePrometheusScrapeJobsResponse < TencentCloud::Common::AbstractModel
# @param ScrapeJobSet: 任务列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ScrapeJobSet: Array
# @param TotalCount: 任务总量
# @type TotalCount: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ScrapeJobSet, :TotalCount, :RequestId
def initialize(scrapejobset=nil, totalcount=nil, requestid=nil)
@ScrapeJobSet = scrapejobset
@TotalCount = totalcount
@RequestId = requestid
end
def deserialize(params)
unless params['ScrapeJobSet'].nil?
@ScrapeJobSet = []
params['ScrapeJobSet'].each do |i|
prometheusscrapejob_tmp = PrometheusScrapeJob.new
prometheusscrapejob_tmp.deserialize(i)
@ScrapeJobSet << prometheusscrapejob_tmp
end
end
@TotalCount = params['TotalCount']
@RequestId = params['RequestId']
end
end
# DescribePrometheusTargetsTMP请求参数结构体
class DescribePrometheusTargetsTMPRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param ClusterId: 集成容器服务填绑定的集群id;
# 集成中心填 non-cluster
# @type ClusterId: String
# @param ClusterType: 集群类型(可不填)
# @type ClusterType: String
# @param Filters: 过滤条件,支持Name=ServiceMonitor/PodMonitor/Probe/RawJob/Job, Value为采集配置名称;Name=Health, Value=up, down, unknown;Name=EndPoint, Value为EndPoint地址
# @type Filters: Array
# @param Offset: targets分页偏移量,默认为0
# @type Offset: Integer
# @param Limit: targets返回数量,默认为20,最大值200
# @type Limit: Integer
attr_accessor :InstanceId, :ClusterId, :ClusterType, :Filters, :Offset, :Limit
def initialize(instanceid=nil, clusterid=nil, clustertype=nil, filters=nil, offset=nil, limit=nil)
@InstanceId = instanceid
@ClusterId = clusterid
@ClusterType = clustertype
@Filters = filters
@Offset = offset
@Limit = limit
end
def deserialize(params)
@InstanceId = params['InstanceId']
@ClusterId = params['ClusterId']
@ClusterType = params['ClusterType']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribePrometheusTargetsTMP返回参数结构体
class DescribePrometheusTargetsTMPResponse < TencentCloud::Common::AbstractModel
# @param Jobs: 所有Job的targets信息
# @type Jobs: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Jobs, :RequestId
def initialize(jobs=nil, requestid=nil)
@Jobs = jobs
@RequestId = requestid
end
def deserialize(params)
unless params['Jobs'].nil?
@Jobs = []
params['Jobs'].each do |i|
prometheusjobtargets_tmp = PrometheusJobTargets.new
prometheusjobtargets_tmp.deserialize(i)
@Jobs << prometheusjobtargets_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribePrometheusTemp请求参数结构体
class DescribePrometheusTempRequest < TencentCloud::Common::AbstractModel
# @param Filters: 仅支持按Name, Values字段过滤:
# * Name = Name
# 按照给定的模板名称列表匹配
# * Name = ID
# 按照给定的模板ID列表匹配
# * Name = Describe
# 按照给定的模板描述列表匹配
# * Name = Level
# 按照给定的模板维度(instance, cluster)列表匹配
# @type Filters: Array
# @param Offset: 分页偏移量,默认为0
# @type Offset: Integer
# @param Limit: 分页返回数量,默认为20,最大值为100
# @type Limit: Integer
attr_accessor :Filters, :Offset, :Limit
def initialize(filters=nil, offset=nil, limit=nil)
@Filters = filters
@Offset = offset
@Limit = limit
end
def deserialize(params)
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribePrometheusTemp返回参数结构体
class DescribePrometheusTempResponse < TencentCloud::Common::AbstractModel
# @param Templates: 模板列表
# @type Templates: Array
# @param Total: 总数
# @type Total: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Templates, :Total, :RequestId
def initialize(templates=nil, total=nil, requestid=nil)
@Templates = templates
@Total = total
@RequestId = requestid
end
def deserialize(params)
unless params['Templates'].nil?
@Templates = []
params['Templates'].each do |i|
prometheustemp_tmp = PrometheusTemp.new
prometheustemp_tmp.deserialize(i)
@Templates << prometheustemp_tmp
end
end
@Total = params['Total']
@RequestId = params['RequestId']
end
end
# DescribePrometheusTempSync请求参数结构体
class DescribePrometheusTempSyncRequest < TencentCloud::Common::AbstractModel
# @param TemplateId: 模板ID
# @type TemplateId: String
attr_accessor :TemplateId
def initialize(templateid=nil)
@TemplateId = templateid
end
def deserialize(params)
@TemplateId = params['TemplateId']
end
end
# DescribePrometheusTempSync返回参数结构体
class DescribePrometheusTempSyncResponse < TencentCloud::Common::AbstractModel
# @param Targets: 同步目标详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Targets: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Targets, :RequestId
def initialize(targets=nil, requestid=nil)
@Targets = targets
@RequestId = requestid
end
def deserialize(params)
unless params['Targets'].nil?
@Targets = []
params['Targets'].each do |i|
prometheustemplatesynctarget_tmp = PrometheusTemplateSyncTarget.new
prometheustemplatesynctarget_tmp.deserialize(i)
@Targets << prometheustemplatesynctarget_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribePrometheusZones请求参数结构体
class DescribePrometheusZonesRequest < TencentCloud::Common::AbstractModel
# @param RegionId: 地域 ID(RegionId 和 RegionName 只需要填一个)
# @type RegionId: Integer
# @param RegionName: 地域名(RegionId 和 RegionName 只需要填一个)
# @type RegionName: String
attr_accessor :RegionId, :RegionName
def initialize(regionid=nil, regionname=nil)
@RegionId = regionid
@RegionName = regionname
end
def deserialize(params)
@RegionId = params['RegionId']
@RegionName = params['RegionName']
end
end
# DescribePrometheusZones返回参数结构体
class DescribePrometheusZonesResponse < TencentCloud::Common::AbstractModel
# @param ZoneSet: 区域列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ZoneSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ZoneSet, :RequestId
def initialize(zoneset=nil, requestid=nil)
@ZoneSet = zoneset
@RequestId = requestid
end
def deserialize(params)
unless params['ZoneSet'].nil?
@ZoneSet = []
params['ZoneSet'].each do |i|
prometheuszoneitem_tmp = PrometheusZoneItem.new
prometheuszoneitem_tmp.deserialize(i)
@ZoneSet << prometheuszoneitem_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeRecordingRules请求参数结构体
class DescribeRecordingRulesRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param Limit: 返回数量,默认为 20,最大值为 100
# @type Limit: Integer
# @param Offset: 偏移量,默认为 0
# @type Offset: Integer
# @param RuleId: 规则 ID
# @type RuleId: String
# @param RuleState: 规则状态码,取值如下:
# 1=RuleDeleted
# 2=RuleEnabled
# 3=RuleDisabled
# @type RuleState: Integer
# @param Name: 规则名称
# @type Name: String
attr_accessor :InstanceId, :Limit, :Offset, :RuleId, :RuleState, :Name
def initialize(instanceid=nil, limit=nil, offset=nil, ruleid=nil, rulestate=nil, name=nil)
@InstanceId = instanceid
@Limit = limit
@Offset = offset
@RuleId = ruleid
@RuleState = rulestate
@Name = name
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Limit = params['Limit']
@Offset = params['Offset']
@RuleId = params['RuleId']
@RuleState = params['RuleState']
@Name = params['Name']
end
end
# DescribeRecordingRules返回参数结构体
class DescribeRecordingRulesResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 规则组数量
# @type TotalCount: Integer
# @param RecordingRuleSet: 规则组详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RecordingRuleSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :RecordingRuleSet, :RequestId
def initialize(totalcount=nil, recordingruleset=nil, requestid=nil)
@TotalCount = totalcount
@RecordingRuleSet = recordingruleset
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['RecordingRuleSet'].nil?
@RecordingRuleSet = []
params['RecordingRuleSet'].each do |i|
recordingruleset_tmp = RecordingRuleSet.new
recordingruleset_tmp.deserialize(i)
@RecordingRuleSet << recordingruleset_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeSSOAccount请求参数结构体
class DescribeSSOAccountRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
# @param UserId: 填写对应的账号 ID,将会按账号 ID 进行过滤,例如:10000
# @type UserId: String
attr_accessor :InstanceId, :UserId
def initialize(instanceid=nil, userid=nil)
@InstanceId = instanceid
@UserId = userid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@UserId = params['UserId']
end
end
# DescribeSSOAccount返回参数结构体
class DescribeSSOAccountResponse < TencentCloud::Common::AbstractModel
# @param AccountSet: 授权账号列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AccountSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :AccountSet, :RequestId
def initialize(accountset=nil, requestid=nil)
@AccountSet = accountset
@RequestId = requestid
end
def deserialize(params)
unless params['AccountSet'].nil?
@AccountSet = []
params['AccountSet'].each do |i|
grafanaaccountinfo_tmp = GrafanaAccountInfo.new
grafanaaccountinfo_tmp.deserialize(i)
@AccountSet << grafanaaccountinfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeServiceDiscovery请求参数结构体
class DescribeServiceDiscoveryRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param KubeClusterId: 类型是 TKE,为对应的腾讯云容器服务集群 ID
# @type KubeClusterId: String
# @param KubeType: 用户 Kubernetes 集群类型:
# 1 = 容器服务集群(TKE)
# @type KubeType: Integer
attr_accessor :InstanceId, :KubeClusterId, :KubeType
def initialize(instanceid=nil, kubeclusterid=nil, kubetype=nil)
@InstanceId = instanceid
@KubeClusterId = kubeclusterid
@KubeType = kubetype
end
def deserialize(params)
@InstanceId = params['InstanceId']
@KubeClusterId = params['KubeClusterId']
@KubeType = params['KubeType']
end
end
# DescribeServiceDiscovery返回参数结构体
class DescribeServiceDiscoveryResponse < TencentCloud::Common::AbstractModel
# @param ServiceDiscoverySet: 返回服务发现列表信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ServiceDiscoverySet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ServiceDiscoverySet, :RequestId
def initialize(servicediscoveryset=nil, requestid=nil)
@ServiceDiscoverySet = servicediscoveryset
@RequestId = requestid
end
def deserialize(params)
unless params['ServiceDiscoverySet'].nil?
@ServiceDiscoverySet = []
params['ServiceDiscoverySet'].each do |i|
servicediscoveryitem_tmp = ServiceDiscoveryItem.new
servicediscoveryitem_tmp.deserialize(i)
@ServiceDiscoverySet << servicediscoveryitem_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeStatisticData请求参数结构体
class DescribeStatisticDataRequest < TencentCloud::Common::AbstractModel
# @param Module: 所属模块,固定值,为monitor
# @type Module: String
# @param Namespace: 命名空间,目前支持QCE/TKE2(Conditions必填),QCE/KEEWIDB,QCE/CAMP
# @type Namespace: String
# @param MetricNames: 指标名列表,相关指标信息可参考对应 [云产品指标文档](https://cloud.tencent.com/document/product/248/62458)
# @type MetricNames: Array
# @param Conditions: 维度条件,操作符支持=、in,详情请参考对应 [指标维度信息](https://cloud.tencent.com/document/product/248/53821)
# @type Conditions: Array
# @param Period: 统计粒度。默认取值为300,单位为s;可选的值为60、300、3600、86400
# 受存储时长限制,统计粒度与统计的时间范围有关:
# 60s:EndTime-StartTime<12小时,且StartTime距当前时间不能超过15天;
# 300s:EndTime-StartTime<3天,且StartTime距当前时间不能超过31天;
# 3600s:EndTime-StartTime<30天,且StartTime距当前时间不能超过93天;
# 86400s:EndTime-StartTime<186天,且StartTime距当前时间不能超过186天。
# @type Period: Integer
# @param StartTime: 起始时间,默认为当前时间,如2020-12-08T19:51:23+08:00
# @type StartTime: String
# @param EndTime: 结束时间,默认为当前时间,如2020-12-08T19:51:23+08:00
# @type EndTime: String
# @param GroupBys: 按指定维度groupBy
# @type GroupBys: Array
attr_accessor :Module, :Namespace, :MetricNames, :Conditions, :Period, :StartTime, :EndTime, :GroupBys
def initialize(_module=nil, namespace=nil, metricnames=nil, conditions=nil, period=nil, starttime=nil, endtime=nil, groupbys=nil)
@Module = _module
@Namespace = namespace
@MetricNames = metricnames
@Conditions = conditions
@Period = period
@StartTime = starttime
@EndTime = endtime
@GroupBys = groupbys
end
def deserialize(params)
@Module = params['Module']
@Namespace = params['Namespace']
@MetricNames = params['MetricNames']
unless params['Conditions'].nil?
@Conditions = []
params['Conditions'].each do |i|
midquerycondition_tmp = MidQueryCondition.new
midquerycondition_tmp.deserialize(i)
@Conditions << midquerycondition_tmp
end
end
@Period = params['Period']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@GroupBys = params['GroupBys']
end
end
# DescribeStatisticData返回参数结构体
class DescribeStatisticDataResponse < TencentCloud::Common::AbstractModel
# @param Period: 统计周期
# @type Period: Integer
# @param StartTime: 开始时间
# @type StartTime: String
# @param EndTime: 结束时间
# @type EndTime: String
# @param Data: 监控数据
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Period, :StartTime, :EndTime, :Data, :RequestId
def initialize(period=nil, starttime=nil, endtime=nil, data=nil, requestid=nil)
@Period = period
@StartTime = starttime
@EndTime = endtime
@Data = data
@RequestId = requestid
end
def deserialize(params)
@Period = params['Period']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
metricdata_tmp = MetricData.new
metricdata_tmp.deserialize(i)
@Data << metricdata_tmp
end
end
@RequestId = params['RequestId']
end
end
# DestroyPrometheusInstance请求参数结构体
class DestroyPrometheusInstanceRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID,该实例必须先被 terminate
# @type InstanceId: String
attr_accessor :InstanceId
def initialize(instanceid=nil)
@InstanceId = instanceid
end
def deserialize(params)
@InstanceId = params['InstanceId']
end
end
# DestroyPrometheusInstance返回参数结构体
class DestroyPrometheusInstanceResponse < 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 Dimension < TencentCloud::Common::AbstractModel
# @param Name: 实例维度名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param Value: 实例维度值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Value: String
attr_accessor :Name, :Value
def initialize(name=nil, value=nil)
@Name = name
@Value = value
end
def deserialize(params)
@Name = params['Name']
@Value = params['Value']
end
end
# 策略类型的维度信息
class DimensionNew < TencentCloud::Common::AbstractModel
# @param Key: 维度 key 标示,后台英文名
# @type Key: String
# @param Name: 维度 key 名称,中英文前台展示名
# @type Name: String
# @param IsRequired: 是否必选
# @type IsRequired: Boolean
# @param Operators: 支持的操作符列表
# @type Operators: Array
# @param IsMultiple: 是否支持多选
# @type IsMultiple: Boolean
# @param IsMutable: 创建后是否可以修改
# @type IsMutable: Boolean
# @param IsVisible: 是否展示给用户
# @type IsVisible: Boolean
# @param CanFilterPolicy: 能否用来过滤策略列表
# @type CanFilterPolicy: Boolean
# @param CanFilterHistory: 能否用来过滤告警历史
# @type CanFilterHistory: Boolean
# @param CanGroupBy: 能否作为聚合维度
# @type CanGroupBy: Boolean
# @param MustGroupBy: 是否必须作为聚合维度
# @type MustGroupBy: Boolean
# @param ShowValueReplace: 前端翻译要替换的 key
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ShowValueReplace: String
attr_accessor :Key, :Name, :IsRequired, :Operators, :IsMultiple, :IsMutable, :IsVisible, :CanFilterPolicy, :CanFilterHistory, :CanGroupBy, :MustGroupBy, :ShowValueReplace
def initialize(key=nil, name=nil, isrequired=nil, operators=nil, ismultiple=nil, ismutable=nil, isvisible=nil, canfilterpolicy=nil, canfilterhistory=nil, cangroupby=nil, mustgroupby=nil, showvaluereplace=nil)
@Key = key
@Name = name
@IsRequired = isrequired
@Operators = operators
@IsMultiple = ismultiple
@IsMutable = ismutable
@IsVisible = isvisible
@CanFilterPolicy = canfilterpolicy
@CanFilterHistory = canfilterhistory
@CanGroupBy = cangroupby
@MustGroupBy = mustgroupby
@ShowValueReplace = showvaluereplace
end
def deserialize(params)
@Key = params['Key']
@Name = params['Name']
@IsRequired = params['IsRequired']
unless params['Operators'].nil?
@Operators = []
params['Operators'].each do |i|
operator_tmp = Operator.new
operator_tmp.deserialize(i)
@Operators << operator_tmp
end
end
@IsMultiple = params['IsMultiple']
@IsMutable = params['IsMutable']
@IsVisible = params['IsVisible']
@CanFilterPolicy = params['CanFilterPolicy']
@CanFilterHistory = params['CanFilterHistory']
@CanGroupBy = params['CanGroupBy']
@MustGroupBy = params['MustGroupBy']
@ShowValueReplace = params['ShowValueReplace']
end
end
# 维度信息
class DimensionsDesc < TencentCloud::Common::AbstractModel
# @param Dimensions: 维度名数组
# @type Dimensions: Array
attr_accessor :Dimensions
def initialize(dimensions=nil)
@Dimensions = dimensions
end
def deserialize(params)
@Dimensions = params['Dimensions']
end
end
# EnableGrafanaInternet请求参数结构体
class EnableGrafanaInternetRequest < TencentCloud::Common::AbstractModel
# @param InstanceID: Grafana 实例 ID,例如:grafana-kleu3gt0
# @type InstanceID: String
# @param EnableInternet: 开启或关闭公网访问,true为开启,false 为不开启
# @type EnableInternet: Boolean
attr_accessor :InstanceID, :EnableInternet
def initialize(instanceid=nil, enableinternet=nil)
@InstanceID = instanceid
@EnableInternet = enableinternet
end
def deserialize(params)
@InstanceID = params['InstanceID']
@EnableInternet = params['EnableInternet']
end
end
# EnableGrafanaInternet返回参数结构体
class EnableGrafanaInternetResponse < 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
# EnableGrafanaSSO请求参数结构体
class EnableGrafanaSSORequest < TencentCloud::Common::AbstractModel
# @param EnableSSO: 是否开启 SSO,true为开启,false 为不开启
# @type EnableSSO: Boolean
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
attr_accessor :EnableSSO, :InstanceId
def initialize(enablesso=nil, instanceid=nil)
@EnableSSO = enablesso
@InstanceId = instanceid
end
def deserialize(params)
@EnableSSO = params['EnableSSO']
@InstanceId = params['InstanceId']
end
end
# EnableGrafanaSSO返回参数结构体
class EnableGrafanaSSOResponse < 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
# EnableSSOCamCheck请求参数结构体
class EnableSSOCamCheckRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
# @param EnableSSOCamCheck: 是否开启 cam 鉴权,true为开启,false 为不开启
# @type EnableSSOCamCheck: Boolean
attr_accessor :InstanceId, :EnableSSOCamCheck
def initialize(instanceid=nil, enablessocamcheck=nil)
@InstanceId = instanceid
@EnableSSOCamCheck = enablessocamcheck
end
def deserialize(params)
@InstanceId = params['InstanceId']
@EnableSSOCamCheck = params['EnableSSOCamCheck']
end
end
# EnableSSOCamCheck返回参数结构体
class EnableSSOCamCheckResponse < 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 EventCondition < TencentCloud::Common::AbstractModel
# @param AlarmNotifyPeriod: 告警通知频率
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlarmNotifyPeriod: String
# @param AlarmNotifyType: 重复通知策略预定义(0 - 只告警一次, 1 - 指数告警,2 - 连接告警)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlarmNotifyType: String
# @param EventID: 事件ID
# @type EventID: String
# @param EventDisplayName: 事件展示名称(对外)
# @type EventDisplayName: String
# @param RuleID: 规则ID
# @type RuleID: String
# @param MetricName: 指标名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MetricName: String
attr_accessor :AlarmNotifyPeriod, :AlarmNotifyType, :EventID, :EventDisplayName, :RuleID, :MetricName
def initialize(alarmnotifyperiod=nil, alarmnotifytype=nil, eventid=nil, eventdisplayname=nil, ruleid=nil, metricname=nil)
@AlarmNotifyPeriod = alarmnotifyperiod
@AlarmNotifyType = alarmnotifytype
@EventID = eventid
@EventDisplayName = eventdisplayname
@RuleID = ruleid
@MetricName = metricname
end
def deserialize(params)
@AlarmNotifyPeriod = params['AlarmNotifyPeriod']
@AlarmNotifyType = params['AlarmNotifyType']
@EventID = params['EventID']
@EventDisplayName = params['EventDisplayName']
@RuleID = params['RuleID']
@MetricName = params['MetricName']
end
end
# 查询过滤参数
class Filter < TencentCloud::Common::AbstractModel
# @param Type: 过滤方式(=, !=, in)
# @type Type: String
# @param Key: 过滤维度名
# @type Key: String
# @param Value: 过滤值,in过滤方式用逗号分割多个值
# @type Value: String
# @param Name: 过滤条件名称
# @type Name: String
# @param Values: 过滤条件取值范围
# @type Values: Array
attr_accessor :Type, :Key, :Value, :Name, :Values
def initialize(type=nil, key=nil, value=nil, name=nil, values=nil)
@Type = type
@Key = key
@Value = value
@Name = name
@Values = values
end
def deserialize(params)
@Type = params['Type']
@Key = params['Key']
@Value = params['Value']
@Name = params['Name']
@Values = params['Values']
end
end
# GetMonitorData请求参数结构体
class GetMonitorDataRequest < TencentCloud::Common::AbstractModel
# @param Namespace: 命名空间,如QCE/CVM。各个云产品的详细命名空间说明请参阅各个产品[监控指标](https://cloud.tencent.com/document/product/248/6140)文档
# @type Namespace: String
# @param MetricName: 指标名称,如CPUUsage,仅支持单指标拉取。各个云产品的详细指标说明请参阅各个产品[监控指标](https://cloud.tencent.com/document/product/248/6140)文档,对应的指标英文名即为MetricName
# @type MetricName: String
# @param Instances: 实例对象的维度组合,格式为key-value键值对形式的集合。不同类型的实例字段完全不同,如CVM为[{"Name":"InstanceId","Value":"ins-j0hk02zo"}],Ckafka为[{"Name":"instanceId","Value":"ckafka-l49k54dd"}],COS为[{"Name":"appid","Value":"1258344699"},{"Name":"bucket","Value":"rig-1258344699"}]。各个云产品的维度请参阅各个产品[监控指标](https://cloud.tencent.com/document/product/248/6140)文档,对应的维度列即为维度组合的key,value为key对应的值。单请求最多支持批量拉取10个实例的监控数据。
# @type Instances: Array
# @param Period: 监控统计周期,如60。默认为取值为300,单位为s。每个指标支持的统计周期不一定相同,各个云产品支持的统计周期请参阅各个产品[监控指标](https://cloud.tencent.com/document/product/248/6140)文档,对应的统计周期列即为支持的统计周期。单请求的数据点数限制为1440个。
# @type Period: Integer
# @param StartTime: 起始时间,如2018-09-22T19:51:23+08:00
# @type StartTime: String
# @param EndTime: 结束时间,如2018-09-22T20:51:23+08:00,默认为当前时间。 EndTime不能小于StartTime
# @type EndTime: String
# @param SpecifyStatistics: 返回多种统计方式数据。avg, max, min (1,2,4)可以自由组合
# @type SpecifyStatistics: Integer
attr_accessor :Namespace, :MetricName, :Instances, :Period, :StartTime, :EndTime, :SpecifyStatistics
def initialize(namespace=nil, metricname=nil, instances=nil, period=nil, starttime=nil, endtime=nil, specifystatistics=nil)
@Namespace = namespace
@MetricName = metricname
@Instances = instances
@Period = period
@StartTime = starttime
@EndTime = endtime
@SpecifyStatistics = specifystatistics
end
def deserialize(params)
@Namespace = params['Namespace']
@MetricName = params['MetricName']
unless params['Instances'].nil?
@Instances = []
params['Instances'].each do |i|
instance_tmp = Instance.new
instance_tmp.deserialize(i)
@Instances << instance_tmp
end
end
@Period = params['Period']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@SpecifyStatistics = params['SpecifyStatistics']
end
end
# GetMonitorData返回参数结构体
class GetMonitorDataResponse < TencentCloud::Common::AbstractModel
# @param Period: 统计周期
# @type Period: Integer
# @param MetricName: 指标名
# @type MetricName: String
# @param DataPoints: 数据点数组
# @type DataPoints: Array
# @param StartTime: 开始时间
# @type StartTime: String
# @param EndTime: 结束时间
# @type EndTime: String
# @param Msg: 返回信息
# @type Msg: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Period, :MetricName, :DataPoints, :StartTime, :EndTime, :Msg, :RequestId
def initialize(period=nil, metricname=nil, datapoints=nil, starttime=nil, endtime=nil, msg=nil, requestid=nil)
@Period = period
@MetricName = metricname
@DataPoints = datapoints
@StartTime = starttime
@EndTime = endtime
@Msg = msg
@RequestId = requestid
end
def deserialize(params)
@Period = params['Period']
@MetricName = params['MetricName']
unless params['DataPoints'].nil?
@DataPoints = []
params['DataPoints'].each do |i|
datapoint_tmp = DataPoint.new
datapoint_tmp.deserialize(i)
@DataPoints << datapoint_tmp
end
end
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@Msg = params['Msg']
@RequestId = params['RequestId']
end
end
# GetPrometheusAgentManagementCommand请求参数结构体
class GetPrometheusAgentManagementCommandRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param AgentId: Prometheus Agent ID
# @type AgentId: String
attr_accessor :InstanceId, :AgentId
def initialize(instanceid=nil, agentid=nil)
@InstanceId = instanceid
@AgentId = agentid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@AgentId = params['AgentId']
end
end
# GetPrometheusAgentManagementCommand返回参数结构体
class GetPrometheusAgentManagementCommandResponse < TencentCloud::Common::AbstractModel
# @param Command: Agent 管理命令
# @type Command: :class:`Tencentcloud::Monitor.v20180724.models.ManagementCommand`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Command, :RequestId
def initialize(command=nil, requestid=nil)
@Command = command
@RequestId = requestid
end
def deserialize(params)
unless params['Command'].nil?
@Command = ManagementCommand.new
@Command.deserialize(params['Command'])
end
@RequestId = params['RequestId']
end
end
# Grafana可视化服务 授权账户信息
class GrafanaAccountInfo < TencentCloud::Common::AbstractModel
# @param UserId: 用户账号ID
# @type UserId: String
# @param Role: 用户权限
# @type Role: Array
# @param Notes: 备注
# @type Notes: String
# @param CreateAt: 创建时间
# @type CreateAt: String
# @param InstanceId: 实例 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceId: String
# @param Uin: 用户主账号 UIN
# @type Uin: String
attr_accessor :UserId, :Role, :Notes, :CreateAt, :InstanceId, :Uin
def initialize(userid=nil, role=nil, notes=nil, createat=nil, instanceid=nil, uin=nil)
@UserId = userid
@Role = role
@Notes = notes
@CreateAt = createat
@InstanceId = instanceid
@Uin = uin
end
def deserialize(params)
@UserId = params['UserId']
unless params['Role'].nil?
@Role = []
params['Role'].each do |i|
grafanaaccountrole_tmp = GrafanaAccountRole.new
grafanaaccountrole_tmp.deserialize(i)
@Role << grafanaaccountrole_tmp
end
end
@Notes = params['Notes']
@CreateAt = params['CreateAt']
@InstanceId = params['InstanceId']
@Uin = params['Uin']
end
end
# Grafana可视化服务 账号权限
class GrafanaAccountRole < TencentCloud::Common::AbstractModel
# @param Organization: 组织
# @type Organization: String
# @param Role: 权限(Admin、Editor、Viewer)
# @type Role: String
attr_accessor :Organization, :Role
def initialize(organization=nil, role=nil)
@Organization = organization
@Role = role
end
def deserialize(params)
@Organization = params['Organization']
@Role = params['Role']
end
end
# Grafana 告警渠道
class GrafanaChannel < TencentCloud::Common::AbstractModel
# @param ChannelId: 渠道 ID
# @type ChannelId: String
# @param ChannelName: 渠道名
# @type ChannelName: String
# @param Receivers: 告警通道模板 ID 数组
# @type Receivers: Array
# @param CreatedAt: 创建时间
# @type CreatedAt: String
# @param UpdatedAt: 更新时间
# @type UpdatedAt: String
# @param OrganizationIds: 告警渠道的所有生效组织
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OrganizationIds: Array
attr_accessor :ChannelId, :ChannelName, :Receivers, :CreatedAt, :UpdatedAt, :OrganizationIds
def initialize(channelid=nil, channelname=nil, receivers=nil, createdat=nil, updatedat=nil, organizationids=nil)
@ChannelId = channelid
@ChannelName = channelname
@Receivers = receivers
@CreatedAt = createdat
@UpdatedAt = updatedat
@OrganizationIds = organizationids
end
def deserialize(params)
@ChannelId = params['ChannelId']
@ChannelName = params['ChannelName']
@Receivers = params['Receivers']
@CreatedAt = params['CreatedAt']
@UpdatedAt = params['UpdatedAt']
@OrganizationIds = params['OrganizationIds']
end
end
# 查询 Grafana 实例时的实例类型
class GrafanaInstanceInfo < TencentCloud::Common::AbstractModel
# @param InstanceName: 实例名
# @type InstanceName: String
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param Region: 地域
# @type Region: String
# @param VpcId: VPC ID
# @type VpcId: String
# @param SubnetIds: 子网 ID 数组
# @type SubnetIds: Array
# @param InternetUrl: Grafana 公网地址
# @type InternetUrl: String
# @param InternalUrl: Grafana 内网地址
# @type InternalUrl: String
# @param CreatedAt: 创建时间
# @type CreatedAt: String
# @param InstanceStatus: 运行状态(1:正在创建;2:运行中;3:异常;4:重启中;5:停机中; 6:已停机; 7: 已删除)
# @type InstanceStatus: Integer
# @param TagSpecification: 实例的标签
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TagSpecification: Array
# @param Zone: 实例的可用区
# @type Zone: String
# @param InstanceChargeType: 计费模式(1:包年包月)
# @type InstanceChargeType: Integer
# @param VpcName: VPC 名称
# @type VpcName: String
# @param SubnetName: 子网名称
# @type SubnetName: String
# @param RegionId: 地域 ID
# @type RegionId: Integer
# @param RootUrl: 可访问此实例的完整 URL
# @type RootUrl: String
# @param EnableSSO: 是否开启 SSO
# @type EnableSSO: Boolean
# @param Version: 版本号
# @type Version: String
# @param EnableSSOCamCheck: SSO登录时是否开启cam鉴权
# @type EnableSSOCamCheck: Boolean
attr_accessor :InstanceName, :InstanceId, :Region, :VpcId, :SubnetIds, :InternetUrl, :InternalUrl, :CreatedAt, :InstanceStatus, :TagSpecification, :Zone, :InstanceChargeType, :VpcName, :SubnetName, :RegionId, :RootUrl, :EnableSSO, :Version, :EnableSSOCamCheck
def initialize(instancename=nil, instanceid=nil, region=nil, vpcid=nil, subnetids=nil, interneturl=nil, internalurl=nil, createdat=nil, instancestatus=nil, tagspecification=nil, zone=nil, instancechargetype=nil, vpcname=nil, subnetname=nil, regionid=nil, rooturl=nil, enablesso=nil, version=nil, enablessocamcheck=nil)
@InstanceName = instancename
@InstanceId = instanceid
@Region = region
@VpcId = vpcid
@SubnetIds = subnetids
@InternetUrl = interneturl
@InternalUrl = internalurl
@CreatedAt = createdat
@InstanceStatus = instancestatus
@TagSpecification = tagspecification
@Zone = zone
@InstanceChargeType = instancechargetype
@VpcName = vpcname
@SubnetName = subnetname
@RegionId = regionid
@RootUrl = rooturl
@EnableSSO = enablesso
@Version = version
@EnableSSOCamCheck = enablessocamcheck
end
def deserialize(params)
@InstanceName = params['InstanceName']
@InstanceId = params['InstanceId']
@Region = params['Region']
@VpcId = params['VpcId']
@SubnetIds = params['SubnetIds']
@InternetUrl = params['InternetUrl']
@InternalUrl = params['InternalUrl']
@CreatedAt = params['CreatedAt']
@InstanceStatus = params['InstanceStatus']
unless params['TagSpecification'].nil?
@TagSpecification = []
params['TagSpecification'].each do |i|
prometheustag_tmp = PrometheusTag.new
prometheustag_tmp.deserialize(i)
@TagSpecification << prometheustag_tmp
end
end
@Zone = params['Zone']
@InstanceChargeType = params['InstanceChargeType']
@VpcName = params['VpcName']
@SubnetName = params['SubnetName']
@RegionId = params['RegionId']
@RootUrl = params['RootUrl']
@EnableSSO = params['EnableSSO']
@Version = params['Version']
@EnableSSOCamCheck = params['EnableSSOCamCheck']
end
end
# Grafana 集成实例配置
class GrafanaIntegrationConfig < TencentCloud::Common::AbstractModel
# @param IntegrationId: 集成 ID
# @type IntegrationId: String
# @param Kind: 集成类型
# @type Kind: String
# @param Content: 集成内容
# @type Content: String
# @param Description: 集成描述
# @type Description: String
# @param GrafanaURL: Grafana 跳转地址
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GrafanaURL: String
attr_accessor :IntegrationId, :Kind, :Content, :Description, :GrafanaURL
def initialize(integrationid=nil, kind=nil, content=nil, description=nil, grafanaurl=nil)
@IntegrationId = integrationid
@Kind = kind
@Content = content
@Description = description
@GrafanaURL = grafanaurl
end
def deserialize(params)
@IntegrationId = params['IntegrationId']
@Kind = params['Kind']
@Content = params['Content']
@Description = params['Description']
@GrafanaURL = params['GrafanaURL']
end
end
# Grafana 告警渠道
class GrafanaNotificationChannel < TencentCloud::Common::AbstractModel
# @param ChannelId: 渠道 ID
# @type ChannelId: String
# @param ChannelName: 渠道名
# @type ChannelName: String
# @param Receivers: 告警通道模板 ID 数组
# @type Receivers: Array
# @param CreatedAt: 创建时间
# @type CreatedAt: String
# @param UpdatedAt: 更新时间
# @type UpdatedAt: String
# @param OrgId: 默认生效组织,已废弃,请使用 OrganizationIds
# @type OrgId: String
# @param ExtraOrgIds: 额外生效组织,已废弃,请使用 OrganizationIds
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExtraOrgIds: Array
# @param OrgIds: 生效组织,已废弃,请使用 OrganizationIds
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OrgIds: Array
# @param OrganizationIds: 告警渠道的所有生效组织
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OrganizationIds: Array
attr_accessor :ChannelId, :ChannelName, :Receivers, :CreatedAt, :UpdatedAt, :OrgId, :ExtraOrgIds, :OrgIds, :OrganizationIds
def initialize(channelid=nil, channelname=nil, receivers=nil, createdat=nil, updatedat=nil, orgid=nil, extraorgids=nil, orgids=nil, organizationids=nil)
@ChannelId = channelid
@ChannelName = channelname
@Receivers = receivers
@CreatedAt = createdat
@UpdatedAt = updatedat
@OrgId = orgid
@ExtraOrgIds = extraorgids
@OrgIds = orgids
@OrganizationIds = organizationids
end
def deserialize(params)
@ChannelId = params['ChannelId']
@ChannelName = params['ChannelName']
@Receivers = params['Receivers']
@CreatedAt = params['CreatedAt']
@UpdatedAt = params['UpdatedAt']
@OrgId = params['OrgId']
@ExtraOrgIds = params['ExtraOrgIds']
@OrgIds = params['OrgIds']
@OrganizationIds = params['OrganizationIds']
end
end
# Grafana 插件
class GrafanaPlugin < TencentCloud::Common::AbstractModel
# @param PluginId: Grafana 插件 ID
# @type PluginId: String
# @param Version: Grafana 插件版本
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Version: String
attr_accessor :PluginId, :Version
def initialize(pluginid=nil, version=nil)
@PluginId = pluginid
@Version = version
end
def deserialize(params)
@PluginId = params['PluginId']
@Version = params['Version']
end
end
# InstallPlugins请求参数结构体
class InstallPluginsRequest < TencentCloud::Common::AbstractModel
# @param Plugins: 插件信息(可通过 DescribePluginOverviews 接口获取)
# @type Plugins: Array
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
attr_accessor :Plugins, :InstanceId
def initialize(plugins=nil, instanceid=nil)
@Plugins = plugins
@InstanceId = instanceid
end
def deserialize(params)
unless params['Plugins'].nil?
@Plugins = []
params['Plugins'].each do |i|
grafanaplugin_tmp = GrafanaPlugin.new
grafanaplugin_tmp.deserialize(i)
@Plugins << grafanaplugin_tmp
end
end
@InstanceId = params['InstanceId']
end
end
# InstallPlugins返回参数结构体
class InstallPluginsResponse < TencentCloud::Common::AbstractModel
# @param PluginIds: 已安装插件 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PluginIds: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PluginIds, :RequestId
def initialize(pluginids=nil, requestid=nil)
@PluginIds = pluginids
@RequestId = requestid
end
def deserialize(params)
@PluginIds = params['PluginIds']
@RequestId = params['RequestId']
end
end
# 实例维度组合数组
class Instance < TencentCloud::Common::AbstractModel
# @param Dimensions: 实例的维度组合
# @type Dimensions: Array
attr_accessor :Dimensions
def initialize(dimensions=nil)
@Dimensions = dimensions
end
def deserialize(params)
unless params['Dimensions'].nil?
@Dimensions = []
params['Dimensions'].each do |i|
dimension_tmp = Dimension.new
dimension_tmp.deserialize(i)
@Dimensions << dimension_tmp
end
end
end
end
# DescribeBasicAlarmList返回的Alarms里的InstanceGroup
class InstanceGroup < TencentCloud::Common::AbstractModel
# @param InstanceGroupId: 实例组ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceGroupId: Integer
# @param InstanceGroupName: 实例组名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceGroupName: String
attr_accessor :InstanceGroupId, :InstanceGroupName
def initialize(instancegroupid=nil, instancegroupname=nil)
@InstanceGroupId = instancegroupid
@InstanceGroupName = instancegroupname
end
def deserialize(params)
@InstanceGroupId = params['InstanceGroupId']
@InstanceGroupName = params['InstanceGroupName']
end
end
# 告警对象所属实例组
class InstanceGroups < TencentCloud::Common::AbstractModel
# @param Id: 实例组 Id
# @type Id: Integer
# @param Name: 实例组名称
# @type Name: String
attr_accessor :Id, :Name
def initialize(id=nil, name=nil)
@Id = id
@Name = name
end
def deserialize(params)
@Id = params['Id']
@Name = params['Name']
end
end
# export 集成配置
class IntegrationConfiguration < TencentCloud::Common::AbstractModel
# @param Name: 名字
# @type Name: String
# @param Kind: 类型
# @type Kind: String
# @param Content: 内容
# @type Content: String
# @param Status: 状态
# @type Status: Integer
# @param Category: 实例类型
# @type Category: String
# @param InstanceDesc: 实例描述
# @type InstanceDesc: String
# @param GrafanaDashboardURL: dashboard 的 URL
# @type GrafanaDashboardURL: String
attr_accessor :Name, :Kind, :Content, :Status, :Category, :InstanceDesc, :GrafanaDashboardURL
def initialize(name=nil, kind=nil, content=nil, status=nil, category=nil, instancedesc=nil, grafanadashboardurl=nil)
@Name = name
@Kind = kind
@Content = content
@Status = status
@Category = category
@InstanceDesc = instancedesc
@GrafanaDashboardURL = grafanadashboardurl
end
def deserialize(params)
@Name = params['Name']
@Kind = params['Kind']
@Content = params['Content']
@Status = params['Status']
@Category = params['Category']
@InstanceDesc = params['InstanceDesc']
@GrafanaDashboardURL = params['GrafanaDashboardURL']
end
end
# k8s中标签,一般以数组的方式存在
class Label < TencentCloud::Common::AbstractModel
# @param Name: map表中的Name
# @type Name: String
# @param Value: map表中的Value
# @type Value: String
attr_accessor :Name, :Value
def initialize(name=nil, value=nil)
@Name = name
@Value = value
end
def deserialize(params)
@Name = params['Name']
@Value = params['Value']
end
end
# 日志告警请求信息
class LogAlarmReq < TencentCloud::Common::AbstractModel
# @param InstanceId: apm实例id
# @type InstanceId: String
# @param Filter: 检索条件信息
# @type Filter: Array
# @param AlarmMerge: 告警合并开启/暂停
# @type AlarmMerge: String
# @param AlarmMergeTime: 告警合并时间
# @type AlarmMergeTime: String
attr_accessor :InstanceId, :Filter, :AlarmMerge, :AlarmMergeTime
def initialize(instanceid=nil, filter=nil, alarmmerge=nil, alarmmergetime=nil)
@InstanceId = instanceid
@Filter = filter
@AlarmMerge = alarmmerge
@AlarmMergeTime = alarmmergetime
end
def deserialize(params)
@InstanceId = params['InstanceId']
unless params['Filter'].nil?
@Filter = []
params['Filter'].each do |i|
logfilterinfo_tmp = LogFilterInfo.new
logfilterinfo_tmp.deserialize(i)
@Filter << logfilterinfo_tmp
end
end
@AlarmMerge = params['AlarmMerge']
@AlarmMergeTime = params['AlarmMergeTime']
end
end
# 日志告警检索条件结构体
class LogFilterInfo < TencentCloud::Common::AbstractModel
# @param Key: 字段名
# @type Key: String
# @param Operator: 比较符号
# @type Operator: String
# @param Value: 字段值
# @type Value: String
attr_accessor :Key, :Operator, :Value
def initialize(key=nil, operator=nil, value=nil)
@Key = key
@Operator = operator
@Value = value
end
def deserialize(params)
@Key = params['Key']
@Operator = params['Operator']
@Value = params['Value']
end
end
# Prometheus Agent 管理命令行
class ManagementCommand < TencentCloud::Common::AbstractModel
# @param Install: Agent 安装命令
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Install: String
# @param Restart: Agent 重启命令
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Restart: String
# @param Stop: Agent 停止命令
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Stop: String
# @param StatusCheck: Agent 状态检测命令
# 注意:此字段可能返回 null,表示取不到有效值。
# @type StatusCheck: String
# @param LogCheck: Agent 日志检测命令
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LogCheck: String
attr_accessor :Install, :Restart, :Stop, :StatusCheck, :LogCheck
def initialize(install=nil, restart=nil, stop=nil, statuscheck=nil, logcheck=nil)
@Install = install
@Restart = restart
@Stop = stop
@StatusCheck = statuscheck
@LogCheck = logcheck
end
def deserialize(params)
@Install = params['Install']
@Restart = params['Restart']
@Stop = params['Stop']
@StatusCheck = params['StatusCheck']
@LogCheck = params['LogCheck']
end
end
# 指标,可用于设置告警、查询数据
class Metric < TencentCloud::Common::AbstractModel
# @param Namespace: 告警策略类型
# @type Namespace: String
# @param MetricName: 指标名
# @type MetricName: String
# @param Description: 指标展示名
# @type Description: String
# @param Min: 最小值
# @type Min: Float
# @param Max: 最大值
# @type Max: Float
# @param Dimensions: 维度列表
# @type Dimensions: Array
# @param Unit: 单位
# @type Unit: String
# @param MetricConfig: 指标配置
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MetricConfig: :class:`Tencentcloud::Monitor.v20180724.models.MetricConfig`
# @param IsAdvanced: 是否为高级指标。1是 0否
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsAdvanced: Integer
# @param IsOpen: 高级指标是否开通。1是 0否
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsOpen: Integer
# @param ProductId: 集成中心产品ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProductId: Integer
# @param Operators: 匹配运算符
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Operators: Array
# @param Periods: 指标触发
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Periods: Array
# @param IsLatenessMetric: 是否延迟指标
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsLatenessMetric: Integer
attr_accessor :Namespace, :MetricName, :Description, :Min, :Max, :Dimensions, :Unit, :MetricConfig, :IsAdvanced, :IsOpen, :ProductId, :Operators, :Periods, :IsLatenessMetric
def initialize(namespace=nil, metricname=nil, description=nil, min=nil, max=nil, dimensions=nil, unit=nil, metricconfig=nil, isadvanced=nil, isopen=nil, productid=nil, operators=nil, periods=nil, islatenessmetric=nil)
@Namespace = namespace
@MetricName = metricname
@Description = description
@Min = min
@Max = max
@Dimensions = dimensions
@Unit = unit
@MetricConfig = metricconfig
@IsAdvanced = isadvanced
@IsOpen = isopen
@ProductId = productid
@Operators = operators
@Periods = periods
@IsLatenessMetric = islatenessmetric
end
def deserialize(params)
@Namespace = params['Namespace']
@MetricName = params['MetricName']
@Description = params['Description']
@Min = params['Min']
@Max = params['Max']
@Dimensions = params['Dimensions']
@Unit = params['Unit']
unless params['MetricConfig'].nil?
@MetricConfig = MetricConfig.new
@MetricConfig.deserialize(params['MetricConfig'])
end
@IsAdvanced = params['IsAdvanced']
@IsOpen = params['IsOpen']
@ProductId = params['ProductId']
unless params['Operators'].nil?
@Operators = []
params['Operators'].each do |i|
operator_tmp = Operator.new
operator_tmp.deserialize(i)
@Operators << operator_tmp
end
end
@Periods = params['Periods']
@IsLatenessMetric = params['IsLatenessMetric']
end
end
# 指标配置
class MetricConfig < TencentCloud::Common::AbstractModel
# @param Operator: 允许使用的运算符
# @type Operator: Array
# @param Period: 允许配置的数据周期,以秒为单位
# @type Period: Array
# @param ContinuePeriod: 允许配置的持续周期个数
# @type ContinuePeriod: Array
attr_accessor :Operator, :Period, :ContinuePeriod
def initialize(operator=nil, period=nil, continueperiod=nil)
@Operator = operator
@Period = period
@ContinuePeriod = continueperiod
end
def deserialize(params)
@Operator = params['Operator']
@Period = params['Period']
@ContinuePeriod = params['ContinuePeriod']
end
end
# DescribeMetricData接口出参
class MetricData < TencentCloud::Common::AbstractModel
# @param MetricName: 指标名
# @type MetricName: String
# @param Points: 监控数据点
# @type Points: Array
attr_accessor :MetricName, :Points
def initialize(metricname=nil, points=nil)
@MetricName = metricname
@Points = points
end
def deserialize(params)
@MetricName = params['MetricName']
unless params['Points'].nil?
@Points = []
params['Points'].each do |i|
metricdatapoint_tmp = MetricDataPoint.new
metricdatapoint_tmp.deserialize(i)
@Points << metricdatapoint_tmp
end
end
end
end
# DescribeMetricData出参
class MetricDataPoint < TencentCloud::Common::AbstractModel
# @param Dimensions: 实例对象维度组合
# @type Dimensions: Array
# @param Values: 数据点列表
# @type Values: Array
attr_accessor :Dimensions, :Values
def initialize(dimensions=nil, values=nil)
@Dimensions = dimensions
@Values = values
end
def deserialize(params)
unless params['Dimensions'].nil?
@Dimensions = []
params['Dimensions'].each do |i|
dimension_tmp = Dimension.new
dimension_tmp.deserialize(i)
@Dimensions << dimension_tmp
end
end
unless params['Values'].nil?
@Values = []
params['Values'].each do |i|
point_tmp = Point.new
point_tmp.deserialize(i)
@Values << point_tmp
end
end
end
end
# 指标数据的解释
class MetricObjectMeaning < TencentCloud::Common::AbstractModel
# @param En: 指标英文解释
# @type En: String
# @param Zh: 指标中文解释
# @type Zh: String
attr_accessor :En, :Zh
def initialize(en=nil, zh=nil)
@En = en
@Zh = zh
end
def deserialize(params)
@En = params['En']
@Zh = params['Zh']
end
end
# 对业务指标的单位及支持统计周期的描述
class MetricSet < TencentCloud::Common::AbstractModel
# @param Namespace: 命名空间,每个云产品会有一个命名空间
# @type Namespace: String
# @param MetricName: 指标名称
# @type MetricName: String
# @param Unit: 指标使用的单位
# @type Unit: String
# @param UnitCname: 指标使用的单位
# @type UnitCname: String
# @param Period: 指标支持的统计周期,单位是秒,如60、300
# @type Period: Array
# @param Periods: 统计周期内指标方式
# @type Periods: Array
# @param Meaning: 统计指标含义解释
# @type Meaning: :class:`Tencentcloud::Monitor.v20180724.models.MetricObjectMeaning`
# @param Dimensions: 维度描述信息
# @type Dimensions: Array
# @param MetricCName: 指标中文名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MetricCName: String
# @param MetricEName: 指标英文名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MetricEName: String
attr_accessor :Namespace, :MetricName, :Unit, :UnitCname, :Period, :Periods, :Meaning, :Dimensions, :MetricCName, :MetricEName
def initialize(namespace=nil, metricname=nil, unit=nil, unitcname=nil, period=nil, periods=nil, meaning=nil, dimensions=nil, metriccname=nil, metricename=nil)
@Namespace = namespace
@MetricName = metricname
@Unit = unit
@UnitCname = unitcname
@Period = period
@Periods = periods
@Meaning = meaning
@Dimensions = dimensions
@MetricCName = metriccname
@MetricEName = metricename
end
def deserialize(params)
@Namespace = params['Namespace']
@MetricName = params['MetricName']
@Unit = params['Unit']
@UnitCname = params['UnitCname']
@Period = params['Period']
unless params['Periods'].nil?
@Periods = []
params['Periods'].each do |i|
periodsst_tmp = PeriodsSt.new
periodsst_tmp.deserialize(i)
@Periods << periodsst_tmp
end
end
unless params['Meaning'].nil?
@Meaning = MetricObjectMeaning.new
@Meaning.deserialize(params['Meaning'])
end
unless params['Dimensions'].nil?
@Dimensions = []
params['Dimensions'].each do |i|
dimensionsdesc_tmp = DimensionsDesc.new
dimensionsdesc_tmp.deserialize(i)
@Dimensions << dimensionsdesc_tmp
end
end
@MetricCName = params['MetricCName']
@MetricEName = params['MetricEName']
end
end
# DescribeMidDimensionValueList的查询条件
class MidQueryCondition < TencentCloud::Common::AbstractModel
# @param Key: 维度
# @type Key: String
# @param Operator: 操作符,支持等于(eq)、不等于(ne),以及in
# @type Operator: String
# @param Value: 维度值,当Op是eq、ne时,只使用第一个元素
# @type Value: Array
attr_accessor :Key, :Operator, :Value
def initialize(key=nil, operator=nil, value=nil)
@Key = key
@Operator = operator
@Value = value
end
def deserialize(params)
@Key = params['Key']
@Operator = params['Operator']
@Value = params['Value']
end
end
# ModifyAlarmNotice请求参数结构体
class ModifyAlarmNoticeRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,这里填“monitor”
# @type Module: String
# @param Name: 告警通知规则名称 60字符以内
# @type Name: String
# @param NoticeType: 通知类型 ALARM=未恢复通知 OK=已恢复通知 ALL=都通知
# @type NoticeType: String
# @param NoticeLanguage: 通知语言 zh-CN=中文 en-US=英文
# @type NoticeLanguage: String
# @param NoticeId: 告警通知模板 ID
# @type NoticeId: String
# @param UserNotices: 用户通知 最多5个
# @type UserNotices: Array
# @param URLNotices: 回调通知 最多6个
# @type URLNotices: Array
# @param CLSNotices: 告警通知推送到CLS服务 最多1个
# @type CLSNotices: Array
# @param PolicyIds: 告警通知模板绑定的告警策略ID列表
# @type PolicyIds: Array
attr_accessor :Module, :Name, :NoticeType, :NoticeLanguage, :NoticeId, :UserNotices, :URLNotices, :CLSNotices, :PolicyIds
def initialize(_module=nil, name=nil, noticetype=nil, noticelanguage=nil, noticeid=nil, usernotices=nil, urlnotices=nil, clsnotices=nil, policyids=nil)
@Module = _module
@Name = name
@NoticeType = noticetype
@NoticeLanguage = noticelanguage
@NoticeId = noticeid
@UserNotices = usernotices
@URLNotices = urlnotices
@CLSNotices = clsnotices
@PolicyIds = policyids
end
def deserialize(params)
@Module = params['Module']
@Name = params['Name']
@NoticeType = params['NoticeType']
@NoticeLanguage = params['NoticeLanguage']
@NoticeId = params['NoticeId']
unless params['UserNotices'].nil?
@UserNotices = []
params['UserNotices'].each do |i|
usernotice_tmp = UserNotice.new
usernotice_tmp.deserialize(i)
@UserNotices << usernotice_tmp
end
end
unless params['URLNotices'].nil?
@URLNotices = []
params['URLNotices'].each do |i|
urlnotice_tmp = URLNotice.new
urlnotice_tmp.deserialize(i)
@URLNotices << urlnotice_tmp
end
end
unless params['CLSNotices'].nil?
@CLSNotices = []
params['CLSNotices'].each do |i|
clsnotice_tmp = CLSNotice.new
clsnotice_tmp.deserialize(i)
@CLSNotices << clsnotice_tmp
end
end
@PolicyIds = params['PolicyIds']
end
end
# ModifyAlarmNotice返回参数结构体
class ModifyAlarmNoticeResponse < 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
# ModifyAlarmPolicyCondition请求参数结构体
class ModifyAlarmPolicyConditionRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,固定值 monitor
# @type Module: String
# @param PolicyId: 告警策略 ID
# @type PolicyId: String
# @param ConditionTemplateId: 触发条件模板 Id,可不传
# @type ConditionTemplateId: Integer
# @param Condition: 指标触发条件
# @type Condition: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyCondition`
# @param EventCondition: 事件触发条件
# @type EventCondition: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyEventCondition`
# @param Filter: 全局过滤条件
# @type Filter: :class:`Tencentcloud::Monitor.v20180724.models.AlarmPolicyFilter`
# @param GroupBy: 聚合维度列表,指定按哪些维度 key 来做 group by
# @type GroupBy: Array
# @param LogAlarmReqInfo: 日志告警创建请求参数信息
# @type LogAlarmReqInfo: :class:`Tencentcloud::Monitor.v20180724.models.LogAlarmReq`
# @param NoticeIds: 模板id,专供prom使用
# @type NoticeIds: Array
# @param Enable: 启停状态,0=停用,1=启用
# @type Enable: Integer
# @param PolicyName: 专供prom策略名称
# @type PolicyName: String
# @param EbSubject: 事件配置的告警
# @type EbSubject: String
attr_accessor :Module, :PolicyId, :ConditionTemplateId, :Condition, :EventCondition, :Filter, :GroupBy, :LogAlarmReqInfo, :NoticeIds, :Enable, :PolicyName, :EbSubject
def initialize(_module=nil, policyid=nil, conditiontemplateid=nil, condition=nil, eventcondition=nil, filter=nil, groupby=nil, logalarmreqinfo=nil, noticeids=nil, enable=nil, policyname=nil, ebsubject=nil)
@Module = _module
@PolicyId = policyid
@ConditionTemplateId = conditiontemplateid
@Condition = condition
@EventCondition = eventcondition
@Filter = filter
@GroupBy = groupby
@LogAlarmReqInfo = logalarmreqinfo
@NoticeIds = noticeids
@Enable = enable
@PolicyName = policyname
@EbSubject = ebsubject
end
def deserialize(params)
@Module = params['Module']
@PolicyId = params['PolicyId']
@ConditionTemplateId = params['ConditionTemplateId']
unless params['Condition'].nil?
@Condition = AlarmPolicyCondition.new
@Condition.deserialize(params['Condition'])
end
unless params['EventCondition'].nil?
@EventCondition = AlarmPolicyEventCondition.new
@EventCondition.deserialize(params['EventCondition'])
end
unless params['Filter'].nil?
@Filter = AlarmPolicyFilter.new
@Filter.deserialize(params['Filter'])
end
@GroupBy = params['GroupBy']
unless params['LogAlarmReqInfo'].nil?
@LogAlarmReqInfo = LogAlarmReq.new
@LogAlarmReqInfo.deserialize(params['LogAlarmReqInfo'])
end
@NoticeIds = params['NoticeIds']
@Enable = params['Enable']
@PolicyName = params['PolicyName']
@EbSubject = params['EbSubject']
end
end
# ModifyAlarmPolicyCondition返回参数结构体
class ModifyAlarmPolicyConditionResponse < 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
# ModifyAlarmPolicyInfo请求参数结构体
class ModifyAlarmPolicyInfoRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,这里填“monitor”
# @type Module: String
# @param PolicyId: 告警策略 ID
# @type PolicyId: String
# @param Key: 要修改的字段 NAME=策略名称 REMARK=策略备注
# @type Key: String
# @param Value: 修改后的值
# @type Value: String
attr_accessor :Module, :PolicyId, :Key, :Value
def initialize(_module=nil, policyid=nil, key=nil, value=nil)
@Module = _module
@PolicyId = policyid
@Key = key
@Value = value
end
def deserialize(params)
@Module = params['Module']
@PolicyId = params['PolicyId']
@Key = params['Key']
@Value = params['Value']
end
end
# ModifyAlarmPolicyInfo返回参数结构体
class ModifyAlarmPolicyInfoResponse < 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
# ModifyAlarmPolicyNotice请求参数结构体
class ModifyAlarmPolicyNoticeRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,这里填“monitor”。
# @type Module: String
# @param PolicyId: 告警策略 ID,如果该参数与PolicyIds参数同时存在,则以PolicyIds为准。
# @type PolicyId: String
# @param NoticeIds: 告警通知模板 ID 列表。
# @type NoticeIds: Array
# @param PolicyIds: 告警策略ID数组,支持给多个告警策略批量绑定通知模板。最多30个。
# @type PolicyIds: Array
# @param HierarchicalNotices: 告警分级通知规则配置
# @type HierarchicalNotices: Array
attr_accessor :Module, :PolicyId, :NoticeIds, :PolicyIds, :HierarchicalNotices
def initialize(_module=nil, policyid=nil, noticeids=nil, policyids=nil, hierarchicalnotices=nil)
@Module = _module
@PolicyId = policyid
@NoticeIds = noticeids
@PolicyIds = policyids
@HierarchicalNotices = hierarchicalnotices
end
def deserialize(params)
@Module = params['Module']
@PolicyId = params['PolicyId']
@NoticeIds = params['NoticeIds']
@PolicyIds = params['PolicyIds']
unless params['HierarchicalNotices'].nil?
@HierarchicalNotices = []
params['HierarchicalNotices'].each do |i|
alarmhierarchicalnotice_tmp = AlarmHierarchicalNotice.new
alarmhierarchicalnotice_tmp.deserialize(i)
@HierarchicalNotices << alarmhierarchicalnotice_tmp
end
end
end
end
# ModifyAlarmPolicyNotice返回参数结构体
class ModifyAlarmPolicyNoticeResponse < 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
# ModifyAlarmPolicyStatus请求参数结构体
class ModifyAlarmPolicyStatusRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,固定值 monitor
# @type Module: String
# @param PolicyId: 告警策略 ID
# @type PolicyId: String
# @param Enable: 启停状态 0=停用 1=启用
# @type Enable: Integer
attr_accessor :Module, :PolicyId, :Enable
def initialize(_module=nil, policyid=nil, enable=nil)
@Module = _module
@PolicyId = policyid
@Enable = enable
end
def deserialize(params)
@Module = params['Module']
@PolicyId = params['PolicyId']
@Enable = params['Enable']
end
end
# ModifyAlarmPolicyStatus返回参数结构体
class ModifyAlarmPolicyStatusResponse < 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
# ModifyAlarmPolicyTasks请求参数结构体
class ModifyAlarmPolicyTasksRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,这里填“monitor”
# @type Module: String
# @param PolicyId: 告警策略 ID
# @type PolicyId: String
# @param TriggerTasks: 告警策略触发任务列表,空数据代表解绑
# @type TriggerTasks: Array
attr_accessor :Module, :PolicyId, :TriggerTasks
def initialize(_module=nil, policyid=nil, triggertasks=nil)
@Module = _module
@PolicyId = policyid
@TriggerTasks = triggertasks
end
def deserialize(params)
@Module = params['Module']
@PolicyId = params['PolicyId']
unless params['TriggerTasks'].nil?
@TriggerTasks = []
params['TriggerTasks'].each do |i|
alarmpolicytriggertask_tmp = AlarmPolicyTriggerTask.new
alarmpolicytriggertask_tmp.deserialize(i)
@TriggerTasks << alarmpolicytriggertask_tmp
end
end
end
end
# ModifyAlarmPolicyTasks返回参数结构体
class ModifyAlarmPolicyTasksResponse < 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
# ModifyAlarmReceivers请求参数结构体
class ModifyAlarmReceiversRequest < TencentCloud::Common::AbstractModel
# @param GroupId: 需要修改接收人的策略组Id
# @type GroupId: Integer
# @param Module: 必填。固定为“monitor”
# @type Module: String
# @param ReceiverInfos: 新接收人信息, 没有填写则删除所有接收人
# @type ReceiverInfos: Array
attr_accessor :GroupId, :Module, :ReceiverInfos
def initialize(groupid=nil, _module=nil, receiverinfos=nil)
@GroupId = groupid
@Module = _module
@ReceiverInfos = receiverinfos
end
def deserialize(params)
@GroupId = params['GroupId']
@Module = params['Module']
unless params['ReceiverInfos'].nil?
@ReceiverInfos = []
params['ReceiverInfos'].each do |i|
receiverinfo_tmp = ReceiverInfo.new
receiverinfo_tmp.deserialize(i)
@ReceiverInfos << receiverinfo_tmp
end
end
end
end
# ModifyAlarmReceivers返回参数结构体
class ModifyAlarmReceiversResponse < 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
# ModifyGrafanaInstance请求参数结构体
class ModifyGrafanaInstanceRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
# @param InstanceName: Grafana 实例名称,例如:test
# @type InstanceName: String
attr_accessor :InstanceId, :InstanceName
def initialize(instanceid=nil, instancename=nil)
@InstanceId = instanceid
@InstanceName = instancename
end
def deserialize(params)
@InstanceId = params['InstanceId']
@InstanceName = params['InstanceName']
end
end
# ModifyGrafanaInstance返回参数结构体
class ModifyGrafanaInstanceResponse < 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 ModifyPolicyGroupCondition < TencentCloud::Common::AbstractModel
# @param MetricId: 指标id
# @type MetricId: Integer
# @param CalcType: 比较类型,1表示大于,2表示大于等于,3表示小于,4表示小于等于,5表示相等,6表示不相等
# @type CalcType: Integer
# @param CalcValue: 检测阈值
# @type CalcValue: String
# @param CalcPeriod: 检测指标的数据周期
# @type CalcPeriod: Integer
# @param ContinuePeriod: 持续周期个数
# @type ContinuePeriod: Integer
# @param AlarmNotifyType: 告警发送收敛类型。0连续告警,1指数告警
# @type AlarmNotifyType: Integer
# @param AlarmNotifyPeriod: 告警发送周期单位秒。<0 不触发, 0 只触发一次, >0 每隔triggerTime秒触发一次
# @type AlarmNotifyPeriod: Integer
# @param RuleId: 规则id,不填表示新增,填写了ruleId表示在已存在的规则基础上进行修改
# @type RuleId: Integer
attr_accessor :MetricId, :CalcType, :CalcValue, :CalcPeriod, :ContinuePeriod, :AlarmNotifyType, :AlarmNotifyPeriod, :RuleId
def initialize(metricid=nil, calctype=nil, calcvalue=nil, calcperiod=nil, continueperiod=nil, alarmnotifytype=nil, alarmnotifyperiod=nil, ruleid=nil)
@MetricId = metricid
@CalcType = calctype
@CalcValue = calcvalue
@CalcPeriod = calcperiod
@ContinuePeriod = continueperiod
@AlarmNotifyType = alarmnotifytype
@AlarmNotifyPeriod = alarmnotifyperiod
@RuleId = ruleid
end
def deserialize(params)
@MetricId = params['MetricId']
@CalcType = params['CalcType']
@CalcValue = params['CalcValue']
@CalcPeriod = params['CalcPeriod']
@ContinuePeriod = params['ContinuePeriod']
@AlarmNotifyType = params['AlarmNotifyType']
@AlarmNotifyPeriod = params['AlarmNotifyPeriod']
@RuleId = params['RuleId']
end
end
# 修改告警策略组传入的事件告警条件
class ModifyPolicyGroupEventCondition < TencentCloud::Common::AbstractModel
# @param EventId: 事件id
# @type EventId: Integer
# @param AlarmNotifyType: 告警发送收敛类型。0连续告警,1指数告警
# @type AlarmNotifyType: Integer
# @param AlarmNotifyPeriod: 告警发送周期单位秒。<0 不触发, 0 只触发一次, >0 每隔triggerTime秒触发一次
# @type AlarmNotifyPeriod: Integer
# @param RuleId: 规则id,不填表示新增,填写了ruleId表示在已存在的规则基础上进行修改
# @type RuleId: Integer
attr_accessor :EventId, :AlarmNotifyType, :AlarmNotifyPeriod, :RuleId
def initialize(eventid=nil, alarmnotifytype=nil, alarmnotifyperiod=nil, ruleid=nil)
@EventId = eventid
@AlarmNotifyType = alarmnotifytype
@AlarmNotifyPeriod = alarmnotifyperiod
@RuleId = ruleid
end
def deserialize(params)
@EventId = params['EventId']
@AlarmNotifyType = params['AlarmNotifyType']
@AlarmNotifyPeriod = params['AlarmNotifyPeriod']
@RuleId = params['RuleId']
end
end
# ModifyPolicyGroup请求参数结构体
class ModifyPolicyGroupRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param GroupId: 策略组id
# @type GroupId: Integer
# @param ViewName: 告警类型
# @type ViewName: String
# @param GroupName: 策略组名称
# @type GroupName: String
# @param IsUnionRule: 指标告警条件的且或关系,1表示且告警,所有指标告警条件都达到才告警,0表示或告警,任意指标告警条件达到都告警
# @type IsUnionRule: Integer
# @param Conditions: 指标告警条件规则,不填表示删除已有的所有指标告警条件规则
# @type Conditions: Array
# @param EventConditions: 事件告警条件,不填表示删除已有的事件告警条件
# @type EventConditions: Array
# @param ConditionTempGroupId: 模板策略组id
# @type ConditionTempGroupId: Integer
attr_accessor :Module, :GroupId, :ViewName, :GroupName, :IsUnionRule, :Conditions, :EventConditions, :ConditionTempGroupId
def initialize(_module=nil, groupid=nil, viewname=nil, groupname=nil, isunionrule=nil, conditions=nil, eventconditions=nil, conditiontempgroupid=nil)
@Module = _module
@GroupId = groupid
@ViewName = viewname
@GroupName = groupname
@IsUnionRule = isunionrule
@Conditions = conditions
@EventConditions = eventconditions
@ConditionTempGroupId = conditiontempgroupid
end
def deserialize(params)
@Module = params['Module']
@GroupId = params['GroupId']
@ViewName = params['ViewName']
@GroupName = params['GroupName']
@IsUnionRule = params['IsUnionRule']
unless params['Conditions'].nil?
@Conditions = []
params['Conditions'].each do |i|
modifypolicygroupcondition_tmp = ModifyPolicyGroupCondition.new
modifypolicygroupcondition_tmp.deserialize(i)
@Conditions << modifypolicygroupcondition_tmp
end
end
unless params['EventConditions'].nil?
@EventConditions = []
params['EventConditions'].each do |i|
modifypolicygroupeventcondition_tmp = ModifyPolicyGroupEventCondition.new
modifypolicygroupeventcondition_tmp.deserialize(i)
@EventConditions << modifypolicygroupeventcondition_tmp
end
end
@ConditionTempGroupId = params['ConditionTempGroupId']
end
end
# ModifyPolicyGroup返回参数结构体
class ModifyPolicyGroupResponse < TencentCloud::Common::AbstractModel
# @param GroupId: 策略组id
# @type GroupId: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :GroupId, :RequestId
def initialize(groupid=nil, requestid=nil)
@GroupId = groupid
@RequestId = requestid
end
def deserialize(params)
@GroupId = params['GroupId']
@RequestId = params['RequestId']
end
end
# ModifyPrometheusAgentExternalLabels请求参数结构体
class ModifyPrometheusAgentExternalLabelsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
# @param ClusterId: 集群ID
# @type ClusterId: String
# @param ExternalLabels: 新的external_labels
# @type ExternalLabels: Array
attr_accessor :InstanceId, :ClusterId, :ExternalLabels
def initialize(instanceid=nil, clusterid=nil, externallabels=nil)
@InstanceId = instanceid
@ClusterId = clusterid
@ExternalLabels = externallabels
end
def deserialize(params)
@InstanceId = params['InstanceId']
@ClusterId = params['ClusterId']
unless params['ExternalLabels'].nil?
@ExternalLabels = []
params['ExternalLabels'].each do |i|
label_tmp = Label.new
label_tmp.deserialize(i)
@ExternalLabels << label_tmp
end
end
end
end
# ModifyPrometheusAgentExternalLabels返回参数结构体
class ModifyPrometheusAgentExternalLabelsResponse < 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
# ModifyPrometheusAlertPolicy请求参数结构体
class ModifyPrometheusAlertPolicyRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param AlertRule: 告警配置,[具体参考](https://cloud.tencent.com/document/api/248/30354#PrometheusAlertPolicyItem)
# @type AlertRule: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusAlertPolicyItem`
attr_accessor :InstanceId, :AlertRule
def initialize(instanceid=nil, alertrule=nil)
@InstanceId = instanceid
@AlertRule = alertrule
end
def deserialize(params)
@InstanceId = params['InstanceId']
unless params['AlertRule'].nil?
@AlertRule = PrometheusAlertPolicyItem.new
@AlertRule.deserialize(params['AlertRule'])
end
end
end
# ModifyPrometheusAlertPolicy返回参数结构体
class ModifyPrometheusAlertPolicyResponse < 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
# ModifyPrometheusConfig请求参数结构体
class ModifyPrometheusConfigRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param ClusterType: 集群类型
# @type ClusterType: String
# @param ClusterId: 集群id
# @type ClusterId: String
# @param ServiceMonitors: ServiceMonitors配置
# @type ServiceMonitors: Array
# @param PodMonitors: PodMonitors配置
# @type PodMonitors: Array
# @param RawJobs: prometheus原生Job配置
# @type RawJobs: Array
# @param UpdateImage: 0: 更新实例组件镜像版本;
# 1: 不更新实例组件镜像版本
# @type UpdateImage: Integer
attr_accessor :InstanceId, :ClusterType, :ClusterId, :ServiceMonitors, :PodMonitors, :RawJobs, :UpdateImage
def initialize(instanceid=nil, clustertype=nil, clusterid=nil, servicemonitors=nil, podmonitors=nil, rawjobs=nil, updateimage=nil)
@InstanceId = instanceid
@ClusterType = clustertype
@ClusterId = clusterid
@ServiceMonitors = servicemonitors
@PodMonitors = podmonitors
@RawJobs = rawjobs
@UpdateImage = updateimage
end
def deserialize(params)
@InstanceId = params['InstanceId']
@ClusterType = params['ClusterType']
@ClusterId = params['ClusterId']
unless params['ServiceMonitors'].nil?
@ServiceMonitors = []
params['ServiceMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@ServiceMonitors << prometheusconfigitem_tmp
end
end
unless params['PodMonitors'].nil?
@PodMonitors = []
params['PodMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@PodMonitors << prometheusconfigitem_tmp
end
end
unless params['RawJobs'].nil?
@RawJobs = []
params['RawJobs'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@RawJobs << prometheusconfigitem_tmp
end
end
@UpdateImage = params['UpdateImage']
end
end
# ModifyPrometheusConfig返回参数结构体
class ModifyPrometheusConfigResponse < 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
# ModifyPrometheusGlobalNotification请求参数结构体
class ModifyPrometheusGlobalNotificationRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
# @param Notification: 告警通知渠道
# @type Notification: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusNotificationItem`
attr_accessor :InstanceId, :Notification
def initialize(instanceid=nil, notification=nil)
@InstanceId = instanceid
@Notification = notification
end
def deserialize(params)
@InstanceId = params['InstanceId']
unless params['Notification'].nil?
@Notification = PrometheusNotificationItem.new
@Notification.deserialize(params['Notification'])
end
end
end
# ModifyPrometheusGlobalNotification返回参数结构体
class ModifyPrometheusGlobalNotificationResponse < 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
# ModifyPrometheusInstanceAttributes请求参数结构体
class ModifyPrometheusInstanceAttributesRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param InstanceName: 实例名称
# @type InstanceName: String
# @param DataRetentionTime: 数据存储时间(单位天),限制值为15, 30, 45, 90, 180, 365, 730之一
# @type DataRetentionTime: Integer
attr_accessor :InstanceId, :InstanceName, :DataRetentionTime
def initialize(instanceid=nil, instancename=nil, dataretentiontime=nil)
@InstanceId = instanceid
@InstanceName = instancename
@DataRetentionTime = dataretentiontime
end
def deserialize(params)
@InstanceId = params['InstanceId']
@InstanceName = params['InstanceName']
@DataRetentionTime = params['DataRetentionTime']
end
end
# ModifyPrometheusInstanceAttributes返回参数结构体
class ModifyPrometheusInstanceAttributesResponse < 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
# ModifyPrometheusRecordRuleYaml请求参数结构体
class ModifyPrometheusRecordRuleYamlRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param Name: 聚合实例名称
# @type Name: String
# @param Content: 新的内容
# @type Content: String
attr_accessor :InstanceId, :Name, :Content
def initialize(instanceid=nil, name=nil, content=nil)
@InstanceId = instanceid
@Name = name
@Content = content
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Name = params['Name']
@Content = params['Content']
end
end
# ModifyPrometheusRecordRuleYaml返回参数结构体
class ModifyPrometheusRecordRuleYamlResponse < 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
# ModifyPrometheusTemp请求参数结构体
class ModifyPrometheusTempRequest < TencentCloud::Common::AbstractModel
# @param TemplateId: 模板ID
# @type TemplateId: String
# @param Template: 修改内容
# @type Template: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusTempModify`
attr_accessor :TemplateId, :Template
def initialize(templateid=nil, template=nil)
@TemplateId = templateid
@Template = template
end
def deserialize(params)
@TemplateId = params['TemplateId']
unless params['Template'].nil?
@Template = PrometheusTempModify.new
@Template.deserialize(params['Template'])
end
end
end
# ModifyPrometheusTemp返回参数结构体
class ModifyPrometheusTempResponse < 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 MonitorTypeInfo < TencentCloud::Common::AbstractModel
# @param Id: 监控类型ID
# @type Id: String
# @param Name: 监控类型
# @type Name: String
# @param SortId: 排列顺序
# @type SortId: Integer
attr_accessor :Id, :Name, :SortId
def initialize(id=nil, name=nil, sortid=nil)
@Id = id
@Name = name
@SortId = sortid
end
def deserialize(params)
@Id = params['Id']
@Name = params['Name']
@SortId = params['SortId']
end
end
# 策略类型
class MonitorTypeNamespace < TencentCloud::Common::AbstractModel
# @param MonitorType: 监控类型
# @type MonitorType: String
# @param Namespace: 策略类型值
# @type Namespace: String
attr_accessor :MonitorType, :Namespace
def initialize(monitortype=nil, namespace=nil)
@MonitorType = monitortype
@Namespace = namespace
end
def deserialize(params)
@MonitorType = params['MonitorType']
@Namespace = params['Namespace']
end
end
# 通知模板与策略绑定关系
class NoticeBindPolicys < TencentCloud::Common::AbstractModel
# @param NoticeId: 告警通知模板 ID
# @type NoticeId: String
# @param PolicyIds: 告警通知模板绑定的告警策略ID列表
# @type PolicyIds: Array
attr_accessor :NoticeId, :PolicyIds
def initialize(noticeid=nil, policyids=nil)
@NoticeId = noticeid
@PolicyIds = policyids
end
def deserialize(params)
@NoticeId = params['NoticeId']
@PolicyIds = params['PolicyIds']
end
end
# 维度支持的操作符信息
class Operator < TencentCloud::Common::AbstractModel
# @param Id: 运算符标识
# @type Id: String
# @param Name: 运算符展示名
# @type Name: String
attr_accessor :Id, :Name
def initialize(id=nil, name=nil)
@Id = id
@Name = name
end
def deserialize(params)
@Id = params['Id']
@Name = params['Name']
end
end
# 周期内的统计方式
class PeriodsSt < TencentCloud::Common::AbstractModel
# @param Period: 周期
# @type Period: String
# @param StatType: 统计方式
# @type StatType: Array
attr_accessor :Period, :StatType
def initialize(period=nil, stattype=nil)
@Period = period
@StatType = stattype
end
def deserialize(params)
@Period = params['Period']
@StatType = params['StatType']
end
end
# 监控数据点
class Point < TencentCloud::Common::AbstractModel
# @param Timestamp: 该监控数据点生成的时间点
# @type Timestamp: Integer
# @param Value: 监控数据点的值
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Value: Float
attr_accessor :Timestamp, :Value
def initialize(timestamp=nil, value=nil)
@Timestamp = timestamp
@Value = value
end
def deserialize(params)
@Timestamp = params['Timestamp']
@Value = params['Value']
end
end
# 策略组信息
class PolicyGroup < TencentCloud::Common::AbstractModel
# @param CanSetDefault: 是否可设为默认告警策略
# @type CanSetDefault: Boolean
# @param GroupID: 告警策略组ID
# @type GroupID: Integer
# @param GroupName: 告警策略组名称
# @type GroupName: String
# @param InsertTime: 创建时间
# @type InsertTime: Integer
# @param IsDefault: 是否为默认告警策略
# @type IsDefault: Integer
# @param Enable: 告警策略启用状态
# @type Enable: Boolean
# @param LastEditUin: 最后修改人UIN
# @type LastEditUin: Integer
# @param NoShieldedInstanceCount: 未屏蔽的实例数
# @type NoShieldedInstanceCount: Integer
# @param ParentGroupID: 父策略组ID
# @type ParentGroupID: Integer
# @param ProjectID: 所属项目ID
# @type ProjectID: Integer
# @param ReceiverInfos: 告警接收对象信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ReceiverInfos: Array
# @param Remark: 备注信息
# @type Remark: String
# @param UpdateTime: 修改时间
# @type UpdateTime: Integer
# @param TotalInstanceCount: 总绑定实例数
# @type TotalInstanceCount: Integer
# @param ViewName: 视图
# @type ViewName: String
# @param IsUnionRule: 是否为与关系规则
# @type IsUnionRule: Integer
attr_accessor :CanSetDefault, :GroupID, :GroupName, :InsertTime, :IsDefault, :Enable, :LastEditUin, :NoShieldedInstanceCount, :ParentGroupID, :ProjectID, :ReceiverInfos, :Remark, :UpdateTime, :TotalInstanceCount, :ViewName, :IsUnionRule
def initialize(cansetdefault=nil, groupid=nil, groupname=nil, inserttime=nil, isdefault=nil, enable=nil, lastedituin=nil, noshieldedinstancecount=nil, parentgroupid=nil, projectid=nil, receiverinfos=nil, remark=nil, updatetime=nil, totalinstancecount=nil, viewname=nil, isunionrule=nil)
@CanSetDefault = cansetdefault
@GroupID = groupid
@GroupName = groupname
@InsertTime = inserttime
@IsDefault = isdefault
@Enable = enable
@LastEditUin = lastedituin
@NoShieldedInstanceCount = noshieldedinstancecount
@ParentGroupID = parentgroupid
@ProjectID = projectid
@ReceiverInfos = receiverinfos
@Remark = remark
@UpdateTime = updatetime
@TotalInstanceCount = totalinstancecount
@ViewName = viewname
@IsUnionRule = isunionrule
end
def deserialize(params)
@CanSetDefault = params['CanSetDefault']
@GroupID = params['GroupID']
@GroupName = params['GroupName']
@InsertTime = params['InsertTime']
@IsDefault = params['IsDefault']
@Enable = params['Enable']
@LastEditUin = params['LastEditUin']
@NoShieldedInstanceCount = params['NoShieldedInstanceCount']
@ParentGroupID = params['ParentGroupID']
@ProjectID = params['ProjectID']
unless params['ReceiverInfos'].nil?
@ReceiverInfos = []
params['ReceiverInfos'].each do |i|
policygroupreceiverinfo_tmp = PolicyGroupReceiverInfo.new
policygroupreceiverinfo_tmp.deserialize(i)
@ReceiverInfos << policygroupreceiverinfo_tmp
end
end
@Remark = params['Remark']
@UpdateTime = params['UpdateTime']
@TotalInstanceCount = params['TotalInstanceCount']
@ViewName = params['ViewName']
@IsUnionRule = params['IsUnionRule']
end
end
# 2018版策略模板列表接收人信息
class PolicyGroupReceiverInfo < TencentCloud::Common::AbstractModel
# @param EndTime: 有效时段结束时间
# @type EndTime: Integer
# @param NeedSendNotice: 是否需要发送通知
# @type NeedSendNotice: Integer
# @param NotifyWay: 告警接收渠道
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NotifyWay: Array
# @param PersonInterval: 电话告警对个人间隔(秒)
# @type PersonInterval: Integer
# @param ReceiverGroupList: 消息接收组列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ReceiverGroupList: Array
# @param ReceiverType: 接受者类型
# @type ReceiverType: String
# @param ReceiverUserList: 接收人列表。通过平台接口查询到的接收人id列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ReceiverUserList: Array
# @param RecoverNotify: 告警恢复通知方式
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RecoverNotify: Array
# @param RoundInterval: 电话告警每轮间隔(秒)
# @type RoundInterval: Integer
# @param RoundNumber: 电话告警轮数
# @type RoundNumber: Integer
# @param SendFor: 电话告警通知时机。可选"OCCUR"(告警时通知),"RECOVER"(恢复时通知)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SendFor: Array
# @param StartTime: 有效时段开始时间
# @type StartTime: Integer
# @param UIDList: 电话告警接收者uid
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UIDList: Array
attr_accessor :EndTime, :NeedSendNotice, :NotifyWay, :PersonInterval, :ReceiverGroupList, :ReceiverType, :ReceiverUserList, :RecoverNotify, :RoundInterval, :RoundNumber, :SendFor, :StartTime, :UIDList
def initialize(endtime=nil, needsendnotice=nil, notifyway=nil, personinterval=nil, receivergrouplist=nil, receivertype=nil, receiveruserlist=nil, recovernotify=nil, roundinterval=nil, roundnumber=nil, sendfor=nil, starttime=nil, uidlist=nil)
@EndTime = endtime
@NeedSendNotice = needsendnotice
@NotifyWay = notifyway
@PersonInterval = personinterval
@ReceiverGroupList = receivergrouplist
@ReceiverType = receivertype
@ReceiverUserList = receiveruserlist
@RecoverNotify = recovernotify
@RoundInterval = roundinterval
@RoundNumber = roundnumber
@SendFor = sendfor
@StartTime = starttime
@UIDList = uidlist
end
def deserialize(params)
@EndTime = params['EndTime']
@NeedSendNotice = params['NeedSendNotice']
@NotifyWay = params['NotifyWay']
@PersonInterval = params['PersonInterval']
@ReceiverGroupList = params['ReceiverGroupList']
@ReceiverType = params['ReceiverType']
@ReceiverUserList = params['ReceiverUserList']
@RecoverNotify = params['RecoverNotify']
@RoundInterval = params['RoundInterval']
@RoundNumber = params['RoundNumber']
@SendFor = params['SendFor']
@StartTime = params['StartTime']
@UIDList = params['UIDList']
end
end
# 策略标签
class PolicyTag < TencentCloud::Common::AbstractModel
# @param Key: 标签Key
# @type Key: String
# @param Value: 标签Value
# @type Value: String
attr_accessor :Key, :Value
def initialize(key=nil, value=nil)
@Key = key
@Value = value
end
def deserialize(params)
@Key = params['Key']
@Value = params['Value']
end
end
# 云产品监控支持的产品简要信息
class ProductSimple < TencentCloud::Common::AbstractModel
# @param Namespace: 命名空间
# @type Namespace: String
# @param ProductName: 产品中文名称
# @type ProductName: String
# @param ProductEnName: 产品英文名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProductEnName: String
attr_accessor :Namespace, :ProductName, :ProductEnName
def initialize(namespace=nil, productname=nil, productenname=nil)
@Namespace = namespace
@ProductName = productname
@ProductEnName = productenname
end
def deserialize(params)
@Namespace = params['Namespace']
@ProductName = params['ProductName']
@ProductEnName = params['ProductEnName']
end
end
# prometheus agent
class PrometheusAgent < TencentCloud::Common::AbstractModel
# @param Name: Agent 名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param AgentId: Agent ID
# @type AgentId: String
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param Ipv4: Agent IP
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Ipv4: String
# @param HeartbeatTime: 心跳时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type HeartbeatTime: String
# @param LastError: 最近一次错误
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LastError: String
# @param AgentVersion: Agent 版本
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AgentVersion: String
# @param Status: Agent 状态
# @type Status: Integer
attr_accessor :Name, :AgentId, :InstanceId, :Ipv4, :HeartbeatTime, :LastError, :AgentVersion, :Status
def initialize(name=nil, agentid=nil, instanceid=nil, ipv4=nil, heartbeattime=nil, lasterror=nil, agentversion=nil, status=nil)
@Name = name
@AgentId = agentid
@InstanceId = instanceid
@Ipv4 = ipv4
@HeartbeatTime = heartbeattime
@LastError = lasterror
@AgentVersion = agentversion
@Status = status
end
def deserialize(params)
@Name = params['Name']
@AgentId = params['AgentId']
@InstanceId = params['InstanceId']
@Ipv4 = params['Ipv4']
@HeartbeatTime = params['HeartbeatTime']
@LastError = params['LastError']
@AgentVersion = params['AgentVersion']
@Status = params['Status']
end
end
# 托管Prometheus agent信息
class PrometheusAgentInfo < TencentCloud::Common::AbstractModel
# @param ClusterType: 集群类型。可填入tke、eks、tkeedge、tdcc,分别代表标准集群、弹性集群、边缘集群、注册集群
# @type ClusterType: String
# @param ClusterId: 集成容器服务中关联的集群ID
# @type ClusterId: String
# @param Describe: 该参数未使用,不需要填写
# @type Describe: String
attr_accessor :ClusterType, :ClusterId, :Describe
def initialize(clustertype=nil, clusterid=nil, describe=nil)
@ClusterType = clustertype
@ClusterId = clusterid
@Describe = describe
end
def deserialize(params)
@ClusterType = params['ClusterType']
@ClusterId = params['ClusterId']
@Describe = params['Describe']
end
end
# 托管prometheus agent概览
class PrometheusAgentOverview < TencentCloud::Common::AbstractModel
# @param ClusterType: 集群类型
# @type ClusterType: String
# @param ClusterId: 集群id
# @type ClusterId: String
# @param Status: agent状态
# normal = 正常
# abnormal = 异常
# @type Status: String
# @param ClusterName: 集群名称
# @type ClusterName: String
# @param ExternalLabels: 额外labels
# 本集群的所有指标都会带上这几个label
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExternalLabels: Array
# @param Region: 集群所在地域
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Region: String
# @param VpcId: 集群所在VPC ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type VpcId: String
# @param FailedReason: 记录关联等操作的失败信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FailedReason: String
# @param Name: agent名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param EnableExternal: 是否已开启公网访问,true 开启,false 未开启
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EnableExternal: Boolean
# @param DesiredAgentNum: 采集agent期望pod数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DesiredAgentNum: Integer
# @param ReadyAgentNum: 采集agent已正常启动pod数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ReadyAgentNum: Integer
attr_accessor :ClusterType, :ClusterId, :Status, :ClusterName, :ExternalLabels, :Region, :VpcId, :FailedReason, :Name, :EnableExternal, :DesiredAgentNum, :ReadyAgentNum
def initialize(clustertype=nil, clusterid=nil, status=nil, clustername=nil, externallabels=nil, region=nil, vpcid=nil, failedreason=nil, name=nil, enableexternal=nil, desiredagentnum=nil, readyagentnum=nil)
@ClusterType = clustertype
@ClusterId = clusterid
@Status = status
@ClusterName = clustername
@ExternalLabels = externallabels
@Region = region
@VpcId = vpcid
@FailedReason = failedreason
@Name = name
@EnableExternal = enableexternal
@DesiredAgentNum = desiredagentnum
@ReadyAgentNum = readyagentnum
end
def deserialize(params)
@ClusterType = params['ClusterType']
@ClusterId = params['ClusterId']
@Status = params['Status']
@ClusterName = params['ClusterName']
unless params['ExternalLabels'].nil?
@ExternalLabels = []
params['ExternalLabels'].each do |i|
label_tmp = Label.new
label_tmp.deserialize(i)
@ExternalLabels << label_tmp
end
end
@Region = params['Region']
@VpcId = params['VpcId']
@FailedReason = params['FailedReason']
@Name = params['Name']
@EnableExternal = params['EnableExternal']
@DesiredAgentNum = params['DesiredAgentNum']
@ReadyAgentNum = params['ReadyAgentNum']
end
end
# Prometheus自定义告警通知时间段
class PrometheusAlertAllowTimeRange < TencentCloud::Common::AbstractModel
# @param Start: 从0点开始的秒数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Start: String
# @param End: 从0点开始的秒数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type End: String
attr_accessor :Start, :End
def initialize(start=nil, _end=nil)
@Start = start
@End = _end
end
def deserialize(params)
@Start = params['Start']
@End = params['End']
end
end
# Prometheus告警自定义通知模板
class PrometheusAlertCustomReceiver < TencentCloud::Common::AbstractModel
# @param Type: 自定义通知类型
# alertmanager -- vpc内自建alertmanager
# webhook -- vpc内webhook地址
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param Url: alertmanager/webhook地址。(prometheus实例同vpc内ip)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Url: String
# @param AllowedTimeRanges: 允许发送告警的时间范围
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AllowedTimeRanges: Array
# @param ClusterId: alertmanager所在的内网集群ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClusterId: String
# @param ClusterType: alertmanager所在的内网集群类型(tke/eks/tdcc)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClusterType: String
attr_accessor :Type, :Url, :AllowedTimeRanges, :ClusterId, :ClusterType
def initialize(type=nil, url=nil, allowedtimeranges=nil, clusterid=nil, clustertype=nil)
@Type = type
@Url = url
@AllowedTimeRanges = allowedtimeranges
@ClusterId = clusterid
@ClusterType = clustertype
end
def deserialize(params)
@Type = params['Type']
@Url = params['Url']
unless params['AllowedTimeRanges'].nil?
@AllowedTimeRanges = []
params['AllowedTimeRanges'].each do |i|
prometheusalertallowtimerange_tmp = PrometheusAlertAllowTimeRange.new
prometheusalertallowtimerange_tmp.deserialize(i)
@AllowedTimeRanges << prometheusalertallowtimerange_tmp
end
end
@ClusterId = params['ClusterId']
@ClusterType = params['ClusterType']
end
end
# 告警分组内告警规则信息
class PrometheusAlertGroupRuleSet < TencentCloud::Common::AbstractModel
# @param RuleName: 告警规则名称,同一告警分组下不允许重名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleName: String
# @param Labels: 标签列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Labels: Array
# @param Annotations: 注释列表
# 告警对象和告警消息是 Prometheus Rule Annotations 的特殊字段,需要通过 annotations 来传递,对应的 Key 分别为summary/description。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Annotations: Array
# @param Duration: 规则报警持续时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Duration: String
# @param Expr: 规则表达式,可参考告警规则说明
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Expr: String
# @param State: 告警规则状态:
# 2-启用
# 3-禁用
# 为空默认启用
# 注意:此字段可能返回 null,表示取不到有效值。
# @type State: Integer
attr_accessor :RuleName, :Labels, :Annotations, :Duration, :Expr, :State
def initialize(rulename=nil, labels=nil, annotations=nil, duration=nil, expr=nil, state=nil)
@RuleName = rulename
@Labels = labels
@Annotations = annotations
@Duration = duration
@Expr = expr
@State = state
end
def deserialize(params)
@RuleName = params['RuleName']
unless params['Labels'].nil?
@Labels = []
params['Labels'].each do |i|
prometheusrulekv_tmp = PrometheusRuleKV.new
prometheusrulekv_tmp.deserialize(i)
@Labels << prometheusrulekv_tmp
end
end
unless params['Annotations'].nil?
@Annotations = []
params['Annotations'].each do |i|
prometheusrulekv_tmp = PrometheusRuleKV.new
prometheusrulekv_tmp.deserialize(i)
@Annotations << prometheusrulekv_tmp
end
end
@Duration = params['Duration']
@Expr = params['Expr']
@State = params['State']
end
end
# Prometheus告警规则分组信息
class PrometheusAlertGroupSet < TencentCloud::Common::AbstractModel
# @param GroupId: 告警分组ID,满足正则表达式`alert-[a-z0-9]{8}`
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GroupId: String
# @param GroupName: 告警分组名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GroupName: String
# @param AMPReceivers: 云监控告警模板ID ,返回告警模板转换后的notice ID。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AMPReceivers: Array
# @param CustomReceiver: 自定义告警模板
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CustomReceiver: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusAlertCustomReceiver`
# @param RepeatInterval: 告警通知间隔
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RepeatInterval: String
# @param TemplateId: 若告警分组通过模板创建,则返回模板ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TemplateId: String
# @param Rules: 分组内告警规则详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Rules: Array
# @param CreatedAt: 分组创建时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CreatedAt: String
# @param UpdatedAt: 分组更新时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdatedAt: String
attr_accessor :GroupId, :GroupName, :AMPReceivers, :CustomReceiver, :RepeatInterval, :TemplateId, :Rules, :CreatedAt, :UpdatedAt
def initialize(groupid=nil, groupname=nil, ampreceivers=nil, customreceiver=nil, repeatinterval=nil, templateid=nil, rules=nil, createdat=nil, updatedat=nil)
@GroupId = groupid
@GroupName = groupname
@AMPReceivers = ampreceivers
@CustomReceiver = customreceiver
@RepeatInterval = repeatinterval
@TemplateId = templateid
@Rules = rules
@CreatedAt = createdat
@UpdatedAt = updatedat
end
def deserialize(params)
@GroupId = params['GroupId']
@GroupName = params['GroupName']
@AMPReceivers = params['AMPReceivers']
unless params['CustomReceiver'].nil?
@CustomReceiver = PrometheusAlertCustomReceiver.new
@CustomReceiver.deserialize(params['CustomReceiver'])
end
@RepeatInterval = params['RepeatInterval']
@TemplateId = params['TemplateId']
unless params['Rules'].nil?
@Rules = []
params['Rules'].each do |i|
prometheusalertgroupruleset_tmp = PrometheusAlertGroupRuleSet.new
prometheusalertgroupruleset_tmp.deserialize(i)
@Rules << prometheusalertgroupruleset_tmp
end
end
@CreatedAt = params['CreatedAt']
@UpdatedAt = params['UpdatedAt']
end
end
# 告警渠道使用自建alertmanager的配置
class PrometheusAlertManagerConfig < TencentCloud::Common::AbstractModel
# @param Url: alertmanager url
# @type Url: String
# @param ClusterType: alertmanager部署所在集群类型
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClusterType: String
# @param ClusterId: alertmanager部署所在集群ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClusterId: String
attr_accessor :Url, :ClusterType, :ClusterId
def initialize(url=nil, clustertype=nil, clusterid=nil)
@Url = url
@ClusterType = clustertype
@ClusterId = clusterid
end
def deserialize(params)
@Url = params['Url']
@ClusterType = params['ClusterType']
@ClusterId = params['ClusterId']
end
end
# 托管prometheus告警策略实例
class PrometheusAlertPolicyItem < TencentCloud::Common::AbstractModel
# @param Name: 策略名称
# @type Name: String
# @param Rules: 规则列表
# @type Rules: Array
# @param Id: 告警策略 id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Id: String
# @param TemplateId: 如果该告警来自模板下发,则TemplateId为模板id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TemplateId: String
# @param Notification: 告警渠道,模板中使用可能返回null
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Notification: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusNotificationItem`
# @param UpdatedAt: 最后修改时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdatedAt: String
# @param ClusterId: 如果告警策略来源于用户集群CRD资源定义,则ClusterId为所属集群ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClusterId: String
attr_accessor :Name, :Rules, :Id, :TemplateId, :Notification, :UpdatedAt, :ClusterId
def initialize(name=nil, rules=nil, id=nil, templateid=nil, notification=nil, updatedat=nil, clusterid=nil)
@Name = name
@Rules = rules
@Id = id
@TemplateId = templateid
@Notification = notification
@UpdatedAt = updatedat
@ClusterId = clusterid
end
def deserialize(params)
@Name = params['Name']
unless params['Rules'].nil?
@Rules = []
params['Rules'].each do |i|
prometheusalertrule_tmp = PrometheusAlertRule.new
prometheusalertrule_tmp.deserialize(i)
@Rules << prometheusalertrule_tmp
end
end
@Id = params['Id']
@TemplateId = params['TemplateId']
unless params['Notification'].nil?
@Notification = PrometheusNotificationItem.new
@Notification.deserialize(params['Notification'])
end
@UpdatedAt = params['UpdatedAt']
@ClusterId = params['ClusterId']
end
end
# Prometheus告警规则
class PrometheusAlertRule < TencentCloud::Common::AbstractModel
# @param Name: 规则名称
# @type Name: String
# @param Rule: prometheus语句
# @type Rule: String
# @param Labels: 额外标签
# @type Labels: Array
# @param Template: 告警发送模板
# @type Template: String
# @param For: 持续时间
# @type For: String
# @param Describe: 该条规则的描述信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Describe: String
# @param Annotations: 参考prometheus rule中的annotations
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Annotations: Array
# @param RuleState: 告警规则状态
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleState: Integer
attr_accessor :Name, :Rule, :Labels, :Template, :For, :Describe, :Annotations, :RuleState
def initialize(name=nil, rule=nil, labels=nil, template=nil, _for=nil, describe=nil, annotations=nil, rulestate=nil)
@Name = name
@Rule = rule
@Labels = labels
@Template = template
@For = _for
@Describe = describe
@Annotations = annotations
@RuleState = rulestate
end
def deserialize(params)
@Name = params['Name']
@Rule = params['Rule']
unless params['Labels'].nil?
@Labels = []
params['Labels'].each do |i|
label_tmp = Label.new
label_tmp.deserialize(i)
@Labels << label_tmp
end
end
@Template = params['Template']
@For = params['For']
@Describe = params['Describe']
unless params['Annotations'].nil?
@Annotations = []
params['Annotations'].each do |i|
label_tmp = Label.new
label_tmp.deserialize(i)
@Annotations << label_tmp
end
end
@RuleState = params['RuleState']
end
end
# 与腾讯云可观测平台融合托管 Prometheus 实例,关联集群基础信息
class PrometheusClusterAgentBasic < TencentCloud::Common::AbstractModel
# @param Region: 地域
# @type Region: String
# @param ClusterType: 集群类型。可填入tke、eks、tkeedge、tdcc,分别代表标准集群、弹性集群、边缘集群、注册集群
# @type ClusterType: String
# @param ClusterId: 集群ID
# @type ClusterId: String
# @param EnableExternal: 是否开启公网CLB
# @type EnableExternal: Boolean
# @param InClusterPodConfig: 集群内部署组件的pod配置
# @type InClusterPodConfig: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusClusterAgentPodConfig`
# @param ExternalLabels: 该集群采集的所有指标都会带上这些labels
# @type ExternalLabels: Array
# @param NotInstallBasicScrape: 是否安装默认采集配置
# @type NotInstallBasicScrape: Boolean
# @param NotScrape: 是否采集指标,true代表drop所有指标,false代表采集默认指标
# @type NotScrape: Boolean
# @param OpenDefaultRecord: 是否开启默认预聚合规则
# @type OpenDefaultRecord: Boolean
attr_accessor :Region, :ClusterType, :ClusterId, :EnableExternal, :InClusterPodConfig, :ExternalLabels, :NotInstallBasicScrape, :NotScrape, :OpenDefaultRecord
def initialize(region=nil, clustertype=nil, clusterid=nil, enableexternal=nil, inclusterpodconfig=nil, externallabels=nil, notinstallbasicscrape=nil, notscrape=nil, opendefaultrecord=nil)
@Region = region
@ClusterType = clustertype
@ClusterId = clusterid
@EnableExternal = enableexternal
@InClusterPodConfig = inclusterpodconfig
@ExternalLabels = externallabels
@NotInstallBasicScrape = notinstallbasicscrape
@NotScrape = notscrape
@OpenDefaultRecord = opendefaultrecord
end
def deserialize(params)
@Region = params['Region']
@ClusterType = params['ClusterType']
@ClusterId = params['ClusterId']
@EnableExternal = params['EnableExternal']
unless params['InClusterPodConfig'].nil?
@InClusterPodConfig = PrometheusClusterAgentPodConfig.new
@InClusterPodConfig.deserialize(params['InClusterPodConfig'])
end
unless params['ExternalLabels'].nil?
@ExternalLabels = []
params['ExternalLabels'].each do |i|
label_tmp = Label.new
label_tmp.deserialize(i)
@ExternalLabels << label_tmp
end
end
@NotInstallBasicScrape = params['NotInstallBasicScrape']
@NotScrape = params['NotScrape']
@OpenDefaultRecord = params['OpenDefaultRecord']
end
end
# 关联集群时在集群内部署组件的pod额外配置
class PrometheusClusterAgentPodConfig < TencentCloud::Common::AbstractModel
# @param HostNet: 是否使用HostNetWork
# @type HostNet: Boolean
# @param NodeSelector: 指定pod运行节点
# @type NodeSelector: Array
# @param Tolerations: 容忍污点
# @type Tolerations: Array
attr_accessor :HostNet, :NodeSelector, :Tolerations
def initialize(hostnet=nil, nodeselector=nil, tolerations=nil)
@HostNet = hostnet
@NodeSelector = nodeselector
@Tolerations = tolerations
end
def deserialize(params)
@HostNet = params['HostNet']
unless params['NodeSelector'].nil?
@NodeSelector = []
params['NodeSelector'].each do |i|
label_tmp = Label.new
label_tmp.deserialize(i)
@NodeSelector << label_tmp
end
end
unless params['Tolerations'].nil?
@Tolerations = []
params['Tolerations'].each do |i|
toleration_tmp = Toleration.new
toleration_tmp.deserialize(i)
@Tolerations << toleration_tmp
end
end
end
end
# prometheus配置
class PrometheusConfigItem < TencentCloud::Common::AbstractModel
# @param Name: 名称
# @type Name: String
# @param Config: 配置内容
# @type Config: String
# @param TemplateId: 用于出参,如果该配置来至模板,则为模板id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TemplateId: String
# @param Targets: 目标数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Targets: :class:`Tencentcloud::Monitor.v20180724.models.Targets`
attr_accessor :Name, :Config, :TemplateId, :Targets
def initialize(name=nil, config=nil, templateid=nil, targets=nil)
@Name = name
@Config = config
@TemplateId = templateid
@Targets = targets
end
def deserialize(params)
@Name = params['Name']
@Config = params['Config']
@TemplateId = params['TemplateId']
unless params['Targets'].nil?
@Targets = Targets.new
@Targets.deserialize(params['Targets'])
end
end
end
# 实例的授权信息
class PrometheusInstanceGrantInfo < TencentCloud::Common::AbstractModel
# @param HasChargeOperation: 是否有计费操作权限(1=有,2=无)
# @type HasChargeOperation: Integer
# @param HasVpcDisplay: 是否显示VPC信息的权限(1=有,2=无)
# @type HasVpcDisplay: Integer
# @param HasGrafanaStatusChange: 是否可修改Grafana的状态(1=有,2=无)
# @type HasGrafanaStatusChange: Integer
# @param HasAgentManage: 是否有管理agent的权限(1=有,2=无)
# @type HasAgentManage: Integer
# @param HasTkeManage: 是否有管理TKE集成的权限(1=有,2=无)
# @type HasTkeManage: Integer
# @param HasApiOperation: 是否显示API等信息(1=有, 2=无)
# @type HasApiOperation: Integer
attr_accessor :HasChargeOperation, :HasVpcDisplay, :HasGrafanaStatusChange, :HasAgentManage, :HasTkeManage, :HasApiOperation
def initialize(haschargeoperation=nil, hasvpcdisplay=nil, hasgrafanastatuschange=nil, hasagentmanage=nil, hastkemanage=nil, hasapioperation=nil)
@HasChargeOperation = haschargeoperation
@HasVpcDisplay = hasvpcdisplay
@HasGrafanaStatusChange = hasgrafanastatuschange
@HasAgentManage = hasagentmanage
@HasTkeManage = hastkemanage
@HasApiOperation = hasapioperation
end
def deserialize(params)
@HasChargeOperation = params['HasChargeOperation']
@HasVpcDisplay = params['HasVpcDisplay']
@HasGrafanaStatusChange = params['HasGrafanaStatusChange']
@HasAgentManage = params['HasAgentManage']
@HasTkeManage = params['HasTkeManage']
@HasApiOperation = params['HasApiOperation']
end
end
# Prometheus用量信息
class PrometheusInstanceTenantUsage < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceId: String
# @param CalcDate: 计费周期
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CalcDate: String
# @param Total: 总用量
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Total: Float
# @param Basic: 基础指标用量
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Basic: Float
# @param Fee: 付费指标用量
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Fee: Float
attr_accessor :InstanceId, :CalcDate, :Total, :Basic, :Fee
def initialize(instanceid=nil, calcdate=nil, total=nil, basic=nil, fee=nil)
@InstanceId = instanceid
@CalcDate = calcdate
@Total = total
@Basic = basic
@Fee = fee
end
def deserialize(params)
@InstanceId = params['InstanceId']
@CalcDate = params['CalcDate']
@Total = params['Total']
@Basic = params['Basic']
@Fee = params['Fee']
end
end
# Prometheus 服务响应体
class PrometheusInstancesItem < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID。
# @type InstanceId: String
# @param InstanceName: 实例名称。
# @type InstanceName: String
# @param InstanceChargeType: 实例计费模式。取值范围:
#
# @type InstanceChargeType: Integer
# @param RegionId: 地域 ID
# @type RegionId: Integer
# @param Zone: 可用区
# @type Zone: String
# @param VpcId: VPC ID
# @type VpcId: String
# @param SubnetId: 子网 ID
# @type SubnetId: String
# @param DataRetentionTime: 存储周期
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DataRetentionTime: Integer
# @param InstanceStatus: 实例业务状态。取值范围:
#
# - 1:正在创建
# - 2:运行中
# - 3:异常
# - 4:重建中
# - 5:销毁中
# - 6:已停服
# - 8:欠费停服中
# - 9:欠费已停服
#
# @type InstanceStatus: Integer
# @param GrafanaURL: Grafana 面板 URL
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GrafanaURL: String
# @param CreatedAt: 创建时间
# @type CreatedAt: String
# @param EnableGrafana: 是否开启 Grafana
# 0:不开启
# 1:开启
# @type EnableGrafana: Integer
# @param IPv4Address: 实例IPV4地址
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IPv4Address: String
# @param TagSpecification: 实例关联的标签列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TagSpecification: Array
# @param ExpireTime: 购买的实例过期时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExpireTime: String
# @param ChargeStatus: 计费状态
#
# - 1:正常
# - 2:过期
# - 3:销毁
# - 4:分配中
# - 5:分配失败
#
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ChargeStatus: Integer
# @param SpecName: 规格名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SpecName: String
# @param AutoRenewFlag: 自动续费标记
#
# - 0:不自动续费
# - 1:开启自动续费
# - 2:禁止自动续费
# - -1:无效
#
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AutoRenewFlag: Integer
# @param IsNearExpire: 是否快过期
#
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsNearExpire: Integer
# @param AuthToken: 数据写入需要的 Token
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AuthToken: String
# @param RemoteWrite: Prometheus Remote Write 的地址
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RemoteWrite: String
# @param ApiRootPath: Prometheus HTTP Api 根地址
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ApiRootPath: String
# @param ProxyAddress: Proxy 的地址
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProxyAddress: String
# @param GrafanaStatus: Grafana 运行状态
#
# - 1:正在创建
# - 2:运行中
# - 3:异常
# - 4:重启中
# - 5:销毁中
# - 6:已停机
# - 7:已删除
#
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GrafanaStatus: Integer
# @param GrafanaIpWhiteList: Grafana IP 白名单列表,使用英文分号分隔
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GrafanaIpWhiteList: String
# @param Grant: 实例的授权信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Grant: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusInstanceGrantInfo`
# @param GrafanaInstanceId: 绑定的 Grafana 实例 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GrafanaInstanceId: String
# @param AlertRuleLimit: 告警规则限制
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlertRuleLimit: Integer
# @param RecordingRuleLimit: 预聚合规则限制
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RecordingRuleLimit: Integer
# @param MigrationType: 迁移状态,0-不在迁移中,1-迁移中、原实例,2-迁移中、目标实例
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MigrationType: Integer
attr_accessor :InstanceId, :InstanceName, :InstanceChargeType, :RegionId, :Zone, :VpcId, :SubnetId, :DataRetentionTime, :InstanceStatus, :GrafanaURL, :CreatedAt, :EnableGrafana, :IPv4Address, :TagSpecification, :ExpireTime, :ChargeStatus, :SpecName, :AutoRenewFlag, :IsNearExpire, :AuthToken, :RemoteWrite, :ApiRootPath, :ProxyAddress, :GrafanaStatus, :GrafanaIpWhiteList, :Grant, :GrafanaInstanceId, :AlertRuleLimit, :RecordingRuleLimit, :MigrationType
def initialize(instanceid=nil, instancename=nil, instancechargetype=nil, regionid=nil, zone=nil, vpcid=nil, subnetid=nil, dataretentiontime=nil, instancestatus=nil, grafanaurl=nil, createdat=nil, enablegrafana=nil, ipv4address=nil, tagspecification=nil, expiretime=nil, chargestatus=nil, specname=nil, autorenewflag=nil, isnearexpire=nil, authtoken=nil, remotewrite=nil, apirootpath=nil, proxyaddress=nil, grafanastatus=nil, grafanaipwhitelist=nil, grant=nil, grafanainstanceid=nil, alertrulelimit=nil, recordingrulelimit=nil, migrationtype=nil)
@InstanceId = instanceid
@InstanceName = instancename
@InstanceChargeType = instancechargetype
@RegionId = regionid
@Zone = zone
@VpcId = vpcid
@SubnetId = subnetid
@DataRetentionTime = dataretentiontime
@InstanceStatus = instancestatus
@GrafanaURL = grafanaurl
@CreatedAt = createdat
@EnableGrafana = enablegrafana
@IPv4Address = ipv4address
@TagSpecification = tagspecification
@ExpireTime = expiretime
@ChargeStatus = chargestatus
@SpecName = specname
@AutoRenewFlag = autorenewflag
@IsNearExpire = isnearexpire
@AuthToken = authtoken
@RemoteWrite = remotewrite
@ApiRootPath = apirootpath
@ProxyAddress = proxyaddress
@GrafanaStatus = grafanastatus
@GrafanaIpWhiteList = grafanaipwhitelist
@Grant = grant
@GrafanaInstanceId = grafanainstanceid
@AlertRuleLimit = alertrulelimit
@RecordingRuleLimit = recordingrulelimit
@MigrationType = migrationtype
end
def deserialize(params)
@InstanceId = params['InstanceId']
@InstanceName = params['InstanceName']
@InstanceChargeType = params['InstanceChargeType']
@RegionId = params['RegionId']
@Zone = params['Zone']
@VpcId = params['VpcId']
@SubnetId = params['SubnetId']
@DataRetentionTime = params['DataRetentionTime']
@InstanceStatus = params['InstanceStatus']
@GrafanaURL = params['GrafanaURL']
@CreatedAt = params['CreatedAt']
@EnableGrafana = params['EnableGrafana']
@IPv4Address = params['IPv4Address']
unless params['TagSpecification'].nil?
@TagSpecification = []
params['TagSpecification'].each do |i|
prometheustag_tmp = PrometheusTag.new
prometheustag_tmp.deserialize(i)
@TagSpecification << prometheustag_tmp
end
end
@ExpireTime = params['ExpireTime']
@ChargeStatus = params['ChargeStatus']
@SpecName = params['SpecName']
@AutoRenewFlag = params['AutoRenewFlag']
@IsNearExpire = params['IsNearExpire']
@AuthToken = params['AuthToken']
@RemoteWrite = params['RemoteWrite']
@ApiRootPath = params['ApiRootPath']
@ProxyAddress = params['ProxyAddress']
@GrafanaStatus = params['GrafanaStatus']
@GrafanaIpWhiteList = params['GrafanaIpWhiteList']
unless params['Grant'].nil?
@Grant = PrometheusInstanceGrantInfo.new
@Grant.deserialize(params['Grant'])
end
@GrafanaInstanceId = params['GrafanaInstanceId']
@AlertRuleLimit = params['AlertRuleLimit']
@RecordingRuleLimit = params['RecordingRuleLimit']
@MigrationType = params['MigrationType']
end
end
# 托管prometheusV2实例概览
class PrometheusInstancesOverview < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
# @param InstanceName: 实例名
# @type InstanceName: String
# @param VpcId: VPC ID
# @type VpcId: String
# @param SubnetId: 子网ID
# @type SubnetId: String
# @param InstanceStatus: 运行状态(1:正在创建;2:运行中;3:异常;4:重启中;5:销毁中; 6:已停机; 7: 已删除)
# @type InstanceStatus: Integer
# @param ChargeStatus: 计费状态(1:正常;2:过期; 3:销毁; 4:分配中; 5:分配失败)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ChargeStatus: Integer
# @param EnableGrafana: 是否开启 Grafana(0:不开启,1:开启)
# @type EnableGrafana: Integer
# @param GrafanaURL: Grafana 面板 URL
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GrafanaURL: String
# @param InstanceChargeType: 实例付费类型(1:试用版;2:预付费)
# @type InstanceChargeType: Integer
# @param SpecName: 规格名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SpecName: String
# @param DataRetentionTime: 存储周期
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DataRetentionTime: Integer
# @param ExpireTime: 购买的实例过期时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExpireTime: String
# @param AutoRenewFlag: 自动续费标记(0:不自动续费;1:开启自动续费;2:禁止自动续费;-1:无效)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AutoRenewFlag: Integer
# @param BoundTotal: 绑定集群总数
# @type BoundTotal: Integer
# @param BoundNormal: 绑定集群正常状态总数
# @type BoundNormal: Integer
# @param ResourcePackageStatus: 资源包状态,0-无可用资源包,1-有可用资源包
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ResourcePackageStatus: Integer
# @param ResourcePackageSpecName: 资源包规格名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ResourcePackageSpecName: String
attr_accessor :InstanceId, :InstanceName, :VpcId, :SubnetId, :InstanceStatus, :ChargeStatus, :EnableGrafana, :GrafanaURL, :InstanceChargeType, :SpecName, :DataRetentionTime, :ExpireTime, :AutoRenewFlag, :BoundTotal, :BoundNormal, :ResourcePackageStatus, :ResourcePackageSpecName
def initialize(instanceid=nil, instancename=nil, vpcid=nil, subnetid=nil, instancestatus=nil, chargestatus=nil, enablegrafana=nil, grafanaurl=nil, instancechargetype=nil, specname=nil, dataretentiontime=nil, expiretime=nil, autorenewflag=nil, boundtotal=nil, boundnormal=nil, resourcepackagestatus=nil, resourcepackagespecname=nil)
@InstanceId = instanceid
@InstanceName = instancename
@VpcId = vpcid
@SubnetId = subnetid
@InstanceStatus = instancestatus
@ChargeStatus = chargestatus
@EnableGrafana = enablegrafana
@GrafanaURL = grafanaurl
@InstanceChargeType = instancechargetype
@SpecName = specname
@DataRetentionTime = dataretentiontime
@ExpireTime = expiretime
@AutoRenewFlag = autorenewflag
@BoundTotal = boundtotal
@BoundNormal = boundnormal
@ResourcePackageStatus = resourcepackagestatus
@ResourcePackageSpecName = resourcepackagespecname
end
def deserialize(params)
@InstanceId = params['InstanceId']
@InstanceName = params['InstanceName']
@VpcId = params['VpcId']
@SubnetId = params['SubnetId']
@InstanceStatus = params['InstanceStatus']
@ChargeStatus = params['ChargeStatus']
@EnableGrafana = params['EnableGrafana']
@GrafanaURL = params['GrafanaURL']
@InstanceChargeType = params['InstanceChargeType']
@SpecName = params['SpecName']
@DataRetentionTime = params['DataRetentionTime']
@ExpireTime = params['ExpireTime']
@AutoRenewFlag = params['AutoRenewFlag']
@BoundTotal = params['BoundTotal']
@BoundNormal = params['BoundNormal']
@ResourcePackageStatus = params['ResourcePackageStatus']
@ResourcePackageSpecName = params['ResourcePackageSpecName']
end
end
# prometheus一个job的targets
class PrometheusJobTargets < TencentCloud::Common::AbstractModel
# @param Targets: 该Job的targets列表
# @type Targets: Array
# @param JobName: job的名称
# @type JobName: String
# @param Total: targets总数
# @type Total: Integer
# @param Up: 健康的target总数
# @type Up: Integer
attr_accessor :Targets, :JobName, :Total, :Up
def initialize(targets=nil, jobname=nil, total=nil, up=nil)
@Targets = targets
@JobName = jobname
@Total = total
@Up = up
end
def deserialize(params)
unless params['Targets'].nil?
@Targets = []
params['Targets'].each do |i|
prometheustarget_tmp = PrometheusTarget.new
prometheustarget_tmp.deserialize(i)
@Targets << prometheustarget_tmp
end
end
@JobName = params['JobName']
@Total = params['Total']
@Up = params['Up']
end
end
# 告警通知渠道配置
class PrometheusNotificationItem < TencentCloud::Common::AbstractModel
# @param Enabled: 是否启用
# @type Enabled: Boolean
# @param Type: 通道类型,默认为amp,支持以下
# amp
# webhook
# alertmanager
# @type Type: String
# @param WebHook: 如果Type为webhook, 则该字段为必填项
# 注意:此字段可能返回 null,表示取不到有效值。
# @type WebHook: String
# @param AlertManager: 如果Type为alertmanager, 则该字段为必填项
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlertManager: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusAlertManagerConfig`
# @param RepeatInterval: 收敛时间
# @type RepeatInterval: String
# @param TimeRangeStart: 生效起始时间
# @type TimeRangeStart: String
# @param TimeRangeEnd: 生效结束时间
# @type TimeRangeEnd: String
# @param NotifyWay: 告警通知方式。目前有SMS、EMAIL、CALL、WECHAT方式。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NotifyWay: Array
# @param ReceiverGroups: 告警接收组(用户组)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ReceiverGroups: Array
# @param PhoneNotifyOrder: 电话告警顺序。
# 注:NotifyWay选择CALL,采用该参数。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PhoneNotifyOrder: Array
# @param PhoneCircleTimes: 电话告警次数。
# 注:NotifyWay选择CALL,采用该参数。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PhoneCircleTimes: Integer
# @param PhoneInnerInterval: 电话告警轮内间隔。单位:秒
# 注:NotifyWay选择CALL,采用该参数。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PhoneInnerInterval: Integer
# @param PhoneCircleInterval: 电话告警轮外间隔。单位:秒
# 注:NotifyWay选择CALL,采用该参数。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PhoneCircleInterval: Integer
# @param PhoneArriveNotice: 电话告警触达通知
# 注:NotifyWay选择CALL,采用该参数。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PhoneArriveNotice: Boolean
attr_accessor :Enabled, :Type, :WebHook, :AlertManager, :RepeatInterval, :TimeRangeStart, :TimeRangeEnd, :NotifyWay, :ReceiverGroups, :PhoneNotifyOrder, :PhoneCircleTimes, :PhoneInnerInterval, :PhoneCircleInterval, :PhoneArriveNotice
def initialize(enabled=nil, type=nil, webhook=nil, alertmanager=nil, repeatinterval=nil, timerangestart=nil, timerangeend=nil, notifyway=nil, receivergroups=nil, phonenotifyorder=nil, phonecircletimes=nil, phoneinnerinterval=nil, phonecircleinterval=nil, phonearrivenotice=nil)
@Enabled = enabled
@Type = type
@WebHook = webhook
@AlertManager = alertmanager
@RepeatInterval = repeatinterval
@TimeRangeStart = timerangestart
@TimeRangeEnd = timerangeend
@NotifyWay = notifyway
@ReceiverGroups = receivergroups
@PhoneNotifyOrder = phonenotifyorder
@PhoneCircleTimes = phonecircletimes
@PhoneInnerInterval = phoneinnerinterval
@PhoneCircleInterval = phonecircleinterval
@PhoneArriveNotice = phonearrivenotice
end
def deserialize(params)
@Enabled = params['Enabled']
@Type = params['Type']
@WebHook = params['WebHook']
unless params['AlertManager'].nil?
@AlertManager = PrometheusAlertManagerConfig.new
@AlertManager.deserialize(params['AlertManager'])
end
@RepeatInterval = params['RepeatInterval']
@TimeRangeStart = params['TimeRangeStart']
@TimeRangeEnd = params['TimeRangeEnd']
@NotifyWay = params['NotifyWay']
@ReceiverGroups = params['ReceiverGroups']
@PhoneNotifyOrder = params['PhoneNotifyOrder']
@PhoneCircleTimes = params['PhoneCircleTimes']
@PhoneInnerInterval = params['PhoneInnerInterval']
@PhoneCircleInterval = params['PhoneCircleInterval']
@PhoneArriveNotice = params['PhoneArriveNotice']
end
end
# prometheus聚合规则实例详情,包含所属集群ID
class PrometheusRecordRuleYamlItem < TencentCloud::Common::AbstractModel
# @param Name: 实例名称
# @type Name: String
# @param UpdateTime: 最近更新时间
# @type UpdateTime: String
# @param TemplateId: Yaml内容
# @type TemplateId: String
# @param Content: 如果该聚合规则来至模板,则TemplateId为模板id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Content: String
# @param ClusterId: 该聚合规则如果来源于用户集群crd资源定义,则ClusterId为所属集群ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClusterId: String
# @param Status: 状态
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Status: Integer
# @param Id: id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Id: String
# @param Count: 规则数量
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Count: Integer
attr_accessor :Name, :UpdateTime, :TemplateId, :Content, :ClusterId, :Status, :Id, :Count
def initialize(name=nil, updatetime=nil, templateid=nil, content=nil, clusterid=nil, status=nil, id=nil, count=nil)
@Name = name
@UpdateTime = updatetime
@TemplateId = templateid
@Content = content
@ClusterId = clusterid
@Status = status
@Id = id
@Count = count
end
def deserialize(params)
@Name = params['Name']
@UpdateTime = params['UpdateTime']
@TemplateId = params['TemplateId']
@Content = params['Content']
@ClusterId = params['ClusterId']
@Status = params['Status']
@Id = params['Id']
@Count = params['Count']
end
end
# DescribePrometheusRegions 响应结构体
class PrometheusRegionItem < TencentCloud::Common::AbstractModel
# @param Region: 区域
# @type Region: String
# @param RegionId: 区域 ID
# @type RegionId: Integer
# @param RegionState: 区域状态( 0: 不可用;1: 可用)
# @type RegionState: Integer
# @param RegionName: 区域名(中文)
# @type RegionName: String
# @param RegionShortName: 区域名(英文缩写)
# @type RegionShortName: String
# @param Area: 区域所在大区名
# @type Area: String
# @param RegionPayMode: 1-仅支持预付费,2-仅支持后付费,3-支持两种计费模式实例
# @type RegionPayMode: Integer
attr_accessor :Region, :RegionId, :RegionState, :RegionName, :RegionShortName, :Area, :RegionPayMode
def initialize(region=nil, regionid=nil, regionstate=nil, regionname=nil, regionshortname=nil, area=nil, regionpaymode=nil)
@Region = region
@RegionId = regionid
@RegionState = regionstate
@RegionName = regionname
@RegionShortName = regionshortname
@Area = area
@RegionPayMode = regionpaymode
end
def deserialize(params)
@Region = params['Region']
@RegionId = params['RegionId']
@RegionState = params['RegionState']
@RegionName = params['RegionName']
@RegionShortName = params['RegionShortName']
@Area = params['Area']
@RegionPayMode = params['RegionPayMode']
end
end
# prometheus 报警规则 KV 参数
class PrometheusRuleKV < TencentCloud::Common::AbstractModel
# @param Key: 键
# @type Key: String
# @param Value: 值
# @type Value: String
attr_accessor :Key, :Value
def initialize(key=nil, value=nil)
@Key = key
@Value = value
end
def deserialize(params)
@Key = params['Key']
@Value = params['Value']
end
end
# prometheus 报警规则集
class PrometheusRuleSet < TencentCloud::Common::AbstractModel
# @param RuleId: 规则 ID
# @type RuleId: String
# @param RuleName: 规则名称
# @type RuleName: String
# @param RuleState: 规则状态码
# @type RuleState: Integer
# @param Type: 规则类别
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param Labels: 规则标签列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Labels: Array
# @param Annotations: 规则注释列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Annotations: Array
# @param Expr: 规则表达式
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Expr: String
# @param Duration: 规则报警持续时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Duration: String
# @param Receivers: 报警接收组列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Receivers: Array
# @param Health: 规则运行健康状态,取值如下:
# unknown 未知状态
# pending 加载中
# ok 运行正常
# err 运行错误
# @type Health: String
# @param CreatedAt: 规则创建时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CreatedAt: String
# @param UpdatedAt: 规则更新时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdatedAt: String
attr_accessor :RuleId, :RuleName, :RuleState, :Type, :Labels, :Annotations, :Expr, :Duration, :Receivers, :Health, :CreatedAt, :UpdatedAt
def initialize(ruleid=nil, rulename=nil, rulestate=nil, type=nil, labels=nil, annotations=nil, expr=nil, duration=nil, receivers=nil, health=nil, createdat=nil, updatedat=nil)
@RuleId = ruleid
@RuleName = rulename
@RuleState = rulestate
@Type = type
@Labels = labels
@Annotations = annotations
@Expr = expr
@Duration = duration
@Receivers = receivers
@Health = health
@CreatedAt = createdat
@UpdatedAt = updatedat
end
def deserialize(params)
@RuleId = params['RuleId']
@RuleName = params['RuleName']
@RuleState = params['RuleState']
@Type = params['Type']
unless params['Labels'].nil?
@Labels = []
params['Labels'].each do |i|
prometheusrulekv_tmp = PrometheusRuleKV.new
prometheusrulekv_tmp.deserialize(i)
@Labels << prometheusrulekv_tmp
end
end
unless params['Annotations'].nil?
@Annotations = []
params['Annotations'].each do |i|
prometheusrulekv_tmp = PrometheusRuleKV.new
prometheusrulekv_tmp.deserialize(i)
@Annotations << prometheusrulekv_tmp
end
end
@Expr = params['Expr']
@Duration = params['Duration']
@Receivers = params['Receivers']
@Health = params['Health']
@CreatedAt = params['CreatedAt']
@UpdatedAt = params['UpdatedAt']
end
end
# Prometheus 抓取任务
class PrometheusScrapeJob < TencentCloud::Common::AbstractModel
# @param Name: 任务名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param AgentId: Agent ID
# @type AgentId: String
# @param JobId: 任务 ID
# @type JobId: String
# @param Config: 配置
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Config: String
attr_accessor :Name, :AgentId, :JobId, :Config
def initialize(name=nil, agentid=nil, jobid=nil, config=nil)
@Name = name
@AgentId = agentid
@JobId = jobid
@Config = config
end
def deserialize(params)
@Name = params['Name']
@AgentId = params['AgentId']
@JobId = params['JobId']
@Config = params['Config']
end
end
# Prometheus 托管服务标签
class PrometheusTag < TencentCloud::Common::AbstractModel
# @param Key: 标签的健值
# @type Key: String
# @param 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
# prometheus一个抓取目标的信息
class PrometheusTarget < TencentCloud::Common::AbstractModel
def initialize()
end
def deserialize(params)
end
end
# 模板实例
class PrometheusTemp < TencentCloud::Common::AbstractModel
# @param Name: 模板名称
# @type Name: String
# @param Level: 模板维度,支持以下类型
# instance 实例级别
# cluster 集群级别
# @type Level: String
# @param Describe: 模板描述
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Describe: String
# @param RecordRules: 当Level为instance时有效,
# 模板中的聚合规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RecordRules: Array
# @param ServiceMonitors: 当Level为cluster时有效,
# 模板中的ServiceMonitor规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ServiceMonitors: Array
# @param PodMonitors: 当Level为cluster时有效,
# 模板中的PodMonitors规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PodMonitors: Array
# @param RawJobs: 当Level为cluster时有效,
# 模板中的RawJobs规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RawJobs: Array
# @param TemplateId: 模板的ID, 用于出参
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TemplateId: String
# @param UpdateTime: 最近更新时间,用于出参
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdateTime: String
# @param Version: 当前版本,用于出参
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Version: String
# @param IsDefault: 是否系统提供的默认模板,用于出参
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsDefault: Boolean
# @param AlertDetailRules: 当Level为instance时有效,
# 模板中的告警配置列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlertDetailRules: Array
# @param TargetsTotal: 关联实例数目
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TargetsTotal: Integer
attr_accessor :Name, :Level, :Describe, :RecordRules, :ServiceMonitors, :PodMonitors, :RawJobs, :TemplateId, :UpdateTime, :Version, :IsDefault, :AlertDetailRules, :TargetsTotal
def initialize(name=nil, level=nil, describe=nil, recordrules=nil, servicemonitors=nil, podmonitors=nil, rawjobs=nil, templateid=nil, updatetime=nil, version=nil, isdefault=nil, alertdetailrules=nil, targetstotal=nil)
@Name = name
@Level = level
@Describe = describe
@RecordRules = recordrules
@ServiceMonitors = servicemonitors
@PodMonitors = podmonitors
@RawJobs = rawjobs
@TemplateId = templateid
@UpdateTime = updatetime
@Version = version
@IsDefault = isdefault
@AlertDetailRules = alertdetailrules
@TargetsTotal = targetstotal
end
def deserialize(params)
@Name = params['Name']
@Level = params['Level']
@Describe = params['Describe']
unless params['RecordRules'].nil?
@RecordRules = []
params['RecordRules'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@RecordRules << prometheusconfigitem_tmp
end
end
unless params['ServiceMonitors'].nil?
@ServiceMonitors = []
params['ServiceMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@ServiceMonitors << prometheusconfigitem_tmp
end
end
unless params['PodMonitors'].nil?
@PodMonitors = []
params['PodMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@PodMonitors << prometheusconfigitem_tmp
end
end
unless params['RawJobs'].nil?
@RawJobs = []
params['RawJobs'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@RawJobs << prometheusconfigitem_tmp
end
end
@TemplateId = params['TemplateId']
@UpdateTime = params['UpdateTime']
@Version = params['Version']
@IsDefault = params['IsDefault']
unless params['AlertDetailRules'].nil?
@AlertDetailRules = []
params['AlertDetailRules'].each do |i|
prometheusalertpolicyitem_tmp = PrometheusAlertPolicyItem.new
prometheusalertpolicyitem_tmp.deserialize(i)
@AlertDetailRules << prometheusalertpolicyitem_tmp
end
end
@TargetsTotal = params['TargetsTotal']
end
end
# 云原生Prometheus模板可修改项
class PrometheusTempModify < TencentCloud::Common::AbstractModel
# @param Name: 修改名称
# @type Name: String
# @param Describe: 修改描述
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Describe: String
# @param ServiceMonitors: 当Level为cluster时有效,
# 模板中的ServiceMonitor规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ServiceMonitors: Array
# @param PodMonitors: 当Level为cluster时有效,
# 模板中的PodMonitors规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PodMonitors: Array
# @param RawJobs: 当Level为cluster时有效,
# 模板中的RawJobs规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RawJobs: Array
# @param RecordRules: 当Level为instance时有效,
# 模板中的聚合规则列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RecordRules: Array
# @param AlertDetailRules: 修改内容,只有当模板类型是Alert时生效
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlertDetailRules: Array
attr_accessor :Name, :Describe, :ServiceMonitors, :PodMonitors, :RawJobs, :RecordRules, :AlertDetailRules
def initialize(name=nil, describe=nil, servicemonitors=nil, podmonitors=nil, rawjobs=nil, recordrules=nil, alertdetailrules=nil)
@Name = name
@Describe = describe
@ServiceMonitors = servicemonitors
@PodMonitors = podmonitors
@RawJobs = rawjobs
@RecordRules = recordrules
@AlertDetailRules = alertdetailrules
end
def deserialize(params)
@Name = params['Name']
@Describe = params['Describe']
unless params['ServiceMonitors'].nil?
@ServiceMonitors = []
params['ServiceMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@ServiceMonitors << prometheusconfigitem_tmp
end
end
unless params['PodMonitors'].nil?
@PodMonitors = []
params['PodMonitors'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@PodMonitors << prometheusconfigitem_tmp
end
end
unless params['RawJobs'].nil?
@RawJobs = []
params['RawJobs'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@RawJobs << prometheusconfigitem_tmp
end
end
unless params['RecordRules'].nil?
@RecordRules = []
params['RecordRules'].each do |i|
prometheusconfigitem_tmp = PrometheusConfigItem.new
prometheusconfigitem_tmp.deserialize(i)
@RecordRules << prometheusconfigitem_tmp
end
end
unless params['AlertDetailRules'].nil?
@AlertDetailRules = []
params['AlertDetailRules'].each do |i|
prometheusalertpolicyitem_tmp = PrometheusAlertPolicyItem.new
prometheusalertpolicyitem_tmp.deserialize(i)
@AlertDetailRules << prometheusalertpolicyitem_tmp
end
end
end
end
# 云原生Prometheus模板同步目标
class PrometheusTemplateSyncTarget < TencentCloud::Common::AbstractModel
# @param Region: 目标所在地域
# @type Region: String
# @param InstanceId: 目标实例
# @type InstanceId: String
# @param ClusterId: 集群id,只有当采集模板的Level为cluster的时候需要
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClusterId: String
# @param SyncTime: 最后一次同步时间, 用于出参
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SyncTime: String
# @param Version: 当前使用的模板版本,用于出参
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Version: String
# @param ClusterType: 集群类型,只有当采集模板的Level为cluster的时候需要
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClusterType: String
# @param InstanceName: 用于出参,实例名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceName: String
# @param ClusterName: 用于出参,集群名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClusterName: String
attr_accessor :Region, :InstanceId, :ClusterId, :SyncTime, :Version, :ClusterType, :InstanceName, :ClusterName
def initialize(region=nil, instanceid=nil, clusterid=nil, synctime=nil, version=nil, clustertype=nil, instancename=nil, clustername=nil)
@Region = region
@InstanceId = instanceid
@ClusterId = clusterid
@SyncTime = synctime
@Version = version
@ClusterType = clustertype
@InstanceName = instancename
@ClusterName = clustername
end
def deserialize(params)
@Region = params['Region']
@InstanceId = params['InstanceId']
@ClusterId = params['ClusterId']
@SyncTime = params['SyncTime']
@Version = params['Version']
@ClusterType = params['ClusterType']
@InstanceName = params['InstanceName']
@ClusterName = params['ClusterName']
end
end
# PrometheusZoneItem 响应结构体内的地域信息
class PrometheusZoneItem < TencentCloud::Common::AbstractModel
# @param Zone: 可用区
# @type Zone: String
# @param ZoneId: 可用区 ID
# @type ZoneId: Integer
# @param ZoneState: 可用区状态( 0: 不可用;1: 可用)
# @type ZoneState: Integer
# @param RegionId: 地域 ID
# @type RegionId: Integer
# @param ZoneName: 可用区名(目前为中文)
# @type ZoneName: String
# @param ZoneResourceState: 可用区资源状态(0:资源不足,不可使用;1:资源足够)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ZoneResourceState: Integer
attr_accessor :Zone, :ZoneId, :ZoneState, :RegionId, :ZoneName, :ZoneResourceState
def initialize(zone=nil, zoneid=nil, zonestate=nil, regionid=nil, zonename=nil, zoneresourcestate=nil)
@Zone = zone
@ZoneId = zoneid
@ZoneState = zonestate
@RegionId = regionid
@ZoneName = zonename
@ZoneResourceState = zoneresourcestate
end
def deserialize(params)
@Zone = params['Zone']
@ZoneId = params['ZoneId']
@ZoneState = params['ZoneState']
@RegionId = params['RegionId']
@ZoneName = params['ZoneName']
@ZoneResourceState = params['ZoneResourceState']
end
end
# 接收人信息
class ReceiverInfo < TencentCloud::Common::AbstractModel
# @param StartTime: 告警时间段开始时间。范围[0,86400),作为 UNIX 时间戳转成北京时间后去掉日期,例如7200表示"10:0:0"
# @type StartTime: Integer
# @param EndTime: 告警时间段结束时间。含义同StartTime
# @type EndTime: Integer
# @param NotifyWay: 告警通知方式。可选 "SMS","SITE","EMAIL","CALL","WECHAT"
# @type NotifyWay: Array
# @param ReceiverType: 接收人类型。“group” 或 “user”
# @type ReceiverType: String
# @param Id: ReceiverId
# @type Id: Integer
# @param SendFor: 电话告警通知时机。可选"OCCUR"(告警时通知),"RECOVER"(恢复时通知)
# @type SendFor: Array
# @param UidList: 电话告警接收者 UID
# @type UidList: Array
# @param RoundNumber: 电话告警轮数
# @type RoundNumber: Integer
# @param PersonInterval: 电话告警对个人间隔(秒)
# @type PersonInterval: Integer
# @param RoundInterval: 电话告警每轮间隔(秒)
# @type RoundInterval: Integer
# @param RecoverNotify: 恢复通知方式。可选"SMS"
# @type RecoverNotify: Array
# @param NeedSendNotice: 是否需要电话告警触达提示。0不需要,1需要
# @type NeedSendNotice: Integer
# @param ReceiverGroupList: 接收组列表。通过平台接口查询到的接收组 ID 列表
# @type ReceiverGroupList: Array
# @param ReceiverUserList: 接收人列表。通过平台接口查询到的接收人 ID 列表
# @type ReceiverUserList: Array
# @param ReceiveLanguage: 告警接收语言,枚举值(zh-CN,en-US)
# @type ReceiveLanguage: String
attr_accessor :StartTime, :EndTime, :NotifyWay, :ReceiverType, :Id, :SendFor, :UidList, :RoundNumber, :PersonInterval, :RoundInterval, :RecoverNotify, :NeedSendNotice, :ReceiverGroupList, :ReceiverUserList, :ReceiveLanguage
def initialize(starttime=nil, endtime=nil, notifyway=nil, receivertype=nil, id=nil, sendfor=nil, uidlist=nil, roundnumber=nil, personinterval=nil, roundinterval=nil, recovernotify=nil, needsendnotice=nil, receivergrouplist=nil, receiveruserlist=nil, receivelanguage=nil)
@StartTime = starttime
@EndTime = endtime
@NotifyWay = notifyway
@ReceiverType = receivertype
@Id = id
@SendFor = sendfor
@UidList = uidlist
@RoundNumber = roundnumber
@PersonInterval = personinterval
@RoundInterval = roundinterval
@RecoverNotify = recovernotify
@NeedSendNotice = needsendnotice
@ReceiverGroupList = receivergrouplist
@ReceiverUserList = receiveruserlist
@ReceiveLanguage = receivelanguage
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@NotifyWay = params['NotifyWay']
@ReceiverType = params['ReceiverType']
@Id = params['Id']
@SendFor = params['SendFor']
@UidList = params['UidList']
@RoundNumber = params['RoundNumber']
@PersonInterval = params['PersonInterval']
@RoundInterval = params['RoundInterval']
@RecoverNotify = params['RecoverNotify']
@NeedSendNotice = params['NeedSendNotice']
@ReceiverGroupList = params['ReceiverGroupList']
@ReceiverUserList = params['ReceiverUserList']
@ReceiveLanguage = params['ReceiveLanguage']
end
end
# Prometheus 聚合规则响应结构体内信息
class RecordingRuleSet < TencentCloud::Common::AbstractModel
# @param RuleId: 规则 ID
# @type RuleId: String
# @param RuleState: 规则状态码
# @type RuleState: Integer
# @param Name: 分组名称
# @type Name: String
# @param Group: 规则内容组
# @type Group: String
# @param Total: 规则数量
# @type Total: Integer
# @param CreatedAt: 规则创建时间
# @type CreatedAt: String
# @param UpdatedAt: 规则最近更新时间
# @type UpdatedAt: String
# @param RuleName: 规则名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleName: String
attr_accessor :RuleId, :RuleState, :Name, :Group, :Total, :CreatedAt, :UpdatedAt, :RuleName
def initialize(ruleid=nil, rulestate=nil, name=nil, group=nil, total=nil, createdat=nil, updatedat=nil, rulename=nil)
@RuleId = ruleid
@RuleState = rulestate
@Name = name
@Group = group
@Total = total
@CreatedAt = createdat
@UpdatedAt = updatedat
@RuleName = rulename
end
def deserialize(params)
@RuleId = params['RuleId']
@RuleState = params['RuleState']
@Name = params['Name']
@Group = params['Group']
@Total = params['Total']
@CreatedAt = params['CreatedAt']
@UpdatedAt = params['UpdatedAt']
@RuleName = params['RuleName']
end
end
# ResumeGrafanaInstance请求参数结构体
class ResumeGrafanaInstanceRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-12345678
# @type InstanceId: String
attr_accessor :InstanceId
def initialize(instanceid=nil)
@InstanceId = instanceid
end
def deserialize(params)
@InstanceId = params['InstanceId']
end
end
# ResumeGrafanaInstance返回参数结构体
class ResumeGrafanaInstanceResponse < 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
# RunPrometheusInstance请求参数结构体
class RunPrometheusInstanceRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
# @param SubnetId: 子网ID,默认使用实例所用子网初始化,也可通过该参数传递新的子网ID初始化
# @type SubnetId: String
attr_accessor :InstanceId, :SubnetId
def initialize(instanceid=nil, subnetid=nil)
@InstanceId = instanceid
@SubnetId = subnetid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@SubnetId = params['SubnetId']
end
end
# RunPrometheusInstance返回参数结构体
class RunPrometheusInstanceResponse < 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
# Prometheus 服务发现信息
class ServiceDiscoveryItem < TencentCloud::Common::AbstractModel
# @param Name: 服务发现名称
# @type Name: String
# @param Namespace: 服务发现属于的 Namespace
# @type Namespace: String
# @param Kind: 服务发现类型: ServiceMonitor/PodMonitor
# @type Kind: String
# @param NamespaceSelector: Namespace 选取方式
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NamespaceSelector: String
# @param Selector: Label 选取方式
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Selector: String
# @param Endpoints: Endpoints 信息(PodMonitor 不含该参数)
# @type Endpoints: String
# @param Yaml: 服务发现对应的配置信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Yaml: String
attr_accessor :Name, :Namespace, :Kind, :NamespaceSelector, :Selector, :Endpoints, :Yaml
def initialize(name=nil, namespace=nil, kind=nil, namespaceselector=nil, selector=nil, endpoints=nil, yaml=nil)
@Name = name
@Namespace = namespace
@Kind = kind
@NamespaceSelector = namespaceselector
@Selector = selector
@Endpoints = endpoints
@Yaml = yaml
end
def deserialize(params)
@Name = params['Name']
@Namespace = params['Namespace']
@Kind = params['Kind']
@NamespaceSelector = params['NamespaceSelector']
@Selector = params['Selector']
@Endpoints = params['Endpoints']
@Yaml = params['Yaml']
end
end
# SetDefaultAlarmPolicy请求参数结构体
class SetDefaultAlarmPolicyRequest < TencentCloud::Common::AbstractModel
# @param Module: 模块名,固定值 monitor
# @type Module: String
# @param PolicyId: 告警策略 ID
# @type PolicyId: String
attr_accessor :Module, :PolicyId
def initialize(_module=nil, policyid=nil)
@Module = _module
@PolicyId = policyid
end
def deserialize(params)
@Module = params['Module']
@PolicyId = params['PolicyId']
end
end
# SetDefaultAlarmPolicy返回参数结构体
class SetDefaultAlarmPolicyResponse < 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
# SyncPrometheusTemp请求参数结构体
class SyncPrometheusTempRequest < TencentCloud::Common::AbstractModel
# @param TemplateId: 实例id
# @type TemplateId: String
# @param Targets: 同步目标
# @type Targets: Array
attr_accessor :TemplateId, :Targets
def initialize(templateid=nil, targets=nil)
@TemplateId = templateid
@Targets = targets
end
def deserialize(params)
@TemplateId = params['TemplateId']
unless params['Targets'].nil?
@Targets = []
params['Targets'].each do |i|
prometheustemplatesynctarget_tmp = PrometheusTemplateSyncTarget.new
prometheustemplatesynctarget_tmp.deserialize(i)
@Targets << prometheustemplatesynctarget_tmp
end
end
end
end
# SyncPrometheusTemp返回参数结构体
class SyncPrometheusTempResponse < 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 Tag < TencentCloud::Common::AbstractModel
# @param Key: 标签key
# @type Key: String
# @param Value: 标签value
# @type Value: String
attr_accessor :Key, :Value
def initialize(key=nil, value=nil)
@Key = key
@Value = value
end
def deserialize(params)
@Key = params['Key']
@Value = params['Value']
end
end
# 策略列表详情标签返回体
class TagInstance < TencentCloud::Common::AbstractModel
# @param Key: 标签Key
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Key: String
# @param Value: 标签Value
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Value: String
# @param InstanceSum: 实例个数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceSum: Integer
# @param ServiceType: 产品类型,如:cvm
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ServiceType: String
# @param RegionId: 地域ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RegionId: Integer
# @param BindingStatus: 绑定状态,2:绑定成功,1:绑定中
# 注意:此字段可能返回 null,表示取不到有效值。
# @type BindingStatus: Integer
# @param TagStatus: 标签状态,2:标签存在,1:标签不存在
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TagStatus: Integer
attr_accessor :Key, :Value, :InstanceSum, :ServiceType, :RegionId, :BindingStatus, :TagStatus
def initialize(key=nil, value=nil, instancesum=nil, servicetype=nil, regionid=nil, bindingstatus=nil, tagstatus=nil)
@Key = key
@Value = value
@InstanceSum = instancesum
@ServiceType = servicetype
@RegionId = regionid
@BindingStatus = bindingstatus
@TagStatus = tagstatus
end
def deserialize(params)
@Key = params['Key']
@Value = params['Value']
@InstanceSum = params['InstanceSum']
@ServiceType = params['ServiceType']
@RegionId = params['RegionId']
@BindingStatus = params['BindingStatus']
@TagStatus = params['TagStatus']
end
end
# 抓取目标数
class Targets < TencentCloud::Common::AbstractModel
# @param Total: 总数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Total: Integer
# @param Up: 在线数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Up: Integer
# @param Down: 不在线数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Down: Integer
# @param Unknown: 未知状态数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Unknown: Integer
attr_accessor :Total, :Up, :Down, :Unknown
def initialize(total=nil, up=nil, down=nil, unknown=nil)
@Total = total
@Up = up
@Down = down
@Unknown = unknown
end
def deserialize(params)
@Total = params['Total']
@Up = params['Up']
@Down = params['Down']
@Unknown = params['Unknown']
end
end
# 任务步骤信息
class TaskStepInfo < TencentCloud::Common::AbstractModel
# @param Step: 步骤名称
# @type Step: String
# @param LifeState: 生命周期
# pending : 步骤未开始
# running: 步骤执行中
# success: 步骤成功完成
# failed: 步骤失败
# @type LifeState: String
# @param StartAt: 步骤开始时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type StartAt: String
# @param EndAt: 步骤结束时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EndAt: String
# @param FailedMsg: 若步骤生命周期为failed,则此字段显示错误信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FailedMsg: String
attr_accessor :Step, :LifeState, :StartAt, :EndAt, :FailedMsg
def initialize(step=nil, lifestate=nil, startat=nil, endat=nil, failedmsg=nil)
@Step = step
@LifeState = lifestate
@StartAt = startat
@EndAt = endat
@FailedMsg = failedmsg
end
def deserialize(params)
@Step = params['Step']
@LifeState = params['LifeState']
@StartAt = params['StartAt']
@EndAt = params['EndAt']
@FailedMsg = params['FailedMsg']
end
end
# 模板列表
class TemplateGroup < TencentCloud::Common::AbstractModel
# @param Conditions: 指标告警规则
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Conditions: Array
# @param EventConditions: 事件告警规则
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EventConditions: Array
# @param PolicyGroups: 关联告警策略组
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PolicyGroups: Array
# @param GroupID: 模板策略组ID
# @type GroupID: Integer
# @param GroupName: 模板策略组名称
# @type GroupName: String
# @param InsertTime: 创建时间
# @type InsertTime: Integer
# @param LastEditUin: 最后修改人UIN
# @type LastEditUin: Integer
# @param Remark: 备注
# @type Remark: String
# @param UpdateTime: 更新时间
# @type UpdateTime: Integer
# @param ViewName: 视图
# @type ViewName: String
# @param IsUnionRule: 是否为与关系
# @type IsUnionRule: Integer
attr_accessor :Conditions, :EventConditions, :PolicyGroups, :GroupID, :GroupName, :InsertTime, :LastEditUin, :Remark, :UpdateTime, :ViewName, :IsUnionRule
def initialize(conditions=nil, eventconditions=nil, policygroups=nil, groupid=nil, groupname=nil, inserttime=nil, lastedituin=nil, remark=nil, updatetime=nil, viewname=nil, isunionrule=nil)
@Conditions = conditions
@EventConditions = eventconditions
@PolicyGroups = policygroups
@GroupID = groupid
@GroupName = groupname
@InsertTime = inserttime
@LastEditUin = lastedituin
@Remark = remark
@UpdateTime = updatetime
@ViewName = viewname
@IsUnionRule = isunionrule
end
def deserialize(params)
unless params['Conditions'].nil?
@Conditions = []
params['Conditions'].each do |i|
condition_tmp = Condition.new
condition_tmp.deserialize(i)
@Conditions << condition_tmp
end
end
unless params['EventConditions'].nil?
@EventConditions = []
params['EventConditions'].each do |i|
eventcondition_tmp = EventCondition.new
eventcondition_tmp.deserialize(i)
@EventConditions << eventcondition_tmp
end
end
unless params['PolicyGroups'].nil?
@PolicyGroups = []
params['PolicyGroups'].each do |i|
policygroup_tmp = PolicyGroup.new
policygroup_tmp.deserialize(i)
@PolicyGroups << policygroup_tmp
end
end
@GroupID = params['GroupID']
@GroupName = params['GroupName']
@InsertTime = params['InsertTime']
@LastEditUin = params['LastEditUin']
@Remark = params['Remark']
@UpdateTime = params['UpdateTime']
@ViewName = params['ViewName']
@IsUnionRule = params['IsUnionRule']
end
end
# TerminatePrometheusInstances请求参数结构体
class TerminatePrometheusInstancesRequest < TencentCloud::Common::AbstractModel
# @param InstanceIds: 实例 ID 列表
# @type InstanceIds: Array
attr_accessor :InstanceIds
def initialize(instanceids=nil)
@InstanceIds = instanceids
end
def deserialize(params)
@InstanceIds = params['InstanceIds']
end
end
# TerminatePrometheusInstances返回参数结构体
class TerminatePrometheusInstancesResponse < 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
# kubernetes Taint
class Toleration < TencentCloud::Common::AbstractModel
# @param Key: 容忍应用到的 taint key
# @type Key: String
# @param Operator: 键与值的关系
# @type Operator: String
# @param Effect: 要匹配的污点效果
# @type Effect: String
attr_accessor :Key, :Operator, :Effect
def initialize(key=nil, operator=nil, effect=nil)
@Key = key
@Operator = operator
@Effect = effect
end
def deserialize(params)
@Key = params['Key']
@Operator = params['Operator']
@Effect = params['Effect']
end
end
# 告警通知模板 - 回调通知详情
class URLNotice < TencentCloud::Common::AbstractModel
# @param URL: 回调 url(限长256字符)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type URL: String
# @param IsValid: 是否通过验证 0=否 1=是
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IsValid: Integer
# @param ValidationCode: 验证码
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ValidationCode: String
# @param StartTime: 通知开始时间 一天开始的秒数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type StartTime: Integer
# @param EndTime: 通知结束时间 一天开始的秒数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EndTime: Integer
# @param Weekday: 通知周期 1-7表示周一到周日
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Weekday: Array
attr_accessor :URL, :IsValid, :ValidationCode, :StartTime, :EndTime, :Weekday
def initialize(url=nil, isvalid=nil, validationcode=nil, starttime=nil, endtime=nil, weekday=nil)
@URL = url
@IsValid = isvalid
@ValidationCode = validationcode
@StartTime = starttime
@EndTime = endtime
@Weekday = weekday
end
def deserialize(params)
@URL = params['URL']
@IsValid = params['IsValid']
@ValidationCode = params['ValidationCode']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@Weekday = params['Weekday']
end
end
# UnBindingAllPolicyObject请求参数结构体
class UnBindingAllPolicyObjectRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param GroupId: 策略组id,如传入 PolicyId 则该字段被忽略可传入任意值如 0
# @type GroupId: Integer
# @param PolicyId: 告警策略ID,使用此字段时 GroupId 会被忽略
# @type PolicyId: String
# @param EbSubject: 事件配置的告警
# @type EbSubject: String
# @param EbEventFlag: 是否配置了事件告警
# @type EbEventFlag: Integer
attr_accessor :Module, :GroupId, :PolicyId, :EbSubject, :EbEventFlag
def initialize(_module=nil, groupid=nil, policyid=nil, ebsubject=nil, ebeventflag=nil)
@Module = _module
@GroupId = groupid
@PolicyId = policyid
@EbSubject = ebsubject
@EbEventFlag = ebeventflag
end
def deserialize(params)
@Module = params['Module']
@GroupId = params['GroupId']
@PolicyId = params['PolicyId']
@EbSubject = params['EbSubject']
@EbEventFlag = params['EbEventFlag']
end
end
# UnBindingAllPolicyObject返回参数结构体
class UnBindingAllPolicyObjectResponse < 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
# UnBindingPolicyObject请求参数结构体
class UnBindingPolicyObjectRequest < TencentCloud::Common::AbstractModel
# @param Module: 固定值,为"monitor"
# @type Module: String
# @param GroupId: 策略组id,如传入 PolicyId 则该字段被忽略可传入任意值如 0
# @type GroupId: Integer
# @param UniqueId: 待删除对象实例的唯一id列表,UniqueId从调用[获取已绑定对象列表接口](https://cloud.tencent.com/document/api/248/40570)的出参的List中得到
# @type UniqueId: Array
# @param InstanceGroupId: 实例分组id,如果按实例分组删除的话UniqueId参数是无效的
# @type InstanceGroupId: Integer
# @param PolicyId: 告警策略ID,使用此字段时 GroupId 会被忽略
# @type PolicyId: String
# @param EbSubject: 事件配置的告警
# @type EbSubject: String
# @param EbEventFlag: 是否配置了事件告警
# @type EbEventFlag: Integer
attr_accessor :Module, :GroupId, :UniqueId, :InstanceGroupId, :PolicyId, :EbSubject, :EbEventFlag
def initialize(_module=nil, groupid=nil, uniqueid=nil, instancegroupid=nil, policyid=nil, ebsubject=nil, ebeventflag=nil)
@Module = _module
@GroupId = groupid
@UniqueId = uniqueid
@InstanceGroupId = instancegroupid
@PolicyId = policyid
@EbSubject = ebsubject
@EbEventFlag = ebeventflag
end
def deserialize(params)
@Module = params['Module']
@GroupId = params['GroupId']
@UniqueId = params['UniqueId']
@InstanceGroupId = params['InstanceGroupId']
@PolicyId = params['PolicyId']
@EbSubject = params['EbSubject']
@EbEventFlag = params['EbEventFlag']
end
end
# UnBindingPolicyObject返回参数结构体
class UnBindingPolicyObjectResponse < 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
# UnbindPrometheusManagedGrafana请求参数结构体
class UnbindPrometheusManagedGrafanaRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param GrafanaId: Grafana 实例 ID
# @type GrafanaId: String
attr_accessor :InstanceId, :GrafanaId
def initialize(instanceid=nil, grafanaid=nil)
@InstanceId = instanceid
@GrafanaId = grafanaid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@GrafanaId = params['GrafanaId']
end
end
# UnbindPrometheusManagedGrafana返回参数结构体
class UnbindPrometheusManagedGrafanaResponse < 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
# UninstallGrafanaDashboard请求参数结构体
class UninstallGrafanaDashboardRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param IntegrationCodes: Prometheus 集成项 Code,删除对应的 Dashboard,Code 如下:
# spring_mvc
# mysql
# go
# redis
# jvm
# pgsql
# mongo
# kafka
# es
# flink
# blackbox
# consule
# memcached
# zk
# tps
# istio
# etcd
# @type IntegrationCodes: Array
attr_accessor :InstanceId, :IntegrationCodes
def initialize(instanceid=nil, integrationcodes=nil)
@InstanceId = instanceid
@IntegrationCodes = integrationcodes
end
def deserialize(params)
@InstanceId = params['InstanceId']
@IntegrationCodes = params['IntegrationCodes']
end
end
# UninstallGrafanaDashboard返回参数结构体
class UninstallGrafanaDashboardResponse < 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
# UninstallGrafanaPlugins请求参数结构体
class UninstallGrafanaPluginsRequest < TencentCloud::Common::AbstractModel
# @param PluginIds: 插件 ID 数组,例如"PluginIds": [ "grafana-clock-panel" ],可通过 DescribePluginOverviews 获取 PluginId
# @type PluginIds: Array
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefg
# @type InstanceId: String
attr_accessor :PluginIds, :InstanceId
def initialize(pluginids=nil, instanceid=nil)
@PluginIds = pluginids
@InstanceId = instanceid
end
def deserialize(params)
@PluginIds = params['PluginIds']
@InstanceId = params['InstanceId']
end
end
# UninstallGrafanaPlugins返回参数结构体
class UninstallGrafanaPluginsResponse < 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
# UpdateAlertRule请求参数结构体
class UpdateAlertRuleRequest < TencentCloud::Common::AbstractModel
# @param RuleId: Prometheus 高警规则 ID
# @type RuleId: String
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param RuleState: 规则状态码,取值如下:
# 1=RuleDeleted
# 2=RuleEnabled
# 3=RuleDisabled
# 默认状态码为 2 启用。
# @type RuleState: Integer
# @param RuleName: 告警规则名称
# @type RuleName: String
# @param Expr: 告警规则表达式
# @type Expr: String
# @param Duration: 告警规则持续时间
# @type Duration: String
# @param Receivers: 告警规则接收组列表(当前规则绑定的接收组列表可通过 DescribeAlertRules 接口获取;用户已有的接收组列表可通过 DescribeAlarmNotices 接口获取)
# @type Receivers: Array
# @param Labels: 报警规则标签列表
# @type Labels: Array
# @param Annotations: 报警规则注释列表。
# 告警对象和告警消息是 Prometheus Rule Annotations 的特殊字段,需要通过 annotations 来传递,对应的 Key 分别为summary/description。
# @type Annotations: Array
# @param Type: 报警策略模板分类(自定义,可不填)
# @type Type: String
attr_accessor :RuleId, :InstanceId, :RuleState, :RuleName, :Expr, :Duration, :Receivers, :Labels, :Annotations, :Type
def initialize(ruleid=nil, instanceid=nil, rulestate=nil, rulename=nil, expr=nil, duration=nil, receivers=nil, labels=nil, annotations=nil, type=nil)
@RuleId = ruleid
@InstanceId = instanceid
@RuleState = rulestate
@RuleName = rulename
@Expr = expr
@Duration = duration
@Receivers = receivers
@Labels = labels
@Annotations = annotations
@Type = type
end
def deserialize(params)
@RuleId = params['RuleId']
@InstanceId = params['InstanceId']
@RuleState = params['RuleState']
@RuleName = params['RuleName']
@Expr = params['Expr']
@Duration = params['Duration']
@Receivers = params['Receivers']
unless params['Labels'].nil?
@Labels = []
params['Labels'].each do |i|
prometheusrulekv_tmp = PrometheusRuleKV.new
prometheusrulekv_tmp.deserialize(i)
@Labels << prometheusrulekv_tmp
end
end
unless params['Annotations'].nil?
@Annotations = []
params['Annotations'].each do |i|
prometheusrulekv_tmp = PrometheusRuleKV.new
prometheusrulekv_tmp.deserialize(i)
@Annotations << prometheusrulekv_tmp
end
end
@Type = params['Type']
end
end
# UpdateAlertRule返回参数结构体
class UpdateAlertRuleResponse < TencentCloud::Common::AbstractModel
# @param RuleId: 规则 ID
# @type RuleId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RuleId, :RequestId
def initialize(ruleid=nil, requestid=nil)
@RuleId = ruleid
@RequestId = requestid
end
def deserialize(params)
@RuleId = params['RuleId']
@RequestId = params['RequestId']
end
end
# UpdateAlertRuleState请求参数结构体
class UpdateAlertRuleStateRequest < TencentCloud::Common::AbstractModel
# @param RuleIds: 规则 ID 列表
# @type RuleIds: Array
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param RuleState: 规则状态码,取值如下:
# 2=RuleEnabled
# 3=RuleDisabled
# 默认状态码为 2 启用。
# @type RuleState: Integer
attr_accessor :RuleIds, :InstanceId, :RuleState
def initialize(ruleids=nil, instanceid=nil, rulestate=nil)
@RuleIds = ruleids
@InstanceId = instanceid
@RuleState = rulestate
end
def deserialize(params)
@RuleIds = params['RuleIds']
@InstanceId = params['InstanceId']
@RuleState = params['RuleState']
end
end
# UpdateAlertRuleState返回参数结构体
class UpdateAlertRuleStateResponse < 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
# UpdateDNSConfig请求参数结构体
class UpdateDNSConfigRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-12345678
# @type InstanceId: String
# @param NameServers: DNS 数组
# @type NameServers: Array
attr_accessor :InstanceId, :NameServers
def initialize(instanceid=nil, nameservers=nil)
@InstanceId = instanceid
@NameServers = nameservers
end
def deserialize(params)
@InstanceId = params['InstanceId']
@NameServers = params['NameServers']
end
end
# UpdateDNSConfig返回参数结构体
class UpdateDNSConfigResponse < 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
# UpdateExporterIntegration请求参数结构体
class UpdateExporterIntegrationRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param Kind: 类型(可通过 DescribeExporterIntegrations 获取对应集成的 Kind)
# @type Kind: String
# @param Content: 配置内容(可通过 DescribeExporterIntegrations 接口获取对应集成的 Content,并在此基础上做修改)
# @type Content: String
# @param KubeType: Kubernetes 集群类型,可不填。取值如下:
# 1= 容器集群(TKE)
# 2=弹性集群(EKS)
# 3= Prometheus管理的弹性集群(MEKS)
# @type KubeType: Integer
# @param ClusterId: 集群 ID,可不填
# @type ClusterId: String
attr_accessor :InstanceId, :Kind, :Content, :KubeType, :ClusterId
def initialize(instanceid=nil, kind=nil, content=nil, kubetype=nil, clusterid=nil)
@InstanceId = instanceid
@Kind = kind
@Content = content
@KubeType = kubetype
@ClusterId = clusterid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Kind = params['Kind']
@Content = params['Content']
@KubeType = params['KubeType']
@ClusterId = params['ClusterId']
end
end
# UpdateExporterIntegration返回参数结构体
class UpdateExporterIntegrationResponse < 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
# UpdateGrafanaConfig请求参数结构体
class UpdateGrafanaConfigRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param Config: JSON 编码后的字符串,如 "{"server":{"root_url":"http://custom.domain"}}"
# @type Config: String
attr_accessor :InstanceId, :Config
def initialize(instanceid=nil, config=nil)
@InstanceId = instanceid
@Config = config
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Config = params['Config']
end
end
# UpdateGrafanaConfig返回参数结构体
class UpdateGrafanaConfigResponse < 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
# UpdateGrafanaEnvironments请求参数结构体
class UpdateGrafanaEnvironmentsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-12345678
# @type InstanceId: String
# @param Envs: JSON 序列化后的环境变量字符串,如 "{\"key1\":\"key2\"}"
# @type Envs: String
attr_accessor :InstanceId, :Envs
def initialize(instanceid=nil, envs=nil)
@InstanceId = instanceid
@Envs = envs
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Envs = params['Envs']
end
end
# UpdateGrafanaEnvironments返回参数结构体
class UpdateGrafanaEnvironmentsResponse < 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
# UpdateGrafanaIntegration请求参数结构体
class UpdateGrafanaIntegrationRequest < TencentCloud::Common::AbstractModel
# @param IntegrationId: 集成 ID,可在实例详情-云产品集成-集成列表查看。例如:integration-abcd1234
# @type IntegrationId: String
# @param InstanceId: Grafana 实例 ID,例如:grafana-12345678
# @type InstanceId: String
# @param Kind: 集成类型,可在实例详情-云产品集成-集成列表查看。例如:tencent-cloud-prometheus
# @type Kind: String
# @param Content: 集成内容,请查看示例
# @type Content: String
attr_accessor :IntegrationId, :InstanceId, :Kind, :Content
def initialize(integrationid=nil, instanceid=nil, kind=nil, content=nil)
@IntegrationId = integrationid
@InstanceId = instanceid
@Kind = kind
@Content = content
end
def deserialize(params)
@IntegrationId = params['IntegrationId']
@InstanceId = params['InstanceId']
@Kind = params['Kind']
@Content = params['Content']
end
end
# UpdateGrafanaIntegration返回参数结构体
class UpdateGrafanaIntegrationResponse < 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
# UpdateGrafanaNotificationChannel请求参数结构体
class UpdateGrafanaNotificationChannelRequest < TencentCloud::Common::AbstractModel
# @param ChannelId: 通道 ID,例如:nchannel-abcd1234
# @type ChannelId: String
# @param InstanceId: Grafana 实例 ID,例如:grafana-12345678
# @type InstanceId: String
# @param Receivers: 接受告警通道 ID 数组
# @type Receivers: Array
# @param ChannelName: 告警通道名称,已废弃,名称不可修改。
# @type ChannelName: String
# @param ExtraOrgIds: 已废弃,请使用 OrganizationIds
# @type ExtraOrgIds: Array
# @param OrganizationIds: 生效的组织 ID 数组
# @type OrganizationIds: Array
attr_accessor :ChannelId, :InstanceId, :Receivers, :ChannelName, :ExtraOrgIds, :OrganizationIds
def initialize(channelid=nil, instanceid=nil, receivers=nil, channelname=nil, extraorgids=nil, organizationids=nil)
@ChannelId = channelid
@InstanceId = instanceid
@Receivers = receivers
@ChannelName = channelname
@ExtraOrgIds = extraorgids
@OrganizationIds = organizationids
end
def deserialize(params)
@ChannelId = params['ChannelId']
@InstanceId = params['InstanceId']
@Receivers = params['Receivers']
@ChannelName = params['ChannelName']
@ExtraOrgIds = params['ExtraOrgIds']
@OrganizationIds = params['OrganizationIds']
end
end
# UpdateGrafanaNotificationChannel返回参数结构体
class UpdateGrafanaNotificationChannelResponse < 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
# UpdateGrafanaWhiteList请求参数结构体
class UpdateGrafanaWhiteListRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
# @param Whitelist: 白名单数组,输入白名单 IP 或 CIDR,如:127.0.0.1或127.0.0.1/24
# 如有多个 IP 可换行输入
# @type Whitelist: Array
attr_accessor :InstanceId, :Whitelist
def initialize(instanceid=nil, whitelist=nil)
@InstanceId = instanceid
@Whitelist = whitelist
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Whitelist = params['Whitelist']
end
end
# UpdateGrafanaWhiteList返回参数结构体
class UpdateGrafanaWhiteListResponse < 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
# UpdatePrometheusAgentStatus请求参数结构体
class UpdatePrometheusAgentStatusRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param AgentIds: Agent ID 列表,例如:agent-abcd1234,可在控制台 Agent 管理中获取
# @type AgentIds: Array
# @param Status: 要更新的状态
# 1= 开启
# 2= 关闭
# @type Status: Integer
attr_accessor :InstanceId, :AgentIds, :Status
def initialize(instanceid=nil, agentids=nil, status=nil)
@InstanceId = instanceid
@AgentIds = agentids
@Status = status
end
def deserialize(params)
@InstanceId = params['InstanceId']
@AgentIds = params['AgentIds']
@Status = params['Status']
end
end
# UpdatePrometheusAgentStatus返回参数结构体
class UpdatePrometheusAgentStatusResponse < 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
# UpdatePrometheusAlertGroup请求参数结构体
class UpdatePrometheusAlertGroupRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: prometheus实例ID
# @type InstanceId: String
# @param GroupId: 告警分组ID,形如alert-xxxx
# @type GroupId: String
# @param GroupName: 告警分组名称,不能与其他告警分组重名
# @type GroupName: String
# @param GroupState: 告警分组状态:
# 2 -- 启用
# 3 -- 禁用
# 不为空时会覆盖 `Rules`字段下所有告警规则状态
# @type GroupState: Integer
# @param AMPReceivers: 云监控告警通知模板ID列表,形如Consumer-xxxx或notice-xxxx
# @type AMPReceivers: Array
# @param CustomReceiver: 自定义告警通知模板
# @type CustomReceiver: :class:`Tencentcloud::Monitor.v20180724.models.PrometheusAlertCustomReceiver`
# @param RepeatInterval: 告警通知周期(收敛时间),为空默认1h
# @type RepeatInterval: String
# @param Rules: 要创建的告警规则列表
# @type Rules: Array
attr_accessor :InstanceId, :GroupId, :GroupName, :GroupState, :AMPReceivers, :CustomReceiver, :RepeatInterval, :Rules
def initialize(instanceid=nil, groupid=nil, groupname=nil, groupstate=nil, ampreceivers=nil, customreceiver=nil, repeatinterval=nil, rules=nil)
@InstanceId = instanceid
@GroupId = groupid
@GroupName = groupname
@GroupState = groupstate
@AMPReceivers = ampreceivers
@CustomReceiver = customreceiver
@RepeatInterval = repeatinterval
@Rules = rules
end
def deserialize(params)
@InstanceId = params['InstanceId']
@GroupId = params['GroupId']
@GroupName = params['GroupName']
@GroupState = params['GroupState']
@AMPReceivers = params['AMPReceivers']
unless params['CustomReceiver'].nil?
@CustomReceiver = PrometheusAlertCustomReceiver.new
@CustomReceiver.deserialize(params['CustomReceiver'])
end
@RepeatInterval = params['RepeatInterval']
unless params['Rules'].nil?
@Rules = []
params['Rules'].each do |i|
prometheusalertgroupruleset_tmp = PrometheusAlertGroupRuleSet.new
prometheusalertgroupruleset_tmp.deserialize(i)
@Rules << prometheusalertgroupruleset_tmp
end
end
end
end
# UpdatePrometheusAlertGroup返回参数结构体
class UpdatePrometheusAlertGroupResponse < TencentCloud::Common::AbstractModel
# @param GroupId: 更新的告警分组ID,满足正则表达式`alert-[a-z0-9]{8}`
# @type GroupId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :GroupId, :RequestId
def initialize(groupid=nil, requestid=nil)
@GroupId = groupid
@RequestId = requestid
end
def deserialize(params)
@GroupId = params['GroupId']
@RequestId = params['RequestId']
end
end
# UpdatePrometheusAlertGroupState请求参数结构体
class UpdatePrometheusAlertGroupStateRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param GroupIds: 告警分组ID列表,形如alert-xxxx
# @type GroupIds: Array
# @param GroupState: 告警分组状态
# 2 -- 启用
# 3 -- 禁用
# @type GroupState: Integer
attr_accessor :InstanceId, :GroupIds, :GroupState
def initialize(instanceid=nil, groupids=nil, groupstate=nil)
@InstanceId = instanceid
@GroupIds = groupids
@GroupState = groupstate
end
def deserialize(params)
@InstanceId = params['InstanceId']
@GroupIds = params['GroupIds']
@GroupState = params['GroupState']
end
end
# UpdatePrometheusAlertGroupState返回参数结构体
class UpdatePrometheusAlertGroupStateResponse < 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
# UpdatePrometheusScrapeJob请求参数结构体
class UpdatePrometheusScrapeJobRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID(可通过 DescribePrometheusInstances 接口获取)
# @type InstanceId: String
# @param AgentId: Agent ID(可通过DescribePrometheusAgents 接口获取)
# @type AgentId: String
# @param JobId: 抓取任务 ID(可通过 DescribePrometheusScrapeJobs 接口获取)
# @type JobId: String
# @param Config: 抓取任务配置
# @type Config: String
attr_accessor :InstanceId, :AgentId, :JobId, :Config
def initialize(instanceid=nil, agentid=nil, jobid=nil, config=nil)
@InstanceId = instanceid
@AgentId = agentid
@JobId = jobid
@Config = config
end
def deserialize(params)
@InstanceId = params['InstanceId']
@AgentId = params['AgentId']
@JobId = params['JobId']
@Config = params['Config']
end
end
# UpdatePrometheusScrapeJob返回参数结构体
class UpdatePrometheusScrapeJobResponse < 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
# UpdateRecordingRule请求参数结构体
class UpdateRecordingRuleRequest < TencentCloud::Common::AbstractModel
# @param Name: 聚合规则名称
# @type Name: String
# @param Group: 聚合规则组内容,格式为 yaml,通过 base64 进行编码。
# @type Group: String
# @param InstanceId: Prometheus 实例 ID(可通过 DescribePrometheusInstances 接口获取)
# @type InstanceId: String
# @param RuleId: Prometheus 聚合规则 ID(可通过 DescribeRecordingRules 接口获取)
# @type RuleId: String
# @param RuleState: 规则状态码,取值如下:
# 1=RuleDeleted
# 2=RuleEnabled
# 3=RuleDisabled
# 默认状态码为 2 启用。
# @type RuleState: Integer
attr_accessor :Name, :Group, :InstanceId, :RuleId, :RuleState
def initialize(name=nil, group=nil, instanceid=nil, ruleid=nil, rulestate=nil)
@Name = name
@Group = group
@InstanceId = instanceid
@RuleId = ruleid
@RuleState = rulestate
end
def deserialize(params)
@Name = params['Name']
@Group = params['Group']
@InstanceId = params['InstanceId']
@RuleId = params['RuleId']
@RuleState = params['RuleState']
end
end
# UpdateRecordingRule返回参数结构体
class UpdateRecordingRuleResponse < TencentCloud::Common::AbstractModel
# @param RuleId: 规则 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RuleId, :RequestId
def initialize(ruleid=nil, requestid=nil)
@RuleId = ruleid
@RequestId = requestid
end
def deserialize(params)
@RuleId = params['RuleId']
@RequestId = params['RequestId']
end
end
# UpdateSSOAccount请求参数结构体
class UpdateSSOAccountRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-abcdefgh
# @type InstanceId: String
# @param UserId: 用户账号 ID ,例如:10000000
# @type UserId: String
# @param Role: 权限
# @type Role: Array
# @param Notes: 备注
# @type Notes: String
attr_accessor :InstanceId, :UserId, :Role, :Notes
def initialize(instanceid=nil, userid=nil, role=nil, notes=nil)
@InstanceId = instanceid
@UserId = userid
@Role = role
@Notes = notes
end
def deserialize(params)
@InstanceId = params['InstanceId']
@UserId = params['UserId']
unless params['Role'].nil?
@Role = []
params['Role'].each do |i|
grafanaaccountrole_tmp = GrafanaAccountRole.new
grafanaaccountrole_tmp.deserialize(i)
@Role << grafanaaccountrole_tmp
end
end
@Notes = params['Notes']
end
end
# UpdateSSOAccount返回参数结构体
class UpdateSSOAccountResponse < 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
# UpdateServiceDiscovery请求参数结构体
class UpdateServiceDiscoveryRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Prometheus 实例 ID
# @type InstanceId: String
# @param KubeClusterId: 类型是 TKE,为对应的腾讯云容器服务集群 ID
# @type KubeClusterId: String
# @param KubeType: 用户 Kubernetes 集群类型:
# 1 = 容器服务集群(TKE)
# @type KubeType: Integer
# @param Type: 服务发现类型,取值如下:
# 1 = ServiceMonitor
# 2 = PodMonitor
# 3 = JobMonitor
# @type Type: Integer
# @param Yaml: 服务发现配置信息,YAML 格式,[具体YAML参数内容请参考](https://cloud.tencent.com/document/product/1416/55995#service-monitor)
# @type Yaml: String
attr_accessor :InstanceId, :KubeClusterId, :KubeType, :Type, :Yaml
def initialize(instanceid=nil, kubeclusterid=nil, kubetype=nil, type=nil, yaml=nil)
@InstanceId = instanceid
@KubeClusterId = kubeclusterid
@KubeType = kubetype
@Type = type
@Yaml = yaml
end
def deserialize(params)
@InstanceId = params['InstanceId']
@KubeClusterId = params['KubeClusterId']
@KubeType = params['KubeType']
@Type = params['Type']
@Yaml = params['Yaml']
end
end
# UpdateServiceDiscovery返回参数结构体
class UpdateServiceDiscoveryResponse < TencentCloud::Common::AbstractModel
# @param ServiceDiscovery: 更新成功之后,返回对应服务发现的信息
# @type ServiceDiscovery: :class:`Tencentcloud::Monitor.v20180724.models.ServiceDiscoveryItem`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ServiceDiscovery, :RequestId
def initialize(servicediscovery=nil, requestid=nil)
@ServiceDiscovery = servicediscovery
@RequestId = requestid
end
def deserialize(params)
unless params['ServiceDiscovery'].nil?
@ServiceDiscovery = ServiceDiscoveryItem.new
@ServiceDiscovery.deserialize(params['ServiceDiscovery'])
end
@RequestId = params['RequestId']
end
end
# UpgradeGrafanaDashboard请求参数结构体
class UpgradeGrafanaDashboardRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID
# @type InstanceId: String
# @param IntegrationCodes: Prometheus 集成项 Code,升级对应的 Dashboard,取值如下:qcloudcvm_process_exportercvm_node_exportercvmtpsnginx-ingressnvidia-gpucdwchemrapacherocketmqrabbitmqspring_mvcmysqlmssqlgoredisjvmpgsqlcephdockernginxoracledbmongokafkaesflinkblackboxconsulememcachedzktpsistioetcdptskong
# @type IntegrationCodes: Array
attr_accessor :InstanceId, :IntegrationCodes
def initialize(instanceid=nil, integrationcodes=nil)
@InstanceId = instanceid
@IntegrationCodes = integrationcodes
end
def deserialize(params)
@InstanceId = params['InstanceId']
@IntegrationCodes = params['IntegrationCodes']
end
end
# UpgradeGrafanaDashboard返回参数结构体
class UpgradeGrafanaDashboardResponse < 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
# UpgradeGrafanaInstance请求参数结构体
class UpgradeGrafanaInstanceRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: Grafana 实例 ID,例如:grafana-12345678
# @type InstanceId: String
# @param Alias: 版本别名,目前固定为 v9.1.5
# @type Alias: String
attr_accessor :InstanceId, :Alias
def initialize(instanceid=nil, _alias=nil)
@InstanceId = instanceid
@Alias = _alias
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Alias = params['Alias']
end
end
# UpgradeGrafanaInstance返回参数结构体
class UpgradeGrafanaInstanceResponse < 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 UserNotice < TencentCloud::Common::AbstractModel
# @param ReceiverType: 接收者类型 USER=用户 GROUP=用户组
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ReceiverType: String
# @param StartTime: 通知开始时间 00:00:00 开始的秒数(取值范围0-86399)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type StartTime: Integer
# @param EndTime: 通知结束时间 00:00:00 开始的秒数(取值范围0-86399)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EndTime: Integer
# @param NoticeWay: 通知渠道列表 EMAIL=邮件 SMS=短信 CALL=电话 WECHAT=微信 RTX=企业微信
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NoticeWay: Array
# @param UserIds: 用户 uid 列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UserIds: Array
# @param GroupIds: 用户组 group id 列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GroupIds: Array
# @param PhoneOrder: 电话轮询列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PhoneOrder: Array
# @param PhoneCircleTimes: 电话轮询次数 (取值范围1-5)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PhoneCircleTimes: Integer
# @param PhoneInnerInterval: 单次轮询内拨打间隔 秒数 (取值范围60-900)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PhoneInnerInterval: Integer
# @param PhoneCircleInterval: 两次轮询间隔 秒数(取值范围60-900)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PhoneCircleInterval: Integer
# @param NeedPhoneArriveNotice: 是否需要触达通知 0=否 1=是
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NeedPhoneArriveNotice: Integer
# @param PhoneCallType: 电话拨打类型 SYNC=同时拨打 CIRCLE=轮询拨打 不指定时默认是轮询
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PhoneCallType: String
# @param Weekday: 通知周期 1-7表示周一到周日
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Weekday: Array
# @param OnCallFormIDs: 值班表id列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OnCallFormIDs: Array
# @param VoiceConfirmKey: 电话按键确认
# 注意:此字段可能返回 null,表示取不到有效值。
# @type VoiceConfirmKey: String
attr_accessor :ReceiverType, :StartTime, :EndTime, :NoticeWay, :UserIds, :GroupIds, :PhoneOrder, :PhoneCircleTimes, :PhoneInnerInterval, :PhoneCircleInterval, :NeedPhoneArriveNotice, :PhoneCallType, :Weekday, :OnCallFormIDs, :VoiceConfirmKey
def initialize(receivertype=nil, starttime=nil, endtime=nil, noticeway=nil, userids=nil, groupids=nil, phoneorder=nil, phonecircletimes=nil, phoneinnerinterval=nil, phonecircleinterval=nil, needphonearrivenotice=nil, phonecalltype=nil, weekday=nil, oncallformids=nil, voiceconfirmkey=nil)
@ReceiverType = receivertype
@StartTime = starttime
@EndTime = endtime
@NoticeWay = noticeway
@UserIds = userids
@GroupIds = groupids
@PhoneOrder = phoneorder
@PhoneCircleTimes = phonecircletimes
@PhoneInnerInterval = phoneinnerinterval
@PhoneCircleInterval = phonecircleinterval
@NeedPhoneArriveNotice = needphonearrivenotice
@PhoneCallType = phonecalltype
@Weekday = weekday
@OnCallFormIDs = oncallformids
@VoiceConfirmKey = voiceconfirmkey
end
def deserialize(params)
@ReceiverType = params['ReceiverType']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@NoticeWay = params['NoticeWay']
@UserIds = params['UserIds']
@GroupIds = params['GroupIds']
@PhoneOrder = params['PhoneOrder']
@PhoneCircleTimes = params['PhoneCircleTimes']
@PhoneInnerInterval = params['PhoneInnerInterval']
@PhoneCircleInterval = params['PhoneCircleInterval']
@NeedPhoneArriveNotice = params['NeedPhoneArriveNotice']
@PhoneCallType = params['PhoneCallType']
@Weekday = params['Weekday']
@OnCallFormIDs = params['OnCallFormIDs']
@VoiceConfirmKey = params['VoiceConfirmKey']
end
end
end
end
end