Querying Log Ingestion Configurations
Function
This API is used to query log ingestion configurations in LTS, displaying their details and enabling you to filter them by multiple dimensions. This allows you to quickly obtain the required data and significantly improves the efficiency of querying log ingestion configurations.
Calling Method
For details, see Calling APIs.
URI
POST /v3/{project_id}/lts/access-config-list
Parameter |
Mandatory |
Type |
Description |
---|---|---|---|
project_id |
Yes |
String |
Parameter description: Project ID. For details about how to obtain it, see Obtaining the Account ID, Project Resource Set ID, Log Group ID, and Log Stream ID. Constraints: N/A. Value range: N/A. Default value: N/A. |
Request Parameters
Parameter |
Mandatory |
Type |
Description |
---|---|---|---|
X-Auth-Token |
Yes |
String |
Parameter description: User token obtained from IAM. For details about how to obtain it, see Obtaining a User Token. Constraints: N/A. Value range: N/A. Default value: N/A. |
Content-Type |
Yes |
String |
Parameter description: Set this parameter to application/json;charset=UTF-8. Constraints: N/A. Value range: N/A. Default value: N/A. |
Parameter |
Mandatory |
Type |
Description |
---|---|---|---|
access_config_name_list |
No |
Array of strings |
Parameter description: List of ingestion configuration names. Constraints: N/A. Value range: N/A. Default value: N/A. |
host_group_name_list |
No |
Array of strings |
Parameter description: Host group name list. Constraints: N/A. Value range: N/A. Default value: N/A. |
log_group_name_list |
No |
Array of strings |
Parameter description: Log group name list. Constraints: N/A. Value range: N/A. Default value: N/A. |
log_stream_name_list |
No |
Array of strings |
Parameter description: Log stream name list. Constraints: N/A. Value range: N/A. Default value: N/A. |
access_config_tag_list |
No |
Array of accessConfigTag objects |
Parameter description: Ingestion configuration tags. Constraints: A tag key must be unique. Up to 20 tags are allowed. Value range: N/A. Default value: N/A. |
Parameter |
Mandatory |
Type |
Description |
---|---|---|---|
key |
No |
String |
Parameter description: Tag key, which must be unique. Constraints: N/A. Value range: It can contain up to 128 characters, including only letters, digits, spaces, and special characters (_.:=+-@). Do not start or end with a space, nor start with sys. |
value |
No |
String |
Parameter description: Tag value. Value range: It can contain up to 255 characters, including only letters, digits, spaces, and special characters (_.:=+-@). |
Response Parameters
Status code: 200
Parameter |
Type |
Description |
---|---|---|
result |
Array of AccessConfigInfo objects |
Parameter description: Ingestion configuration list. Value range: N/A. |
total |
Long |
Parameter description: Total number of ingestion configurations. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
access_config_id |
String |
Parameter description: Ingestion configuration ID. Value range: N/A. |
access_config_name |
String |
Parameter description: Ingestion configuration name. Value range: N/A. |
access_config_type |
String |
Parameter description: Ingestion configuration type. The value can be AGENT (ECS log ingestion) or K8S_CCE (CCE log ingestion). Value range: N/A. |
create_time |
Long |
Parameter description: Creation time. Value range: N/A. |
access_config_detail |
AccessConfigDeatilCreate object |
Parameter description: Ingestion configuration details. Value range: N/A. |
log_info |
AccessConfigQueryLogInfo object |
Parameter description: Log details. Value range: N/A. |
host_group_info |
AccessConfigHostGroupIdList object |
Parameter description: Host group ID list. Value range: N/A. |
access_config_tag |
Array of accessConfigTag objects |
Parameter description: Tag information. A tag key must be unique. Up to 20 tags are allowed. Value range: N/A. |
log_split |
Boolean |
Parameter description: Log splitting. Value range: N/A. |
binary_collect |
Boolean |
Parameter description: Binary file collection. Value range: N/A. |
cluster_id |
String |
Parameter description: CCE cluster ID. Value range: N/A. |
encoding_format |
String |
Parameter description: Encoding format. The default format is UTF-8. Value range: N/A. |
incremental_collect |
Boolean |
Parameter description: Collection policy. The value can be incremental. Value range: N/A. |
processor_type |
String |
Parameter description: ICAgent structuring parsing type. Value range: N/A. |
demo_log |
String |
Parameter description: Sample log event. Value range: N/A. |
demo_fields |
Array of DemoFieldAccess objects |
Parameter description: Parsing fields of the sample log event. Value range: N/A. |
processors |
Array of Processor objects |
Parameter description: ICAgent structuring parser. Value range: N/A. |
application_id |
String |
Parameter description: ServiceStage application ID. Value range: N/A. |
environment_id |
String |
Parameter description: ServiceStage environment ID. Value range: N/A. |
component_id |
Array of strings |
Parameter description: ServiceStage component ID. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
paths |
Array of strings |
Parameter description: Collection paths.
The container path and host path are mandatory for the CCE type and are not mandatory for the standard output. Value range: N/A. |
black_paths |
Array of strings |
Parameter description: Collection path blacklist.
Value range: N/A. |
format |
AccessConfigFormatCreate object |
Parameter description: Collection path blacklist.
Value range: N/A. |
windows_log_info |
Parameter description: Windows event logs. Value range: N/A. |
|
stdout |
Boolean |
Parameter description: Standard output switch. This parameter is used only for CCE log ingestion. Value range: N/A. |
stderr |
Boolean |
Parameter description: Standard error switch. This parameter is used only for CCE log ingestion. Value range: N/A. |
pathType |
String |
Parameter description: CCE log ingestion type. This parameter is used only for CCE log ingestion. Value range: N/A. |
namespaceRegex |
String |
Parameter description: Regular expression matching of Kubernetes namespaces. This parameter is used only for CCE log ingestion. Value range: N/A. |
podNameRegex |
String |
Parameter description: Regular expression matching of Kubernetes pods. This parameter is used only for CCE log ingestion. Value range: N/A. |
containerNameRegex |
String |
Parameter description: Regular expression matching of Kubernetes container names. This parameter is used only for CCE log ingestion. Value range: N/A. |
includeLabels |
Map<String,String> |
Parameter description: Container label whitelist. You can create up to 30 whitelists. The key names must be unique. This parameter is used only for CCE log ingestion. Value range: N/A. |
excludeLabels |
Map<String,String> |
Parameter description: Container label blacklist. You can create up to 30 blacklists. The key names must be unique. This parameter is used only for CCE log ingestion. Value range: N/A. |
includeEnvs |
Map<String,String> |
Parameter description: Environment variable whitelist. You can create up to 30 whitelists. The key names must be unique. This parameter is used only for CCE log ingestion. Value range: N/A. |
excludeEnvs |
Map<String,String> |
Parameter description: Environment variable blacklist. You can create up to 30 blacklists. The key names must be unique. This parameter is used only for CCE log ingestion. Value range: N/A. |
logLabels |
Map<String,String> |
Parameter description: Container label. You can create up to 30 labels. The key names must be unique. This parameter is used only for CCE log ingestion. Value range: N/A. |
logEnvs |
Map<String,String> |
Parameter description: Environment variable label. You can create up to 30 labels. The key names must be unique. This parameter is used only for CCE log ingestion. Value range: N/A. |
includeK8sLabels |
Map<String,String> |
Parameter description: Kubernetes label whitelist. You can create up to 30 whitelists. The key names must be unique. This parameter is used only for CCE log ingestion. Value range: N/A. |
excludeK8sLabels |
Map<String,String> |
Parameter description: Kubernetes label blacklist. You can create up to 30 blacklists. The key names must be unique. This parameter is used only for CCE log ingestion. Value range: N/A. |
logK8s |
Map<String,String> |
Parameter description: Kubernetes label. You can create up to 30 labels. The key names must be unique. This parameter is used only for CCE log ingestion. Value range: N/A. |
repeat_collect |
Boolean |
Parameter description: Forcible repeated collection. Value range: N/A. |
system_fields |
Array of strings |
Parameter description: System built-in fields. When configuring a log ingestion rule, you can specify system fields to include in the tag data of each log reported. The system fields for host log files are hostName, hostId, hostIP, pathFile, hostIPv6, category, collectTime, and __host_group__. The system fields for Kubernetes cluster container log files are hostName, hostId, hostIP, pathFile, hostIPv6, clusterId, podName, appName, containerName, nameSpace, category, collectTime, __host_group__, serviceID, podIp, clusterName, workloadType, and __image_name__. If this parameter is transferred during modification, the original configuration will be overwritten. When you configure metadata for the first time, this parameter is mandatory and the value is ["pathFile"]. In this case, pathFile is mandatory and other fields are optional. Value range: N/A. |
custom_key_value |
Map<String,String> |
Parameter description: Custom key-value pairs. When configuring a log ingestion rule, you can configure up to 20 custom key-value pairs to include in the tag data of each log reported. A key can contain up to 128 characters, including letters, digits, hyphens (-), and underscores (_). A value can contain up to 1,024 characters. If this parameter is transferred during modification, the original configuration will be overwritten. Value range: N/A. |
includeLabelsLogical |
String |
Parameter description: Logic for the container label whitelist to take effect. The value can be AND or OR (default). When there are multiple conditions for the container label whitelist, AND indicates that the whitelist takes effect only when all the conditions are met, and OR indicates that the whitelist takes effect when one of the conditions is met. Value range: N/A. |
excludeLabelsLogical |
String |
Parameter description: Logic for the container label blacklist to take effect. The value can be AND or OR (default). When there are multiple conditions for the container label blacklist, AND indicates that the blacklist takes effect only when all the conditions are met, and OR indicates that the blacklist takes effect when one of the conditions is met. Value range: N/A. |
includeK8sLabelsLogical |
String |
Parameter description: Logic for the Kubernetes label whitelist to take effect. The value can be AND or OR (default). When there are multiple conditions for the Kubernetes label whitelist, AND indicates that the whitelist takes effect only when all the conditions are met, and OR indicates that the whitelist takes effect when one of the conditions is met. Value range: N/A. |
excludeK8sLabelsLogical |
String |
Parameter description: Logic for the Kubernetes label blacklist to take effect. The value can be AND or OR (default). When there are multiple conditions for the Kubernetes label blacklist, AND indicates that the blacklist takes effect only when all the conditions are met, and OR indicates that the blacklist takes effect when one of the conditions is met. Value range: N/A. |
includeEnvsLogical |
String |
Parameter description: Logic for the environment variable whitelist to take effect. The value can be AND or OR (default). When there are multiple conditions for the environment variable whitelist, AND indicates that the whitelist takes effect only when all the conditions are met, and OR indicates that the whitelist takes effect when one of the conditions is met. Value range: N/A. |
excludeEnvsLogical |
String |
Parameter description: Logic for the environment variable blacklist to take effect. The value can be AND or OR (default). When there are multiple conditions for the environment variable blacklist, AND indicates that the blacklist takes effect only when all the conditions are met, and OR indicates that the blacklist takes effect when one of the conditions is met. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
single |
Parameter description: Single-line format is set as the log ingestion format. Value range: N/A. |
|
multi |
Parameter description: Multi-line format is set as the log ingestion format. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
mode |
String |
Parameter description: Single-line logs. The value can be system (system time) or wildcard (time wildcard). Value range: N/A. |
value |
String |
Parameter description: Log time. If mode is system, the value is the current timestamp. If mode is wildcard, the value is a time wildcard, which is used to match the log printing time displayed at the beginning of a log event. If the time format in a log event is 2019-01-01 23:59:59, the time wildcard is YYYY-MM-DD hh:mm:ss. If the time format in a log event is 19-1-1 23:59:59, the time wildcard is YY-M-D hh:mm:ss. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
mode |
String |
Parameter description: Single-line logs. The value can be time (log time) or regular (regular expression). Value range: N/A. |
value |
String |
Parameter description: Log time. If mode is regular, the value is a regular expression. If mode is time, the value is a time wildcard, which is used to match the log printing time displayed at the beginning of a log event. If the time format in a log event is 2019-01-01 23:59:59, the time wildcard is YYYY-MM-DD hh:mm:ss. If the time format in a log event is 19-1-1 23:59:59, the time wildcard is YY-M-D hh:mm:ss. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
categorys |
Array of strings |
Parameter description: Type of Windows event logs to be collected. The value can be Application (application system logs), System (system logs), Security (security logs), or Setup (startup logs). Value range: N/A. |
time_offset |
AccessConfigTimeOffset object |
Parameter description: Time offset for log ingestion. Value range: N/A. |
event_level |
Array of strings |
Parameter description: Event level. The value can be information, warning, error, critical, or verbose. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
offset |
Long |
Parameter description: Time offset. When unit is day, the value ranges from 1 to 7. When unit is hour, the value ranges from 1 to 168. When unit is sec, the value ranges from 1 to 604,800. Value range: N/A. |
unit |
String |
Parameter description: Unit of the time offset. The value can be day, hour, or sec. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
log_group_id |
String |
Parameter description: Log group ID. Value range: N/A. |
log_stream_id |
String |
Parameter description: Log stream ID. Value range: N/A. |
log_group_name |
String |
Parameter description: Log group name. Value range: N/A. |
log_stream_name |
String |
Parameter description: Log stream name. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
host_group_id_list |
Array of strings |
Parameter description: Host group ID list. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
key |
String |
Parameter description: Tag key, which must be unique. Constraints: N/A. Value range: It can contain up to 128 characters, including only letters, digits, spaces, and special characters (_.:=+-@). Do not start or end with a space, nor start with sys. |
value |
String |
Parameter description: Tag value. Value range: It can contain up to 255 characters, including only letters, digits, spaces, and special characters (_.:=+-@). |
Parameter |
Type |
Description |
---|---|---|
field_name |
String |
Parameter description: Field name, which must be the same as that in keys. Value range: N/A. |
field_value |
String |
Parameter description: Field value. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
type |
String |
Parameter description: Parser type. processor_regex: regular expression processor_split_string: delimiter processor_json: JSON processor_gotime: custom time type processor_filter_regex: log filtering processor_drop: type of fields to be deleted processor_rename: type of fields to be modified Value range: N/A. |
detail |
Detail object |
Parameter description: Parser configuration. Value range: N/A. |
Parameter |
Type |
Description |
---|---|---|
source_key |
String |
Parameter description: Custom time key field name. Value range: N/A. |
regex |
String |
Parameter description: Regular expression for parsing. This field is required for a single-line completely regular expression or a multi-line completely regular expression. Value range: N/A. |
keys |
Array of strings |
Parameter description: Field name list, which is consistent with the field_name field. Value range: N/A. |
multi_line_regex |
String |
Parameter description: First line regular expression. Value range: N/A. |
keep_source |
Boolean |
Parameter description: Whether to upload raw logs. Value range: N/A. |
keep_source_if_parse_error |
Boolean |
Parameter description: Whether to upload logs that fail to be parsed. Value range: N/A. |
split_sep |
String |
Parameter description: Delimiters. Value range: The maximum length of custom characters is 10 characters, and the maximum length of a custom string is 30 characters. |
split_type |
String |
Parameter description: Delimiter type. The value can be char (custom characters), special_char (invisible characters), or string (custom string). Value range: N/A. |
fields |
Map<String,String> |
Parameter description: List of added fields, in [/topic/body/section/table/tgroup/tbody/row/entry/p/br {""}) (br] format. Value range: N/A. |
drop_keys |
Array of strings |
Parameter description: List of deleted fields. Value range: N/A. |
source_keys |
Array of strings |
Parameter description: List of source field names for renaming fields. Value range: N/A. |
dest_keys |
Array of strings |
Parameter description: List of field names that are renamed and replaced. Value range: N/A. |
expand_depth |
Integer |
Parameter description: JSON parsing depth. The value ranges from 1 (default) to 4. Value range: N/A. |
expand_connector |
String |
Parameter description: JSON parsing field name connector. Value range: N/A. |
source_format |
String |
Parameter description: Custom time format. Value range: N/A. |
source_value |
String |
Parameter description: Custom time field value. Value range: N/A. |
set_time |
Boolean |
Parameter description: Whether to enable the custom time function. Value range: N/A. |
include |
Map<String,String> |
Parameter description: A key of a log filtering whitelist rule can contain up to 256 characters, and a value can contain up to 128 characters. A key must be unique. Value range: N/A. |
exclude |
Map<String,String> |
Parameter description: A key of a log filtering whitelist rule can contain up to 256 characters, and a value can contain up to 128 characters. A key must be unique. Value range: N/A. |
Status code: 400
Parameter |
Type |
Description |
---|---|---|
error_code |
String |
Parameter description: Error code. Value range: Minimum characters: 8 Maximum characters: 8 |
error_msg |
String |
Parameter description: Error message. Value range: N/A. |
Status code: 500
Parameter |
Type |
Description |
---|---|---|
error_code |
String |
Parameter description: Error code. Value range: Minimum characters: 8 Maximum characters: 8 |
error_msg |
String |
Parameter description: Error message. Value range: N/A. |
Example Requests
Log ingestion configurations are filtered by the request body.
POST https://{endpoint}/v3/{project_id}/lts/access-config-list
{
"access_config_name_list" : [ "Collectionxx2", "22x", "2x", "CollectionWjxxxx" ],
"host_group_name_list" : [ "wwxx" ],
"log_group_name_list" : [ "lts-grxx", "lts-xx", "lts-gxx" ],
"log_stream_name_list" : [ "lts-topixx", "lts-txx" ],
"access_config_tag_list" : [ {
"key" : "xxx",
"value" : "xxx"
}, {
"key" : "xxx1",
"value" : "xxx1"
} ]
}
Example Responses
Status code: 200
The log ingestion list query is successful.
{
"result" : [ {
"access_config_detail" : {
"containerNameRegex" : "my",
"excludeEnvs" : {
"h" : "8"
},
"excludeK8sLabels" : {
"e" : "5"
},
"excludeLabels" : {
"b" : "2"
},
"format" : {
"single" : {
"mode" : "system",
"value" : "1678969382000"
}
},
"includeEnvs" : {
"g" : "7"
},
"includeK8sLabels" : {
"d30" : "4"
},
"includeLabels" : {
"a" : "1"
},
"logEnvs" : {
"i" : "9"
},
"logK8s" : {
"f" : "6"
},
"logLabels" : {
"c" : "3"
},
"namespaceRegex" : "default",
"pathType" : "container_stdout",
"paths" : [ ],
"podNameRegex" : "abc",
"stderr" : false,
"stdout" : true
},
"access_config_id" : "c3152f88-8b06-4f7f-bbbe-129512f49f87",
"access_config_name" : "myapinew322",
"access_config_tag" : [ {
"key" : "my01",
"value" : "001"
}, {
"key" : "my02",
"value" : "002"
} ],
"access_config_type" : "K8S_CCE",
"binary_collect" : false,
"create_time" : 1684467787996,
"host_group_info" : {
"host_group_id_list" : [ "12b0bbd1-4eda-456b-a641-647aa66bdeab" ]
},
"log_info" : {
"log_group_id" : "9575cb24-290c-478e-a5db-88d6d1dc513b",
"log_group_name" : "my-group",
"log_stream_id" : "3581bee9-8698-476e-a0ba-b0f310ed99cf",
"log_stream_name" : "lts-topic-api"
},
"log_split" : false
}, {
"access_config_detail" : {
"containerNameRegex" : "my",
"excludeEnvs" : {
"h" : "8"
},
"excludeK8sLabels" : {
"e" : "5"
},
"excludeLabels" : {
"b" : "2"
},
"format" : {
"single" : {
"mode" : "system",
"value" : "1678969382000"
}
},
"includeEnvs" : {
"g" : "7"
},
"includeK8sLabels" : {
"d10" : "4",
"d" : "4",
"d12" : "4",
"d11" : "4",
"d14" : "4",
"d13" : "4",
"d16" : "4",
"d15" : "4",
"d18" : "4",
"d17" : "4",
"d1" : "4",
"d2" : "4",
"d3" : "4",
"d4" : "4",
"d5" : "4",
"d6" : "4",
"d7" : "4",
"d8" : "4",
"d9" : "4"
},
"includeLabels" : {
"a" : "1"
},
"logEnvs" : {
"i" : "9"
},
"logK8s" : {
"f" : "6"
},
"logLabels" : {
"c" : "3"
},
"namespaceRegex" : "default",
"pathType" : "container_stdout",
"paths" : [ ],
"podNameRegex" : "abc",
"stderr" : false,
"stdout" : true
},
"access_config_id" : "550cd738-7b16-4724-9c59-aba61bf16528",
"access_config_name" : "myapinew32",
"access_config_tag" : [ {
"key" : "my01",
"value" : "001"
}, {
"key" : "my02",
"value" : "002"
} ],
"access_config_type" : "K8S_CCE",
"binary_collect" : false,
"create_time" : 1684463134956,
"host_group_info" : {
"host_group_id_list" : [ "12b0bbd1-4eda-456b-a641-647aa66bdeab" ]
},
"log_info" : {
"log_group_id" : "9575cb24-290c-478e-a5db-88d6d1dc513b",
"log_group_name" : "my-group",
"log_stream_id" : "3581bee9-8698-476e-a0ba-b0f310ed99cf",
"log_stream_name" : "lts-topic-api"
},
"log_split" : false
} ],
"total" : 2
}
Status code: 400
Invalid request. Modify the request based on the description in error_msg before a retry.
{
"error_code" : "LTS.1807",
"error_msg" : "Invalid access config name"
}
Status code: 500
The server has received the request but encountered an internal error.
{
"error_code" : "LTS.0010",
"error_msg" : "The system encountered an internal error"
}
SDK Sample Code
The SDK sample code is as follows.
Log ingestion configurations are filtered by the request body.
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 68 69 70 71 72 73 74 75 76 77 78 79 80 81 |
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 ListAccessConfigSolution {
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");
String projectId = "{project_id}";
ICredential auth = new BasicCredentials()
.withProjectId(projectId)
.withAk(ak)
.withSk(sk);
LtsClient client = LtsClient.newBuilder()
.withCredential(auth)
.withRegion(LtsRegion.valueOf("<YOUR REGION>"))
.build();
ListAccessConfigRequest request = new ListAccessConfigRequest();
GetAccessConfigListRequestBody body = new GetAccessConfigListRequestBody();
List<AccessConfigTag> listbodyAccessConfigTagList = new ArrayList<>();
listbodyAccessConfigTagList.add(
new AccessConfigTag()
.withKey("xxx")
.withValue("xxx")
);
listbodyAccessConfigTagList.add(
new AccessConfigTag()
.withKey("xxx1")
.withValue("xxx1")
);
List<String> listbodyLogStreamNameList = new ArrayList<>();
listbodyLogStreamNameList.add("lts-topixx");
listbodyLogStreamNameList.add("lts-txx");
List<String> listbodyLogGroupNameList = new ArrayList<>();
listbodyLogGroupNameList.add("lts-grxx");
listbodyLogGroupNameList.add("lts-xx");
listbodyLogGroupNameList.add("lts-gxx");
List<String> listbodyHostGroupNameList = new ArrayList<>();
listbodyHostGroupNameList.add("wwxx");
List<String> listbodyAccessConfigNameList = new ArrayList<>();
listbodyAccessConfigNameList.add("Collectionxx2");
listbodyAccessConfigNameList.add("22x");
listbodyAccessConfigNameList.add("2x");
listbodyAccessConfigNameList.add("CollectionWjxxxx");
body.withAccessConfigTagList(listbodyAccessConfigTagList);
body.withLogStreamNameList(listbodyLogStreamNameList);
body.withLogGroupNameList(listbodyLogGroupNameList);
body.withHostGroupNameList(listbodyHostGroupNameList);
body.withAccessConfigNameList(listbodyAccessConfigNameList);
request.withBody(body);
try {
ListAccessConfigResponse response = client.listAccessConfig(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());
}
}
}
|
Log ingestion configurations are filtered by the request body.
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 |
# 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"]
projectId = "{project_id}"
credentials = BasicCredentials(ak, sk, projectId)
client = LtsClient.new_builder() \
.with_credentials(credentials) \
.with_region(LtsRegion.value_of("<YOUR REGION>")) \
.build()
try:
request = ListAccessConfigRequest()
listAccessConfigTagListbody = [
AccessConfigTag(
key="xxx",
value="xxx"
),
AccessConfigTag(
key="xxx1",
value="xxx1"
)
]
listLogStreamNameListbody = [
"lts-topixx",
"lts-txx"
]
listLogGroupNameListbody = [
"lts-grxx",
"lts-xx",
"lts-gxx"
]
listHostGroupNameListbody = [
"wwxx"
]
listAccessConfigNameListbody = [
"Collectionxx2",
"22x",
"2x",
"CollectionWjxxxx"
]
request.body = GetAccessConfigListRequestBody(
access_config_tag_list=listAccessConfigTagListbody,
log_stream_name_list=listLogStreamNameListbody,
log_group_name_list=listLogGroupNameListbody,
host_group_name_list=listHostGroupNameListbody,
access_config_name_list=listAccessConfigNameListbody
)
response = client.list_access_config(request)
print(response)
except exceptions.ClientRequestException as e:
print(e.status_code)
print(e.request_id)
print(e.error_code)
print(e.error_msg)
|
Log ingestion configurations are filtered by the request body.
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 68 69 70 71 72 73 74 75 76 |
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")
projectId := "{project_id}"
auth := basic.NewCredentialsBuilder().
WithAk(ak).
WithSk(sk).
WithProjectId(projectId).
Build()
client := lts.NewLtsClient(
lts.LtsClientBuilder().
WithRegion(region.ValueOf("<YOUR REGION>")).
WithCredential(auth).
Build())
request := &model.ListAccessConfigRequest{}
keyAccessConfigTagList:= "xxx"
valueAccessConfigTagList:= "xxx"
keyAccessConfigTagList1:= "xxx1"
valueAccessConfigTagList1:= "xxx1"
var listAccessConfigTagListbody = []model.AccessConfigTag{
{
Key: &keyAccessConfigTagList,
Value: &valueAccessConfigTagList,
},
{
Key: &keyAccessConfigTagList1,
Value: &valueAccessConfigTagList1,
},
}
var listLogStreamNameListbody = []string{
"lts-topixx",
"lts-txx",
}
var listLogGroupNameListbody = []string{
"lts-grxx",
"lts-xx",
"lts-gxx",
}
var listHostGroupNameListbody = []string{
"wwxx",
}
var listAccessConfigNameListbody = []string{
"Collectionxx2",
"22x",
"2x",
"CollectionWjxxxx",
}
request.Body = &model.GetAccessConfigListRequestBody{
AccessConfigTagList: &listAccessConfigTagListbody,
LogStreamNameList: &listLogStreamNameListbody,
LogGroupNameList: &listLogGroupNameListbody,
HostGroupNameList: &listHostGroupNameListbody,
AccessConfigNameList: &listAccessConfigNameListbody,
}
response, err := client.ListAccessConfig(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.
Log ingestion configurations are filtered by the request body.
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 68 69 70 71 72 73 74 75 76 77 78 79 80 81 |
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 ListAccessConfigSolution {
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");
String projectId = "{project_id}";
ICredential auth = new BasicCredentials()
.withProjectId(projectId)
.withAk(ak)
.withSk(sk);
LtsClient client = LtsClient.newBuilder()
.withCredential(auth)
.withRegion(LtsRegion.valueOf("<YOUR REGION>"))
.build();
ListAccessConfigRequest request = new ListAccessConfigRequest();
GetAccessConfigListRequestBody body = new GetAccessConfigListRequestBody();
List<AccessConfigTag> listbodyAccessConfigTagList = new ArrayList<>();
listbodyAccessConfigTagList.add(
new AccessConfigTag()
.withKey("xxx")
.withValue("xxx")
);
listbodyAccessConfigTagList.add(
new AccessConfigTag()
.withKey("xxx1")
.withValue("xxx1")
);
List<String> listbodyLogStreamNameList = new ArrayList<>();
listbodyLogStreamNameList.add("lts-topixx");
listbodyLogStreamNameList.add("lts-txx");
List<String> listbodyLogGroupNameList = new ArrayList<>();
listbodyLogGroupNameList.add("lts-grxx");
listbodyLogGroupNameList.add("lts-xx");
listbodyLogGroupNameList.add("lts-gxx");
List<String> listbodyHostGroupNameList = new ArrayList<>();
listbodyHostGroupNameList.add("wwxx");
List<String> listbodyAccessConfigNameList = new ArrayList<>();
listbodyAccessConfigNameList.add("Collectionxx2");
listbodyAccessConfigNameList.add("22x");
listbodyAccessConfigNameList.add("2x");
listbodyAccessConfigNameList.add("CollectionWjxxxx");
body.withAccessConfigTagList(listbodyAccessConfigTagList);
body.withLogStreamNameList(listbodyLogStreamNameList);
body.withLogGroupNameList(listbodyLogGroupNameList);
body.withHostGroupNameList(listbodyHostGroupNameList);
body.withAccessConfigNameList(listbodyAccessConfigNameList);
request.withBody(body);
try {
ListAccessConfigResponse response = client.listAccessConfig(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());
}
}
}
|
Log ingestion configurations are filtered by the request body.
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 |
# 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"]
projectId = "{project_id}"
credentials = BasicCredentials(ak, sk, projectId)
client = LtsClient.new_builder() \
.with_credentials(credentials) \
.with_region(LtsRegion.value_of("<YOUR REGION>")) \
.build()
try:
request = ListAccessConfigRequest()
listAccessConfigTagListbody = [
AccessConfigTag(
key="xxx",
value="xxx"
),
AccessConfigTag(
key="xxx1",
value="xxx1"
)
]
listLogStreamNameListbody = [
"lts-topixx",
"lts-txx"
]
listLogGroupNameListbody = [
"lts-grxx",
"lts-xx",
"lts-gxx"
]
listHostGroupNameListbody = [
"wwxx"
]
listAccessConfigNameListbody = [
"Collectionxx2",
"22x",
"2x",
"CollectionWjxxxx"
]
request.body = GetAccessConfigListRequestBody(
access_config_tag_list=listAccessConfigTagListbody,
log_stream_name_list=listLogStreamNameListbody,
log_group_name_list=listLogGroupNameListbody,
host_group_name_list=listHostGroupNameListbody,
access_config_name_list=listAccessConfigNameListbody
)
response = client.list_access_config(request)
print(response)
except exceptions.ClientRequestException as e:
print(e.status_code)
print(e.request_id)
print(e.error_code)
print(e.error_msg)
|
Log ingestion configurations are filtered by the request body.
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 68 69 70 71 72 73 74 75 76 |
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")
projectId := "{project_id}"
auth := basic.NewCredentialsBuilder().
WithAk(ak).
WithSk(sk).
WithProjectId(projectId).
Build()
client := lts.NewLtsClient(
lts.LtsClientBuilder().
WithRegion(region.ValueOf("<YOUR REGION>")).
WithCredential(auth).
Build())
request := &model.ListAccessConfigRequest{}
keyAccessConfigTagList:= "xxx"
valueAccessConfigTagList:= "xxx"
keyAccessConfigTagList1:= "xxx1"
valueAccessConfigTagList1:= "xxx1"
var listAccessConfigTagListbody = []model.AccessConfigTag{
{
Key: &keyAccessConfigTagList,
Value: &valueAccessConfigTagList,
},
{
Key: &keyAccessConfigTagList1,
Value: &valueAccessConfigTagList1,
},
}
var listLogStreamNameListbody = []string{
"lts-topixx",
"lts-txx",
}
var listLogGroupNameListbody = []string{
"lts-grxx",
"lts-xx",
"lts-gxx",
}
var listHostGroupNameListbody = []string{
"wwxx",
}
var listAccessConfigNameListbody = []string{
"Collectionxx2",
"22x",
"2x",
"CollectionWjxxxx",
}
request.Body = &model.GetAccessConfigListRequestBody{
AccessConfigTagList: &listAccessConfigTagListbody,
LogStreamNameList: &listLogStreamNameListbody,
LogGroupNameList: &listLogGroupNameListbody,
HostGroupNameList: &listHostGroupNameListbody,
AccessConfigNameList: &listAccessConfigNameListbody,
}
response, err := client.ListAccessConfig(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 log ingestion list query is successful. |
400 |
Invalid request. Modify the request based on the description in error_msg before a retry. |
500 |
The server has received the request but encountered an internal error. |
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