The only agent that thinks for itself

Autonomous Monitoring with self-learning AI built-in, operating independently across your entire stack.

Unlimited Metrics & Logs
Machine learning & MCP
5% CPU, 150MB RAM
3GB disk, >1 year retention
800+ integrations, zero config
Dashboards, alerts out of the box
> Discover Netdata Agents

Centralized metrics streaming and storage

Aggregate metrics from multiple agents into centralized Parent nodes for unified monitoring across your infrastructure.

Stream from unlimited agents
Long-term data retention
High availability clustering
Data replication & backup
Scalable architecture
Enterprise-grade security
> Learn about Parents

Fully managed cloud platform

Access your monitoring data from anywhere with our SaaS platform. No infrastructure to manage, automatic updates, and global availability.

Zero infrastructure management
99.9% uptime SLA
Global data centers
Automatic updates & patches
Enterprise SSO & RBAC
SOC2 & ISO certified
> Explore Netdata Cloud

Deploy Netdata Cloud in your infrastructure

Run the full Netdata Cloud platform on-premises for complete data sovereignty and compliance with your security policies.

Complete data sovereignty
Air-gapped deployment
Custom compliance controls
Private network integration
Dedicated support team
Kubernetes & Docker support
> Learn about Cloud On-Premises

Powerful, intuitive monitoring interface

Modern, responsive UI built for real-time troubleshooting with customizable dashboards and advanced visualization capabilities.

Real-time chart updates
Customizable dashboards
Dark & light themes
Advanced filtering & search
Responsive on all devices
Collaboration features
> Explore Netdata UI

Monitor on the go

Native iOS and Android apps bring full monitoring capabilities to your mobile device with real-time alerts and notifications.

iOS & Android apps
Push notifications
Touch-optimized interface
Offline data access
Biometric authentication
Widget support
> Download apps

The future of infrastructure observability

See our strategic direction across AI-native observability, full-stack signals, operational intelligence, and enterprise platform maturity.

AI-native observability
Full-stack signal coverage
Operational intelligence
Enterprise platform maturity
Agent releases every 6 weeks
Cloud continuous delivery
> Explore Product Roadmap

Best energy efficiency

True real-time per-second

100% automated zero config

Centralized observability

Multi-year retention

High availability built-in

Zero maintenance

Always up-to-date

Enterprise security

Complete data control

Air-gap ready

Compliance certified

Millisecond responsiveness

Infinite zoom & pan

Works on any device

Native performance

Instant alerts

Monitor anywhere

AI-native observability

Continuous delivery

Open source foundation

80% Faster Incident Resolution

AI-powered troubleshooting from detection, to root cause and blast radius identification, to reporting.

True Real-Time and Simple, even at Scale

Linearly and infinitely scalable full-stack observability, that can be deployed even mid-crisis.

90% Cost Reduction, Full Fidelity

Instead of centralizing the data, Netdata distributes the code, eliminating pipelines and complexity.

Control Without Surrender

SOC 2 Type 2 certified with every metric kept on your infrastructure.

Integrations

800+ collectors and notification channels, auto-discovered and ready out of the box.

800+ data collectors
Auto-discovery & zero config
Cloud, infra, app protocols
Notifications out of the box
> Explore integrations
Real Results
46% Cost Reduction

Reduced monitoring costs by 46% while cutting staff overhead by 67%.

— Leonardo Antunez, Codyas

Zero Pipeline

No data shipping. No central storage costs. Query at the edge.

From Our Users
"Out-of-the-Box"

So many out-of-the-box features! I mostly don't have to develop anything.

— Simon Beginn, LANCOM Systems

No Query Language

Point-and-click troubleshooting. No PromQL, no LogQL, no learning curve.

Enterprise Ready
67% Less Staff, 46% Cost Cut

Enterprise efficiency without enterprise complexity—real ROI from day one.

— Leonardo Antunez, Codyas

SOC 2 Type 2 Certified

Zero data egress. Only metadata reaches the cloud. Your metrics stay on your infrastructure.

Full Coverage
800+ Collectors

Auto-discovered and configured. No manual setup required.

Any Notification Channel

Slack, PagerDuty, Teams, email, webhooks—all built-in.

Built for the People Who Get Paged

Because 3am alerts deserve instant answers, not hour-long hunts.

Every Industry Has Rules. We Master Them.

See how healthcare, finance, and government teams cut monitoring costs 90% while staying audit-ready.

Monitor Any Technology. Configure Nothing.

