Getting Dynamic Configuration List
The dynamicConfigs() GraphQL query allows users to retrieve a comprehensive list of dynamic configuration settings in key-value pair format. The query can be executed using various programming languages including curl, Perl, Python, and Node.js, with the available configuration parameters varying based on version, feature flags, and environment settings.
To obtain a list of all the available dynamic configurations, use the dynamicConfigs() GraphQL query.
query {
dynamicConfigs {
dynamicConfigKey,dynamicConfigValue
}
}
curl -v -X POST $YOUR_LOGSCALE_URL/graphql \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d @- << EOF
{"query" : "query {
dynamicConfigs {
dynamicConfigKey,dynamicConfigValue
}
}"
}
EOF
curl -v -X POST $YOUR_LOGSCALE_URL/graphql \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d @- << EOF
{"query" : "query {
dynamicConfigs {
dynamicConfigKey,dynamicConfigValue
}
}"
}
EOF
curl -v -X POST $YOUR_LOGSCALE_URL/graphql ^
-H "Authorization: Bearer $TOKEN" ^
-H "Content-Type: application/json" ^
-d @'{"query" : "query { ^
dynamicConfigs { ^
dynamicConfigKey,dynamicConfigValue ^
} ^
}" ^
} '
curl.exe -X POST
-H "Authorization: Bearer $TOKEN"
-H "Content-Type: application/json"
-d '{"query" : "query {
dynamicConfigs {
dynamicConfigKey,dynamicConfigValue
}
}"
}'
"$YOUR_LOGSCALE_URL/graphql"
#!/usr/bin/perl
use HTTP::Request;
use LWP;
my $INGEST_TOKEN = "TOKEN";
my $uri = '$YOUR_LOGSCALE_URL/graphql';
my $json = '{"query" : "query {
dynamicConfigs {
dynamicConfigKey,dynamicConfigValue
}
}"
}';
my $req = HTTP::Request->new("POST", $uri );
$req->header("Authorization" => "Bearer $TOKEN");
$req->header("Content-Type" => "application/json");
$req->content( $json );
my $lwp = LWP::UserAgent->new;
my $result = $lwp->request( $req );
print $result->{"_content"},"\n";
#! /usr/local/bin/python3
import requests
url = '$YOUR_LOGSCALE_URL/graphql'
mydata = r'''{"query" : "query {
dynamicConfigs {
dynamicConfigKey,dynamicConfigValue
}
}"
}'''
resp = requests.post(url,
data = mydata,
headers = {
"Authorization" : "Bearer $TOKEN",
"Content-Type" : "application/json"
}
)
print(resp.text)
const https = require('https');
const data = JSON.stringify(
{"query" : "query {
dynamicConfigs {
dynamicConfigKey,dynamicConfigValue
}
}"
}
);
const options = {
hostname: '$YOUR_LOGSCALE_URL/graphql',
path: '/graphql',
port: 443,
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Content-Length': data.length,
Authorization: 'BEARER ' + process.env.TOKEN,
'User-Agent': 'Node',
},
};
const req = https.request(options, (res) => {
let data = '';
console.log(`statusCode: ${res.statusCode}`);
res.on('data', (d) => {
data += d;
});
res.on('end', () => {
console.log(JSON.parse(data).data);
});
});
req.on('error', (error) => {
console.error(error);
});
req.write(data);
req.end();
This will return a list of key/value pairs for the configuration key and current setting. For example:
{
"data": {
"dynamicConfigs": [
{
"dynamicConfigKey": "MaxIngestRequestSize",
"dynamicConfigValue": "None"
},
{
"dynamicConfigKey": "JoinRowLimit",
"dynamicConfigValue": "200000"
},
{
"dynamicConfigKey": "JoinDefaultLimit",
"dynamicConfigValue": "100000"
},
...
]
}
}
The exact list of configurable parameters available will depend on the version, feature flags and environment.