Container Deployment #
INFINI Agent supports container deployment.
Download Image #
The images of INFINI Agent are published at the official repository of Docker. The URL is as follows: https://hub.docker.com/r/infinilabs/agent
Run the following command:
docker pull infinilabs/agent:1.27.0-1936
Verifying the Image #
After downloading the image locally, you will notice that the container image of INFINI Agent is very small, with a size less than 25 MB. So, the downloading is very fast.
✗ docker images |grep "agent" |grep "1.27.0-1936"
REPOSITORY TAG IMAGE ID CREATED SIZE
infinilabs/agent 1.27.0-1936 c7bd9ad063d9 4 days ago 13.8MB
Configuration #
Create a configuration file agent.yml
to perform basic configuration as follows:
api:
enabled: true
network:
binding: 0.0.0.0:8080
metrics:
enabled: true
queue: metrics
network:
enabled: true
summary: true
details: true
memory:
metrics:
- swap
- memory
disk:
metrics:
- ioqs
- usage
cpu:
metrics:
- idle
- system
- user
- iowait
- load
elasticsearch:
enabled: true
agent_mode: true
node_stats: true
index_stats: true
cluster_stats: true
elasticsearch:
- name: default
enabled: true
endpoint: http://192.168.3.4:9200
monitored: false
discovery:
enabled: true
pipeline:
- name: metrics_ingest
auto_start: true
keep_running: true
processor:
- json_indexing:
index_name: ".infini_metrics"
elasticsearch: "default"
input_queue: "metrics"
output_queue:
name: "metrics_requests"
label:
tag: "metrics"
worker_size: 1
bulk_size_in_mb: 10
- name: consume-metrics_requests
auto_start: true
keep_running: true
processor:
- bulk_indexing:
bulk:
compress: true
batch_size_in_mb: 10
batch_size_in_docs: 5000
consumer:
fetch_max_messages: 100
queues:
type: indexing_merge
when:
cluster_available: [ "default" ]
agent:
major_ip_pattern: "192.*"
labels:
env: dev
tags:
- linux
- x86
- es7
- v7.5
path.data: data
path.logs: log
agent.manager.endpoint: http://192.168.3.4:9000
Note: In the above configuration, replace the Elasticsearch configuration with the actual server connection address and authentication information.
Starting #
Run the following command:
docker run -p 8080:8080 -v=`pwd`/agent.yml:/agent.yml infinilabs/agent:1.27.0-1936
Docker Compose #
You can also use docker compose to manage container instances. Create one docker-compose.yml file as follows:
version: "3.5"
services:
infini-agent:
image: infinilabs/agent:1.27.0-1936
ports:
- 8080:8080
container_name: "infini-agent"
volumes:
- ./agent.yml:/agent.yml
volumes:
dist:
Run the following command to start INFINI Agent.
➜ docker-compose up
Recreating infini-agent ... done
Attaching to infini-agent
infini-agent | _ ___ __ __ _____
infini-agent | /_\ / _ \ /__\/\ \ \/__ \
infini-agent | //_\\ / /_\//_\ / \/ / / /\/
infini-agent | / _ \/ /_\\//__/ /\ / / /
infini-agent | \_/ \_/\____/\__/\_\ \/ \/
infini-agent |
infini-agent | [AGENT] A light-weight, powerful and high-performance elasticsearch agent.
infini-agent | [AGENT] 0.1.0_SNAPSHOT#15, 2022-08-26 15:05:43, 2025-12-31 10:10:10, 164bd8a0d74cfd0ba5607352e125d72b46a1079e
infini-agent | [08-31 09:11:45] [INF] [app.go:164] initializing agent.
infini-agent | [08-31 09:11:45] [INF] [app.go:165] using config: /agent.yml.
infini-agent | [08-31 09:11:45] [INF] [instance.go:72] workspace: /data/agent/nodes/cc7ibke5epac7314bf9g
infini-agent | [08-31 09:11:45] [INF] [metrics.go:63] ip:172.18.0.2, host:bd9f43490911, labels:, tags:
infini-agent | [08-31 09:11:45] [INF] [api.go:261] api listen at: http://0.0.0.0:8080
infini-agent | [08-31 09:11:45] [INF] [actions.go:367] elasticsearch [default] is available
infini-agent | [08-31 09:11:45] [INF] [module.go:116] all modules are started
infini-agent | [08-31 09:11:45] [INF] [manage.go:180] register agent to console
infini-agent | [08-31 09:11:45] [INF] [app.go:334] agent is up and running now.