Install the agent. It already knows your stack.
From Our Users
"A Rare Unicorn"

Netdata gives more than you invest in it. A rare unicorn that obeys the Pareto rule.

— Eduard Porquet Mateu, TMB Barcelona

99% Downtime Reduction

Reduced website downtime by 99% and cloud bill by 30% using Netdata alerts.

— Falkland Islands Government

Real Savings
30% Cloud Cost Reduction

Optimized resource allocation based on Netdata alerts cut cloud spending by 30%.

— Falkland Islands Government

46% Cost Cut

Reduced monitoring staff by 67% while cutting operational costs by 46%.

— Codyas

Real Coverage
"Plugin for Everything"

Netdata has agent capacity or a plugin for everything, including Windows and Kubernetes.

— Eduard Porquet Mateu, TMB Barcelona

"Out-of-the-Box"

So many out-of-the-box features! I mostly don't have to develop anything.

— Simon Beginn, LANCOM Systems

Real Speed
Troubleshooting in 30 Seconds

From 2-3 minutes to 30 seconds—instant visibility into any node issue.

— Matthew Artist, Nodecraft

20% Downtime Reduction

20% less downtime and 40% budget optimization from out-of-the-box monitoring.

— Simon Beginn, LANCOM Systems

Pay per Node. Unlimited Everything Else.

One price per node. Unlimited metrics, logs, users, and retention. No per-GB surprises.

Free tier—forever
No metric limits or caps
Retention you control
Cancel anytime
> See pricing plans

What's Your Monitoring Really Costing You?

Most teams overpay by 40-60%. Let's find out why.

Expose hidden metric charges
Calculate tool consolidation
Customers report 30-67% savings
Results in under 60 seconds
> See what you're really paying

Your Infrastructure Is Unique. Let's Talk.

Because monitoring 10 nodes is different from monitoring 10,000.

On-prem & air-gapped deployment
Volume pricing & agreements
Architecture review for your scale
Compliance & security support
> Start a conversation

Monitoring That Sells Itself

Deploy in minutes. Impress clients in hours. Earn recurring revenue for years.

30-second live demos close deals
Zero config = zero support burden
Competitive margins & deal protection
Response in 48 hours
> Apply to partner

Per-Second Metrics at Homelab Prices

Same engine, same dashboards, same ML. Just priced for tinkerers.

Community: Free forever · 5 nodes · non-commercial
Homelab: $90/yr · unlimited nodes · fair usage
> Get the Homelab Plan

$1,000 Per Referral. Unlimited Referrals.

Your colleagues get 10% off. You get 10% commission. Everyone wins.

10% of subscriptions, up to $1,000 each
Track earnings inside Netdata Cloud
PayPal/Venmo payouts in 3-4 weeks
No caps, no complexity
> Get your referral link
Cost Proof
40% Budget Optimization

"Netdata's significant positive impact" — LANCOM Systems

Calculate Your Savings

Compare vs Datadog, Grafana, Dynatrace

Savings Proof
46% Cost Reduction

"Cut costs by 46%, staff by 67%" — Codyas

30% Cloud Bill Savings

"Reduced cloud bill by 30%" — Falkland Islands Gov

Enterprise Proof
"Better Than Combined Alternatives"

"Better observability with Netdata than combining other tools." — TMB Barcelona

Real Engineers, <24h Response

DPA, SLAs, on-prem, volume pricing

Why Partners Win
Demo Live Infrastructure

One command, 30 seconds, real data—no sandbox needed

Zero Tickets, High Margins

Auto-config + per-node pricing = predictable profit

Homelab Ready
Free Video Course

8-episode Netdata tutorial by LearnLinux.tv

76k+ GitHub Stars

3rd most starred monitoring project

Worth Recommending
Product That Delivers

Customers report 40-67% cost cuts, 99% downtime reduction

Zero Risk to Your Rep

Free tier lets them try before they buy

AI Support Assistant, Available 24/7

Nedi has access to all official documentation, source code, and resources. Ask any question about Netdata—responds in your language.

Deployment & configuration
Troubleshooting & sizing
Alerts & notifications
Evidence-based answers
> Ask Nedi now

Never Fight Fires Alone

Docs, community, and expert help—pick your path to resolution.

Learn.netdata.cloud docs
Discord, Forums, GitHub
Premium support available
> Get answers now

60 Seconds to First Dashboard

One command to install. Zero config. 850+ integrations documented.

