Monitor your servers, containers, and applications, in high-resolution and in real-time! https://www.netdata.cloud/
![]() |
6 лет назад | |
---|---|---|
.github | 6 лет назад | |
.travis | 6 лет назад | |
backends | 6 лет назад | |
build | 6 лет назад | |
collectors | 6 лет назад | |
contrib | 6 лет назад | |
daemon | 6 лет назад | |
database | 6 лет назад | |
diagrams | 6 лет назад | |
docs | 6 лет назад | |
health | 6 лет назад | |
installer | 6 лет назад | |
libnetdata | 6 лет назад | |
makeself | 6 лет назад | |
packaging | 6 лет назад | |
registry | 6 лет назад | |
streaming | 6 лет назад | |
system | 6 лет назад | |
tests | 6 лет назад | |
web | 6 лет назад | |
.codacy.yml | 6 лет назад | |
.codeclimate.yml | 6 лет назад | |
.csslintrc | 8 лет назад | |
.eslintignore | 8 лет назад | |
.eslintrc | 8 лет назад | |
.gitignore | 6 лет назад | |
.lgtm.yml | 6 лет назад | |
.travis.yml | 6 лет назад | |
CHANGELOG.md | 6 лет назад | |
CMakeLists.txt | 6 лет назад | |
CODE_OF_CONDUCT.md | 6 лет назад | |
CONTRIBUTING.md | 6 лет назад | |
CONTRIBUTORS.md | 6 лет назад | |
HISTORICAL_CHANGELOG.md | 6 лет назад | |
LICENSE | 6 лет назад | |
Makefile.am | 6 лет назад | |
README.md | 6 лет назад | |
REDISTRIBUTED.md | 6 лет назад | |
configs.signatures | 6 лет назад | |
configure.ac | 6 лет назад | |
coverity-scan.sh | 6 лет назад | |
cppcheck.sh | 6 лет назад | |
kickstart-static64.sh | 6 лет назад | |
kickstart.sh | 6 лет назад | |
netdata-installer.sh | 6 лет назад | |
netdata.cppcheck | 6 лет назад | |
netdata.spec.in | 6 лет назад | |
netlify.toml | 6 лет назад | |
package.json | 7 лет назад |
Netdata is distributed, real-time, performance and health monitoring for systems and applications. It is a highly optimized monitoring agent you install on all your systems and containers.
Netdata provides unparalleled insights, in real-time, of everything happening on the systems it runs (including web servers, databases, applications), using highly interactive web dashboards. It can run autonomously, without any third party components, or it can be integrated to existing monitoring tool chains (Prometheus, Graphite, OpenTSDB, Kafka, Grafana, etc).
Netdata is fast and efficient, designed to permanently run on all systems (physical & virtual servers, containers, IoT devices), without disrupting their core function.
Netdata is free, open-source software and it currently runs on Linux, FreeBSD, and MacOS.
Netdata is in the Cloud Native Computing Foundation (CNCF) landscape. Check the CNCF TOC Netdata presentation.
People get addicted to netdata.
Once you use it on your systems, there is no going back! You have been warned...
The following animated image, shows the top part of a typical netdata dashboard.
*A typical netdata dashboard, in 1:1 timing. Charts can be panned by dragging them, zoomed in/out with SHIFT
+ mouse wheel
, an area can be selected for zoom-in with SHIFT
+ mouse selection
. Netdata is highly interactive and real-time, optimized to get the work done!*
We have a few online demos to experience it live: https://my-netdata.io
Netdata is used by hundreds of thousands of users all over the world. Check our GitHub watchers list. You will find people working for Amazon, Atos, Baidu, Cisco Systems, Citrix, Deutsche Telekom, DigitalOcean, Elastic, EPAM Systems, Ericsson, Google, Groupon, Hortonworks, HP, Huawei, IBM, Microsoft, NewRelic, Nvidia, Red Hat, SAP, Selectel, TicketMaster, Vimeo, and many more!
We provide docker images for the most common architectures. These are statistics reported by docker hub:
When you install multiple netdata, they are integrated into one distributed application, via a netdata registry. This is a web browser feature and it allows us to count the number of unique users and unique netdata servers installed. The following information comes from the global public netdata registry we run:
You can quickly install netdata on a Linux box (physical, virtual, container, IoT) with the following command:
# make sure you run `bash` for your shell
bash
# install netdata, directly from github sources
bash <(curl -Ss https://my-netdata.io/kickstart.sh)
The above command will:
/usr/src/netdata.git
More installation methods and additional options can be found at the installation page.
To try netdata in a docker container, run this:
docker run -d --name=netdata \
-p 19999:19999 \
-v /proc:/host/proc:ro \
-v /sys:/host/sys:ro \
-v /var/run/docker.sock:/var/run/docker.sock:ro \
--cap-add SYS_PTRACE \
--security-opt apparmor=unconfined \
netdata/netdata
For more information about running netdata in docker, check the docker installation page.
Netdata has a quite different approach to monitoring.
Netdata is a monitoring agent you install on all your systems. It is:
All the above, are packaged together in a very flexible, extremely modular, distributed application.
This is how netdata compares to other monitoring solutions:
netdata | others (open-source and commercial) |
---|---|
High resolution metrics (1s granularity) | Low resolution metrics (10s granularity at best) |
Monitors everything, thousands of metrics per node | Monitor just a few metrics |
UI is super fast, optimized for anomaly detection | UI is good for just an abstract view |
Meaningful presentation, to help you understand the metrics | You have to know the metrics before you start |
Install and get results immediately | Long preparation is required to get any useful results |
Use it for troubleshooting performance problems | Use them to get statistics of past performance |
Kills the console for tracing performance issues | The console is always required for troubleshooting |
Requires zero dedicated resources | Require large dedicated resources |
Netdata is open-source, free, super fast, very easy, completely open, extremely efficient, flexible and integrate-able.
It has been designed by SysAdmins, DevOps and Developers for troubleshooting performance problems, not just visualize metrics.
Nov 22nd, 2018
- netdata v1.11.1 released!
openldap
, tor
, nvidia_smi
.smartd_log
, cpufreq
, sensors
.alerta.io
, conntrack_max
.my-netdata
menu has been refactored.openrc
service definition got a few improvements.Sep 18, 2018
- netdata has its own organization
Netdata used to be a firehol.org project, accessible as firehol/netdata
.
Netdata now has its own github organization netdata
, so all github URLs are now netdata/netdata
. The old github URLs, repo clones, forks, etc redirect automatically to the new repo.
Netdata is a highly efficient, highly modular, metrics management engine. Its lockless design makes it ideal for concurrent operations on the metrics.
This is how it works:
Function | Description | Documentation |
---|---|---|
Collect | Multiple independent data collection workers are collecting metrics from their sources using the optimal protocol for each application and push the metrics to the database. Each data collection worker has lockless write access to the metrics it collects. | collectors |
Store | Metrics are stored in RAM in a round robin database (ring buffer), using a custom made floating point number for minimal footprint. | database |
Check | A lockless independent watchdog is evaluating health checks on the collected metrics, triggers alarms, maintains a health transaction log and dispatches alarm notifications. | health |
Stream | An lockless independent worker is streaming metrics, in full detail and in real-time, to remote netdata servers, as soon as they are collected. | streaming |
Archive | A lockless independent worker is down-sampling the metrics and pushes them to backend time-series databases. | backends |
Query | Multiple independent workers are attached to the internal web server, servicing API requests, including data queries. | web/api |
The result is a highly efficient, low latency system, supporting multiple readers and one writer on each metric.
This is a high level overview of netdata feature set and architecture.
Click it to to interact with it (it has direct links to documentation).
This is what you should expect from Netdata:
error
and access
logs).graphite
, opentsdb
, prometheus
, json document DBs, in the same or lower resolution (lower: to prevent it from congesting these servers due to the amount of data collected).slate
(dark) and white
.To improve clarity on charts, netdata dashboards present positive values for metrics representing read
, input
, inbound
, received
and negative values for metrics representing write
, output
, outbound
, sent
.
Netdata charts showing the bandwidth and packets of a network interface. received
is positive and sent
is negative.
Netdata charts automatically zoom vertically, to visualize the variation of each metric within the visible time-frame.
A zero based stacked
chart, automatically switches to an auto-scaled area
chart when a single dimension is selected.
Charts on netdata dashboards are synchronized to each other. There is no master chart. Any chart can be panned or zoomed at any time, and all other charts will follow.
Charts are panned by dragging them with the mouse. Charts can be zoomed in/out withSHIFT
+ mouse wheel
while the mouse pointer is over a chart.
The visible time-frame (pan and zoom) is propagated from netdata server to netdata server, when navigating via the
my-netdata
menu.
To improve visual anomaly detection across charts, the user can highlight a time-frame (by pressing ALT
+ mouse selection
) on all charts.
A highlighted time-frame can be given by pressing ALT
+ mouse selection
on any chart. Netdata will highlight the same range on all charts.
Highlighted ranges are propagated from netdata server to netdata server, when navigating via the
my-netdata
menu.
Netdata data collection is extensible - you can monitor anything you can get a metric for. Its Plugin API supports all programing languages (anything can be a netdata plugin, BASH, python, perl, node.js, java, Go, ruby, etc).
C
.python
.tc
classes in real-timehostapd
).mod-status
(v2.2, v2.4) and cache log statistics, for multiple servers.stub-status
, for multiple servers.access.log
files - extracting in real-time, web server and proxy performance metrics and applying several health checks, etc.named.stats
dump file to collect real-time performance metrics. All versions of bind after 9.6 are supported.chronyc
command to collect chrony statistics (Frequency, Last offset, RMS offset, Residual freq, Root delay, Root dispersion, Skew, System time).radclient
command to provide freeradius statistics (authentication, accounting, proxy-authentication, proxy-accounting).You can easily extend Netdata, by writing plugins that collect data from any source, using any computer language.
The netdata documentation is at https://docs.netdata.cloud. But you can also find it inside the repo, so by just navigating the repo on github you can find all the documentation.
Here is a quick list:
Directory | Description |
---|---|
installer |
Instructions to install netdata on your systems. |
docker |
Instructions to install netdata using docker. |
daemon |
Information about the netdata daemon and its configuration. |
collectors |
Information about data collection plugins. |
health |
How netdata's health monitoring works, how to create your own alarms and how to configure alarm notification methods. |
streaming |
How to build hierarchies of netdata servers, by streaming metrics between them. |
backends |
Long term archiving of metrics to industry standard time-series databases, like prometheus , graphite , opentsdb . |
web/api |
Learn how to query the netdata API and the queries it supports. |
web/api/badges |
Learn how to generate badges (SVG images) from live data. |
web/gui/custom |
Learn how to create custom netdata dashboards. |
web/gui/confluence |
Learn how to create netdata dashboards on Atlassian's Confluence. |
You can also check all the other directories. Most of them have plenty of documentation.
We welcome contributions. So, feel free to join the team.
To report bugs, or get help, use GitHub Issues.
You can also find netdata on:
netdata is GPLv3+.
Netdata re-distributes other open-source tools and libraries. Please check the third party licenses.