Mateusz Bularz d5211d5f63 removing IP address information. Bumping traefik version (#19222) 1 month ago
..
README.md 8dea7e4702 Docs edits on Cloud versions and On Prem (#19104) 1 month ago
infrastructure.jpeg f27f4f714a Documentation changes, new files and restructuring the hierarchy (#17014) 11 months ago
installation.md d5211d5f63 removing IP address information. Bumping traefik version (#19222) 1 month ago
poc-without-k8s.md 9db4982a7b On-prem docs edits 2 (#19105) 1 month ago
troubleshooting.md 9db4982a7b On-prem docs edits 2 (#19105) 1 month ago

README.md

Netdata Cloud On-Prem

Netdata Cloud is built as microservices and is orchestrated by a Kubernetes cluster, providing a highly available and auto-scaled observability platform.

The overall architecture looks like this:

flowchart TD
    Agents("🌍 <b>Netdata Agents</b><br/>Users' infrastructure<br/>Netdata Children & Parents")
    users[["πŸ”₯ <b>Unified Dashboards</b><br/>Integrated Infrastructure<br/>Dashboards"]]
    ingress("πŸ›‘οΈ <b>Ingress Gateway</b><br/>TLS termination")
    traefik((("πŸ”’ <b>Traefik</b><br/>Authentication &<br/>Authorization")))
    emqx(("πŸ“€ <b>EMQX</b><br/>Agents Communication<br/>Message Bus<br/>MQTT"))
    pulsar(("⚑ <b>Pulsar</b><br/>Internal Microservices<br/>Message Bus"))
    frontend("🌐 <b>Front-End</b><br/>Static Web Files")
    auth("πŸ‘¨β€πŸ’Ό <b>Users &amp; Agents</b><br/>Authorization<br/>Microservices")
    spaceroom("🏑 <b>Spaces, Rooms,<br/>Nodes, Settings</b><br/>Microservices for<br/>managing Spaces,<br/>Rooms, Nodes and<br/>related settings")
    charts("πŸ“ˆ <b>Metrics & Queries</b><br/>Microservices for<br/>dispatching queries<br/>to Netdata Agents")
    alerts("πŸ”” <b>Alerts & Notifications</b><br/>Microservices for<br/>tracking alert<br/>transitions and<br/>deduplicating alerts")
    sql[("✨ <b>PostgreSQL</b><br/>Users, Spaces, Rooms,<br/>Agents, Nodes, Metric<br/>Names, Metrics Retention,<br/>Custom Dashboards,<br/>Settings")]
    redis[("πŸ—’οΈ <b>Redis</b><br/>Caches needed<br/>by Microservices")]
    elk[("πŸ—žοΈ <b>Elasticsearch</b><br/>Feed Events Database")]
    bridges("🀝 <b>Input & Output</b><br/>Microservices bridging<br/>agents to internal<br/>components")
    notifications("πŸ“’ <b>Notifications Integrations</b><br/>Dispatch alert<br/>notifications to<br/>3rd party services")
    feed("πŸ“ <b>Feed & Events</b><br/>Microservices for<br/>managing the events feed")
    users --> ingress
    agents --> ingress
    ingress --> traefik
    ingress ==>|agents<br/>websockets| emqx
    traefik -.- auth
    traefik ==>|http| spaceroom
    traefik ==>|http| frontend
    traefik ==>|http| charts
    traefik ==>|http| alerts
    spaceroom o-...-o pulsar
    spaceroom -.- redis
    spaceroom x-..-x sql
    spaceroom -.-> feed
    charts o-.-o pulsar
    charts -.- redis
    charts x-.-x sql
    charts -..-> feed
    alerts o-.-o pulsar
    alerts -.- redis
    alerts x-.-x sql
    alerts -..-> feed
    auth o-.-o pulsar
    auth -.- redis
    auth x-.-x sql
    auth -.-> feed
    feed <--> elk
    alerts ----> notifications
    %% auth ~~~ spaceroom
    emqx <.-> bridges o-..-o pulsar