Linux, Windows, K8s, Docker
Auto-discovers your stack
> Read our documentation

Level Up Your Monitoring

Real problems. Real solutions. 112+ guides from basic monitoring to AI observability.

76,000+ Engineers Strong

615+ contributors. 1.5M daily downloads. One mission: simplify observability.

Per-Second. 90% Cheaper. Data Stays Home.

Side-by-side comparisons: costs, real-time granularity, and data sovereignty for every major tool.

See why teams switch from Datadog, Prometheus, Grafana, and more.

> Browse all comparisons
Edge-Native Observability, Born Open Source
Per-second visibility, ML on every metric, and data that never leaves your infrastructure.
Founded in 2016
615+ contributors worldwide
Remote-first, engineering-driven
Open source first
> Read our story
Promises We Publish—and Prove
12 principles backed by open code, independent validation, and measurable outcomes.
Open source, peer-reviewed
Zero config, instant value
Data sovereignty by design
Aligned pricing, no surprises
> See all 12 principles
Edge-Native, AI-Ready, 100% Open
76k+ stars. Full ML, AI, and automation—GPLv3+, not premium add-ons.
76,000+ GitHub stars
GPLv3+ licensed forever
ML on every metric, included
Zero vendor lock-in
> Explore our open source
Build Real-Time Observability for the World
Remote-first team shipping per-second monitoring with ML on every metric.
Remote-first, fully distributed
Open source (76k+ stars)
Challenging technical problems
Your code on millions of systems
> See open roles
Meet the Team Behind Netdata
Conferences, meetups, and tradeshows where you can see Netdata in action and talk to the engineers who build it.
Live demos and deep dives
Book 1-on-1 meetings
Talks and panel sessions
Event recaps and photos
> See all events
Talk to a Netdata Human in <24 Hours
Sales, partnerships, press, or professional services—real engineers, fast answers.
Discuss your observability needs
Pricing and volume discounts
Partnership opportunities
Media and press inquiries
> Book a conversation
Your Data. Your Rules.
On-prem data, cloud control plane, transparent terms.
Trust & Scale
76,000+ GitHub Stars

One of the most popular open-source monitoring projects

SOC 2 Type 2 Certified

Enterprise-grade security and compliance

Data Sovereignty

Your metrics stay on your infrastructure

Validated
University of Amsterdam

"Most energy-efficient monitoring solution" — ICSOC 2023, peer-reviewed

ADASTEC (Autonomous Driving)

"Doesn't miss alerts—mission-critical trust for safety software"

Community Stats
615+ Contributors

Global community improving monitoring for everyone

1.5M+ Downloads/Day

Trusted by teams worldwide

GPLv3+ Licensed

Free forever, fully open source agent

Why Join?
Remote-First

Work from anywhere, async-friendly culture

Impact at Scale

Your work helps millions of systems

$ guides / mysql
MYSQL · OPERATIONS PLAYBOOK

Running MySQL in production, without the 3 a.m. surprises

A connection-per-thread server, an InnoDB buffer pool, a circular redo log, undo-based MVCC, and a binlog replication contract. The mental model of how MySQL actually behaves under load, where it tends to break, what to monitor as your operation matures, and the runbooks for the incidents you'll see.

"

MySQL is famously easy to start and famously unforgiving once the write rate, the connection count, or the dataset grows past what the defaults assumed.

The defaults work. Until the InnoDB redo log fills, a sharp checkpoint forces a synchronous flush, and every write on the server freezes at once. Until an idle BEGIN nobody committed pins an MVCC read view, the history list climbs past a million, and every read across every table slows down. Until an ALTER TABLE queues behind that same transaction and the whole table goes dark behind Waiting for table metadata lock. Until the working set outgrows the buffer pool and a system that was fine at 98% falls off a cliff at 101%. Until max_connections is reached and the server answers every client with ERROR 1040 (HY000): Too many connections while looking, to the database itself, perfectly healthy.

These guides are written for engineers who already run MySQL, not for people learning what a table is. The goal is to give you the mental model of how the server actually behaves under load, the failure patterns that keep recurring, the monitoring story that catches problems before they page anyone, and the runbooks you wish someone had handed you before your last incident.

How MySQL actually runs in production

MySQL is not just a place to put rows. It is a connection-threaded SQL processor sitting on top of InnoDB — a buffer pool, a write-ahead redo log, undo-based MVCC, and a streaming binary-log replication contract. Most production failures live between these layers, not inside any one of them.

