-
Notifications
You must be signed in to change notification settings - Fork 1
Internal Plugins
Internally the following plugins have been implemented:
-
/proc/net/dev(all network interfaces for all their values) -
/proc/diskstats(all disks for all their values) -
/proc/net/snmp(total IPv4, TCP and UDP usage) -
/proc/net/snmp6(total IPv6 usage) -
/proc/net/netstat(more IPv4 usage) -
/proc/net/stat/nf_conntrack(connection tracking performance) -
/proc/net/stat/synproxy(synproxy performance) -
/proc/net/ip_vs/stats(IPVS connection statistics) -
/proc/stat(CPU utilization) -
/proc/meminfo(memory information) -
/proc/vmstat(system performance) -
/proc/net/rpc/nfsd(NFS server statistics for both v3 and v4 NFS servers) -
/sys/fs/cgroup(Control Groups - Linux Containers) -
/proc/self/mountinfo(mount points) -
/proc/interrupts(total and per core hardware interrupts) -
/proc/softirqs(total and per core software interrupts) -
/proc/loadavg(system load and total processes running) -
/proc/sys/kernel/random/entropy_avail(random numbers pool availability - used in cryptography) -
ksmKernel Same-Page Merging performance (several files under/sys/kernel/mm/ksm). -
netdata(internal netdata resources utilization)
In case this page is left behind in updates, the source code for runs these internal plugins is here.
Netdata monitors tc QoS classes for all interfaces.
If you also use FireQOS) it will collect interface and class names.
There is a shell helper for this (all parsing is done by the plugin in C code - this shell script is just a configuration for the command to run to get tc output).
The source of the tc plugin is here. It is somewhat complex, because a state machine was needed to keep track of all the tc classes, including the pseudo classes tc dynamically creates.
There is also a plugin that collects NFACCT statistics. This plugin is currently disabled by default, because it requires root access. I have to move the code to an external plugin to setuid just the plugin not the whole netdata server.
You can build netdata with it to test it though. Just run ./configure with the option --enable-plugin-nfacct (and any other options you may need). Remember, you have to tell netdata you want it to run as root for this plugin to work.
Idle jitter is calculated by netdata. It works like this:
A thread is spawned that requests to sleep for a few microseconds. When the system wakes it up, it measures how many microseconds have passed. The difference between the requested and the actual duration of the sleep, is the idle jitter.
This number is useful in real-time environments, where CPU jitter can affect the quality of the service (like VoIP media gateways).
The source code is here.
General
- Home
- Why netdata
- Installation
- Installation with docker
- Command Line Options
- Configuration
- Log Files
- Tracing Options
Running Netdata
Special Uses
-
netdata for IoT
lower netdata resource utilization -
high performance netdata
netdata public on the internet
Notes on memory management
-
Memory deduplication
half netdata memory requirements - netdata virtual memory size
Database Replication and Mirroring
- Replication Overview
-
monitoring ephemeral nodes
Use netdata to monitor auto-scaled cloud servers. -
netdata proxies
Streaming netdata metrics between netdata servers.
Backends
archiving netdata collected metrics to a time-series database
-
netdata-backends
graphite,opentsdb,kairosdb,influxdb,elasticsearch,blueflood - netdata with prometheus
- Walk Through: netdata with prometheus and grafana
Health monitoring - Alarms
alarms and alarm notifications in netdata
- Overview
-
Reference
reference for writing alarms -
Examples
simple how-to for writing alarms -
Notifications Configuration
- health API calls
- troubleshooting alarms
Netdata Registry
Monitoring Info
-
Monitoring web servers
The spectacles of a web server log file -
monitoring ephemeral containers
Use netdata to monitor auto-scaled containers. - monitoring systemd services
-
monitoring cgroups
Use netdata to monitor containers and virtual machines. -
monitoring IPMI
Use netdata to monitor enterprise server hardware - Monitoring disks
- Monitoring Go Applications
Netdata Badges
Data Collection
- Add more charts to netdata
- Internal Plugins
- External Plugins
-
statsd
netdata is a fully featured statsd server -
Third Party Plugins
netdata plugins distributed by third parties
Binary Modules
Python Modules
- How to write new module
- apache
- beanstalk
- bind_rndc
- ceph
- couchdb
- cpuidle
- cpufreq
- dns_query_time
- dovecot
- elasticsearch
- exim
- fail2ban
- freeradius
- go_expvar
- haproxy
- hddtemp
- httpcheck
- icecast
- ipfs
- isc_dhcpd
- litespeed
- mdstat
- megacli
- memcached
- mongodb
- mysql
- nginx
- nginx_plus
- nsd
- ntpd
- ovpn_status_log
- phpfpm
- portcheck
- postfix
- postgres
- powerdns
- puppet
- rabbitmq
- redis
- rethinkdbs
- retroshare
- sensors
- spigotmc
- springboot
- squid
- smartd_log
- tomcat
- traefik
- unbound
- varnish
- w1sensor
- web_log
Node.js Modules
BASH Modules
Active BASH Modules
Obsolete BASH Modules
- apache
- cpufreq
- cpu_apps
- exim
- hddtemp
- load_average
- mem_apps
- mysql
- nginx
- phpfpm
- postfix
- sensors
- squid
- tomcat
API Documentation
Web Dashboards
-
Learn how to create dashboards with charts from one or more netdata servers!
Running behind another web server
Package Maintainers
Donations
Blog
-
December, 2016
Linux console tools, fail to report per process CPU usage properly
-
April, 2016
You should install QoS on all your servers (Linux QoS for humans)
Monitor application bandwidth with Linux QoS (Good to do it, anyway)
Monitoring SYNPROXY (Linux TCP Anti-DDoS)
-
March, 2016
Article: Introducing netdata (the design principles of netdata)