Querying the Active or Historical Alarm List
Function
This API is used to query the alarm list.
Calling Method
For details, see Calling APIs.
URI
POST /v2/{project_id}/{domain_id}/lts/alarms/sql-alarm/query
Parameter |
Mandatory |
Type |
Description |
---|---|---|---|
project_id |
Yes |
String |
Project ID. For details about how to obtain a project ID, see Obtaining the Project ID, Account ID, Log Group ID, and Log Stream ID. |
domain_id |
Yes |
String |
Account ID. For details about how to obtain an account ID, see Obtaining the Project ID, Account ID, Log Group ID, and Log Stream ID. |
Parameter |
Mandatory |
Type |
Description |
---|---|---|---|
type |
Yes |
String |
Whether the alarm is an active alarm or a historical alarm. |
marker |
No |
String |
The value is the ID of the last record on the previous page (value of previous_marker or next_marker returned by the previous page). |
limit |
No |
Integer |
Number of records on each page. |
Request Parameters
Parameter |
Mandatory |
Type |
Description |
---|---|---|---|
X-Auth-Token |
Yes |
String |
User token obtained from IAM. For details about how to obtain a user token, see Obtaining a User Token. |
Content-Type |
Yes |
String |
Set this parameter to application/json;charset=UTF-8. |
Parameter |
Mandatory |
Type |
Description |
---|---|---|---|
whether_custom_field |
Yes |
Boolean |
Whether to customize the query time segment. |
start_time |
No |
Long |
Start time of a customized time segment (timestamp). |
end_time |
No |
Long |
End time of a customized time segment (timestamp). |
time_range |
No |
String |
Non-customized time range (in minutes). |
search |
No |
String |
Keyword search criteria. |
alarm_level_ids |
No |
Array of strings |
Alarm severity (Critical, Major, Minor, Info).
NOTE:
alarmLevelIds is a parameter of an earlier version and is currently compatible with this parameter. You are advised to use this parameter. alarm_level_ids |
sort |
No |
Sort object |
Sort search criteria. |
step |
No |
Integer |
Keyword search criteria. |
Response Parameters
Status code: 200
Parameter |
Type |
Description |
---|---|---|
events |
Array of Events objects |
Alarm information. Minimum length: 0 characters Maximum length: 2048 characters |
page_info |
PageInfo object |
Pagination details. Minimum length: 0 characters Maximum length: 2048 characters |
Parameter |
Type |
Description |
---|---|---|
annotations |
Annotations object |
Alarm details. The length ranges from 0 to 5000 characters. |
metadata |
Metadata object |
Alarms Minimum length: 0 characters Maximum length: 2048 characters |
arrives_at |
Long |
Arrival time (timestamp). |
ends_at |
Long |
Alarm clearance time (timestamp). |
id |
String |
Alarm ID. |
starts_at |
Long |
Alarm generation time (timestamp). |
timeout |
Long |
Time when an alarm is automatically cleared (timestamp). |
type |
String |
Alarm rule type (SQL/keyword). |
Parameter |
Type |
Description |
---|---|---|
message |
String |
Alarm list details. |
log_info |
String |
Log group/stream ID. |
current_value |
String |
Current value. |
old_annotations |
String |
Original data of (SQL/keyword) alarm details. |
Parameter |
Type |
Description |
---|---|---|
event_type |
String |
Alarm type. |
event_id |
String |
Alarm ID. |
event_severity |
String |
Alarm severity. |
event_name |
String |
Alarm name. |
resource_type |
String |
Resource type. |
resource_id |
String |
Log group/stream name. |
resource_provider |
String |
Alarm source. |
lts_alarm_type |
String |
Alarm rule type (SQL/keyword). |
log_group_name |
String |
Original log group name. |
log_stream_name |
String |
Original log stream name. |
Example Requests
Querying the active or historical alarm list
POST https://{endpoint}/v2/{project_id}/{domain_id}/lts/alarms/sql-alarm/query { "whether_custom_field" : false, "start_time" : 0, "end_time" : 0, "time_range" : "30", "search" : "", "alarm_level_ids" : [ "Critical", "Major", "Minor", "Info" ], "sort" : { "order_by" : [ "starts_at" ], "order" : "desc" } }
Example Responses
Status code: 200
The request is successful.
{ "events" : [ { "annotations" : { "message" : "string", "log_info" : "string", "current_value" : "string" }, "metadata" : { "event_type" : "string", "event_id" : "string", "event_severity" : "string", "event_name" : "string", "resource_type" : "string", "resource_id" : "string", "resource_provider" : "string", "lts_alarm_type" : "string" }, "id" : "string", "type" : "string" } ], "page_info" : { "next_marker" : "string", "previous_marker" : "string", "current_count" : 0 } }
SDK Sample Code
The SDK sample code is as follows.
Querying the active or historical alarm list
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 |
package com.huaweicloud.sdk.test; import com.huaweicloud.sdk.core.auth.ICredential; import com.huaweicloud.sdk.core.auth.BasicCredentials; import com.huaweicloud.sdk.core.exception.ConnectionException; import com.huaweicloud.sdk.core.exception.RequestTimeoutException; import com.huaweicloud.sdk.core.exception.ServiceResponseException; import com.huaweicloud.sdk.lts.v2.region.LtsRegion; import com.huaweicloud.sdk.lts.v2.*; import com.huaweicloud.sdk.lts.v2.model.*; import java.util.List; import java.util.ArrayList; public class ListActiveOrHistoryAlarmsSolution { public static void main(String[] args) { // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security. // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment String ak = System.getenv("CLOUD_SDK_AK"); String sk = System.getenv("CLOUD_SDK_SK"); ICredential auth = new BasicCredentials() .withAk(ak) .withSk(sk); LtsClient client = LtsClient.newBuilder() .withCredential(auth) .withRegion(LtsRegion.valueOf("<YOUR REGION>")) .build(); ListActiveOrHistoryAlarmsRequest request = new ListActiveOrHistoryAlarmsRequest(); request.withDomainId("{domain_id}"); ListActiveOrHistoryAlarmsRequestBody body = new ListActiveOrHistoryAlarmsRequestBody(); List<String> listSortOrderBy = new ArrayList<>(); listSortOrderBy.add("starts_at"); Sort sortbody = new Sort(); sortbody.withOrderBy(listSortOrderBy) .withOrder(Sort.OrderEnum.fromValue("desc")); List<String> listbodyAlarmLevelIds = new ArrayList<>(); listbodyAlarmLevelIds.add("Critical"); listbodyAlarmLevelIds.add("Major"); listbodyAlarmLevelIds.add("Minor"); listbodyAlarmLevelIds.add("Info"); body.withSort(sortbody); body.withAlarmLevelIds(listbodyAlarmLevelIds); body.withSearch(""); body.withTimeRange("30"); body.withEndTime(0L); body.withStartTime(0L); body.withWhetherCustomField(false); request.withBody(body); try { ListActiveOrHistoryAlarmsResponse response = client.listActiveOrHistoryAlarms(request); System.out.println(response.toString()); } catch (ConnectionException e) { e.printStackTrace(); } catch (RequestTimeoutException e) { e.printStackTrace(); } catch (ServiceResponseException e) { e.printStackTrace(); System.out.println(e.getHttpStatusCode()); System.out.println(e.getRequestId()); System.out.println(e.getErrorCode()); System.out.println(e.getErrorMsg()); } } } |
Querying the active or historical alarm list
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 |
# coding: utf-8 import os from huaweicloudsdkcore.auth.credentials import BasicCredentials from huaweicloudsdklts.v2.region.lts_region import LtsRegion from huaweicloudsdkcore.exceptions import exceptions from huaweicloudsdklts.v2 import * if __name__ == "__main__": # The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security. # In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak = os.environ["CLOUD_SDK_AK"] sk = os.environ["CLOUD_SDK_SK"] credentials = BasicCredentials(ak, sk) client = LtsClient.new_builder() \ .with_credentials(credentials) \ .with_region(LtsRegion.value_of("<YOUR REGION>")) \ .build() try: request = ListActiveOrHistoryAlarmsRequest() request.domain_id = "{domain_id}" listOrderBySort = [ "starts_at" ] sortbody = Sort( order_by=listOrderBySort, order="desc" ) listAlarmLevelIdsbody = [ "Critical", "Major", "Minor", "Info" ] request.body = ListActiveOrHistoryAlarmsRequestBody( sort=sortbody, alarm_level_ids=listAlarmLevelIdsbody, search="", time_range="30", end_time=0, start_time=0, whether_custom_field=False ) response = client.list_active_or_history_alarms(request) print(response) except exceptions.ClientRequestException as e: print(e.status_code) print(e.request_id) print(e.error_code) print(e.error_msg) |
Querying the active or historical alarm list
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 |
package main import ( "fmt" "github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/basic" lts "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/lts/v2" "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/lts/v2/model" region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/lts/v2/region" ) func main() { // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security. // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak := os.Getenv("CLOUD_SDK_AK") sk := os.Getenv("CLOUD_SDK_SK") auth := basic.NewCredentialsBuilder(). WithAk(ak). WithSk(sk). Build() client := lts.NewLtsClient( lts.LtsClientBuilder(). WithRegion(region.ValueOf("<YOUR REGION>")). WithCredential(auth). Build()) request := &model.ListActiveOrHistoryAlarmsRequest{} request.DomainId = "{domain_id}" var listOrderBySort = []string{ "starts_at", } sortbody := &model.Sort{ OrderBy: listOrderBySort, Order: model.GetSortOrderEnum().DESC, } var listAlarmLevelIdsbody = []string{ "Critical", "Major", "Minor", "Info", } searchListActiveOrHistoryAlarmsRequestBody:= "" timeRangeListActiveOrHistoryAlarmsRequestBody:= "30" endTimeListActiveOrHistoryAlarmsRequestBody:= int64(0) startTimeListActiveOrHistoryAlarmsRequestBody:= int64(0) request.Body = &model.ListActiveOrHistoryAlarmsRequestBody{ Sort: sortbody, AlarmLevelIds: &listAlarmLevelIdsbody, Search: &searchListActiveOrHistoryAlarmsRequestBody, TimeRange: &timeRangeListActiveOrHistoryAlarmsRequestBody, EndTime: &endTimeListActiveOrHistoryAlarmsRequestBody, StartTime: &startTimeListActiveOrHistoryAlarmsRequestBody, WhetherCustomField: false, } response, err := client.ListActiveOrHistoryAlarms(request) if err == nil { fmt.Printf("%+v\n", response) } else { fmt.Println(err) } } |
For SDK sample code of more programming languages, see the Sample Code tab in API Explorer. SDK sample code can be automatically generated.
Status Codes
Status Code |
Description |
---|---|
200 |
The request is successful. |
Error Codes
See Error Codes.
Feedback
Was this page helpful?
Provide feedbackThank you very much for your feedback. We will continue working to improve the documentation.See the reply and handling status in My Cloud VOC.
For any further questions, feel free to contact us through the chatbot.
Chatbot