01
clients / connection threads
Every client connection gets a dedicated thread holding session memory — sort, join, and net buffers, plus temp tables. The count is bounded by <code>max_connections</code>; exceed it and new connections are refused with <code>Too many connections</code>. Idle <code>Sleep</code> connections still hold a slot and memory.
CLIENT
02
parser + optimizer
Each statement is parsed, then the optimizer picks a plan. A plan that loses its index turns a point lookup into a full scan — <code>Handler_read_rnd_next</code> and <code>Select_full_join</code> climb, and the same query that was fast yesterday is slow after a deploy or an <code>ANALYZE TABLE</code>.
OPTIMIZER
03
InnoDB buffer pool
A fixed-size LRU cache of 16 KB pages split into young (hot) and old (cold) sublists. The single strongest predictor of read latency. When the working set outgrows it, the hit ratio collapses non-linearly and every read goes to disk.
BUFFERPOOL
04
row locks + MVCC (undo)
InnoDB takes row and next-key locks held until commit, and keeps old row versions in undo for consistent reads. Lock waits time out at <code>innodb_lock_wait_timeout</code>; a held read view blocks the purge thread and the history list grows.
MVCC
05
metadata locks (DDL)
A separate locking layer from InnoDB row locks. DDL needs an exclusive metadata lock; any open transaction holding a shared one makes it wait — and every <code>DML</code> on that table queues behind the exclusive request. Invisible in <code>SHOW ENGINE INNODB STATUS</code>.
MDL
06
redo log + checkpointing
All modifications hit the circular redo log before the data files. As checkpoint age approaches <code>innodb_redo_log_capacity</code>, InnoDB forces a sharp checkpoint that stalls every write. Page cleaners flush dirty pages in the background to keep that age down.
REDO
07
binlog + replication
Commits also write the binary log, which replicas fetch (I/O thread) and apply (SQL thread). The apply side can fall behind the primary's write rate; <code>Seconds_Behind_Source</code> grows, relay logs accumulate, and a lagging replica can block binlog purge on the primary.
REPLICA
08
OS, memory + storage
Total memory is the buffer pool plus per-connection buffers times <code>max_connections</code> — overshoot it and the kernel OOM killer fires. Redo and binlog <code>fsync</code> latency on the data volume sets the floor on commit throughput, and a full disk stops writes hard.
OS

Why this matters: MySQL can be slow because of a missing index, a buffer-pool miss, a row-lock wait, a metadata-lock stall, a checkpoint freeze, purge lag, an fsync stall, or replication apply falling behind. The symptom is often the same — MySQL is slow — but each layer has a different signal and a different fix.

The failures you'll actually see

Most MySQL incidents fall into a small set of recurring patterns. Recognise the shape, and triage gets dramatically faster.

CRITICAL

The redo log checkpoint stall

The write rate outruns the page cleaners. Dirty pages accumulate and checkpoint age climbs toward innodb_redo_log_capacity. Past roughly 85% InnoDB forces a sharp checkpoint — a synchronous flush that stalls every write on the server at once. This is MySQL's most dangerous cliff edge, and the most common cause of a sudden, unexplained write freeze.

  • checkpoint age above 85% of redo log capacity
  • Questions or commit rate collapsing while clients stay connected
  • Innodb_buffer_pool_pages_dirty ratio flat or climbing
  • disk write latency spiking with normal queue depth
Investigate
IMMINENT

The metadata lock cascade

A DDL statement needs an exclusive metadata lock. A long-running (often idle) transaction holds a shared lock on the same table, so the ALTER TABLE waits — and every new query on that table queues behind the exclusive request. Within minutes the connection pool fills with sessions stuck in Waiting for table metadata lock. One table goes dark while the rest of the server looks fine.

  • many threads in Waiting for table metadata lock on one table
  • Threads_running climbing while Questions drops
  • Threads_connected approaching max_connections
  • no rise in Innodb_row_lock_waits — this is not row locking
Investigate
ACTIVE

The purge lag history-list explosion

A single transaction left open — a forgotten BEGIN, an ORM that never committed, a pool returning a connection without rollback — pins an MVCC read view. The purge thread cannot reclaim old row versions, the history list grows without bound, and every consistent read has to traverse longer version chains. The whole server gets slower by the hour, with no single slow query to blame.

  • trx_rseg_history_len above 1,000,000 and climbing
  • one very old transaction in INNODB_TRX with trx_query NULL
  • read latency rising across all tables at a steady read rate
  • undo tablespace growing on disk
