Enroll agents
After installing and connecting an NXLog Agent instance to NXLog Platform, you must enroll it before you can monitor and configure it from NXLog Platform. For more information, see Enroll an agent and Agent deployment state in the NXLog Platform User Guide.
Prerequisites
-
A machine with NXLog Agent installed and connected to NXLog Platform.
-
Your NXLog Platform organization ID.
-
An NXLog Platform API Personal Access Token (PAT).
About the enroll command
Calling the agents
endpoint with the enroll
command enrolls an agent to NXLog Platform.
The command requires an Enrollment
object specifying one of the following:
-
The connection mode (
connect
orlisten
) and NXLog Platform agent management URL and port.$ curl --verbose --request POST \ --url "https://agents.example.com/api/{ORG_ID}/api/v1/agents/*/enroll/?filter=({QUERY})" \ --header "Authorization: Bearer {TOKEN}" \ --header "Content-Type: application/json" \ --header "Accept: */*" \ --data '{"connection": {"mode": "connect", "address": "{AGENTS_URL}"}}'
-
A configuration template UUID.
$ curl --verbose --request POST \ --url "https://agents.example.com/api/{ORG_ID}/api/v1/agents/*/enroll/?filter=({QUERY})" \ --header "Authorization: Bearer {TOKEN}" \ --header "Content-Type: application/json" \ --header "Accept: */*" \ --data '{"templateId": "{TEMPLATE_UUID}"}'
If matching agents exist, the command returns 200 OK
with the following JSON body.
Otherwise, it returns an empty JSON array.
[
{
"id": "{AGENT_UUID}",
"status": "success"
}
]
Enrolling an agent that is already enrolled overwrites its configuration. |
Enroll new agents
When you install and connect an agent to NXLog Platform, it is registered as a new agent.
You can only start and stop the agent and view its logs at this stage.
This example enrolls all new agents so that NXLog Platform starts collecting metrics from them.
It specifies an Enrollment
object with the connection mode and the NXLog Platform agent management URL.
Alternatively, see Enroll and configure an agent below to enroll and configure agents simultaneously.
POST /agents/*/enroll/?filter=(enrolled=false) | |
---|---|
Entity type |
|
Entity UUID |
|
Command |
|
Filter |
|
Request body |
|
Try it
Execute the following curl command or Python script to enroll all new agents.
curl
$ curl --verbose --request POST \
--url "https://agents.example.com/api/{ORG_ID}/api/v1/agents/*/enroll/?filter=(enrolled=false)" \(1)
--header "Authorization: Bearer {TOKEN}" \(2)
--header "Content-Type: application/json" \
--header "Accept: */*" \
--data '{"connection": {"mode": "connect", "address": "agents.example.com:5515"}}' (3)
1 | Replace example.com with the NXLog Platform domain you specified when installing NXLog Platform and {ORG_ID} with your organization ID. |
2 | Replace {TOKEN} with your API token.
See Generating a token for instructions. |
3 | Replace the address with your agent management URL and port. |
Python
'''
Requires Python 3.x
'''
import requests
import json
api_token = '<API_TOKEN>' (1)
base_url = 'https://agents.<DOMAIN>/api' (2)
org = '<ORG_ID>' (3)
agents_url = '<AGENTS_URL>' (4)
endpoint = 'api/v1/agents'
url = '{}/{}/{}'.format(base_url, org, endpoint)
headers = {
'Authorization': 'Bearer {}'.format(api_token),
'Content-Type': 'application/json',
'Accept': '*/*'
}
query = '*/enroll/?filter=(enrolled=false)'
payload = {'connection': {'mode': 'connect', 'address': agents_url}}
r = requests.post('{}/{}'.format(url, query), headers=headers, data=json.dumps(payload))
if r.status_code == 200:
print('Status: {} {}'.format(r.status_code, r.reason))
print(json.dumps(r.json(), indent=2))
else:
print('Error: {} {}'.format(r.status_code, r.text))
1 | Replace {TOKEN} with your API token.
See Generating a token for instructions. |
2 | Replace <DOMAIN> with the NXLog Platform domain you specified when installing NXLog Platform. |
3 | Replace <ORG_ID> with your organization ID. |
4 | Replace <AGENTS_URL> with your agent management URL and port.
It is typically agents.example.com:5515 . |
Example response
Status: 200
[
{
"id": "1589a98a-66b3-11ee-80d5-4f584c6f672d",
"status": "success"
},
{
"id": "94fbcd8e-484c-11ef-8000-656536087e74",
"status": "success"
}
]
Enroll an agent by hostname
If you’ve just installed and connected an agent to NXLog Platform and want to enroll it, the easiest way is to filter by hostname.
This example enrolls an agent to NXLog Platform by its hostname.
It specifies an Enrollment
object with the connection mode and the NXLog Platform agent management URL.
Once enrolled, NXLog Platform starts collecting metrics from the agent.
Alternatively, see Enroll and configure an agent below to simultaneously enroll and configure an agent.
The hostname is case-sensitive. |
POST /agents/*/enroll/?filter=(hostname=PC1 AND enrolled=false) | |
---|---|
Entity type |
|
Entity UUID |
|
Command |
|
Filter |
|
Request body |
|
Try it
Execute the following curl command or Python script to enroll an agent by its hostname.
curl
$ curl --verbose --request POST \
--url "https://agents.example.com/api/{ORG_ID}/api/v1/agents/*/enroll/?filter=(hostname=PC1 AND enrolled=false)" \(1)
--header "Authorization: Bearer {TOKEN}" \(2)
--header "Content-Type: application/json" \
--header "Accept: */*" \
--data '{"connection": {"mode": "connect", "address": "agents.example.com:5515"}}' (3)
1 | Replace example.com with the NXLog Platform domain you specified when installing NXLog Platform and {ORG_ID} with your organization ID. |
2 | Replace {TOKEN} with your API token.
See Generating a token for instructions. |
3 | Replace the address with your agent management URL and port. |
Python
'''
Requires Python 3.x
'''
import requests
import json
# Set these variables for your environment
api_token = '<API_TOKEN>' (1)
base_url = 'https://agents.<DOMAIN>/api' (2)
org = '<ORG_ID>' (3)
agent = '<HOSTNAME>' (4)
agents_url = '<AGENTS_URL>' (5)
endpoint = 'api/v1/agents'
url = '{}/{}/{}'.format(base_url, org, endpoint)
headers = {
'Authorization': 'Bearer {}'.format(api_token),
'Content-Type': 'application/json',
'Accept': '*/*'
}
query = '*/enroll/?filter=(hostname={} AND enrolled=false)'.format(agent)
payload = {'connection': {'mode': 'connect', 'address': agents_url}}
r = requests.post('{}/{}'.format(url, query), headers=headers, data=json.dumps(payload))
if r.status_code == 200:
print('Status: {} {}'.format(r.status_code, r.reason))
print(json.dumps(r.json(), indent=2))
else:
print('Error: {} {}'.format(r.status_code, r.text))
1 | Replace {TOKEN} with your API token.
See Generating a token for instructions. |
2 | Replace <DOMAIN> with the NXLog Platform domain you specified when installing NXLog Platform. |
3 | Replace <ORG_ID> with your organization ID. |
4 | Replace <HOSTNAME> with the hostname of the agent you want to enroll. |
5 | Replace <AGENTS_URL> with your agent management URL and port.
It is typically agents.example.com:5515 . |
Example response
Status: 200
[
{
"id": "94fbcd8e-484c-11ef-8000-656536087e74",
"status": "success"
}
]
Enroll and configure agents
You can simultaneously enroll and configure an agent by assigning it a configuration template. To do so, you need the template UUID. This example enrolls all new agents and assigns them a template called New agents. Alternatively, see Enroll an agent by hostname above to enroll a single agent.
GET /templates/*/id?filter=(name LIKE 'New agents') | |
---|---|
Entity type |
|
Entity UUID |
|
Field |
|
Filter |
|
You can also get the template UUID from the NXLog Platform UI by opening the template from the Configurations Overview and copying the last part of the URL. |
POST /agents/*/enroll/?filter=(enrolled=false) | |
---|---|
Entity type |
|
Entity UUID |
|
Data path |
|
Filter |
|
Request body |
|
Try it
Execute the following curl commands or Python script to enroll and configure agents.
curl
- Get the configuration template UUID
-
$ curl --verbose --request GET \ --url "https://agents.example.com/api/{ORG_ID}/api/v1/templates/*/id?filter=(name%20LIKE%20'New%20agents')" \(1) --header "Authorization: Bearer {TOKEN}" (2)
1 Replace example.com
with the NXLog Platform domain you specified when installing NXLog Platform and{ORG_ID}
with your organization ID.2 Replace {TOKEN}
with your API token. See Generating a token for instructions. - Enroll and configure the agents
-
$ curl --verbose --request POST \ --url "https://agents.example.com/api/{ORG_ID}/api/v1/agents/*/enroll/?filter=(enrolled=false)" \(1) --header "Authorization: Bearer {TOKEN}" \(2) --header "Content-Type: application/json" \ --header "Accept: */*" \ --data '{"templateId": "ef5b6794-4dbf-11ef-8000-aa8b17d1ce7b"}' (3)
1 Replace example.com
with the NXLog Platform domain you specified when installing NXLog Platform and{ORG_ID}
with your organization ID.2 Replace {TOKEN}
with your API token. See Generating a token for instructions.3 Replace the template UUID with the one you retrieved above.
Python
'''
Requires Python 3.x
'''
import requests
import json
api_token = '<API_TOKEN>' (1)
base_url = 'https://agents.<DOMAIN>/api' (2)
org = '<ORG_ID>' (3)
template_name = '<TEMPLATE_NAME>' (4)
endpoint = 'api/v1/templates'
url = '{}/{}/{}'.format(base_url, org, endpoint)
headers = {'Authorization': 'Bearer {}'.format(api_token)}
query = '*/id?filter=(name LIKE "{}")'.format(template_name)
r = requests.get('{}/{}'.format(url, query), headers=headers, verify=False)
if r.status_code == 200:
template_uuid = r.json()[0]
endpoint = 'api/v1/agents'
url = '{}/{}/{}'.format(base_url, org, endpoint)
headers['Content-Type'] = 'application/json'
query = '*/enroll/?filter=(enrolled=false)'
payload = {"templateId": template_uuid}
r = requests.post('{}/{}'.format(url, query), headers=headers, data=json.dumps(payload), verify=False)
if r.status_code == 200:
print('Status: {} {}'.format(r.status_code, r.reason))
print(json.dumps(r.json(), indent=2))
else:
print('Error: {} {}'.format(r.status_code, r.text))
1 | Replace {TOKEN} with your API token.
See Generating a token for instructions. |
2 | Replace <DOMAIN> with the NXLog Platform domain you specified when installing NXLog Platform. |
3 | Replace <ORG_ID> with your organization ID. |
4 | Replace <TEMPLATE_NAME> with your configuration template name. |
Example response
Status: 200
[
{
"id": "1589a98a-66b3-11ee-80d5-4f584c6f672d",
"status": "success"
},
{
"id": "94fbcd8e-484c-11ef-8000-656536087e74",
"status": "success"
}
]