From 5f807832ee17c0eca8c104dc19f8588a88c06a29 Mon Sep 17 00:00:00 2001 From: mikatong Date: Fri, 6 Dec 2024 20:40:15 +0800 Subject: [PATCH 1/7] lite hbase support prepay --- go.mod | 2 +- go.sum | 2 + .../emr/resource_tc_lite_hbase_instance.go | 81 +- .../resource_tc_lite_hbase_instance_test.go | 61 +- .../tencentcloud/emr/v20190103/client.go | 366 +++++- .../tencentcloud/emr/v20190103/errors.go | 2 +- .../tencentcloud/emr/v20190103/models.go | 1047 ++++++++++++++--- vendor/modules.txt | 2 +- .../docs/r/lite_hbase_instance.html.markdown | 9 +- 9 files changed, 1387 insertions(+), 185 deletions(-) diff --git a/go.mod b/go.mod index 012256169f..7ecf99ae6d 100644 --- a/go.mod +++ b/go.mod @@ -59,7 +59,7 @@ require ( github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/domain v1.0.414 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/dts v1.0.628 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/eb v1.0.760 - github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr v1.0.1004 + github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr v1.0.1055 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/es v1.0.777 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/gaap v1.0.970 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/kms v1.0.563 diff --git a/go.sum b/go.sum index a73ebf1f04..0111f6a34d 100644 --- a/go.sum +++ b/go.sum @@ -974,6 +974,8 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/eb v1.0.760 h1:IKP2LFgJ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/eb v1.0.760/go.mod h1:pSQXTeuC6BahiUIfssVqvL1/BoXccLkyD7nJ+tKgygw= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr v1.0.1004 h1:PbKCgIXZSwX0eraNZGG+AqVjgLZwW/C+up/6mL9FP3o= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr v1.0.1004/go.mod h1:6H1XZ2TIVV6VHdjkdQQl611NsIJkeTqugZ1jaUfPop4= +github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr v1.0.1055 h1:CAxiWYRFmvpcDMkpoF7E0HZXgpM2BPYE+uyrS92LPQE= +github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr v1.0.1055/go.mod h1:tmcOt09PyU+2nQgdbz0Lwe8aS8/Sb1spemL9kxusCPU= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/es v1.0.777 h1:G1eX/DkiznhSjNVF97BAQyycFXOiPHxeTxgOadp5J/o= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/es v1.0.777/go.mod h1:ehbc9eaNknF/VU/kPTFLZbIUmkL06vQ/JYydu6yeXp4= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/gaap v1.0.970 h1:Z82LbcEnE2m4CGvcOY024N7REhAN++xdEyE88HG2YBA= diff --git a/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go b/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go index fd89b33f73..ff839773d7 100644 --- a/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go +++ b/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go @@ -34,19 +34,19 @@ func ResourceTencentCloudLiteHbaseInstance() *schema.Resource { "pay_mode": { Type: schema.TypeInt, Required: true, - Description: "Instance pay mode. Value range: 0: indicates post pay mode, that is, pay-as-you-go.", + Description: "Instance pay mode. Value range: 0: indicates post-pay mode, that is, pay-as-you-go. 1: indicates pre-pay mode, that is, monthly subscription.", }, "disk_type": { Type: schema.TypeString, Required: true, - Description: "Instance disk type, fill in CLOUD_HSSD to indicate performance cloud storage.", + Description: "Instance disk type, Value range: CLOUD_HSSD: indicate performance cloud storage(ESSD). CLOUD_BSSD: indicate standard cloud storage(SSD).", }, "disk_size": { Type: schema.TypeInt, Required: true, - Description: "Instance single-node disk capacity, in GB. The single-node disk capacity must be greater than or equal to 100 and less than or equal to 10000, with an adjustment step size of 20.", + Description: "Instance single-node disk capacity, in GB. The single-node disk capacity must be greater than or equal to 100 and less than or equal to 250 times the number of CPU cores. The capacity adjustment step is 100.", }, "node_type": { @@ -114,6 +114,23 @@ func ResourceTencentCloudLiteHbaseInstance() *schema.Resource { }, }, }, + + "time_span": { + Type: schema.TypeInt, + Optional: true, + Description: "Time span.", + }, + "time_unit": { + Type: schema.TypeString, + Optional: true, + Description: "Time unit, fill in m which means month.", + }, + "auto_renew_flag": { + Type: schema.TypeInt, + Optional: true, + Computed: true, + Description: "AutoRenewFlag, Value range: 0: indicates NOTIFY_AND_MANUAL_RENEW; 1: indicates NOTIFY_AND_AUTO_RENEW; 2: indicates DISABLE_NOTIFY_AND_MANUAL_RENEW.", + }, }, } } @@ -189,6 +206,31 @@ func resourceTencentCloudLiteHbaseInstanceCreate(d *schema.ResourceData, meta in } } + var prePaySetting *emr.PrePaySetting + if v, ok := d.GetOk("time_span"); ok { + prePaySetting = &emr.PrePaySetting{} + prePaySetting.Period = &emr.Period{} + prePaySetting.Period.TimeSpan = helper.IntInt64(v.(int)) + } + if v, ok := d.GetOk("time_unit"); ok { + if prePaySetting == nil { + prePaySetting = &emr.PrePaySetting{} + } + if prePaySetting.Period == nil { + prePaySetting.Period = &emr.Period{} + } + prePaySetting.Period.TimeUnit = helper.String(v.(string)) + } + if v, ok := d.GetOk("auto_renew_flag"); ok { + if prePaySetting == nil { + prePaySetting = &emr.PrePaySetting{} + } + prePaySetting.AutoRenewFlag = helper.IntInt64(v.(int)) + } + if prePaySetting != nil { + request.PrePaySetting = prePaySetting + } + err := resource.Retry(tccommon.WriteRetryTimeout, func() *resource.RetryError { result, e := meta.(tccommon.ProviderMeta).GetAPIV3Conn().UseEmrClient().CreateSLInstanceWithContext(ctx, request) if e != nil { @@ -267,10 +309,6 @@ func resourceTencentCloudLiteHbaseInstanceRead(d *schema.ResourceData, meta inte _ = d.Set("disk_size", respData.DiskSize) } - if respData.NodeType != nil { - _ = d.Set("node_type", respData.NodeType) - } - zoneSettingsList := make([]map[string]interface{}, 0, len(respData.ZoneSettings)) if respData.ZoneSettings != nil { for _, zoneSettings := range respData.ZoneSettings { @@ -322,6 +360,9 @@ func resourceTencentCloudLiteHbaseInstanceRead(d *schema.ResourceData, meta inte _ = d.Set("tags", tagsList) } + if respData.AutoRenewFlag != nil { + _ = d.Set("auto_renew_flag", respData.AutoRenewFlag) + } _ = instanceId return nil @@ -335,7 +376,7 @@ func resourceTencentCloudLiteHbaseInstanceUpdate(d *schema.ResourceData, meta in ctx := tccommon.NewResourceLifeCycleHandleFuncContext(context.Background(), logId, d, meta) - immutableArgs := []string{"instance_name", "pay_mode", "disk_type", "disk_size", "node_type", "tags"} + immutableArgs := []string{"instance_name", "pay_mode", "disk_type", "disk_size", "node_type", "tags", "time_span", "time_unit", "auto_renew_flag"} for _, v := range immutableArgs { if d.HasChange(v) { return fmt.Errorf("argument `%s` cannot be changed", v) @@ -434,9 +475,33 @@ func resourceTencentCloudLiteHbaseInstanceDelete(d *schema.ResourceData, meta in log.Printf("[CRITAL]%s delete lite hbase instance failed, reason:%+v", logId, err) return err } + emrService := EMRService{ client: meta.(tccommon.ProviderMeta).GetAPIV3Conn(), } + + if d.Get("pay_mode").(int) == 1 { + conf := tccommon.BuildStateChangeConf([]string{}, []string{"201"}, 10*tccommon.ReadRetryTimeout, time.Second, emrService.SLInstanceStateRefreshFunc(instanceId, []string{})) + if _, e := conf.WaitForState(); e != nil { + return e + } + + err := resource.Retry(tccommon.WriteRetryTimeout, func() *resource.RetryError { + result, e := meta.(tccommon.ProviderMeta).GetAPIV3Conn().UseEmrClient().TerminateSLInstanceWithContext(ctx, request) + if e != nil { + return tccommon.RetryError(e) + } else { + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", logId, request.GetAction(), request.ToJsonString(), result.ToJsonString()) + } + response = result + return nil + }) + if err != nil { + log.Printf("[CRITAL]%s delete lite hbase instance failed, reason:%+v", logId, err) + return err + } + } + conf := tccommon.BuildStateChangeConf([]string{}, []string{"-2"}, 10*tccommon.ReadRetryTimeout, time.Second, emrService.SLInstanceStateRefreshFunc(instanceId, []string{})) if _, e := conf.WaitForState(); e != nil { return e diff --git a/tencentcloud/services/emr/resource_tc_lite_hbase_instance_test.go b/tencentcloud/services/emr/resource_tc_lite_hbase_instance_test.go index bb8b7243ba..ddfb66ca0f 100644 --- a/tencentcloud/services/emr/resource_tc_lite_hbase_instance_test.go +++ b/tencentcloud/services/emr/resource_tc_lite_hbase_instance_test.go @@ -51,9 +51,39 @@ func TestAccTencentCloudLiteHbaseInstanceResource_basic(t *testing.T) { ), }, { - ResourceName: "tencentcloud_lite_hbase_instance.lite_hbase_instance", - ImportState: true, - ImportStateVerify: true, + ResourceName: "tencentcloud_lite_hbase_instance.lite_hbase_instance", + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"node_type", "time_span", "time_unit"}, + }, + }, + }) +} + +func TestAccTencentCloudLiteHbaseInstanceResource_prepay(t *testing.T) { + t.Parallel() + resource.Test(t, resource.TestCase{ + PreCheck: func() { + tcacctest.AccPreCheck(t) + }, + Providers: tcacctest.AccProviders, + Steps: []resource.TestStep{ + { + Config: testAccLiteHbaseInstancePrePay, + Check: resource.ComposeTestCheckFunc( + resource.TestCheckResourceAttrSet("tencentcloud_lite_hbase_instance.lite_hbase_instance_prepay", "id"), + resource.TestCheckResourceAttr("tencentcloud_lite_hbase_instance.lite_hbase_instance_prepay", "instance_name", "tf-test-prepay"), + resource.TestCheckResourceAttr("tencentcloud_lite_hbase_instance.lite_hbase_instance_prepay", "pay_mode", "1"), + resource.TestCheckResourceAttr("tencentcloud_lite_hbase_instance.lite_hbase_instance_prepay", "time_span", "1"), + resource.TestCheckResourceAttr("tencentcloud_lite_hbase_instance.lite_hbase_instance_prepay", "time_unit", "m"), + resource.TestCheckResourceAttr("tencentcloud_lite_hbase_instance.lite_hbase_instance_prepay", "auto_renew_flag", "1"), + ), + }, + { + ResourceName: "tencentcloud_lite_hbase_instance.lite_hbase_instance_prepay", + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"node_type", "time_span", "time_unit"}, }, }, }) @@ -140,6 +170,31 @@ resource "tencentcloud_lite_hbase_instance" "lite_hbase_instance" { } ` +const testAccLiteHbaseInstancePrePay = ` +resource "tencentcloud_lite_hbase_instance" "lite_hbase_instance_prepay" { + instance_name = "tf-test-prepay" + pay_mode = 1 + disk_type = "CLOUD_HSSD" + disk_size = 100 + node_type = "4C16G" + zone_settings { + zone = "ap-guangzhou-6" + vpc_settings { + vpc_id = "vpc-a5pph3hr" + subnet_id = "subnet-bpr2mo2g" + } + node_num = 3 + } + tags { + tag_key = "test" + tag_value = "test" + } + time_span = 1 + time_unit = "m" + auto_renew_flag = 1 +} +` + const testAccLiteHbaseInstanceMultiZone = ` resource "tencentcloud_lite_hbase_instance" "lite_hbase_instance_multi_zone" { instance_name = "tf-test-multi-zone" diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/client.go b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/client.go index c0163f714c..37148c3d34 100644 --- a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/client.go +++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/client.go @@ -511,11 +511,11 @@ func NewCreateSLInstanceResponse() (response *CreateSLInstanceResponse) { } // CreateSLInstance -// 本接口(CreateSLInstance)用于创建 Lite HBase 实例 +// 本接口(CreateSLInstance)用于创建Serverless HBase实例 // -// - 接口调用成功,会创建Lite HBase实例,创建实例请求成功会返回创建实例的 InstaceId 和请求的 RequestID。 +// - 接口调用成功,会创建Serverless HBase实例,创建实例请求成功会返回创建实例的InstaceId和请求的 RequestID。 // -// - 接口为异步接口,接口返回时操作并未立即完成,实例操作结果可以通过调用 DescribeInstancesList 查看当前实例的 StatusDesc 状态。 +// - 接口为异步接口,接口返回时操作并未立即完成,实例操作结果可以通过调用DescribeInstancesList查看当前实例的StatusDesc状态。 // // 可能返回的错误码: // FAILEDOPERATION = "FailedOperation" @@ -542,11 +542,11 @@ func (c *Client) CreateSLInstance(request *CreateSLInstanceRequest) (response *C } // CreateSLInstance -// 本接口(CreateSLInstance)用于创建 Lite HBase 实例 +// 本接口(CreateSLInstance)用于创建Serverless HBase实例 // -// - 接口调用成功,会创建Lite HBase实例,创建实例请求成功会返回创建实例的 InstaceId 和请求的 RequestID。 +// - 接口调用成功,会创建Serverless HBase实例,创建实例请求成功会返回创建实例的InstaceId和请求的 RequestID。 // -// - 接口为异步接口,接口返回时操作并未立即完成,实例操作结果可以通过调用 DescribeInstancesList 查看当前实例的 StatusDesc 状态。 +// - 接口为异步接口,接口返回时操作并未立即完成,实例操作结果可以通过调用DescribeInstancesList查看当前实例的StatusDesc状态。 // // 可能返回的错误码: // FAILEDOPERATION = "FailedOperation" @@ -1245,6 +1245,65 @@ func (c *Client) DescribeEmrOverviewMetricsWithContext(ctx context.Context, requ return } +func NewDescribeGlobalConfigRequest() (request *DescribeGlobalConfigRequest) { + request = &DescribeGlobalConfigRequest{ + BaseRequest: &tchttp.BaseRequest{}, + } + + request.Init().WithApiInfo("emr", APIVersion, "DescribeGlobalConfig") + + + return +} + +func NewDescribeGlobalConfigResponse() (response *DescribeGlobalConfigResponse) { + response = &DescribeGlobalConfigResponse{ + BaseResponse: &tchttp.BaseResponse{}, + } + return + +} + +// DescribeGlobalConfig +// 查询YARN资源调度的全局配置 +// +// 可能返回的错误码: +// INTERNALERROR = "InternalError" +// INTERNALERROR_CAMCGWERROR = "InternalError.CamCgwError" +// INTERNALERROR_WOODSERVERERROR = "InternalError.WoodServerError" +// INVALIDPARAMETER = "InvalidParameter" +// INVALIDPARAMETER_INVALIDINSTANCENAME = "InvalidParameter.InvalidInstanceName" +// RESOURCENOTFOUND_INSTANCENOTFOUND = "ResourceNotFound.InstanceNotFound" +func (c *Client) DescribeGlobalConfig(request *DescribeGlobalConfigRequest) (response *DescribeGlobalConfigResponse, err error) { + return c.DescribeGlobalConfigWithContext(context.Background(), request) +} + +// DescribeGlobalConfig +// 查询YARN资源调度的全局配置 +// +// 可能返回的错误码: +// INTERNALERROR = "InternalError" +// INTERNALERROR_CAMCGWERROR = "InternalError.CamCgwError" +// INTERNALERROR_WOODSERVERERROR = "InternalError.WoodServerError" +// INVALIDPARAMETER = "InvalidParameter" +// INVALIDPARAMETER_INVALIDINSTANCENAME = "InvalidParameter.InvalidInstanceName" +// RESOURCENOTFOUND_INSTANCENOTFOUND = "ResourceNotFound.InstanceNotFound" +func (c *Client) DescribeGlobalConfigWithContext(ctx context.Context, request *DescribeGlobalConfigRequest) (response *DescribeGlobalConfigResponse, err error) { + if request == nil { + request = NewDescribeGlobalConfigRequest() + } + + if c.GetCredential() == nil { + return nil, errors.New("DescribeGlobalConfig require credential") + } + + request.SetContext(ctx) + + response = NewDescribeGlobalConfigResponse() + err = c.Send(request, response) + return +} + func NewDescribeHBaseTableOverviewRequest() (request *DescribeHBaseTableOverviewRequest) { request = &DescribeHBaseTableOverviewRequest{ BaseRequest: &tchttp.BaseRequest{}, @@ -1300,6 +1359,61 @@ func (c *Client) DescribeHBaseTableOverviewWithContext(ctx context.Context, requ return } +func NewDescribeHDFSStorageInfoRequest() (request *DescribeHDFSStorageInfoRequest) { + request = &DescribeHDFSStorageInfoRequest{ + BaseRequest: &tchttp.BaseRequest{}, + } + + request.Init().WithApiInfo("emr", APIVersion, "DescribeHDFSStorageInfo") + + + return +} + +func NewDescribeHDFSStorageInfoResponse() (response *DescribeHDFSStorageInfoResponse) { + response = &DescribeHDFSStorageInfoResponse{ + BaseResponse: &tchttp.BaseResponse{}, + } + return + +} + +// DescribeHDFSStorageInfo +// 查询HDFS存储文件信息 +// +// 可能返回的错误码: +// INTERNALERROR_DOOPENTSDBREQUESTEXCEPTION = "InternalError.DoOpenTSDBRequestException" +// INTERNALERROR_OPENTSDBHTTPRETURNCODENOTOK = "InternalError.OpenTSDBHttpReturnCodeNotOK" +// RESOURCENOTFOUND = "ResourceNotFound" +// RESOURCENOTFOUND_CLUSTERNOTFOUND = "ResourceNotFound.ClusterNotFound" +func (c *Client) DescribeHDFSStorageInfo(request *DescribeHDFSStorageInfoRequest) (response *DescribeHDFSStorageInfoResponse, err error) { + return c.DescribeHDFSStorageInfoWithContext(context.Background(), request) +} + +// DescribeHDFSStorageInfo +// 查询HDFS存储文件信息 +// +// 可能返回的错误码: +// INTERNALERROR_DOOPENTSDBREQUESTEXCEPTION = "InternalError.DoOpenTSDBRequestException" +// INTERNALERROR_OPENTSDBHTTPRETURNCODENOTOK = "InternalError.OpenTSDBHttpReturnCodeNotOK" +// RESOURCENOTFOUND = "ResourceNotFound" +// RESOURCENOTFOUND_CLUSTERNOTFOUND = "ResourceNotFound.ClusterNotFound" +func (c *Client) DescribeHDFSStorageInfoWithContext(ctx context.Context, request *DescribeHDFSStorageInfoRequest) (response *DescribeHDFSStorageInfoResponse, err error) { + if request == nil { + request = NewDescribeHDFSStorageInfoRequest() + } + + if c.GetCredential() == nil { + return nil, errors.New("DescribeHDFSStorageInfo require credential") + } + + request.SetContext(ctx) + + response = NewDescribeHDFSStorageInfoResponse() + err = c.Send(request, response) + return +} + func NewDescribeHiveQueriesRequest() (request *DescribeHiveQueriesRequest) { request = &DescribeHiveQueriesRequest{ BaseRequest: &tchttp.BaseRequest{}, @@ -1819,6 +1933,57 @@ func (c *Client) DescribeJobFlowWithContext(ctx context.Context, request *Descri return } +func NewDescribeKyuubiQueryInfoRequest() (request *DescribeKyuubiQueryInfoRequest) { + request = &DescribeKyuubiQueryInfoRequest{ + BaseRequest: &tchttp.BaseRequest{}, + } + + request.Init().WithApiInfo("emr", APIVersion, "DescribeKyuubiQueryInfo") + + + return +} + +func NewDescribeKyuubiQueryInfoResponse() (response *DescribeKyuubiQueryInfoResponse) { + response = &DescribeKyuubiQueryInfoResponse{ + BaseResponse: &tchttp.BaseResponse{}, + } + return + +} + +// DescribeKyuubiQueryInfo +// 查询Kyuubi查询信息 +// +// 可能返回的错误码: +// RESOURCENOTFOUND_CLUSTERNOTFOUND = "ResourceNotFound.ClusterNotFound" +// UNAUTHORIZEDOPERATION_APPIDMISMATCHED = "UnauthorizedOperation.AppIdMismatched" +func (c *Client) DescribeKyuubiQueryInfo(request *DescribeKyuubiQueryInfoRequest) (response *DescribeKyuubiQueryInfoResponse, err error) { + return c.DescribeKyuubiQueryInfoWithContext(context.Background(), request) +} + +// DescribeKyuubiQueryInfo +// 查询Kyuubi查询信息 +// +// 可能返回的错误码: +// RESOURCENOTFOUND_CLUSTERNOTFOUND = "ResourceNotFound.ClusterNotFound" +// UNAUTHORIZEDOPERATION_APPIDMISMATCHED = "UnauthorizedOperation.AppIdMismatched" +func (c *Client) DescribeKyuubiQueryInfoWithContext(ctx context.Context, request *DescribeKyuubiQueryInfoRequest) (response *DescribeKyuubiQueryInfoResponse, err error) { + if request == nil { + request = NewDescribeKyuubiQueryInfoRequest() + } + + if c.GetCredential() == nil { + return nil, errors.New("DescribeKyuubiQueryInfo require credential") + } + + request.SetContext(ctx) + + response = NewDescribeKyuubiQueryInfoResponse() + err = c.Send(request, response) + return +} + func NewDescribeResourceScheduleRequest() (request *DescribeResourceScheduleRequest) { request = &DescribeResourceScheduleRequest{ BaseRequest: &tchttp.BaseRequest{}, @@ -1957,7 +2122,7 @@ func NewDescribeSLInstanceResponse() (response *DescribeSLInstanceResponse) { } // DescribeSLInstance -// 本接口(DescribeSLInstance)用于查询 Lite HBase 实例基本信息 +// 本接口(DescribeSLInstance)用于查询 Serverless HBase实例基本信息 // // 可能返回的错误码: // FAILEDOPERATION = "FailedOperation" @@ -1979,7 +2144,7 @@ func (c *Client) DescribeSLInstance(request *DescribeSLInstanceRequest) (respons } // DescribeSLInstance -// 本接口(DescribeSLInstance)用于查询 Lite HBase 实例基本信息 +// 本接口(DescribeSLInstance)用于查询 Serverless HBase实例基本信息 // // 可能返回的错误码: // FAILEDOPERATION = "FailedOperation" @@ -2032,7 +2197,7 @@ func NewDescribeSLInstanceListResponse() (response *DescribeSLInstanceListRespon } // DescribeSLInstanceList -// 本接口(DescribeSLInstanceList)用于查询 Lite HBase 实例列表详细信息 +// 本接口(DescribeSLInstanceList)用于查询Serverless HBase实例列表详细信息 // // 可能返回的错误码: // FAILEDOPERATION = "FailedOperation" @@ -2109,7 +2274,7 @@ func (c *Client) DescribeSLInstanceList(request *DescribeSLInstanceListRequest) } // DescribeSLInstanceList -// 本接口(DescribeSLInstanceList)用于查询 Lite HBase 实例列表详细信息 +// 本接口(DescribeSLInstanceList)用于查询Serverless HBase实例列表详细信息 // // 可能返回的错误码: // FAILEDOPERATION = "FailedOperation" @@ -2294,6 +2459,108 @@ func (c *Client) DescribeServiceNodeInfosWithContext(ctx context.Context, reques return } +func NewDescribeSparkQueriesRequest() (request *DescribeSparkQueriesRequest) { + request = &DescribeSparkQueriesRequest{ + BaseRequest: &tchttp.BaseRequest{}, + } + + request.Init().WithApiInfo("emr", APIVersion, "DescribeSparkQueries") + + + return +} + +func NewDescribeSparkQueriesResponse() (response *DescribeSparkQueriesResponse) { + response = &DescribeSparkQueriesResponse{ + BaseResponse: &tchttp.BaseResponse{}, + } + return + +} + +// DescribeSparkQueries +// 查询Spark查询信息列表 +// +// 可能返回的错误码: +// INVALIDPARAMETER_INVALIDCLUSTERID = "InvalidParameter.InvalidClusterId" +// UNAUTHORIZEDOPERATION_APPIDMISMATCHED = "UnauthorizedOperation.AppIdMismatched" +func (c *Client) DescribeSparkQueries(request *DescribeSparkQueriesRequest) (response *DescribeSparkQueriesResponse, err error) { + return c.DescribeSparkQueriesWithContext(context.Background(), request) +} + +// DescribeSparkQueries +// 查询Spark查询信息列表 +// +// 可能返回的错误码: +// INVALIDPARAMETER_INVALIDCLUSTERID = "InvalidParameter.InvalidClusterId" +// UNAUTHORIZEDOPERATION_APPIDMISMATCHED = "UnauthorizedOperation.AppIdMismatched" +func (c *Client) DescribeSparkQueriesWithContext(ctx context.Context, request *DescribeSparkQueriesRequest) (response *DescribeSparkQueriesResponse, err error) { + if request == nil { + request = NewDescribeSparkQueriesRequest() + } + + if c.GetCredential() == nil { + return nil, errors.New("DescribeSparkQueries require credential") + } + + request.SetContext(ctx) + + response = NewDescribeSparkQueriesResponse() + err = c.Send(request, response) + return +} + +func NewDescribeStarRocksQueryInfoRequest() (request *DescribeStarRocksQueryInfoRequest) { + request = &DescribeStarRocksQueryInfoRequest{ + BaseRequest: &tchttp.BaseRequest{}, + } + + request.Init().WithApiInfo("emr", APIVersion, "DescribeStarRocksQueryInfo") + + + return +} + +func NewDescribeStarRocksQueryInfoResponse() (response *DescribeStarRocksQueryInfoResponse) { + response = &DescribeStarRocksQueryInfoResponse{ + BaseResponse: &tchttp.BaseResponse{}, + } + return + +} + +// DescribeStarRocksQueryInfo +// 查询StarRocks查询信息 +// +// 可能返回的错误码: +// INVALIDPARAMETER_INVALIDCLUSTERID = "InvalidParameter.InvalidClusterId" +// UNAUTHORIZEDOPERATION_APPIDMISMATCHED = "UnauthorizedOperation.AppIdMismatched" +func (c *Client) DescribeStarRocksQueryInfo(request *DescribeStarRocksQueryInfoRequest) (response *DescribeStarRocksQueryInfoResponse, err error) { + return c.DescribeStarRocksQueryInfoWithContext(context.Background(), request) +} + +// DescribeStarRocksQueryInfo +// 查询StarRocks查询信息 +// +// 可能返回的错误码: +// INVALIDPARAMETER_INVALIDCLUSTERID = "InvalidParameter.InvalidClusterId" +// UNAUTHORIZEDOPERATION_APPIDMISMATCHED = "UnauthorizedOperation.AppIdMismatched" +func (c *Client) DescribeStarRocksQueryInfoWithContext(ctx context.Context, request *DescribeStarRocksQueryInfoRequest) (response *DescribeStarRocksQueryInfoResponse, err error) { + if request == nil { + request = NewDescribeStarRocksQueryInfoRequest() + } + + if c.GetCredential() == nil { + return nil, errors.New("DescribeStarRocksQueryInfo require credential") + } + + request.SetContext(ctx) + + response = NewDescribeStarRocksQueryInfoResponse() + err = c.Send(request, response) + return +} + func NewDescribeTrinoQueryInfoRequest() (request *DescribeTrinoQueryInfoRequest) { request = &DescribeTrinoQueryInfoRequest{ BaseRequest: &tchttp.BaseRequest{}, @@ -2314,7 +2581,7 @@ func NewDescribeTrinoQueryInfoResponse() (response *DescribeTrinoQueryInfoRespon } // DescribeTrinoQueryInfo -// 获取trino查询结果 +// 查询Trino(PrestoSQL)查询信息 // // 可能返回的错误码: // RESOURCENOTFOUND_CLUSTERNOTFOUND = "ResourceNotFound.ClusterNotFound" @@ -2324,7 +2591,7 @@ func (c *Client) DescribeTrinoQueryInfo(request *DescribeTrinoQueryInfoRequest) } // DescribeTrinoQueryInfo -// 获取trino查询结果 +// 查询Trino(PrestoSQL)查询信息 // // 可能返回的错误码: // RESOURCENOTFOUND_CLUSTERNOTFOUND = "ResourceNotFound.ClusterNotFound" @@ -3252,6 +3519,65 @@ func (c *Client) ModifyAutoScaleStrategyWithContext(ctx context.Context, request return } +func NewModifyGlobalConfigRequest() (request *ModifyGlobalConfigRequest) { + request = &ModifyGlobalConfigRequest{ + BaseRequest: &tchttp.BaseRequest{}, + } + + request.Init().WithApiInfo("emr", APIVersion, "ModifyGlobalConfig") + + + return +} + +func NewModifyGlobalConfigResponse() (response *ModifyGlobalConfigResponse) { + response = &ModifyGlobalConfigResponse{ + BaseResponse: &tchttp.BaseResponse{}, + } + return + +} + +// ModifyGlobalConfig +// 修改YARN资源调度的全局配置 +// +// 可能返回的错误码: +// INTERNALERROR = "InternalError" +// INTERNALERROR_CAMCGWERROR = "InternalError.CamCgwError" +// INTERNALERROR_WOODSERVERERROR = "InternalError.WoodServerError" +// INVALIDPARAMETER = "InvalidParameter" +// INVALIDPARAMETER_INVALIDINSTANCENAME = "InvalidParameter.InvalidInstanceName" +// RESOURCENOTFOUND_INSTANCENOTFOUND = "ResourceNotFound.InstanceNotFound" +func (c *Client) ModifyGlobalConfig(request *ModifyGlobalConfigRequest) (response *ModifyGlobalConfigResponse, err error) { + return c.ModifyGlobalConfigWithContext(context.Background(), request) +} + +// ModifyGlobalConfig +// 修改YARN资源调度的全局配置 +// +// 可能返回的错误码: +// INTERNALERROR = "InternalError" +// INTERNALERROR_CAMCGWERROR = "InternalError.CamCgwError" +// INTERNALERROR_WOODSERVERERROR = "InternalError.WoodServerError" +// INVALIDPARAMETER = "InvalidParameter" +// INVALIDPARAMETER_INVALIDINSTANCENAME = "InvalidParameter.InvalidInstanceName" +// RESOURCENOTFOUND_INSTANCENOTFOUND = "ResourceNotFound.InstanceNotFound" +func (c *Client) ModifyGlobalConfigWithContext(ctx context.Context, request *ModifyGlobalConfigRequest) (response *ModifyGlobalConfigResponse, err error) { + if request == nil { + request = NewModifyGlobalConfigRequest() + } + + if c.GetCredential() == nil { + return nil, errors.New("ModifyGlobalConfig require credential") + } + + request.SetContext(ctx) + + response = NewModifyGlobalConfigResponse() + err = c.Send(request, response) + return +} + func NewModifyResourcePoolsRequest() (request *ModifyResourcePoolsRequest) { request = &ModifyResourcePoolsRequest{ BaseRequest: &tchttp.BaseRequest{}, @@ -3504,11 +3830,11 @@ func NewModifySLInstanceResponse() (response *ModifySLInstanceResponse) { } // ModifySLInstance -// 本接口(ModifySLInstance)用于修改Lite HBase 实例节点数。 +// 本接口(ModifySLInstance)用于Serverless HBase变配实例。 // -// - 接口调用成功,会创建Lite HBase实例,创建实例请求成功会返回请求的 RequestID。 +// - 接口调用成功,会创建Serverless HBase实例,创建实例请求成功会返回请求的 RequestID。 // -// - 接口为异步接口,接口返回时操作并未立即完成,实例操作结果可以通过调用 DescribeInstancesList 查看当前实例的 StatusDesc 状态。 +// - 接口为异步接口,接口返回时操作并未立即完成,实例操作结果可以通过调用DescribeInstancesList查看当前实例的StatusDesc状态。 // // 可能返回的错误码: // FAILEDOPERATION = "FailedOperation" @@ -3532,11 +3858,11 @@ func (c *Client) ModifySLInstance(request *ModifySLInstanceRequest) (response *M } // ModifySLInstance -// 本接口(ModifySLInstance)用于修改Lite HBase 实例节点数。 +// 本接口(ModifySLInstance)用于Serverless HBase变配实例。 // -// - 接口调用成功,会创建Lite HBase实例,创建实例请求成功会返回请求的 RequestID。 +// - 接口调用成功,会创建Serverless HBase实例,创建实例请求成功会返回请求的 RequestID。 // -// - 接口为异步接口,接口返回时操作并未立即完成,实例操作结果可以通过调用 DescribeInstancesList 查看当前实例的 StatusDesc 状态。 +// - 接口为异步接口,接口返回时操作并未立即完成,实例操作结果可以通过调用DescribeInstancesList查看当前实例的StatusDesc状态。 // // 可能返回的错误码: // FAILEDOPERATION = "FailedOperation" @@ -4560,7 +4886,7 @@ func NewTerminateSLInstanceResponse() (response *TerminateSLInstanceResponse) { } // TerminateSLInstance -// 本接口(TerminateSLInstance)用于销毁 Lite HBase 实例 +// 本接口(TerminateSLInstance)用于销毁Serverless HBase实例 // // 可能返回的错误码: // FAILEDOPERATION = "FailedOperation" @@ -4583,7 +4909,7 @@ func (c *Client) TerminateSLInstance(request *TerminateSLInstanceRequest) (respo } // TerminateSLInstance -// 本接口(TerminateSLInstance)用于销毁 Lite HBase 实例 +// 本接口(TerminateSLInstance)用于销毁Serverless HBase实例 // // 可能返回的错误码: // FAILEDOPERATION = "FailedOperation" diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/errors.go b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/errors.go index fed11bc182..210502758b 100644 --- a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/errors.go +++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/errors.go @@ -377,7 +377,7 @@ const ( // 无效的Tke集群ID,或Tke集群不符合条件。 INVALIDPARAMETER_INVALIDTKEINSTANCE = "InvalidParameter.InvalidTkeInstance" - // 父帐号uin参数输入异常。 + // 父账号uin参数输入异常。 INVALIDPARAMETER_INVALIDUINNUM = "InvalidParameter.InvalidUinNum" // 无效的统一元数据库。 diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/models.go b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/models.go index 19bde1e7be..454b90839a 100644 --- a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/models.go +++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103/models.go @@ -374,6 +374,23 @@ type COSSettings struct { LogOnCosPath *string `json:"LogOnCosPath,omitnil,omitempty" name:"LogOnCosPath"` } +type CapacityGlobalConfig struct { + // 是否开启了标签调度 + EnableLabel *bool `json:"EnableLabel,omitnil,omitempty" name:"EnableLabel"` + + // 如果开启了标签调度,标签信息存放的路径 + // 注意:此字段可能返回 null,表示取不到有效值。 + LabelDir *string `json:"LabelDir,omitnil,omitempty" name:"LabelDir"` + + // 是否覆盖用户指定队列,为true表示覆盖。 + // 注意:此字段可能返回 null,表示取不到有效值。 + QueueMappingOverride *bool `json:"QueueMappingOverride,omitnil,omitempty" name:"QueueMappingOverride"` + + // 高级设置 + // 注意:此字段可能返回 null,表示取不到有效值。 + DefaultSettings []*DefaultSetting `json:"DefaultSettings,omitnil,omitempty" name:"DefaultSettings"` +} + type CdbInfo struct { // 数据库实例 // 注意:此字段可能返回 null,表示取不到有效值。 @@ -671,6 +688,10 @@ type ClusterInstancesInfo struct { // 集群产品配置信息 // 注意:此字段可能返回 null,表示取不到有效值。 ConfigDetail *EmrProductConfigDetail `json:"ConfigDetail,omitnil,omitempty" name:"ConfigDetail"` + + // 集群绑定的文件系统数 + // 注意:此字段可能返回 null,表示取不到有效值。 + BindFileSystemNum *int64 `json:"BindFileSystemNum,omitnil,omitempty" name:"BindFileSystemNum"` } type ClusterSetting struct { @@ -1455,7 +1476,7 @@ type CreateSLInstanceRequestParams struct { // 实例存储类型,填写CLOUD_HSSD,表示性能云存储。 DiskType *string `json:"DiskType,omitnil,omitempty" name:"DiskType"` - // 实例单节点磁盘容量,单位GB,单节点磁盘容量需大于等于100,小于等于10000,容量调整步长为20。 + // 实例单节点磁盘容量,单位GB,单节点磁盘容量需大于等于100,小于等于250*CPU核心数,容量调整步长为100。 DiskSize *int64 `json:"DiskSize,omitnil,omitempty" name:"DiskSize"` // 实例节点规格,可填写4C16G、8C32G、16C64G、32C128G,不区分大小写。 @@ -1466,6 +1487,9 @@ type CreateSLInstanceRequestParams struct { // 实例要绑定的标签列表。 Tags []*Tag `json:"Tags,omitnil,omitempty" name:"Tags"` + + // 预付费参数 + PrePaySetting *PrePaySetting `json:"PrePaySetting,omitnil,omitempty" name:"PrePaySetting"` } type CreateSLInstanceRequest struct { @@ -1480,7 +1504,7 @@ type CreateSLInstanceRequest struct { // 实例存储类型,填写CLOUD_HSSD,表示性能云存储。 DiskType *string `json:"DiskType,omitnil,omitempty" name:"DiskType"` - // 实例单节点磁盘容量,单位GB,单节点磁盘容量需大于等于100,小于等于10000,容量调整步长为20。 + // 实例单节点磁盘容量,单位GB,单节点磁盘容量需大于等于100,小于等于250*CPU核心数,容量调整步长为100。 DiskSize *int64 `json:"DiskSize,omitnil,omitempty" name:"DiskSize"` // 实例节点规格,可填写4C16G、8C32G、16C64G、32C128G,不区分大小写。 @@ -1491,6 +1515,9 @@ type CreateSLInstanceRequest struct { // 实例要绑定的标签列表。 Tags []*Tag `json:"Tags,omitnil,omitempty" name:"Tags"` + + // 预付费参数 + PrePaySetting *PrePaySetting `json:"PrePaySetting,omitnil,omitempty" name:"PrePaySetting"` } func (r *CreateSLInstanceRequest) ToJsonString() string { @@ -1512,6 +1539,7 @@ func (r *CreateSLInstanceRequest) FromJsonString(s string) error { delete(f, "NodeType") delete(f, "ZoneSettings") delete(f, "Tags") + delete(f, "PrePaySetting") if len(f) > 0 { return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "CreateSLInstanceRequest has unknown keys!", "") } @@ -1592,6 +1620,24 @@ type DayRepeatStrategy struct { Step *uint64 `json:"Step,omitnil,omitempty" name:"Step"` } +type DefaultSetting struct { + // 名称,作为入参的key + Name *string `json:"Name,omitnil,omitempty" name:"Name"` + + // 描述 + Desc *string `json:"Desc,omitnil,omitempty" name:"Desc"` + + // 提示 + Prompt *string `json:"Prompt,omitnil,omitempty" name:"Prompt"` + + // key,用于展示,该配置对应与配置文件中的配置项 + Key *string `json:"Key,omitnil,omitempty" name:"Key"` + + // Name对应的值 + // 注意:此字段可能返回 null,表示取不到有效值。 + Value *string `json:"Value,omitnil,omitempty" name:"Value"` +} + // Predefined struct for user type DeleteAutoScaleStrategyRequestParams struct { // 实例ID。 @@ -1683,6 +1729,9 @@ type DeleteUserManagerUserListRequestParams struct { // 用户组 UserGroupList []*UserAndGroup `json:"UserGroupList,omitnil,omitempty" name:"UserGroupList"` + + // 是否删除家目录,只针对cvm集群 + DeleteHomeDir *bool `json:"DeleteHomeDir,omitnil,omitempty" name:"DeleteHomeDir"` } type DeleteUserManagerUserListRequest struct { @@ -1702,6 +1751,9 @@ type DeleteUserManagerUserListRequest struct { // 用户组 UserGroupList []*UserAndGroup `json:"UserGroupList,omitnil,omitempty" name:"UserGroupList"` + + // 是否删除家目录,只针对cvm集群 + DeleteHomeDir *bool `json:"DeleteHomeDir,omitnil,omitempty" name:"DeleteHomeDir"` } func (r *DeleteUserManagerUserListRequest) ToJsonString() string { @@ -1721,6 +1773,7 @@ func (r *DeleteUserManagerUserListRequest) FromJsonString(s string) error { delete(f, "TkeClusterId") delete(f, "DisplayStrategy") delete(f, "UserGroupList") + delete(f, "DeleteHomeDir") if len(f) > 0 { return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DeleteUserManagerUserListRequest has unknown keys!", "") } @@ -2169,10 +2222,10 @@ type DescribeClusterNodesRequestParams struct { // 支持搜索的字段 SearchFields []*SearchItem `json:"SearchFields,omitnil,omitempty" name:"SearchFields"` - // 无 + // 排序字段 OrderField *string `json:"OrderField,omitnil,omitempty" name:"OrderField"` - // 无 + // 是否升序,1:升序,0:降序 Asc *int64 `json:"Asc,omitnil,omitempty" name:"Asc"` } @@ -2211,10 +2264,10 @@ type DescribeClusterNodesRequest struct { // 支持搜索的字段 SearchFields []*SearchItem `json:"SearchFields,omitnil,omitempty" name:"SearchFields"` - // 无 + // 排序字段 OrderField *string `json:"OrderField,omitnil,omitempty" name:"OrderField"` - // 无 + // 是否升序,1:升序,0:降序 Asc *int64 `json:"Asc,omitnil,omitempty" name:"Asc"` } @@ -2499,7 +2552,7 @@ type DescribeEmrOverviewMetricsRequestParams struct { // 结束时间 End *int64 `json:"End,omitnil,omitempty" name:"End"` - // 指标名 + // 指标名,NODE.CPU:节点平均CPU利用率和总核数;NODE.CPU.SLHBASE:Serverless实例平均CPU利用率和总核数;HDFS.NN.CAPACITY:存储使用率和总量 Metric *string `json:"Metric,omitnil,omitempty" name:"Metric"` // 集群id @@ -2524,7 +2577,7 @@ type DescribeEmrOverviewMetricsRequest struct { // 结束时间 End *int64 `json:"End,omitnil,omitempty" name:"End"` - // 指标名 + // 指标名,NODE.CPU:节点平均CPU利用率和总核数;NODE.CPU.SLHBASE:Serverless实例平均CPU利用率和总核数;HDFS.NN.CAPACITY:存储使用率和总量 Metric *string `json:"Metric,omitnil,omitempty" name:"Metric"` // 集群id @@ -2593,6 +2646,77 @@ func (r *DescribeEmrOverviewMetricsResponse) FromJsonString(s string) error { return json.Unmarshal([]byte(s), &r) } +// Predefined struct for user +type DescribeGlobalConfigRequestParams struct { + // emr集群的英文id + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` +} + +type DescribeGlobalConfigRequest struct { + *tchttp.BaseRequest + + // emr集群的英文id + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` +} + +func (r *DescribeGlobalConfigRequest) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *DescribeGlobalConfigRequest) FromJsonString(s string) error { + f := make(map[string]interface{}) + if err := json.Unmarshal([]byte(s), &f); err != nil { + return err + } + delete(f, "InstanceId") + if len(f) > 0 { + return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeGlobalConfigRequest has unknown keys!", "") + } + return json.Unmarshal([]byte(s), &r) +} + +// Predefined struct for user +type DescribeGlobalConfigResponseParams struct { + // 是否开启了资源调度功能 + EnableResourceSchedule *bool `json:"EnableResourceSchedule,omitnil,omitempty" name:"EnableResourceSchedule"` + + // 当前生效的资源调度器 + ActiveScheduler *string `json:"ActiveScheduler,omitnil,omitempty" name:"ActiveScheduler"` + + // 公平调度器的信息 + // 注意:此字段可能返回 null,表示取不到有效值。 + CapacityGlobalConfig *CapacityGlobalConfig `json:"CapacityGlobalConfig,omitnil,omitempty" name:"CapacityGlobalConfig"` + + // 容量调度器的信息 + // 注意:此字段可能返回 null,表示取不到有效值。 + FairGlobalConfig *FairGlobalConfig `json:"FairGlobalConfig,omitnil,omitempty" name:"FairGlobalConfig"` + + // 最新的资源调度器 + Scheduler *string `json:"Scheduler,omitnil,omitempty" name:"Scheduler"` + + // 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 + RequestId *string `json:"RequestId,omitnil,omitempty" name:"RequestId"` +} + +type DescribeGlobalConfigResponse struct { + *tchttp.BaseResponse + Response *DescribeGlobalConfigResponseParams `json:"Response"` +} + +func (r *DescribeGlobalConfigResponse) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *DescribeGlobalConfigResponse) FromJsonString(s string) error { + return json.Unmarshal([]byte(s), &r) +} + // Predefined struct for user type DescribeHBaseTableOverviewRequestParams struct { // 实例ID @@ -2691,6 +2815,82 @@ func (r *DescribeHBaseTableOverviewResponse) FromJsonString(s string) error { return json.Unmarshal([]byte(s), &r) } +// Predefined struct for user +type DescribeHDFSStorageInfoRequestParams struct { + // 集群id + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 获取查询信息开始时间 (s) + StartTime *int64 `json:"StartTime,omitnil,omitempty" name:"StartTime"` + + // 获取查询信息结束时间 (s) + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` +} + +type DescribeHDFSStorageInfoRequest struct { + *tchttp.BaseRequest + + // 集群id + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 获取查询信息开始时间 (s) + StartTime *int64 `json:"StartTime,omitnil,omitempty" name:"StartTime"` + + // 获取查询信息结束时间 (s) + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` +} + +func (r *DescribeHDFSStorageInfoRequest) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *DescribeHDFSStorageInfoRequest) FromJsonString(s string) error { + f := make(map[string]interface{}) + if err := json.Unmarshal([]byte(s), &f); err != nil { + return err + } + delete(f, "InstanceId") + delete(f, "StartTime") + delete(f, "EndTime") + if len(f) > 0 { + return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeHDFSStorageInfoRequest has unknown keys!", "") + } + return json.Unmarshal([]byte(s), &r) +} + +// Predefined struct for user +type DescribeHDFSStorageInfoResponseParams struct { + // 采样时间 + // 注意:此字段可能返回 null,表示取不到有效值。 + SampleTime *int64 `json:"SampleTime,omitnil,omitempty" name:"SampleTime"` + + // hdfs存储详情 + // 注意:此字段可能返回 null,表示取不到有效值。 + StorageSummaryDistribution []*StorageSummaryDistribution `json:"StorageSummaryDistribution,omitnil,omitempty" name:"StorageSummaryDistribution"` + + // 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 + RequestId *string `json:"RequestId,omitnil,omitempty" name:"RequestId"` +} + +type DescribeHDFSStorageInfoResponse struct { + *tchttp.BaseResponse + Response *DescribeHDFSStorageInfoResponseParams `json:"Response"` +} + +func (r *DescribeHDFSStorageInfoResponse) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *DescribeHDFSStorageInfoResponse) FromJsonString(s string) error { + return json.Unmarshal([]byte(s), &r) +} + // Predefined struct for user type DescribeHiveQueriesRequestParams struct { // 集群ID @@ -2925,6 +3125,9 @@ type DescribeInsightListRequestParams struct { // 分页查询时的页号,从1开始 Page *int64 `json:"Page,omitnil,omitempty" name:"Page"` + + // 查询类型,支持HIVE,SPARK,DLC_SPARK,SPARK_SQL,SCHEDULE,MAPREDUCE,TRINO等类型,默认查询全部 + Type *string `json:"Type,omitnil,omitempty" name:"Type"` } type DescribeInsightListRequest struct { @@ -2944,6 +3147,9 @@ type DescribeInsightListRequest struct { // 分页查询时的页号,从1开始 Page *int64 `json:"Page,omitnil,omitempty" name:"Page"` + + // 查询类型,支持HIVE,SPARK,DLC_SPARK,SPARK_SQL,SCHEDULE,MAPREDUCE,TRINO等类型,默认查询全部 + Type *string `json:"Type,omitnil,omitempty" name:"Type"` } func (r *DescribeInsightListRequest) ToJsonString() string { @@ -2963,6 +3169,7 @@ func (r *DescribeInsightListRequest) FromJsonString(s string) error { delete(f, "EndTime") delete(f, "PageSize") delete(f, "Page") + delete(f, "Type") if len(f) > 0 { return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeInsightListRequest has unknown keys!", "") } @@ -3081,7 +3288,7 @@ type DescribeInstancesListRequestParams struct { // 按照OrderField升序或者降序进行排序。取值范围:
  • 0:表示升序。
  • 1:表示降序。
  • 默认值为0。 Asc *int64 `json:"Asc,omitnil,omitempty" name:"Asc"` - // 自定义查询 + // 自定义查询过滤器。示例:
  • 根据ClusterId过滤实例:[{"Name":"ClusterId","Values":["emr-xxxxxxxx"]}]
  • 根据clusterName过滤实例:[{"Name": "ClusterName","Values": ["cluster_name"]}]
  • 根据ClusterStatus过滤实例:[{"Name": "ClusterStatus","Values": ["2"]}]
  • Filters []*Filters `json:"Filters,omitnil,omitempty" name:"Filters"` } @@ -3104,7 +3311,7 @@ type DescribeInstancesListRequest struct { // 按照OrderField升序或者降序进行排序。取值范围:
  • 0:表示升序。
  • 1:表示降序。
  • 默认值为0。 Asc *int64 `json:"Asc,omitnil,omitempty" name:"Asc"` - // 自定义查询 + // 自定义查询过滤器。示例:
  • 根据ClusterId过滤实例:[{"Name":"ClusterId","Values":["emr-xxxxxxxx"]}]
  • 根据clusterName过滤实例:[{"Name": "ClusterName","Values": ["cluster_name"]}]
  • 根据ClusterStatus过滤实例:[{"Name": "ClusterStatus","Values": ["2"]}]
  • Filters []*Filters `json:"Filters,omitnil,omitempty" name:"Filters"` } @@ -3354,6 +3561,95 @@ func (r *DescribeJobFlowResponse) FromJsonString(s string) error { return json.Unmarshal([]byte(s), &r) } +// Predefined struct for user +type DescribeKyuubiQueryInfoRequestParams struct { + // 集群ID + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 获取查询信息开始时间 (s) + StartTime *int64 `json:"StartTime,omitnil,omitempty" name:"StartTime"` + + // 获取查询信息结束时间 (s) + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` + + // 分页查询时的分页大小,最小1,最大100 + PageSize *int64 `json:"PageSize,omitnil,omitempty" name:"PageSize"` + + // 分页查询时的页号,从1开始 + Page *int64 `json:"Page,omitnil,omitempty" name:"Page"` +} + +type DescribeKyuubiQueryInfoRequest struct { + *tchttp.BaseRequest + + // 集群ID + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 获取查询信息开始时间 (s) + StartTime *int64 `json:"StartTime,omitnil,omitempty" name:"StartTime"` + + // 获取查询信息结束时间 (s) + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` + + // 分页查询时的分页大小,最小1,最大100 + PageSize *int64 `json:"PageSize,omitnil,omitempty" name:"PageSize"` + + // 分页查询时的页号,从1开始 + Page *int64 `json:"Page,omitnil,omitempty" name:"Page"` +} + +func (r *DescribeKyuubiQueryInfoRequest) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *DescribeKyuubiQueryInfoRequest) FromJsonString(s string) error { + f := make(map[string]interface{}) + if err := json.Unmarshal([]byte(s), &f); err != nil { + return err + } + delete(f, "InstanceId") + delete(f, "StartTime") + delete(f, "EndTime") + delete(f, "PageSize") + delete(f, "Page") + if len(f) > 0 { + return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeKyuubiQueryInfoRequest has unknown keys!", "") + } + return json.Unmarshal([]byte(s), &r) +} + +// Predefined struct for user +type DescribeKyuubiQueryInfoResponseParams struct { + // 总数,分页查询时使用 + TotalCount *int64 `json:"TotalCount,omitnil,omitempty" name:"TotalCount"` + + // Kyuubi查询信息列表 + // 注意:此字段可能返回 null,表示取不到有效值。 + KyuubiQueryInfoList []*KyuubiQueryInfo `json:"KyuubiQueryInfoList,omitnil,omitempty" name:"KyuubiQueryInfoList"` + + // 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 + RequestId *string `json:"RequestId,omitnil,omitempty" name:"RequestId"` +} + +type DescribeKyuubiQueryInfoResponse struct { + *tchttp.BaseResponse + Response *DescribeKyuubiQueryInfoResponseParams `json:"Response"` +} + +func (r *DescribeKyuubiQueryInfoResponse) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *DescribeKyuubiQueryInfoResponse) FromJsonString(s string) error { + return json.Unmarshal([]byte(s), &r) +} + // Predefined struct for user type DescribeResourceScheduleDiffDetailRequestParams struct { // emr集群的英文id @@ -3499,10 +3795,10 @@ type DescribeSLInstanceListRequestParams struct { // 排序字段。取值范围:
  • clusterId:表示按照实例ID排序。
  • addTime:表示按照实例创建时间排序。
  • status:表示按照实例的状态码排序。
  • OrderField *string `json:"OrderField,omitnil,omitempty" name:"OrderField"` - // 按照OrderField升序或者降序进行排序。取值范围:
  • 0:表示降序。
  • 1:表示升序。
  • 默认值为0。 + // 按照OrderField升序或者降序进行排序。取值范围:
  • 0:表示升序。
  • 1:表示降序。
  • 默认值为0。 Asc *int64 `json:"Asc,omitnil,omitempty" name:"Asc"` - // 自定义查询过滤器。 + // 自定义查询过滤器。示例:
  • 根据ClusterId过滤实例:[{"Name":"ClusterId","Values":["emr-xxxxxxxx"]}]
  • 根据clusterName过滤实例:[{"Name": "ClusterName","Values": ["cluster_name"]}]
  • 根据ClusterStatus过滤实例:[{"Name": "ClusterStatus","Values": ["2"]}]
  • Filters []*Filters `json:"Filters,omitnil,omitempty" name:"Filters"` } @@ -3521,10 +3817,10 @@ type DescribeSLInstanceListRequest struct { // 排序字段。取值范围:
  • clusterId:表示按照实例ID排序。
  • addTime:表示按照实例创建时间排序。
  • status:表示按照实例的状态码排序。
  • OrderField *string `json:"OrderField,omitnil,omitempty" name:"OrderField"` - // 按照OrderField升序或者降序进行排序。取值范围:
  • 0:表示降序。
  • 1:表示升序。
  • 默认值为0。 + // 按照OrderField升序或者降序进行排序。取值范围:
  • 0:表示升序。
  • 1:表示降序。
  • 默认值为0。 Asc *int64 `json:"Asc,omitnil,omitempty" name:"Asc"` - // 自定义查询过滤器。 + // 自定义查询过滤器。示例:
  • 根据ClusterId过滤实例:[{"Name":"ClusterId","Values":["emr-xxxxxxxx"]}]
  • 根据clusterName过滤实例:[{"Name": "ClusterName","Values": ["cluster_name"]}]
  • 根据ClusterStatus过滤实例:[{"Name": "ClusterStatus","Values": ["2"]}]
  • Filters []*Filters `json:"Filters,omitnil,omitempty" name:"Filters"` } @@ -3614,6 +3910,9 @@ func (r *DescribeSLInstanceRequest) FromJsonString(s string) error { // Predefined struct for user type DescribeSLInstanceResponseParams struct { + // 实例字符串标识。 + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + // 实例名称。 InstanceName *string `json:"InstanceName,omitnil,omitempty" name:"InstanceName"` @@ -3636,6 +3935,33 @@ type DescribeSLInstanceResponseParams struct { // 注意:此字段可能返回 null,表示取不到有效值。 Tags []*Tag `json:"Tags,omitnil,omitempty" name:"Tags"` + // 实例数字标识。 + ClusterId *int64 `json:"ClusterId,omitnil,omitempty" name:"ClusterId"` + + // 实例区域ID。 + RegionId *int64 `json:"RegionId,omitnil,omitempty" name:"RegionId"` + + // 实例主可用区。 + Zone *string `json:"Zone,omitnil,omitempty" name:"Zone"` + + // 实例过期时间,后付费返回0000-00-00 00:00:00 + ExpireTime *string `json:"ExpireTime,omitnil,omitempty" name:"ExpireTime"` + + // 实例隔离时间,未隔离返回0000-00-00 00:00:00。 + IsolateTime *string `json:"IsolateTime,omitnil,omitempty" name:"IsolateTime"` + + // 实例创建时间。 + CreateTime *string `json:"CreateTime,omitnil,omitempty" name:"CreateTime"` + + // 实例状态码,-2: "TERMINATED", 2: "RUNNING", 14: "TERMINATING", 19: "ISOLATING", 22: "ADJUSTING", 201: "ISOLATED"。 + Status *int64 `json:"Status,omitnil,omitempty" name:"Status"` + + // 自动续费标记, 0:表示通知即将过期,但不自动续费 1:表示通知即将过期,而且自动续费 2:表示不通知即将过期,也不自动续费,若业务无续费概念为0 + AutoRenewFlag *int64 `json:"AutoRenewFlag,omitnil,omitempty" name:"AutoRenewFlag"` + + // 实例节点总数。 + NodeNum *int64 `json:"NodeNum,omitnil,omitempty" name:"NodeNum"` + // 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 RequestId *string `json:"RequestId,omitnil,omitempty" name:"RequestId"` } @@ -3697,12 +4023,7 @@ type DescribeServiceNodeInfosRequestParams struct { // 服务组件名称,都是大写例如YARN ServiceName *string `json:"ServiceName,omitnil,omitempty" name:"ServiceName"` - // 节点名称 - // master - // core - // task - // common - // router + // 节点名称master,core,task,common,router NodeTypeName *string `json:"NodeTypeName,omitnil,omitempty" name:"NodeTypeName"` // 过滤条件:dn是否处于维护状态 @@ -3756,12 +4077,7 @@ type DescribeServiceNodeInfosRequest struct { // 服务组件名称,都是大写例如YARN ServiceName *string `json:"ServiceName,omitnil,omitempty" name:"ServiceName"` - // 节点名称 - // master - // core - // task - // common - // router + // 节点名称master,core,task,common,router NodeTypeName *string `json:"NodeTypeName,omitnil,omitempty" name:"NodeTypeName"` // 过滤条件:dn是否处于维护状态 @@ -3841,6 +4157,191 @@ func (r *DescribeServiceNodeInfosResponse) FromJsonString(s string) error { return json.Unmarshal([]byte(s), &r) } +// Predefined struct for user +type DescribeSparkQueriesRequestParams struct { + // 集群ID + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 开始时间 + StartTime *int64 `json:"StartTime,omitnil,omitempty" name:"StartTime"` + + // 结束时间 + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` + + // 分页起始偏移,从0开始 + Offset *int64 `json:"Offset,omitnil,omitempty" name:"Offset"` + + // 分页大小,合法范围[1,100] + Limit *int64 `json:"Limit,omitnil,omitempty" name:"Limit"` + + // 执行状态:RUNNING,COMPLETED,FAILED + Status []*string `json:"Status,omitnil,omitempty" name:"Status"` +} + +type DescribeSparkQueriesRequest struct { + *tchttp.BaseRequest + + // 集群ID + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 开始时间 + StartTime *int64 `json:"StartTime,omitnil,omitempty" name:"StartTime"` + + // 结束时间 + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` + + // 分页起始偏移,从0开始 + Offset *int64 `json:"Offset,omitnil,omitempty" name:"Offset"` + + // 分页大小,合法范围[1,100] + Limit *int64 `json:"Limit,omitnil,omitempty" name:"Limit"` + + // 执行状态:RUNNING,COMPLETED,FAILED + Status []*string `json:"Status,omitnil,omitempty" name:"Status"` +} + +func (r *DescribeSparkQueriesRequest) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *DescribeSparkQueriesRequest) FromJsonString(s string) error { + f := make(map[string]interface{}) + if err := json.Unmarshal([]byte(s), &f); err != nil { + return err + } + delete(f, "InstanceId") + delete(f, "StartTime") + delete(f, "EndTime") + delete(f, "Offset") + delete(f, "Limit") + delete(f, "Status") + if len(f) > 0 { + return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeSparkQueriesRequest has unknown keys!", "") + } + return json.Unmarshal([]byte(s), &r) +} + +// Predefined struct for user +type DescribeSparkQueriesResponseParams struct { + // 总数 + Total *int64 `json:"Total,omitnil,omitempty" name:"Total"` + + // 结果列表 + // 注意:此字段可能返回 null,表示取不到有效值。 + Results []*SparkQuery `json:"Results,omitnil,omitempty" name:"Results"` + + // 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 + RequestId *string `json:"RequestId,omitnil,omitempty" name:"RequestId"` +} + +type DescribeSparkQueriesResponse struct { + *tchttp.BaseResponse + Response *DescribeSparkQueriesResponseParams `json:"Response"` +} + +func (r *DescribeSparkQueriesResponse) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *DescribeSparkQueriesResponse) FromJsonString(s string) error { + return json.Unmarshal([]byte(s), &r) +} + +// Predefined struct for user +type DescribeStarRocksQueryInfoRequestParams struct { + // 集群ID + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 获取查询信息开始时间 (s) + StartTime *int64 `json:"StartTime,omitnil,omitempty" name:"StartTime"` + + // 获取查询信息结束时间 (s) + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` + + // 分页查询时的分页大小,最小1,最大100 + PageSize *int64 `json:"PageSize,omitnil,omitempty" name:"PageSize"` + + // 分页查询时的页号,从1开始 + Page *int64 `json:"Page,omitnil,omitempty" name:"Page"` +} + +type DescribeStarRocksQueryInfoRequest struct { + *tchttp.BaseRequest + + // 集群ID + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 获取查询信息开始时间 (s) + StartTime *int64 `json:"StartTime,omitnil,omitempty" name:"StartTime"` + + // 获取查询信息结束时间 (s) + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` + + // 分页查询时的分页大小,最小1,最大100 + PageSize *int64 `json:"PageSize,omitnil,omitempty" name:"PageSize"` + + // 分页查询时的页号,从1开始 + Page *int64 `json:"Page,omitnil,omitempty" name:"Page"` +} + +func (r *DescribeStarRocksQueryInfoRequest) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *DescribeStarRocksQueryInfoRequest) FromJsonString(s string) error { + f := make(map[string]interface{}) + if err := json.Unmarshal([]byte(s), &f); err != nil { + return err + } + delete(f, "InstanceId") + delete(f, "StartTime") + delete(f, "EndTime") + delete(f, "PageSize") + delete(f, "Page") + if len(f) > 0 { + return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeStarRocksQueryInfoRequest has unknown keys!", "") + } + return json.Unmarshal([]byte(s), &r) +} + +// Predefined struct for user +type DescribeStarRocksQueryInfoResponseParams struct { + // 总数,分页查询时使用 + TotalCount *int64 `json:"TotalCount,omitnil,omitempty" name:"TotalCount"` + + // Starrocks 查询信息列表 + // 注意:此字段可能返回 null,表示取不到有效值。 + StarRocksQueryInfoList []*StarRocksQueryInfo `json:"StarRocksQueryInfoList,omitnil,omitempty" name:"StarRocksQueryInfoList"` + + // 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 + RequestId *string `json:"RequestId,omitnil,omitempty" name:"RequestId"` +} + +type DescribeStarRocksQueryInfoResponse struct { + *tchttp.BaseResponse + Response *DescribeStarRocksQueryInfoResponseParams `json:"Response"` +} + +func (r *DescribeStarRocksQueryInfoResponse) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *DescribeStarRocksQueryInfoResponse) FromJsonString(s string) error { + return json.Unmarshal([]byte(s), &r) +} + // Predefined struct for user type DescribeTrinoQueryInfoRequestParams struct { // 集群ID @@ -4140,115 +4641,23 @@ func (r *DescribeYarnQueueRequest) ToJsonString() string { } // FromJsonString It is highly **NOT** recommended to use this function -// because it has no param check, nor strict type check -func (r *DescribeYarnQueueRequest) FromJsonString(s string) error { - f := make(map[string]interface{}) - if err := json.Unmarshal([]byte(s), &f); err != nil { - return err - } - delete(f, "InstanceId") - delete(f, "Scheduler") - if len(f) > 0 { - return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeYarnQueueRequest has unknown keys!", "") - } - return json.Unmarshal([]byte(s), &r) -} - -// Predefined struct for user -type DescribeYarnQueueResponseParams struct { - // 队列信息。是一个对象转成的json字符串,对应的golang结构体如下所示,比如`QueueWithConfigSetForFairScheduler`的第一个字段`Name`: - // - // ``` - // Name string `json:"name"` //队列名称 - // ``` - // - `Name`:字段名 - // - `string`:字段类型 - // - `json:"name"`:表示在序列化和反序列化`json`时,对应的`json key`,下面以`json key`来指代 - // - `//`:后面的注释内容对应页面上看到的名称 - // - // 字段类型以`*`开头的表示取值可能为json规范下的null,不同的语言需要使用能表达null的类型来接收,比如java的包装类型;字段类型以`[]`开头的表示是数组类型;`json key`在调用`ModifyYarnQueueV2 `接口也会使用。 - // - // - 公平调度器 - // - // ``` - // type QueueWithConfigSetForFairScheduler struct { - // Name string `json:"name"` //队列名称 - // MyId string `json:"myId"` // 队列id,用于编辑、删除、克隆时使用 - // ParentId string `json:"parentId"` // 父队列Id - // Type *string `json:"type"` // 队列归属。parent或空,当确定某个队列是父队列,且没有子队列时,才可以设置,通常用来支持放置策略nestedUserQueue - // AclSubmitApps *AclForYarnQueue `json:"aclSubmitApps"` // 提交访问控制 - // AclAdministerApps *AclForYarnQueue `json:"aclAdministerApps"` // 管理访问控制 - // MinSharePreemptionTimeout *int `json:"minSharePreemptionTimeout"` // 最小共享优先权超时时间 - // FairSharePreemptionTimeout *int `json:"fairSharePreemptionTimeout"` // 公平份额抢占超时时间 - // FairSharePreemptionThreshold *float32 `json:"fairSharePreemptionThreshold"` // 公平份额抢占阈值。取值 (0,1] - // AllowPreemptionFrom *bool `json:"allowPreemptionFrom"` // 抢占模式 - // SchedulingPolicy *string `json:"schedulingPolicy"` // 调度策略,取值有drf、fair、fifo - // IsDefault *bool `json:"isDefault"` // 是否是root.default队列 - // IsRoot *bool `json:"isRoot"` // 是否是root队列 - // ConfigSets []ConfigSetForFairScheduler `json:"configSets"` // 配置集设置 - // Children []QueueWithConfigSetForFairScheduler `json:"queues"` // 子队列信息。递归 - // } - // - // type AclForYarnQueue struct { - // User *string `json:"user"` //用户名 - // Group *string `json:"group"`//组名 - // } - // - // type ConfigSetForFairScheduler struct { - // Name string `json:"name"` // 配置集名称 - // MinResources *YarnResource `json:"minResources"` // 最小资源量 - // MaxResources *YarnResource `json:"maxResources"` // 最大资源量 - // MaxChildResources *YarnResource `json:"maxChildResources"` // 能够分配给为未声明子队列的最大资源量 - // MaxRunningApps *int `json:"maxRunningApps"` // 最高可同时处于运行的App数量 - // Weight *float32 `json:"weight"` // 权重 - // MaxAMShare *float32 `json:"maxAMShare"` // App Master最大份额 - // } - // - // type YarnResource struct { - // Vcores *int `json:"vcores"` - // Memory *int `json:"memory"` - // Type *string `json:"type"` // 当值为`percent`时,表示使用的百分比,否则就是使用的绝对数值 - // } - // ``` - // - // - 容量调度器 - // - // ``` - // type QueueForCapacitySchedulerV3 struct { - // Name string `json:"name"` // 队列名称 - // MyId string `json:"myId"` // 队列id,用于编辑、删除、克隆时使用 - // ParentId string `json:"parentId"` // 父队列Id - // Configs []ConfigForCapacityV3 `json:"configs"` //配置集设置 - // State *string `json:"state"` // 资源池状态 - // DefaultNodeLabelExpression *string `json:"default-node-label-expression"` // 默认标签表达式 - // AclSubmitApps *AclForYarnQueue `json:"acl_submit_applications"` // 提交访问控制 - // AclAdminQueue *AclForYarnQueue `json:"acl_administer_queue"` //管理访问控制 - // MaxAllocationMB *int32 `json:"maximum-allocation-mb"` // 分配Container最大内存数量 - // MaxAllocationVcores *int32 `json:"maximum-allocation-vcores"` // Container最大vCore数量 - // IsDefault *bool `json:"isDefault"`// 是否是root.default队列 - // IsRoot *bool `json:"isRoot"` // 是否是root队列 - // Queues []*QueueForCapacitySchedulerV3 `json:"queues"`//子队列信息。递归 - // } - // type ConfigForCapacityV3 struct { - // Name string `json:"configName"` // 配置集名称 - // Labels []CapacityLabel `json:"labels"` // 标签信息 - // MinUserLimitPercent *int32 `json:"minimum-user-limit-percent"` // 用户最小容量 - // UserLimitFactor *float32 `json:"user-limit-factor" valid:"rangeExcludeLeft(0|)"` // 用户资源因子 - // MaxApps *int32 `json:"maximum-applications" valid:"rangeExcludeLeft(0|)"` // 最大应用数Max-Applications - // MaxAmPercent *float32 `json:"maximum-am-resource-percent"` // 最大AM比例 - // DefaultApplicationPriority *int32 `json:"default-application-priority"` // 资源池优先级 - // } - // type CapacityLabel struct { - // Name string `json:"labelName"` - // Capacity *float32 `json:"capacity"` // 容量 - // MaxCapacity *float32 `json:"maximum-capacity"` //最大容量 - // } - // - // type AclForYarnQueue struct { - // User *string `json:"user"` //用户名 - // Group *string `json:"group"`//组名 - // } - // ``` +// because it has no param check, nor strict type check +func (r *DescribeYarnQueueRequest) FromJsonString(s string) error { + f := make(map[string]interface{}) + if err := json.Unmarshal([]byte(s), &f); err != nil { + return err + } + delete(f, "InstanceId") + delete(f, "Scheduler") + if len(f) > 0 { + return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeYarnQueueRequest has unknown keys!", "") + } + return json.Unmarshal([]byte(s), &r) +} + +// Predefined struct for user +type DescribeYarnQueueResponseParams struct { + // 队列信息。是一个对象转成的json字符串,对应的golang结构体如下所示,例如`QueueWithConfigSetForFairScheduler`的第一个字段`Name`:```Name string `json:"name"` //队列名称```- `Name`:字段名- `string`:字段类型- `json:"name"`:表示在序列化和反序列化`json`时,对应的`json key`,下面以`json key`来指代- `//`:后面的注释内容对应页面上看到的名称字段类型以`*`开头的表示取值可能为json规范下的null,不同的语言需要使用能表达null的类型来接收,例如java的包装类型;字段类型以`[]`开头的表示是数组类型;`json key`在调用`ModifyYarnQueueV2 `接口也会使用。- 公平调度器```type QueueWithConfigSetForFairScheduler struct { Name string `json:"name"` //队列名称 MyId string `json:"myId"` // 队列id,用于编辑、删除、克隆时使用 ParentId string `json:"parentId"` // 父队列Id Type *string `json:"type"` // 队列归属。parent或空,当确定某个队列是父队列,且没有子队列时,才可以设置,通常用来支持放置策略nestedUserQueue AclSubmitApps *AclForYarnQueue `json:"aclSubmitApps"` // 提交访问控制 AclAdministerApps *AclForYarnQueue `json:"aclAdministerApps"` // 管理访问控制 MinSharePreemptionTimeout *int `json:"minSharePreemptionTimeout"` // 最小共享优先权超时时间 FairSharePreemptionTimeout *int `json:"fairSharePreemptionTimeout"` // 公平份额抢占超时时间 FairSharePreemptionThreshold *float32 `json:"fairSharePreemptionThreshold"` // 公平份额抢占阈值。取值 (0,1] AllowPreemptionFrom *bool `json:"allowPreemptionFrom"` // 抢占模式 SchedulingPolicy *string `json:"schedulingPolicy"` // 调度策略,取值有drf、fair、fifo IsDefault *bool `json:"isDefault"` // 是否是root.default队列 IsRoot *bool `json:"isRoot"` // 是否是root队列 ConfigSets []ConfigSetForFairScheduler `json:"configSets"` // 配置集设置 Children []QueueWithConfigSetForFairScheduler `json:"queues"` // 子队列信息。递归}type AclForYarnQueue struct { User *string `json:"user"` //用户名 Group *string `json:"group"`//组名}type ConfigSetForFairScheduler struct { Name string `json:"name"` // 配置集名称 MinResources *YarnResource `json:"minResources"` // 最小资源量 MaxResources *YarnResource `json:"maxResources"` // 最大资源量 MaxChildResources *YarnResource `json:"maxChildResources"` // 能够分配给为未声明子队列的最大资源量 MaxRunningApps *int `json:"maxRunningApps"` // 最高可同时处于运行的App数量 Weight *float32 `json:"weight"` // 权重 MaxAMShare *float32 `json:"maxAMShare"` // App Master最大份额}type YarnResource struct { Vcores *int `json:"vcores"` Memory *int `json:"memory"` Type *string `json:"type"` // 当值为`percent`时,表示使用的百分比,否则就是使用的绝对数值}```- 容量调度器```type QueueForCapacitySchedulerV3 struct { Name string `json:"name"` // 队列名称 MyId string `json:"myId"` // 队列id,用于编辑、删除、克隆时使用 ParentId string `json:"parentId"` // 父队列Id Configs []ConfigForCapacityV3 `json:"configs"` //配置集设置 State *string `json:"state"` // 资源池状态 DefaultNodeLabelExpression *string `json:"default-node-label-expression"` // 默认标签表达式 AclSubmitApps *AclForYarnQueue `json:"acl_submit_applications"` // 提交访问控制 AclAdminQueue *AclForYarnQueue `json:"acl_administer_queue"` //管理访问控制 MaxAllocationMB *int32 `json:"maximum-allocation-mb"` // 分配Container最大内存数量 MaxAllocationVcores *int32 `json:"maximum-allocation-vcores"` // Container最大vCore数量 IsDefault *bool `json:"isDefault"`// 是否是root.default队列 IsRoot *bool `json:"isRoot"` // 是否是root队列 Queues []*QueueForCapacitySchedulerV3 `json:"queues"`//子队列信息。递归}type ConfigForCapacityV3 struct { Name string `json:"configName"` // 配置集名称 Labels []CapacityLabel `json:"labels"` // 标签信息 MinUserLimitPercent *int32 `json:"minimum-user-limit-percent"` // 用户最小容量 UserLimitFactor *float32 `json:"user-limit-factor" valid:"rangeExcludeLeft(0|)"` // 用户资源因子 MaxApps *int32 `json:"maximum-applications" valid:"rangeExcludeLeft(0|)"` // 最大应用数Max-Applications MaxAmPercent *float32 `json:"maximum-am-resource-percent"` // 最大AM比例 DefaultApplicationPriority *int32 `json:"default-application-priority"` // 资源池优先级}type CapacityLabel struct { Name string `json:"labelName"` Capacity *float32 `json:"capacity"` // 容量 MaxCapacity *float32 `json:"maximum-capacity"` //最大容量}type AclForYarnQueue struct { User *string `json:"user"` //用户名 Group *string `json:"group"`//组名}``` Queue *string `json:"Queue,omitnil,omitempty" name:"Queue"` // 版本 @@ -4513,6 +4922,20 @@ type DiskSpecInfo struct { // 数据容量,单位为GB // 注意:此字段可能返回 null,表示取不到有效值。 DiskSize *int64 `json:"DiskSize,omitnil,omitempty" name:"DiskSize"` + + // 额外性能 + // 注意:此字段可能返回 null,表示取不到有效值。 + ExtraPerformance *int64 `json:"ExtraPerformance,omitnil,omitempty" name:"ExtraPerformance"` +} + +type Dps struct { + // 时间戳 + // 注意:此字段可能返回 null,表示取不到有效值。 + Timestamp *string `json:"Timestamp,omitnil,omitempty" name:"Timestamp"` + + // 采样值 + // 注意:此字段可能返回 null,表示取不到有效值。 + Value *string `json:"Value,omitnil,omitempty" name:"Value"` } type DynamicPodSpec struct { @@ -4838,14 +5261,20 @@ type ExternalService struct { // 共用组件类型,EMR/CUSTOM ShareType *string `json:"ShareType,omitnil,omitempty" name:"ShareType"` - // 自定义参数集合 - CustomServiceDefineList []*CustomServiceDefine `json:"CustomServiceDefineList,omitnil,omitempty" name:"CustomServiceDefineList"` - // 共用组件名 Service *string `json:"Service,omitnil,omitempty" name:"Service"` // 共用组件集群 InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 自定义参数集合 + CustomServiceDefineList []*CustomServiceDefine `json:"CustomServiceDefineList,omitnil,omitempty" name:"CustomServiceDefineList"` +} + +type FairGlobalConfig struct { + // 对应与页面的

    程序上限

    + // 注意:此字段可能返回 null,表示取不到有效值。 + UserMaxAppsDefault *int64 `json:"UserMaxAppsDefault,omitnil,omitempty" name:"UserMaxAppsDefault"` } type Filters struct { @@ -5231,11 +5660,7 @@ type InquiryPriceCreateInstanceRequestParams struct { // 产品ID,不同产品ID表示不同的EMR产品版本。取值范围:
  • 2:表示EMR-V2.0.1
  • 16:表示EMR-V2.3.0
  • 20:表示EMR-V2.5.0
  • 30:表示EMR-V2.6.0
  • 38:表示EMR-V2.7.0
  • 57:表示EMR-V2.8.0
  • 7:表示EMR-V3.0.0
  • 25:表示EMR-V3.1.0
  • 31:表示EMR-V3.1.1
  • 28:表示EMR-V3.2.0
  • 33:表示EMR-V3.2.1
  • 34:表示EMR-V3.3.0
  • 37:表示EMR-V3.4.0
  • 44:表示EMR-V3.5.0
  • 53:表示EMR-V3.6.0
  • 58:表示EMR-V3.6.1
  • 47:表示EMR-V4.0.0
  • ProductId *uint64 `json:"ProductId,omitnil,omitempty" name:"ProductId"` - // 场景化取值: - // Hadoop-Kudu - // Hadoop-Zookeeper - // Hadoop-Presto - // Hadoop-Hbase + // 场景化取值:Hadoop-Kudu,Hadoop-Zookeeper,Hadoop-Presto,Hadoop-Hbase SceneName *string `json:"SceneName,omitnil,omitempty" name:"SceneName"` // 共用组件信息 @@ -5302,11 +5727,7 @@ type InquiryPriceCreateInstanceRequest struct { // 产品ID,不同产品ID表示不同的EMR产品版本。取值范围:
  • 2:表示EMR-V2.0.1
  • 16:表示EMR-V2.3.0
  • 20:表示EMR-V2.5.0
  • 30:表示EMR-V2.6.0
  • 38:表示EMR-V2.7.0
  • 57:表示EMR-V2.8.0
  • 7:表示EMR-V3.0.0
  • 25:表示EMR-V3.1.0
  • 31:表示EMR-V3.1.1
  • 28:表示EMR-V3.2.0
  • 33:表示EMR-V3.2.1
  • 34:表示EMR-V3.3.0
  • 37:表示EMR-V3.4.0
  • 44:表示EMR-V3.5.0
  • 53:表示EMR-V3.6.0
  • 58:表示EMR-V3.6.1
  • 47:表示EMR-V4.0.0
  • ProductId *uint64 `json:"ProductId,omitnil,omitempty" name:"ProductId"` - // 场景化取值: - // Hadoop-Kudu - // Hadoop-Zookeeper - // Hadoop-Presto - // Hadoop-Hbase + // 场景化取值:Hadoop-Kudu,Hadoop-Zookeeper,Hadoop-Presto,Hadoop-Hbase SceneName *string `json:"SceneName,omitnil,omitempty" name:"SceneName"` // 共用组件信息 @@ -6005,6 +6426,56 @@ type KeyValue struct { Value *string `json:"Value,omitnil,omitempty" name:"Value"` } +type KyuubiQueryInfo struct { + // 提交IP + // 注意:此字段可能返回 null,表示取不到有效值。 + ClientIP *string `json:"ClientIP,omitnil,omitempty" name:"ClientIP"` + + // 执行时长 + // 注意:此字段可能返回 null,表示取不到有效值。 + Duration *int64 `json:"Duration,omitnil,omitempty" name:"Duration"` + + // 结束时间 + // 注意:此字段可能返回 null,表示取不到有效值。 + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` + + // Engine Id + // 注意:此字段可能返回 null,表示取不到有效值。 + EngineID *string `json:"EngineID,omitnil,omitempty" name:"EngineID"` + + // 计算引擎 + // 注意:此字段可能返回 null,表示取不到有效值。 + EngineType *string `json:"EngineType,omitnil,omitempty" name:"EngineType"` + + // ID + // 注意:此字段可能返回 null,表示取不到有效值。 + Id *string `json:"Id,omitnil,omitempty" name:"Id"` + + // Session Id + // 注意:此字段可能返回 null,表示取不到有效值。 + SessionID *string `json:"SessionID,omitnil,omitempty" name:"SessionID"` + + // 开始时间 + // 注意:此字段可能返回 null,表示取不到有效值。 + BeginTime *int64 `json:"BeginTime,omitnil,omitempty" name:"BeginTime"` + + // 执行状态 + // 注意:此字段可能返回 null,表示取不到有效值。 + ExecutionState *string `json:"ExecutionState,omitnil,omitempty" name:"ExecutionState"` + + // 执行语句 + // 注意:此字段可能返回 null,表示取不到有效值。 + ExecutionStatement *string `json:"ExecutionStatement,omitnil,omitempty" name:"ExecutionStatement"` + + // Statement Id + // 注意:此字段可能返回 null,表示取不到有效值。 + StatementID *string `json:"StatementID,omitnil,omitempty" name:"StatementID"` + + // 提交用户 + // 注意:此字段可能返回 null,表示取不到有效值。 + User *string `json:"User,omitnil,omitempty" name:"User"` +} + type LoadAutoScaleStrategy struct { // 规则ID。 // 注意:此字段可能返回 null,表示取不到有效值。 @@ -6286,6 +6757,83 @@ func (r *ModifyAutoScaleStrategyResponse) FromJsonString(s string) error { return json.Unmarshal([]byte(s), &r) } +// Predefined struct for user +type ModifyGlobalConfigRequestParams struct { + // emr集群的英文id + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 修改的配置列表。其中Key的取值与`DescribeGlobalConfig`接口的出参一一对应,不区分大小写(如果报错找不到Key,以出参为准),分别为: + // 1. 开启或关闭资源调度:enableResourceSchedule;在关闭时会有一个同步的选项,Key为sync,取值为true或false。 + // 2. 调度器类型:scheduler。 + // 2. 开启或关闭标签:enableLabel,取值为true或false。 + // 2. 标签目录:labelDir。 + // 3. 是否覆盖用户指定队列:queueMappingOverride,取值为true、false。 + // 4. 程序上限:userMaxAppsDefault。 + // 5. 动态配置项:`DescribeGlobalConfig`接口返回的DefaultSettings中的Name字段。 + // Value的取值都是字符串,对于**是否覆盖用户指定队列**、**程序上限**,json规范中的null表示清空该配置的值。支持修改单个配置项的值。对于**动态配置项**则需要全量传递以进行覆盖。 + Items []*Item `json:"Items,omitnil,omitempty" name:"Items"` +} + +type ModifyGlobalConfigRequest struct { + *tchttp.BaseRequest + + // emr集群的英文id + InstanceId *string `json:"InstanceId,omitnil,omitempty" name:"InstanceId"` + + // 修改的配置列表。其中Key的取值与`DescribeGlobalConfig`接口的出参一一对应,不区分大小写(如果报错找不到Key,以出参为准),分别为: + // 1. 开启或关闭资源调度:enableResourceSchedule;在关闭时会有一个同步的选项,Key为sync,取值为true或false。 + // 2. 调度器类型:scheduler。 + // 2. 开启或关闭标签:enableLabel,取值为true或false。 + // 2. 标签目录:labelDir。 + // 3. 是否覆盖用户指定队列:queueMappingOverride,取值为true、false。 + // 4. 程序上限:userMaxAppsDefault。 + // 5. 动态配置项:`DescribeGlobalConfig`接口返回的DefaultSettings中的Name字段。 + // Value的取值都是字符串,对于**是否覆盖用户指定队列**、**程序上限**,json规范中的null表示清空该配置的值。支持修改单个配置项的值。对于**动态配置项**则需要全量传递以进行覆盖。 + Items []*Item `json:"Items,omitnil,omitempty" name:"Items"` +} + +func (r *ModifyGlobalConfigRequest) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *ModifyGlobalConfigRequest) FromJsonString(s string) error { + f := make(map[string]interface{}) + if err := json.Unmarshal([]byte(s), &f); err != nil { + return err + } + delete(f, "InstanceId") + delete(f, "Items") + if len(f) > 0 { + return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "ModifyGlobalConfigRequest has unknown keys!", "") + } + return json.Unmarshal([]byte(s), &r) +} + +// Predefined struct for user +type ModifyGlobalConfigResponseParams struct { + // 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 + RequestId *string `json:"RequestId,omitnil,omitempty" name:"RequestId"` +} + +type ModifyGlobalConfigResponse struct { + *tchttp.BaseResponse + Response *ModifyGlobalConfigResponseParams `json:"Response"` +} + +func (r *ModifyGlobalConfigResponse) ToJsonString() string { + b, _ := json.Marshal(r) + return string(b) +} + +// FromJsonString It is highly **NOT** recommended to use this function +// because it has no param check, nor strict type check +func (r *ModifyGlobalConfigResponse) FromJsonString(s string) error { + return json.Unmarshal([]byte(s), &r) +} + // Predefined struct for user type ModifyResourcePoolsRequestParams struct { // emr集群id @@ -6930,6 +7478,10 @@ type MultiDiskMC struct { // 注意:此字段可能返回 null,表示取不到有效值。 Type *int64 `json:"Type,omitnil,omitempty" name:"Type"` + // 磁盘大小 + // 注意:此字段可能返回 null,表示取不到有效值。 + Size *string `json:"Size,omitnil,omitempty" name:"Size"` + // 云盘大小 // 注意:此字段可能返回 null,表示取不到有效值。 Volume *int64 `json:"Volume,omitnil,omitempty" name:"Volume"` @@ -7194,6 +7746,14 @@ type NodeHardwareInfo struct { // 备注 // 注意:此字段可能返回 null,表示取不到有效值。 Remark *string `json:"Remark,omitnil,omitempty" name:"Remark"` + + // 共享集群id + // 注意:此字段可能返回 null,表示取不到有效值。 + SharedClusterId *string `json:"SharedClusterId,omitnil,omitempty" name:"SharedClusterId"` + + // 共享集群id描述 + // 注意:此字段可能返回 null,表示取不到有效值。 + SharedClusterIdDesc *string `json:"SharedClusterIdDesc,omitnil,omitempty" name:"SharedClusterIdDesc"` } type NodeResourceSpec struct { @@ -7340,6 +7900,16 @@ type PartDetailPriceItem struct { GoodsNum *int64 `json:"GoodsNum,omitnil,omitempty" name:"GoodsNum"` } +type Period struct { + // 时间跨度 + // 注意:此字段可能返回 null,表示取不到有效值。 + TimeSpan *int64 `json:"TimeSpan,omitnil,omitempty" name:"TimeSpan"` + + // 时间单位,"m"代表月。 + // 注意:此字段可能返回 null,表示取不到有效值。 + TimeUnit *string `json:"TimeUnit,omitnil,omitempty" name:"TimeUnit"` +} + type PersistentVolumeContext struct { // 磁盘大小,单位为GB。 // 注意:此字段可能返回 null,表示取不到有效值。 @@ -7786,6 +8356,16 @@ type PreExecuteFileSettings struct { Remark *string `json:"Remark,omitnil,omitempty" name:"Remark"` } +type PrePaySetting struct { + // 时间 + // 注意:此字段可能返回 null,表示取不到有效值。 + Period *Period `json:"Period,omitnil,omitempty" name:"Period"` + + // 自动续费标记,0:表示通知即将过期,但不自动续费 1:表示通知即将过期,而且自动续费 2:表示不通知即将过期,也不自动续费 + // 注意:此字段可能返回 null,表示取不到有效值。 + AutoRenewFlag *int64 `json:"AutoRenewFlag,omitnil,omitempty" name:"AutoRenewFlag"` +} + type PriceDetail struct { // 节点ID ResourceId *string `json:"ResourceId,omitnil,omitempty" name:"ResourceId"` @@ -7910,6 +8490,18 @@ type RenewInstancesInfo struct { // 磁盘类型 StorageType *int64 `json:"StorageType,omitnil,omitempty" name:"StorageType"` + + // 系统盘大小 + // 注意:此字段可能返回 null,表示取不到有效值。 + RootSize *int64 `json:"RootSize,omitnil,omitempty" name:"RootSize"` + + // 系统盘类型 + // 注意:此字段可能返回 null,表示取不到有效值。 + RootStorageType *int64 `json:"RootStorageType,omitnil,omitempty" name:"RootStorageType"` + + // 数据盘信息 + // 注意:此字段可能返回 null,表示取不到有效值。 + MCMultiDisk []*MultiDiskMC `json:"MCMultiDisk,omitnil,omitempty" name:"MCMultiDisk"` } type RepeatStrategy struct { @@ -8328,6 +8920,15 @@ type SLInstanceInfo struct { // 实例标签 // 注意:此字段可能返回 null,表示取不到有效值。 Tags []*Tag `json:"Tags,omitnil,omitempty" name:"Tags"` + + // 自动续费标记, 0:表示通知即将过期,但不自动续费 1:表示通知即将过期,而且自动续费 2:表示不通知即将过期,也不自动续费,若业务无续费概念,设置为0 + AutoRenewFlag *uint64 `json:"AutoRenewFlag,omitnil,omitempty" name:"AutoRenewFlag"` + + // 隔离时间,未隔离返回0000-00-00 00:00:00。 + IsolateTime *string `json:"IsolateTime,omitnil,omitempty" name:"IsolateTime"` + + // 过期时间,后付费返回0000-00-00 00:00:00 + ExpireTime *string `json:"ExpireTime,omitnil,omitempty" name:"ExpireTime"` } // Predefined struct for user @@ -9075,6 +9676,64 @@ type SoftDependInfo struct { Required *bool `json:"Required,omitnil,omitempty" name:"Required"` } +type SparkQuery struct { + // 执行语句 + Statement *string `json:"Statement,omitnil,omitempty" name:"Statement"` + + // 执行时长(单位毫秒) + Duration *int64 `json:"Duration,omitnil,omitempty" name:"Duration"` + + // 执行状态 + Status *string `json:"Status,omitnil,omitempty" name:"Status"` + + // 查询ID + Id *string `json:"Id,omitnil,omitempty" name:"Id"` + + // 扫描分区数 + // 注意:此字段可能返回 null,表示取不到有效值。 + ScanPartitionNum *int64 `json:"ScanPartitionNum,omitnil,omitempty" name:"ScanPartitionNum"` + + // 扫描总行数 + // 注意:此字段可能返回 null,表示取不到有效值。 + ScanRowNum *int64 `json:"ScanRowNum,omitnil,omitempty" name:"ScanRowNum"` + + // 扫描总文件数 + // 注意:此字段可能返回 null,表示取不到有效值。 + ScanFileNum *int64 `json:"ScanFileNum,omitnil,omitempty" name:"ScanFileNum"` + + // 查询扫描总数据量(单位B) + // 注意:此字段可能返回 null,表示取不到有效值。 + ScanTotalData *int64 `json:"ScanTotalData,omitnil,omitempty" name:"ScanTotalData"` + + // 应用ID + // 注意:此字段可能返回 null,表示取不到有效值。 + ApplicationId []*string `json:"ApplicationId,omitnil,omitempty" name:"ApplicationId"` + + // 输出总行数 + // 注意:此字段可能返回 null,表示取不到有效值。 + OutputRowNum *int64 `json:"OutputRowNum,omitnil,omitempty" name:"OutputRowNum"` + + // 输出总文件数 + // 注意:此字段可能返回 null,表示取不到有效值。 + OutputFileNum *int64 `json:"OutputFileNum,omitnil,omitempty" name:"OutputFileNum"` + + // 输出分区数 + // 注意:此字段可能返回 null,表示取不到有效值。 + OutputPartitionNum *int64 `json:"OutputPartitionNum,omitnil,omitempty" name:"OutputPartitionNum"` + + // 输出总数据量(单位B) + // 注意:此字段可能返回 null,表示取不到有效值。 + OutputTotalData *int64 `json:"OutputTotalData,omitnil,omitempty" name:"OutputTotalData"` + + // 开始时间 + // 注意:此字段可能返回 null,表示取不到有效值。 + BeginTime *int64 `json:"BeginTime,omitnil,omitempty" name:"BeginTime"` + + // 结束时间 + // 注意:此字段可能返回 null,表示取不到有效值。 + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` +} + type StageInfoDetail struct { // 步骤id Stage *string `json:"Stage,omitnil,omitempty" name:"Stage"` @@ -9133,6 +9792,84 @@ type StageInfoDetail struct { TimeConsuming *string `json:"TimeConsuming,omitnil,omitempty" name:"TimeConsuming"` } +type StarRocksQueryInfo struct { + // 提交IP + // 注意:此字段可能返回 null,表示取不到有效值。 + ClientIP *string `json:"ClientIP,omitnil,omitempty" name:"ClientIP"` + + // CPU总时间(ns) + // 注意:此字段可能返回 null,表示取不到有效值。 + CPUCost *int64 `json:"CPUCost,omitnil,omitempty" name:"CPUCost"` + + // 默认DB + // 注意:此字段可能返回 null,表示取不到有效值。 + DefaultDB *string `json:"DefaultDB,omitnil,omitempty" name:"DefaultDB"` + + // 结束时间 + // 注意:此字段可能返回 null,表示取不到有效值。 + EndTime *int64 `json:"EndTime,omitnil,omitempty" name:"EndTime"` + + // 执行IP + // 注意:此字段可能返回 null,表示取不到有效值。 + ExecutionIP *string `json:"ExecutionIP,omitnil,omitempty" name:"ExecutionIP"` + + // 查询ID + // 注意:此字段可能返回 null,表示取不到有效值。 + QueryID *string `json:"QueryID,omitnil,omitempty" name:"QueryID"` + + // 查询类型 + // 注意:此字段可能返回 null,表示取不到有效值。 + QueryType *string `json:"QueryType,omitnil,omitempty" name:"QueryType"` + + // 消耗总内存(bytes) + // 注意:此字段可能返回 null,表示取不到有效值。 + MemCost *int64 `json:"MemCost,omitnil,omitempty" name:"MemCost"` + + // plan阶段CPU占用(ns) + // 注意:此字段可能返回 null,表示取不到有效值。 + PlanCpuCosts *int64 `json:"PlanCpuCosts,omitnil,omitempty" name:"PlanCpuCosts"` + + // plan阶段内存占用(bytes) + // 注意:此字段可能返回 null,表示取不到有效值。 + PlanMemCosts *int64 `json:"PlanMemCosts,omitnil,omitempty" name:"PlanMemCosts"` + + // 执行时长 + // 注意:此字段可能返回 null,表示取不到有效值。 + QueryTime *int64 `json:"QueryTime,omitnil,omitempty" name:"QueryTime"` + + // 资源组 + // 注意:此字段可能返回 null,表示取不到有效值。 + ResourceGroup *string `json:"ResourceGroup,omitnil,omitempty" name:"ResourceGroup"` + + // 获取行数 + // 注意:此字段可能返回 null,表示取不到有效值。 + ReturnRows *int64 `json:"ReturnRows,omitnil,omitempty" name:"ReturnRows"` + + // 扫描数据量(bytes) + // 注意:此字段可能返回 null,表示取不到有效值。 + ScanBytes *int64 `json:"ScanBytes,omitnil,omitempty" name:"ScanBytes"` + + // 扫描行数 + // 注意:此字段可能返回 null,表示取不到有效值。 + ScanRows *int64 `json:"ScanRows,omitnil,omitempty" name:"ScanRows"` + + // 开始时间 + // 注意:此字段可能返回 null,表示取不到有效值。 + BeginTime *int64 `json:"BeginTime,omitnil,omitempty" name:"BeginTime"` + + // 执行状态 + // 注意:此字段可能返回 null,表示取不到有效值。 + ExecutionState *string `json:"ExecutionState,omitnil,omitempty" name:"ExecutionState"` + + // 执行语句 + // 注意:此字段可能返回 null,表示取不到有效值。 + ExecutionStatement *string `json:"ExecutionStatement,omitnil,omitempty" name:"ExecutionStatement"` + + // 用户 + // 注意:此字段可能返回 null,表示取不到有效值。 + User *string `json:"User,omitnil,omitempty" name:"User"` +} + // Predefined struct for user type StartStopServiceOrMonitorRequestParams struct { // 集群ID @@ -9257,6 +9994,20 @@ type StopParams struct { ThreadCount *int64 `json:"ThreadCount,omitnil,omitempty" name:"ThreadCount"` } +type StorageSummaryDistribution struct { + // 数据项 + // 注意:此字段可能返回 null,表示取不到有效值。 + MetricItem *string `json:"MetricItem,omitnil,omitempty" name:"MetricItem"` + + // 数据项描述 + // 注意:此字段可能返回 null,表示取不到有效值。 + MetricName *string `json:"MetricName,omitnil,omitempty" name:"MetricName"` + + // 采样值 + // 注意:此字段可能返回 null,表示取不到有效值。 + Dps []*Dps `json:"Dps,omitnil,omitempty" name:"Dps"` +} + type StrategyConfig struct { // 0:关闭滚动重启 // 1:开启滚动启动 diff --git a/vendor/modules.txt b/vendor/modules.txt index 8e8ba25074..6bd286ec27 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -1216,7 +1216,7 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/dts/v20211206 # github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/eb v1.0.760 ## explicit; go 1.14 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/eb/v20210416 -# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr v1.0.1004 +# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr v1.0.1055 ## explicit; go 1.14 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103 # github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/es v1.0.777 diff --git a/website/docs/r/lite_hbase_instance.html.markdown b/website/docs/r/lite_hbase_instance.html.markdown index c3eb9634a7..b6c2f18b5f 100644 --- a/website/docs/r/lite_hbase_instance.html.markdown +++ b/website/docs/r/lite_hbase_instance.html.markdown @@ -39,13 +39,16 @@ resource "tencentcloud_lite_hbase_instance" "lite_hbase_instance" { The following arguments are supported: -* `disk_size` - (Required, Int) Instance single-node disk capacity, in GB. The single-node disk capacity must be greater than or equal to 100 and less than or equal to 10000, with an adjustment step size of 20. -* `disk_type` - (Required, String) Instance disk type, fill in CLOUD_HSSD to indicate performance cloud storage. +* `disk_size` - (Required, Int) Instance single-node disk capacity, in GB. The single-node disk capacity must be greater than or equal to 100 and less than or equal to 250 times the number of CPU cores. The capacity adjustment step is 100. +* `disk_type` - (Required, String) Instance disk type, Value range: CLOUD_HSSD: indicate performance cloud storage(ESSD). CLOUD_BSSD: indicate standard cloud storage(SSD). * `instance_name` - (Required, String) Instance name. Length limit is 6-36 characters. Only Chinese characters, letters, numbers, -, and _ are allowed. * `node_type` - (Required, String) Instance node type, can be filled in as 4C16G, 8C32G, 16C64G, 32C128G, case insensitive. -* `pay_mode` - (Required, Int) Instance pay mode. Value range: 0: indicates post pay mode, that is, pay-as-you-go. +* `pay_mode` - (Required, Int) Instance pay mode. Value range: 0: indicates post-pay mode, that is, pay-as-you-go. 1: indicates pre-pay mode, that is, monthly subscription. * `zone_settings` - (Required, List) Detailed configuration of the instance availability zone, currently supports multiple availability zones, the number of availability zones can only be 1 or 3, including zone name, VPC information, and number of nodes. The total number of nodes across all zones must be greater than or equal to 3 and less than or equal to 50. +* `auto_renew_flag` - (Optional, Int) AutoRenewFlag, Value range: 0: indicates NOTIFY_AND_MANUAL_RENEW; 1: indicates NOTIFY_AND_AUTO_RENEW; 2: indicates DISABLE_NOTIFY_AND_MANUAL_RENEW. * `tags` - (Optional, List) List of tags to bind to the instance. +* `time_span` - (Optional, Int) Time span. +* `time_unit` - (Optional, String) Time unit, fill in m which means month. The `tags` object supports the following: From 38bb8130272ee47ef619d20473de82880f6d790b Mon Sep 17 00:00:00 2001 From: mikatong Date: Fri, 6 Dec 2024 20:43:21 +0800 Subject: [PATCH 2/7] add changelog --- .changelog/3002.txt | 3 +++ 1 file changed, 3 insertions(+) create mode 100644 .changelog/3002.txt diff --git a/.changelog/3002.txt b/.changelog/3002.txt new file mode 100644 index 0000000000..476c4f3922 --- /dev/null +++ b/.changelog/3002.txt @@ -0,0 +1,3 @@ +```release-note:enhancement +resource/tencentcloud_lite_hbase_instance: support `time_span`, `time_unit` and `auto_renew_flag` +``` \ No newline at end of file From 51bb4c6390fea42dcdcb81eb27eadfc4a29ef86d Mon Sep 17 00:00:00 2001 From: mikatong Date: Mon, 9 Dec 2024 16:11:39 +0800 Subject: [PATCH 3/7] add tencentcloud_serverless_hbase_instance --- tencentcloud/provider.go | 1 + tencentcloud/provider.md | 1 + .../emr/resource_tc_lite_hbase_instance.go | 9 +- .../resource_tc_serverless_hbase_instance.go | 513 ++++++++++++++++++ .../resource_tc_serverless_hbase_instance.md | 33 ++ ...ource_tc_serverless_hbase_instance_test.go | 234 ++++++++ .../r/serverless_hbase_instance.html.markdown | 84 +++ website/tencentcloud.erb | 3 + 8 files changed, 874 insertions(+), 4 deletions(-) create mode 100644 tencentcloud/services/emr/resource_tc_serverless_hbase_instance.go create mode 100644 tencentcloud/services/emr/resource_tc_serverless_hbase_instance.md create mode 100644 tencentcloud/services/emr/resource_tc_serverless_hbase_instance_test.go create mode 100644 website/docs/r/serverless_hbase_instance.html.markdown diff --git a/tencentcloud/provider.go b/tencentcloud/provider.go index 737ee0ee08..b3981b7787 100644 --- a/tencentcloud/provider.go +++ b/tencentcloud/provider.go @@ -2190,6 +2190,7 @@ func Provider() *schema.Provider { "tencentcloud_thpc_workspaces": thpc.ResourceTencentCloudThpcWorkspaces(), "tencentcloud_kubernetes_health_check_policy": tke.ResourceTencentCloudKubernetesHealthCheckPolicy(), "tencentcloud_lite_hbase_instance": emr.ResourceTencentCloudLiteHbaseInstance(), + "tencentcloud_serverless_hbase_instance": emr.ResourceTencentCloudServerlessHbaseInstance(), "tencentcloud_kubernetes_log_config": tke.ResourceTencentCloudKubernetesLogConfig(), "tencentcloud_tcss_image_registry": tcss.ResourceTencentCloudTcssImageRegistry(), }, diff --git a/tencentcloud/provider.md b/tencentcloud/provider.md index 109f49a3d0..c592f06364 100644 --- a/tencentcloud/provider.md +++ b/tencentcloud/provider.md @@ -1330,6 +1330,7 @@ MapReduce(EMR) tencentcloud_emr_cluster tencentcloud_emr_user_manager tencentcloud_lite_hbase_instance + tencentcloud_serverless_hbase_instance DNSPOD Resource diff --git a/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go b/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go index ff839773d7..a6f3751efe 100644 --- a/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go +++ b/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go @@ -17,10 +17,11 @@ import ( func ResourceTencentCloudLiteHbaseInstance() *schema.Resource { return &schema.Resource{ - Create: resourceTencentCloudLiteHbaseInstanceCreate, - Read: resourceTencentCloudLiteHbaseInstanceRead, - Update: resourceTencentCloudLiteHbaseInstanceUpdate, - Delete: resourceTencentCloudLiteHbaseInstanceDelete, + DeprecationMessage: "This resource will been deprecated in Terraform TencentCloud provider later version. Please use `tencentcloud_serverless_hbase_instance` instead.", + Create: resourceTencentCloudLiteHbaseInstanceCreate, + Read: resourceTencentCloudLiteHbaseInstanceRead, + Update: resourceTencentCloudLiteHbaseInstanceUpdate, + Delete: resourceTencentCloudLiteHbaseInstanceDelete, Importer: &schema.ResourceImporter{ State: schema.ImportStatePassthrough, }, diff --git a/tencentcloud/services/emr/resource_tc_serverless_hbase_instance.go b/tencentcloud/services/emr/resource_tc_serverless_hbase_instance.go new file mode 100644 index 0000000000..e2438c74de --- /dev/null +++ b/tencentcloud/services/emr/resource_tc_serverless_hbase_instance.go @@ -0,0 +1,513 @@ +package emr + +import ( + "context" + "fmt" + "log" + "time" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + emr "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/emr/v20190103" + + tccommon "github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/common" + "github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/internal/helper" + "github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/ratelimit" +) + +func ResourceTencentCloudServerlessHbaseInstance() *schema.Resource { + return &schema.Resource{ + Create: resourceTencentCloudServerlessHbaseInstanceCreate, + Read: resourceTencentCloudServerlessHbaseInstanceRead, + Update: resourceTencentCloudServerlessHbaseInstanceUpdate, + Delete: resourceTencentCloudServerlessHbaseInstanceDelete, + Importer: &schema.ResourceImporter{ + State: schema.ImportStatePassthrough, + }, + Schema: map[string]*schema.Schema{ + "instance_name": { + Type: schema.TypeString, + Required: true, + Description: "Instance name. Length limit is 6-36 characters. Only Chinese characters, letters, numbers, -, and _ are allowed.", + }, + + "pay_mode": { + Type: schema.TypeInt, + Required: true, + Description: "Instance pay mode. Value range: 0: indicates post-pay mode, that is, pay-as-you-go. 1: indicates pre-pay mode, that is, monthly subscription.", + }, + + "disk_type": { + Type: schema.TypeString, + Required: true, + Description: "Instance disk type, Value range: CLOUD_HSSD: indicate performance cloud storage(ESSD). CLOUD_BSSD: indicate standard cloud storage(SSD).", + }, + + "disk_size": { + Type: schema.TypeInt, + Required: true, + Description: "Instance single-node disk capacity, in GB. The single-node disk capacity must be greater than or equal to 100 and less than or equal to 250 times the number of CPU cores. The capacity adjustment step is 100.", + }, + + "node_type": { + Type: schema.TypeString, + Required: true, + Description: "Instance node type, can be filled in as 4C16G, 8C32G, 16C64G, 32C128G, case insensitive.", + }, + + "zone_settings": { + Type: schema.TypeList, + Required: true, + Description: "Detailed configuration of the instance availability zone, currently supports multiple availability zones, the number of availability zones can only be 1 or 3, including zone name, VPC information, and number of nodes. The total number of nodes across all zones must be greater than or equal to 3 and less than or equal to 50.", + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "zone": { + Type: schema.TypeString, + Required: true, + Description: "The availability zone to which the instance belongs, such as ap-guangzhou-1.", + }, + "vpc_settings": { + Type: schema.TypeList, + Required: true, + MaxItems: 1, + Description: "Private network related information configuration. This parameter can be used to specify the ID of the private network, subnet ID, and other information.", + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "vpc_id": { + Type: schema.TypeString, + Required: true, + Description: "VPC ID.", + }, + "subnet_id": { + Type: schema.TypeString, + Required: true, + Description: "Subnet ID.", + }, + }, + }, + }, + "node_num": { + Type: schema.TypeInt, + Required: true, + Description: "Number of nodes.", + }, + }, + }, + }, + + "tags": { + Type: schema.TypeList, + Optional: true, + Description: "List of tags to bind to the instance.", + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "tag_key": { + Type: schema.TypeString, + Optional: true, + Description: "Tag key.", + }, + "tag_value": { + Type: schema.TypeString, + Optional: true, + Description: "Tag value.", + }, + }, + }, + }, + + "time_span": { + Type: schema.TypeInt, + Optional: true, + Description: "Time span.", + }, + "time_unit": { + Type: schema.TypeString, + Optional: true, + Description: "Time unit, fill in m which means month.", + }, + "auto_renew_flag": { + Type: schema.TypeInt, + Optional: true, + Computed: true, + Description: "AutoRenewFlag, Value range: 0: indicates NOTIFY_AND_MANUAL_RENEW; 1: indicates NOTIFY_AND_AUTO_RENEW; 2: indicates DISABLE_NOTIFY_AND_MANUAL_RENEW.", + }, + }, + } +} + +func resourceTencentCloudServerlessHbaseInstanceCreate(d *schema.ResourceData, meta interface{}) error { + defer tccommon.LogElapsed("resource.tencentcloud_serverless_hbase_instance.create")() + defer tccommon.InconsistentCheck(d, meta)() + + logId := tccommon.GetLogId(tccommon.ContextNil) + + ctx := tccommon.NewResourceLifeCycleHandleFuncContext(context.Background(), logId, d, meta) + + var ( + request = emr.NewCreateSLInstanceRequest() + response = emr.NewCreateSLInstanceResponse() + ) + + if v, ok := d.GetOk("instance_name"); ok { + request.InstanceName = helper.String(v.(string)) + } + + if v, ok := d.GetOkExists("pay_mode"); ok { + request.PayMode = helper.IntInt64(v.(int)) + } + + if v, ok := d.GetOk("disk_type"); ok { + request.DiskType = helper.String(v.(string)) + } + + if v, ok := d.GetOkExists("disk_size"); ok { + request.DiskSize = helper.IntInt64(v.(int)) + } + + if v, ok := d.GetOk("node_type"); ok { + request.NodeType = helper.String(v.(string)) + } + + if v, ok := d.GetOk("zone_settings"); ok { + for _, item := range v.([]interface{}) { + zoneSettingsMap := item.(map[string]interface{}) + zoneSetting := emr.ZoneSetting{} + if v, ok := zoneSettingsMap["zone"]; ok { + zoneSetting.Zone = helper.String(v.(string)) + } + if vPCSettingsMap, ok := helper.ConvertInterfacesHeadToMap(zoneSettingsMap["vpc_settings"]); ok { + vPCSettings := emr.VPCSettings{} + if v, ok := vPCSettingsMap["vpc_id"]; ok { + vPCSettings.VpcId = helper.String(v.(string)) + } + if v, ok := vPCSettingsMap["subnet_id"]; ok { + vPCSettings.SubnetId = helper.String(v.(string)) + } + zoneSetting.VPCSettings = &vPCSettings + } + if v, ok := zoneSettingsMap["node_num"]; ok { + zoneSetting.NodeNum = helper.IntInt64(v.(int)) + } + request.ZoneSettings = append(request.ZoneSettings, &zoneSetting) + } + } + + if v, ok := d.GetOk("tags"); ok { + for _, item := range v.([]interface{}) { + tagsMap := item.(map[string]interface{}) + tag := emr.Tag{} + if v, ok := tagsMap["tag_key"]; ok { + tag.TagKey = helper.String(v.(string)) + } + if v, ok := tagsMap["tag_value"]; ok { + tag.TagValue = helper.String(v.(string)) + } + request.Tags = append(request.Tags, &tag) + } + } + + var prePaySetting *emr.PrePaySetting + if v, ok := d.GetOk("time_span"); ok { + prePaySetting = &emr.PrePaySetting{} + prePaySetting.Period = &emr.Period{} + prePaySetting.Period.TimeSpan = helper.IntInt64(v.(int)) + } + if v, ok := d.GetOk("time_unit"); ok { + if prePaySetting == nil { + prePaySetting = &emr.PrePaySetting{} + } + if prePaySetting.Period == nil { + prePaySetting.Period = &emr.Period{} + } + prePaySetting.Period.TimeUnit = helper.String(v.(string)) + } + if v, ok := d.GetOk("auto_renew_flag"); ok { + if prePaySetting == nil { + prePaySetting = &emr.PrePaySetting{} + } + prePaySetting.AutoRenewFlag = helper.IntInt64(v.(int)) + } + if prePaySetting != nil { + request.PrePaySetting = prePaySetting + } + + err := resource.Retry(tccommon.WriteRetryTimeout, func() *resource.RetryError { + result, e := meta.(tccommon.ProviderMeta).GetAPIV3Conn().UseEmrClient().CreateSLInstanceWithContext(ctx, request) + if e != nil { + return tccommon.RetryError(e) + } else { + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", logId, request.GetAction(), request.ToJsonString(), result.ToJsonString()) + } + response = result + return nil + }) + if err != nil { + log.Printf("[CRITAL]%s create serverless hbase instance failed, reason:%+v", logId, err) + return err + } + + instanceId := *response.Response.InstanceId + d.SetId(instanceId) + + emrService := EMRService{ + client: meta.(tccommon.ProviderMeta).GetAPIV3Conn(), + } + conf := tccommon.BuildStateChangeConf([]string{}, []string{"2"}, 10*tccommon.ReadRetryTimeout, time.Second, emrService.SLInstanceStateRefreshFunc(instanceId, []string{})) + if _, e := conf.WaitForState(); e != nil { + return e + } + + return resourceTencentCloudServerlessHbaseInstanceRead(d, meta) +} + +func resourceTencentCloudServerlessHbaseInstanceRead(d *schema.ResourceData, meta interface{}) error { + defer tccommon.LogElapsed("resource.tencentcloud_serverless_hbase_instance.read")() + defer tccommon.InconsistentCheck(d, meta)() + + logId := tccommon.GetLogId(tccommon.ContextNil) + + instanceId := d.Id() + + request := emr.NewDescribeSLInstanceRequest() + response := emr.NewDescribeSLInstanceResponse() + request.InstanceId = helper.String(instanceId) + err := resource.Retry(tccommon.WriteRetryTimeout, func() *resource.RetryError { + ratelimit.Check(request.GetAction()) + result, e := meta.(tccommon.ProviderMeta).GetAPIV3Conn().UseEmrClient().DescribeSLInstance(request) + if e != nil { + return tccommon.RetryError(e) + } else { + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", logId, request.GetAction(), request.ToJsonString(), result.ToJsonString()) + } + response = result + return nil + }) + if err != nil { + log.Printf("[CRITAL]%s update serverless hbase instance failed, reason:%+v", logId, err) + return err + } + + if response.Response == nil { + d.SetId("") + log.Printf("[WARN]%s resource `serverless_hbase_instance` [%s] not found, please check if it has been deleted.\n", logId, d.Id()) + return nil + } + respData := response.Response + if respData.InstanceName != nil { + _ = d.Set("instance_name", respData.InstanceName) + } + + if respData.PayMode != nil { + _ = d.Set("pay_mode", respData.PayMode) + } + + if respData.DiskType != nil { + _ = d.Set("disk_type", respData.DiskType) + } + + if respData.DiskSize != nil { + _ = d.Set("disk_size", respData.DiskSize) + } + + zoneSettingsList := make([]map[string]interface{}, 0, len(respData.ZoneSettings)) + if respData.ZoneSettings != nil { + for _, zoneSettings := range respData.ZoneSettings { + zoneSettingsMap := map[string]interface{}{} + + if zoneSettings.Zone != nil { + zoneSettingsMap["zone"] = zoneSettings.Zone + } + + vPCSettingsMap := map[string]interface{}{} + + if zoneSettings.VPCSettings != nil { + if zoneSettings.VPCSettings.VpcId != nil { + vPCSettingsMap["vpc_id"] = zoneSettings.VPCSettings.VpcId + } + + if zoneSettings.VPCSettings.SubnetId != nil { + vPCSettingsMap["subnet_id"] = zoneSettings.VPCSettings.SubnetId + } + + zoneSettingsMap["vpc_settings"] = []interface{}{vPCSettingsMap} + } + + if zoneSettings.NodeNum != nil { + zoneSettingsMap["node_num"] = zoneSettings.NodeNum + } + + zoneSettingsList = append(zoneSettingsList, zoneSettingsMap) + } + + _ = d.Set("zone_settings", zoneSettingsList) + } + + tagsList := make([]map[string]interface{}, 0, len(respData.Tags)) + if respData.Tags != nil { + for _, tags := range respData.Tags { + tagsMap := map[string]interface{}{} + + if tags.TagKey != nil { + tagsMap["tag_key"] = tags.TagKey + } + + if tags.TagValue != nil { + tagsMap["tag_value"] = tags.TagValue + } + + tagsList = append(tagsList, tagsMap) + } + + _ = d.Set("tags", tagsList) + } + if respData.AutoRenewFlag != nil { + _ = d.Set("auto_renew_flag", respData.AutoRenewFlag) + } + + _ = instanceId + return nil +} + +func resourceTencentCloudServerlessHbaseInstanceUpdate(d *schema.ResourceData, meta interface{}) error { + defer tccommon.LogElapsed("resource.tencentcloud_serverless_hbase_instance.update")() + defer tccommon.InconsistentCheck(d, meta)() + + logId := tccommon.GetLogId(tccommon.ContextNil) + + ctx := tccommon.NewResourceLifeCycleHandleFuncContext(context.Background(), logId, d, meta) + + immutableArgs := []string{"instance_name", "pay_mode", "disk_type", "disk_size", "node_type", "tags", "time_span", "time_unit", "auto_renew_flag"} + for _, v := range immutableArgs { + if d.HasChange(v) { + return fmt.Errorf("argument `%s` cannot be changed", v) + } + } + instanceId := d.Id() + + needChange := false + if d.HasChange("zone_settings") { + for idx, zoneSetting := range d.Get("zone_settings").([]interface{}) { + for k := range zoneSetting.(map[string]interface{}) { + param := fmt.Sprintf("zone_settings.%d.%s", idx, k) + if d.HasChange(param) { + if k == "node_num" { + needChange = true + } else { + return fmt.Errorf("argument `%s` cannot be changed", param) + } + } + } + } + } + if needChange { + for idx, zoneSetting := range d.Get("zone_settings").([]interface{}) { + param := fmt.Sprintf("zone_settings.%d.node_num", idx) + if !d.HasChange(param) { + continue + } + zoneSettingMap := zoneSetting.(map[string]interface{}) + request := emr.NewModifySLInstanceRequest() + + request.InstanceId = helper.String(instanceId) + + if v, ok := zoneSettingMap["zone"]; ok { + request.Zone = helper.String(v.(string)) + } + + if v, ok := zoneSettingMap["node_num"]; ok { + request.NodeNum = helper.IntInt64(v.(int)) + } + + err := resource.Retry(tccommon.WriteRetryTimeout, func() *resource.RetryError { + result, e := meta.(tccommon.ProviderMeta).GetAPIV3Conn().UseEmrClient().ModifySLInstanceWithContext(ctx, request) + if e != nil { + return tccommon.RetryError(e) + } else { + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", logId, request.GetAction(), request.ToJsonString(), result.ToJsonString()) + } + return nil + }) + if err != nil { + log.Printf("[CRITAL]%s update serverless hbase instance failed, reason:%+v", logId, err) + return err + } + emrService := EMRService{ + client: meta.(tccommon.ProviderMeta).GetAPIV3Conn(), + } + conf := tccommon.BuildStateChangeConf([]string{}, []string{"2"}, 10*tccommon.ReadRetryTimeout, time.Second, emrService.SLInstanceStateRefreshFunc(instanceId, []string{})) + if _, e := conf.WaitForState(); e != nil { + return e + } + } + } + + _ = instanceId + return resourceTencentCloudServerlessHbaseInstanceRead(d, meta) +} + +func resourceTencentCloudServerlessHbaseInstanceDelete(d *schema.ResourceData, meta interface{}) error { + defer tccommon.LogElapsed("resource.tencentcloud_serverless_hbase_instance.delete")() + defer tccommon.InconsistentCheck(d, meta)() + + logId := tccommon.GetLogId(tccommon.ContextNil) + ctx := tccommon.NewResourceLifeCycleHandleFuncContext(context.Background(), logId, d, meta) + + instanceId := d.Id() + + var ( + request = emr.NewTerminateSLInstanceRequest() + response = emr.NewTerminateSLInstanceResponse() + ) + + request.InstanceId = helper.String(instanceId) + + err := resource.Retry(tccommon.WriteRetryTimeout, func() *resource.RetryError { + result, e := meta.(tccommon.ProviderMeta).GetAPIV3Conn().UseEmrClient().TerminateSLInstanceWithContext(ctx, request) + if e != nil { + return tccommon.RetryError(e) + } else { + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", logId, request.GetAction(), request.ToJsonString(), result.ToJsonString()) + } + response = result + return nil + }) + if err != nil { + log.Printf("[CRITAL]%s delete serverless hbase instance failed, reason:%+v", logId, err) + return err + } + + emrService := EMRService{ + client: meta.(tccommon.ProviderMeta).GetAPIV3Conn(), + } + + if d.Get("pay_mode").(int) == 1 { + conf := tccommon.BuildStateChangeConf([]string{}, []string{"201"}, 10*tccommon.ReadRetryTimeout, time.Second, emrService.SLInstanceStateRefreshFunc(instanceId, []string{})) + if _, e := conf.WaitForState(); e != nil { + return e + } + + err := resource.Retry(tccommon.WriteRetryTimeout, func() *resource.RetryError { + result, e := meta.(tccommon.ProviderMeta).GetAPIV3Conn().UseEmrClient().TerminateSLInstanceWithContext(ctx, request) + if e != nil { + return tccommon.RetryError(e) + } else { + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", logId, request.GetAction(), request.ToJsonString(), result.ToJsonString()) + } + response = result + return nil + }) + if err != nil { + log.Printf("[CRITAL]%s delete serverless hbase instance failed, reason:%+v", logId, err) + return err + } + } + + conf := tccommon.BuildStateChangeConf([]string{}, []string{"-2"}, 10*tccommon.ReadRetryTimeout, time.Second, emrService.SLInstanceStateRefreshFunc(instanceId, []string{})) + if _, e := conf.WaitForState(); e != nil { + return e + } + + _ = response + _ = instanceId + return nil +} diff --git a/tencentcloud/services/emr/resource_tc_serverless_hbase_instance.md b/tencentcloud/services/emr/resource_tc_serverless_hbase_instance.md new file mode 100644 index 0000000000..d189634816 --- /dev/null +++ b/tencentcloud/services/emr/resource_tc_serverless_hbase_instance.md @@ -0,0 +1,33 @@ +Provides a resource to create a emr serverless_hbase_instance + +Example Usage + +```hcl +resource "tencentcloud_serverless_hbase_instance" "serverless_hbase_instance" { + instance_name = "tf-test" + pay_mode = 0 + disk_type = "CLOUD_HSSD" + disk_size = 100 + node_type = "8C32G" + zone_settings { + zone = "ap-shanghai-2" + vpc_settings { + vpc_id = "vpc-xxxxxx" + subnet_id = "subnet-xxxxxx" + } + node_num = 3 + } + tags { + tag_key = "test" + tag_value = "test" + } +} +``` + +Import + +emr serverless_hbase_instance can be imported using the id, e.g. + +``` +terraform import tencentcloud_serverless_hbase_instance.serverless_hbase_instance serverless_hbase_instance_id +``` diff --git a/tencentcloud/services/emr/resource_tc_serverless_hbase_instance_test.go b/tencentcloud/services/emr/resource_tc_serverless_hbase_instance_test.go new file mode 100644 index 0000000000..486e0d5d08 --- /dev/null +++ b/tencentcloud/services/emr/resource_tc_serverless_hbase_instance_test.go @@ -0,0 +1,234 @@ +package emr_test + +import ( + "testing" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + + tcacctest "github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/acctest" +) + +func TestAccTencentCloudServerlessHbaseInstanceResource_basic(t *testing.T) { + t.Parallel() + resource.Test(t, resource.TestCase{ + PreCheck: func() { + tcacctest.AccPreCheck(t) + }, + Providers: tcacctest.AccProviders, + Steps: []resource.TestStep{ + { + Config: testAccServerlessHbaseInstanceBasic, + Check: resource.ComposeTestCheckFunc( + resource.TestCheckResourceAttrSet("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "id"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "instance_name", "tf-test"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "pay_mode", "0"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "disk_type", "CLOUD_HSSD"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "disk_size", "100"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "node_type", "4C16G"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "zone_settings.0.zone", "ap-shanghai-2"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "zone_settings.0.vpc_settings.0.vpc_id", "vpc-muytmxhk"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "zone_settings.0.vpc_settings.0.subnet_id", "subnet-9ye3xm5v"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "zone_settings.0.node_num", "3"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "tags.0.tag_key", "test"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "tags.0.tag_value", "test"), + ), + }, + { + Config: testAccServerlessHbaseInstanceBasicUpdate, + Check: resource.ComposeTestCheckFunc( + resource.TestCheckResourceAttrSet("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "id"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "instance_name", "tf-test"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "pay_mode", "0"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "disk_type", "CLOUD_HSSD"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "disk_size", "100"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "node_type", "4C16G"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "zone_settings.0.zone", "ap-shanghai-2"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "zone_settings.0.vpc_settings.0.vpc_id", "vpc-muytmxhk"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "zone_settings.0.vpc_settings.0.subnet_id", "subnet-9ye3xm5v"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "zone_settings.0.node_num", "5"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "tags.0.tag_key", "test"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance", "tags.0.tag_value", "test"), + ), + }, + { + ResourceName: "tencentcloud_serverless_hbase_instance.serverless_hbase_instance", + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"node_type", "time_span", "time_unit"}, + }, + }, + }) +} + +func TestAccTencentCloudServerlessHbaseInstanceResource_prepay(t *testing.T) { + t.Parallel() + resource.Test(t, resource.TestCase{ + PreCheck: func() { + tcacctest.AccPreCheck(t) + }, + Providers: tcacctest.AccProviders, + Steps: []resource.TestStep{ + { + Config: testAccServerlessHbaseInstancePrePay, + Check: resource.ComposeTestCheckFunc( + resource.TestCheckResourceAttrSet("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_prepay", "id"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_prepay", "instance_name", "tf-test-prepay"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_prepay", "pay_mode", "1"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_prepay", "time_span", "1"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_prepay", "time_unit", "m"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_prepay", "auto_renew_flag", "1"), + ), + }, + { + ResourceName: "tencentcloud_serverless_hbase_instance.serverless_hbase_instance_prepay", + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"node_type", "time_span", "time_unit"}, + }, + }, + }) +} + +func TestAccTencentCloudServerlessHbaseInstanceResource_multiZone(t *testing.T) { + t.Parallel() + resource.Test(t, resource.TestCase{ + PreCheck: func() { + tcacctest.AccPreCheck(t) + }, + Providers: tcacctest.AccProviders, + Steps: []resource.TestStep{ + { + Config: testAccServerlessHbaseInstanceMultiZone, + Check: resource.ComposeTestCheckFunc( + resource.TestCheckResourceAttrSet("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "id"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "instance_name", "tf-test-multi-zone"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "pay_mode", "0"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "disk_type", "CLOUD_HSSD"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "disk_size", "100"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "node_type", "4C16G"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.0.zone", "ap-shanghai-2"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.0.vpc_settings.0.vpc_id", "vpc-muytmxhk"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.0.vpc_settings.0.subnet_id", "subnet-9ye3xm5v"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.0.node_num", "1"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.1.zone", "ap-shanghai-5"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.1.vpc_settings.0.vpc_id", "vpc-muytmxhk"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.1.vpc_settings.0.subnet_id", "subnet-1ppkfg6t"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.1.node_num", "1"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.2.zone", "ap-shanghai-8"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.2.vpc_settings.0.vpc_id", "vpc-muytmxhk"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.2.vpc_settings.0.subnet_id", "subnet-1tup7mn1"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "zone_settings.2.node_num", "1"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "tags.0.tag_key", "test"), + resource.TestCheckResourceAttr("tencentcloud_serverless_hbase_instance.serverless_hbase_instance_multi_zone", "tags.0.tag_value", "test"), + ), + }, + }, + }) +} + +const testAccServerlessHbaseInstanceBasic = ` +resource "tencentcloud_serverless_hbase_instance" "serverless_hbase_instance" { + instance_name = "tf-test" + pay_mode = 0 + disk_type = "CLOUD_HSSD" + disk_size = 100 + node_type = "4C16G" + zone_settings { + zone = "ap-shanghai-2" + vpc_settings { + vpc_id = "vpc-muytmxhk" + subnet_id = "subnet-9ye3xm5v" + } + node_num = 3 + } + tags { + tag_key = "test" + tag_value = "test" + } +} +` + +const testAccServerlessHbaseInstanceBasicUpdate = ` +resource "tencentcloud_serverless_hbase_instance" "serverless_hbase_instance" { + instance_name = "tf-test" + pay_mode = 0 + disk_type = "CLOUD_HSSD" + disk_size = 100 + node_type = "4C16G" + zone_settings { + zone = "ap-shanghai-2" + vpc_settings { + vpc_id = "vpc-muytmxhk" + subnet_id = "subnet-9ye3xm5v" + } + node_num = 5 + } + tags { + tag_key = "test" + tag_value = "test" + } +} +` + +const testAccServerlessHbaseInstancePrePay = ` +resource "tencentcloud_serverless_hbase_instance" "serverless_hbase_instance_prepay" { + instance_name = "tf-test-prepay" + pay_mode = 1 + disk_type = "CLOUD_HSSD" + disk_size = 100 + node_type = "4C16G" + zone_settings { + zone = "ap-guangzhou-6" + vpc_settings { + vpc_id = "vpc-a5pph3hr" + subnet_id = "subnet-bpr2mo2g" + } + node_num = 3 + } + tags { + tag_key = "test" + tag_value = "test" + } + time_span = 1 + time_unit = "m" + auto_renew_flag = 1 +} +` + +const testAccServerlessHbaseInstanceMultiZone = ` +resource "tencentcloud_serverless_hbase_instance" "serverless_hbase_instance_multi_zone" { + instance_name = "tf-test-multi-zone" + pay_mode = 0 + disk_type = "CLOUD_HSSD" + disk_size = 100 + node_type = "4C16G" + zone_settings { + zone = "ap-shanghai-2" + vpc_settings { + vpc_id = "vpc-muytmxhk" + subnet_id = "subnet-9ye3xm5v" + } + node_num = 1 + } + zone_settings { + zone = "ap-shanghai-5" + vpc_settings { + vpc_id = "vpc-muytmxhk" + subnet_id = "subnet-1ppkfg6t" + } + node_num = 1 + } + zone_settings { + zone = "ap-shanghai-8" + vpc_settings { + vpc_id = "vpc-muytmxhk" + subnet_id = "subnet-1tup7mn1" + } + node_num = 1 + } + tags { + tag_key = "test" + tag_value = "test" + } +} +` diff --git a/website/docs/r/serverless_hbase_instance.html.markdown b/website/docs/r/serverless_hbase_instance.html.markdown new file mode 100644 index 0000000000..0673065e8b --- /dev/null +++ b/website/docs/r/serverless_hbase_instance.html.markdown @@ -0,0 +1,84 @@ +--- +subcategory: "MapReduce(EMR)" +layout: "tencentcloud" +page_title: "TencentCloud: tencentcloud_serverless_hbase_instance" +sidebar_current: "docs-tencentcloud-resource-serverless_hbase_instance" +description: |- + Provides a resource to create a emr serverless_hbase_instance +--- + +# tencentcloud_serverless_hbase_instance + +Provides a resource to create a emr serverless_hbase_instance + +## Example Usage + +```hcl +resource "tencentcloud_serverless_hbase_instance" "serverless_hbase_instance" { + instance_name = "tf-test" + pay_mode = 0 + disk_type = "CLOUD_HSSD" + disk_size = 100 + node_type = "8C32G" + zone_settings { + zone = "ap-shanghai-2" + vpc_settings { + vpc_id = "vpc-xxxxxx" + subnet_id = "subnet-xxxxxx" + } + node_num = 3 + } + tags { + tag_key = "test" + tag_value = "test" + } +} +``` + +## Argument Reference + +The following arguments are supported: + +* `disk_size` - (Required, Int) Instance single-node disk capacity, in GB. The single-node disk capacity must be greater than or equal to 100 and less than or equal to 250 times the number of CPU cores. The capacity adjustment step is 100. +* `disk_type` - (Required, String) Instance disk type, Value range: CLOUD_HSSD: indicate performance cloud storage(ESSD). CLOUD_BSSD: indicate standard cloud storage(SSD). +* `instance_name` - (Required, String) Instance name. Length limit is 6-36 characters. Only Chinese characters, letters, numbers, -, and _ are allowed. +* `node_type` - (Required, String) Instance node type, can be filled in as 4C16G, 8C32G, 16C64G, 32C128G, case insensitive. +* `pay_mode` - (Required, Int) Instance pay mode. Value range: 0: indicates post-pay mode, that is, pay-as-you-go. 1: indicates pre-pay mode, that is, monthly subscription. +* `zone_settings` - (Required, List) Detailed configuration of the instance availability zone, currently supports multiple availability zones, the number of availability zones can only be 1 or 3, including zone name, VPC information, and number of nodes. The total number of nodes across all zones must be greater than or equal to 3 and less than or equal to 50. +* `auto_renew_flag` - (Optional, Int) AutoRenewFlag, Value range: 0: indicates NOTIFY_AND_MANUAL_RENEW; 1: indicates NOTIFY_AND_AUTO_RENEW; 2: indicates DISABLE_NOTIFY_AND_MANUAL_RENEW. +* `tags` - (Optional, List) List of tags to bind to the instance. +* `time_span` - (Optional, Int) Time span. +* `time_unit` - (Optional, String) Time unit, fill in m which means month. + +The `tags` object supports the following: + +* `tag_key` - (Optional, String) Tag key. +* `tag_value` - (Optional, String) Tag value. + +The `vpc_settings` object of `zone_settings` supports the following: + +* `subnet_id` - (Required, String) Subnet ID. +* `vpc_id` - (Required, String) VPC ID. + +The `zone_settings` object supports the following: + +* `node_num` - (Required, Int) Number of nodes. +* `vpc_settings` - (Required, List) Private network related information configuration. This parameter can be used to specify the ID of the private network, subnet ID, and other information. +* `zone` - (Required, String) The availability zone to which the instance belongs, such as ap-guangzhou-1. + +## Attributes Reference + +In addition to all arguments above, the following attributes are exported: + +* `id` - ID of the resource. + + + +## Import + +emr serverless_hbase_instance can be imported using the id, e.g. + +``` +terraform import tencentcloud_serverless_hbase_instance.serverless_hbase_instance serverless_hbase_instance_id +``` + diff --git a/website/tencentcloud.erb b/website/tencentcloud.erb index aeb772fa99..34001dd1a8 100644 --- a/website/tencentcloud.erb +++ b/website/tencentcloud.erb @@ -2913,6 +2913,9 @@
  • tencentcloud_lite_hbase_instance
  • +
  • + tencentcloud_serverless_hbase_instance +
  • From 2dda66317930628fdfd12eb0626e004d199abfee Mon Sep 17 00:00:00 2001 From: mikatong Date: Mon, 9 Dec 2024 16:14:42 +0800 Subject: [PATCH 4/7] update changelog --- .changelog/3002.txt | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/.changelog/3002.txt b/.changelog/3002.txt index 476c4f3922..20e46cfc51 100644 --- a/.changelog/3002.txt +++ b/.changelog/3002.txt @@ -1,3 +1,7 @@ ```release-note:enhancement resource/tencentcloud_lite_hbase_instance: support `time_span`, `time_unit` and `auto_renew_flag` +``` + +```release-note:new-resource +tencentcloud_serverless_hbase_instance ``` \ No newline at end of file From 4d846d49d04e3cfa80fbd8be9887506506248851 Mon Sep 17 00:00:00 2001 From: mikatong Date: Mon, 9 Dec 2024 17:00:21 +0800 Subject: [PATCH 5/7] update test case --- .../services/emr/resource_tc_lite_hbase_instance_test.go | 9 ++++++--- .../emr/resource_tc_serverless_hbase_instance_test.go | 9 ++++++--- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/tencentcloud/services/emr/resource_tc_lite_hbase_instance_test.go b/tencentcloud/services/emr/resource_tc_lite_hbase_instance_test.go index ddfb66ca0f..d81391036c 100644 --- a/tencentcloud/services/emr/resource_tc_lite_hbase_instance_test.go +++ b/tencentcloud/services/emr/resource_tc_lite_hbase_instance_test.go @@ -12,6 +12,7 @@ func TestAccTencentCloudLiteHbaseInstanceResource_basic(t *testing.T) { t.Parallel() resource.Test(t, resource.TestCase{ PreCheck: func() { + tcacctest.AccStepSetRegion(t, "ap-shanghai") tcacctest.AccPreCheck(t) }, Providers: tcacctest.AccProviders, @@ -64,6 +65,7 @@ func TestAccTencentCloudLiteHbaseInstanceResource_prepay(t *testing.T) { t.Parallel() resource.Test(t, resource.TestCase{ PreCheck: func() { + tcacctest.AccStepSetRegion(t, "ap-shanghai") tcacctest.AccPreCheck(t) }, Providers: tcacctest.AccProviders, @@ -93,6 +95,7 @@ func TestAccTencentCloudLiteHbaseInstanceResource_multiZone(t *testing.T) { t.Parallel() resource.Test(t, resource.TestCase{ PreCheck: func() { + tcacctest.AccStepSetRegion(t, "ap-shanghai") tcacctest.AccPreCheck(t) }, Providers: tcacctest.AccProviders, @@ -178,10 +181,10 @@ resource "tencentcloud_lite_hbase_instance" "lite_hbase_instance_prepay" { disk_size = 100 node_type = "4C16G" zone_settings { - zone = "ap-guangzhou-6" + zone = "ap-shanghai-2" vpc_settings { - vpc_id = "vpc-a5pph3hr" - subnet_id = "subnet-bpr2mo2g" + vpc_id = "vpc-muytmxhk" + subnet_id = "subnet-9ye3xm5v" } node_num = 3 } diff --git a/tencentcloud/services/emr/resource_tc_serverless_hbase_instance_test.go b/tencentcloud/services/emr/resource_tc_serverless_hbase_instance_test.go index 486e0d5d08..1b36f7e4a9 100644 --- a/tencentcloud/services/emr/resource_tc_serverless_hbase_instance_test.go +++ b/tencentcloud/services/emr/resource_tc_serverless_hbase_instance_test.go @@ -12,6 +12,7 @@ func TestAccTencentCloudServerlessHbaseInstanceResource_basic(t *testing.T) { t.Parallel() resource.Test(t, resource.TestCase{ PreCheck: func() { + tcacctest.AccStepSetRegion(t, "ap-shanghai") tcacctest.AccPreCheck(t) }, Providers: tcacctest.AccProviders, @@ -64,6 +65,7 @@ func TestAccTencentCloudServerlessHbaseInstanceResource_prepay(t *testing.T) { t.Parallel() resource.Test(t, resource.TestCase{ PreCheck: func() { + tcacctest.AccStepSetRegion(t, "ap-shanghai") tcacctest.AccPreCheck(t) }, Providers: tcacctest.AccProviders, @@ -93,6 +95,7 @@ func TestAccTencentCloudServerlessHbaseInstanceResource_multiZone(t *testing.T) t.Parallel() resource.Test(t, resource.TestCase{ PreCheck: func() { + tcacctest.AccStepSetRegion(t, "ap-shanghai") tcacctest.AccPreCheck(t) }, Providers: tcacctest.AccProviders, @@ -178,10 +181,10 @@ resource "tencentcloud_serverless_hbase_instance" "serverless_hbase_instance_pre disk_size = 100 node_type = "4C16G" zone_settings { - zone = "ap-guangzhou-6" + zone = "ap-shanghai-2" vpc_settings { - vpc_id = "vpc-a5pph3hr" - subnet_id = "subnet-bpr2mo2g" + vpc_id = "vpc-muytmxhk" + subnet_id = "subnet-9ye3xm5v" } node_num = 3 } From a6ea722c60f07cb2c18d286c0d1047c84325c5e0 Mon Sep 17 00:00:00 2001 From: mikatong Date: Wed, 18 Dec 2024 10:41:10 +0800 Subject: [PATCH 6/7] update node_type --- tencentcloud/services/emr/resource_tc_lite_hbase_instance.go | 2 +- .../services/emr/resource_tc_serverless_hbase_instance.go | 2 +- website/docs/r/lite_hbase_instance.html.markdown | 2 +- website/docs/r/serverless_hbase_instance.html.markdown | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go b/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go index a6f3751efe..b37a863205 100644 --- a/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go +++ b/tencentcloud/services/emr/resource_tc_lite_hbase_instance.go @@ -52,7 +52,7 @@ func ResourceTencentCloudLiteHbaseInstance() *schema.Resource { "node_type": { Type: schema.TypeString, - Required: true, + Optional: true, Description: "Instance node type, can be filled in as 4C16G, 8C32G, 16C64G, 32C128G, case insensitive.", }, diff --git a/tencentcloud/services/emr/resource_tc_serverless_hbase_instance.go b/tencentcloud/services/emr/resource_tc_serverless_hbase_instance.go index e2438c74de..62b2879248 100644 --- a/tencentcloud/services/emr/resource_tc_serverless_hbase_instance.go +++ b/tencentcloud/services/emr/resource_tc_serverless_hbase_instance.go @@ -51,7 +51,7 @@ func ResourceTencentCloudServerlessHbaseInstance() *schema.Resource { "node_type": { Type: schema.TypeString, - Required: true, + Optional: true, Description: "Instance node type, can be filled in as 4C16G, 8C32G, 16C64G, 32C128G, case insensitive.", }, diff --git a/website/docs/r/lite_hbase_instance.html.markdown b/website/docs/r/lite_hbase_instance.html.markdown index b6c2f18b5f..e77d99abaa 100644 --- a/website/docs/r/lite_hbase_instance.html.markdown +++ b/website/docs/r/lite_hbase_instance.html.markdown @@ -42,10 +42,10 @@ The following arguments are supported: * `disk_size` - (Required, Int) Instance single-node disk capacity, in GB. The single-node disk capacity must be greater than or equal to 100 and less than or equal to 250 times the number of CPU cores. The capacity adjustment step is 100. * `disk_type` - (Required, String) Instance disk type, Value range: CLOUD_HSSD: indicate performance cloud storage(ESSD). CLOUD_BSSD: indicate standard cloud storage(SSD). * `instance_name` - (Required, String) Instance name. Length limit is 6-36 characters. Only Chinese characters, letters, numbers, -, and _ are allowed. -* `node_type` - (Required, String) Instance node type, can be filled in as 4C16G, 8C32G, 16C64G, 32C128G, case insensitive. * `pay_mode` - (Required, Int) Instance pay mode. Value range: 0: indicates post-pay mode, that is, pay-as-you-go. 1: indicates pre-pay mode, that is, monthly subscription. * `zone_settings` - (Required, List) Detailed configuration of the instance availability zone, currently supports multiple availability zones, the number of availability zones can only be 1 or 3, including zone name, VPC information, and number of nodes. The total number of nodes across all zones must be greater than or equal to 3 and less than or equal to 50. * `auto_renew_flag` - (Optional, Int) AutoRenewFlag, Value range: 0: indicates NOTIFY_AND_MANUAL_RENEW; 1: indicates NOTIFY_AND_AUTO_RENEW; 2: indicates DISABLE_NOTIFY_AND_MANUAL_RENEW. +* `node_type` - (Optional, String) Instance node type, can be filled in as 4C16G, 8C32G, 16C64G, 32C128G, case insensitive. * `tags` - (Optional, List) List of tags to bind to the instance. * `time_span` - (Optional, Int) Time span. * `time_unit` - (Optional, String) Time unit, fill in m which means month. diff --git a/website/docs/r/serverless_hbase_instance.html.markdown b/website/docs/r/serverless_hbase_instance.html.markdown index 0673065e8b..a8b2e7cbca 100644 --- a/website/docs/r/serverless_hbase_instance.html.markdown +++ b/website/docs/r/serverless_hbase_instance.html.markdown @@ -42,10 +42,10 @@ The following arguments are supported: * `disk_size` - (Required, Int) Instance single-node disk capacity, in GB. The single-node disk capacity must be greater than or equal to 100 and less than or equal to 250 times the number of CPU cores. The capacity adjustment step is 100. * `disk_type` - (Required, String) Instance disk type, Value range: CLOUD_HSSD: indicate performance cloud storage(ESSD). CLOUD_BSSD: indicate standard cloud storage(SSD). * `instance_name` - (Required, String) Instance name. Length limit is 6-36 characters. Only Chinese characters, letters, numbers, -, and _ are allowed. -* `node_type` - (Required, String) Instance node type, can be filled in as 4C16G, 8C32G, 16C64G, 32C128G, case insensitive. * `pay_mode` - (Required, Int) Instance pay mode. Value range: 0: indicates post-pay mode, that is, pay-as-you-go. 1: indicates pre-pay mode, that is, monthly subscription. * `zone_settings` - (Required, List) Detailed configuration of the instance availability zone, currently supports multiple availability zones, the number of availability zones can only be 1 or 3, including zone name, VPC information, and number of nodes. The total number of nodes across all zones must be greater than or equal to 3 and less than or equal to 50. * `auto_renew_flag` - (Optional, Int) AutoRenewFlag, Value range: 0: indicates NOTIFY_AND_MANUAL_RENEW; 1: indicates NOTIFY_AND_AUTO_RENEW; 2: indicates DISABLE_NOTIFY_AND_MANUAL_RENEW. +* `node_type` - (Optional, String) Instance node type, can be filled in as 4C16G, 8C32G, 16C64G, 32C128G, case insensitive. * `tags` - (Optional, List) List of tags to bind to the instance. * `time_span` - (Optional, Int) Time span. * `time_unit` - (Optional, String) Time unit, fill in m which means month. From 4b78d9f07570e97ea9906a679b9c747e78ec9746 Mon Sep 17 00:00:00 2001 From: mikatong Date: Wed, 18 Dec 2024 11:06:32 +0800 Subject: [PATCH 7/7] update changelog --- .changelog/3002.txt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.changelog/3002.txt b/.changelog/3002.txt index 20e46cfc51..02ab551032 100644 --- a/.changelog/3002.txt +++ b/.changelog/3002.txt @@ -1,5 +1,5 @@ -```release-note:enhancement -resource/tencentcloud_lite_hbase_instance: support `time_span`, `time_unit` and `auto_renew_flag` +```release-note:deprecation +resource/tencentcloud_lite_hbase_instance ``` ```release-note:new-resource