Investigate
CRITICAL

The connection exhaustion cliff

Connections reach max_connections and MySQL answers new ones with ERROR 1040 (HY000): Too many connections. To clients it looks like MySQL is down; to the server it is simply full. Low Threads_running underneath means a connection leak or idle accumulation; high Threads_running means genuine overload backing up. A reserved admin slot is your only way in.

  • Connection_errors_max_connections incrementing
  • Threads_connected / max_connections above 0.95
  • low Threads_running (leak) or high Threads_running (overload)
  • SHOW PROCESSLIST full of long Sleep connections
Investigate
IMMINENT

The buffer pool cliff edge

The working set outgrows the buffer pool. Every query contends for a shrinking pool of in-memory pages, evictions force disk reads, the disk saturates, and all queries slow at once. The hit ratio drops non-linearly — gentle from 99.9% to 99%, fast from 99% to 95%, then catastrophic. A system that ran fine at 98% utilization falls off the edge at 101%.

  • buffer pool hit ratio dropping below 99%, then 95%
  • Innodb_buffer_pool_reads rate rising sharply
  • Innodb_buffer_pool_wait_free becoming nonzero
  • disk read I/O near 100% with latency up across all queries
Investigate
WATCHFUL

The replication lag spiral

The replica's apply threads cannot keep up with the primary's write rate. Seconds_Behind_Source grows monotonically, relay logs pile up on the replica's disk, and reads return progressively staler data. If the primary's binlog expiry fires before the replica catches up, replication breaks and the replica needs a rebuild. Single-threaded apply and large transactions are the usual culprits.

  • Seconds_Behind_Source increasing without a plateau
  • Relay_Log_Space growing faster than the apply rate
  • replica Threads_running elevated, primary healthy
  • replica_parallel_workers at 0 or 1 on a multi-core replica
Investigate

MySQL monitoring maturity levels

MySQL observability works in four practical levels. Each is a complete operation, not a stepping stone. Pick the level that matches how much your database matters. Most production instances should land at the second level.

Level 1: Survival

Know that something is wrong

Survival monitoring is the floor. With these signals you can answer one question: is MySQL still functioning? You will not learn what broke, but you will learn that something broke before users do. Survival is enough for dev environments and side-project databases.

  • SELECT 1 liveness Does the server answer a real query path within a couple of seconds?
  • Uptime / unexpected restarts Did Uptime reset without your permission (crash or OOM kill)?
  • Threads_connected vs max_connections Are you within the hard connection ceiling?
  • Replica_IO_Running / Replica_SQL_Running Are both replication threads still Yes?
  • Seconds_Behind_Source Is the replica applying, even if the number is rough?
  • Disk free on the data volume Is the volume hosting data, redo, and binlogs near full?
  • Error log for [ERROR] lines Is MySQL writing crash, corruption, or replication errors?

Level 2: Operational

Diagnose most incidents on your own

Operational monitoring is what most production databases should target. Survival tells you something is wrong; operational tells you what. With this coverage your team can usually diagnose an incident on its own: lock contention, buffer-pool pressure, slow queries, connection pile-up, replication thread state.

  • Questions rate Is throughput where it should be — or have queries stalled?
  • Threads_running vs CPU cores Is active load oversubscribing the cores?
  • Slow_queries rate (long_query_time ≤ 1s) Is query latency regressing? The 10s default hides everything.
  • Buffer pool hit ratio Is the working set still served from RAM?
  • Innodb_row_lock_waits and lock_deadlocks Is row-lock contention throttling the workload?
  • Connection_errors_max_connections Are clients being refused at the ceiling?
  • Aborted_connects / Aborted_clients Are auth or network failures climbing?
  • Created_tmp_disk_tables ratio Are temp tables spilling to disk?
  • Seconds_Behind_Source trend Is replication lag growing, stable, or recovering?

Level 3: Mature

Catch problems before they become incidents

Mature monitoring catches problems before they wake anyone up. Checkpoint age creeping toward redo capacity, the history list drifting up, a metadata-lock wait forming, an old transaction sitting open, binlogs outgrowing their expiry. None of these will page you on day one. They become page-out incidents on day thirty.

  • Checkpoint age / redo log capacity How close is the next sharp-checkpoint write stall?
  • trx_rseg_history_len (history list) Is purge keeping up, or is a read view blocking it?
  • Metadata lock waits (performance_schema.metadata_locks) Is a DDL cascade forming on one table?
  • Oldest open transaction age (INNODB_TRX) Is anything holding locks or a read view for minutes?
  • Innodb_os_log_pending_fsyncs Is the storage layer keeping up with durable commits?
  • Binary log growth vs expiry Will binlogs fill the disk before they purge?
  • Opened_tables rate / table_open_cache Is the table cache churning file descriptors?
  • Threads_created rate Is connection pooling actually being used?
  • GTID set comparison across topology Are replicas truly caught up, or just reporting zero lag?

Level 4: Expert

Reactive instrumentation after real incidents

Expert signals enter your stack the day after a specific incident proved you needed them. Lock-wait chain reconstruction, per-index access stats, adaptive-hash-index latch contention, page-cleaner efficiency, GTID errant transactions, sort-merge pass rates. Most teams never need every signal here. Add the ones your incident history says you do.

  • data_lock_waits + data_locks chains (8.0) Who is blocking whom, in real time?
  • Per-index access from table_io_waits_summary Which indexes are unused or hot?
  • btr_search latch waits (SEMAPHORES) Is the adaptive hash index spinning CPU without progress?
  • Page cleaner flush rate vs dirty ratio Are checkpoints flushing what the cleaners should?
  • GTID errant transactions Does a replica hold transactions the source never had?
  • Sort_merge_passes / sort scans Is sort_buffer_size too small for real queries?
  • Handler_read_rnd_next step-changes Did a deploy introduce a new full-table scan?
  • performance_schema digest top-N Which query shapes actually cost the most time?

Operating mistakes worth avoiding

The traps MySQL teams keep falling into. Each has a clear, well-known fix. Most teams only learn it after an incident.

Alerting on Threads_connected instead of Threads_running

Teams page on "too many connections" while the server is idle, and miss the real killer: too many <em>active</em> connections. High <code>Threads_connected</code> with low <code>Threads_running</code> is a pool leak; low connected with high running is a crisis. Alert on <code>Threads_running</code> relative to CPU cores, not on raw connection count.

Leaving long_query_time at the 10-second default

The default misses every operationally relevant slowdown, so incidents show "no slow queries" while users wait seconds. Set <code>long_query_time ≤ 1</code> for OLTP and track the <code>Slow_queries</code> / <code>Questions</code> ratio, not the absolute count.

Not monitoring checkpoint age

Checkpoint stall is the most common mysterious write freeze in production MySQL, yet it is rarely watched until the first incident. There is no <code>Innodb_checkpoint_age</code> in <code>SHOW STATUS</code> — derive it from the <code>Innodb_redo_log_*</code> status variables (8.0.30+) or <code>INNODB_METRICS</code>, and alert at 75% of capacity.

Not monitoring the history list length

<code>trx_rseg_history_len</code> was removed from <code>SHOW STATUS</code> in 8.0 and lives in <code>INNODB_METRICS</code>. Teams learn about purge lag during their first incident with a forgotten transaction. A history list above a million degrades every read on the server — alert on it.

Running ALTER TABLE without checking for long transactions

An online schema change still takes a brief exclusive metadata lock, and if any open transaction holds a shared lock it cascades into a full-table stall. Check <code>INNODB_TRX</code> for old transactions before any DDL, and never assume "online" means "lock-free".

Trusting Seconds_Behind_Source for failover decisions

It reports 0 when the I/O thread is behind, NULL (not infinity) when broken, and jumps to thousands after an idle source bursts — and it is inaccurate with parallel replication. Use <code>pt-heartbeat</code> or GTID set comparison for any decision that matters.

No disk-space monitoring on the binlog and tmpdir volumes

Binlogs fill the disk when a replica lags and blocks purge; <code>tmpdir</code> fills when a query spills a huge temp table. Both stop the server with <code>No space left on device</code>, and neither is on the data volume teams usually watch. Monitor every filesystem MySQL writes to.

Treating the error log as optional

InnoDB crash recovery details, page corruption, assertion failures, and full replication errors are written only to the error log — not to any status variable. Many teams never collect it, so the most valuable forensic data during an incident sits in a file nobody was watching.

MySQL runbooks in this section

Each guide is a focused runbook for one symptom or topic. Pick one when you have an incident, or use the categories to learn the area.

WHERE TO GO NEXT

Setting up MySQL monitoring, or putting out a fire?

If you're starting from scratch, the monitoring checklist is the path of least regret. If you're mid-incident, jump straight to the symptom that matches what you're seeing.