Error handling patterns that actually work in production
Most n8n tutorials skip error handling. That's fine for demos. But when a workflow runs 10,000 times a day, you need it to fail gracefully.
Here's what we've learned from 300+ production workflows.
The problem with default behavior
By default, when a node fails in n8n, the whole workflow stops. That's often not what you want.
Imagine you're processing 500 leads. Lead #47 has a malformed email. Should the other 453 leads get stuck? No.
Pattern 1: Continue on fail
The simplest fix. On any node, enable "Continue On Fail" in settings. The workflow keeps running even if that node errors.
// The failed item gets an error property you can check
if ($input.item.json.error) {
// Handle the error case
return { success: false, reason: $input.item.json.error.message };
}
When to use: Processing batches where individual failures shouldn't stop everything.
Pattern 2: Try/catch with IF node
For more control, route errors explicitly:
- Enable "Continue On Fail" on the risky node
- Add an IF node after it
- Check for
$json.errorto route failures separately
This lets you:
- Log failures to a database
- Send alerts for certain error types
- Retry with different parameters
Pattern 3: Error workflow
n8n has a built-in error workflow feature. When any workflow fails, it triggers a separate workflow.
We use this for:
- Slack notifications to the team
- Logging to our monitoring system
- Auto-creating tickets for critical failures
Set it in Workflow Settings → Error Workflow.
Pattern 4: Graceful degradation
Sometimes the right response to an error is doing something simpler instead of failing.
Example: Your AI summarization fails because the API is overloaded. Instead of failing the whole workflow, fall back to extracting the first 500 characters.
// In a Code node after the AI node
const aiResult = $input.item.json;
if (aiResult.error) {
// Fallback: just use the first 500 chars
return {
summary: $('Previous Node').item.json.content.substring(0, 500) + '...',
method: 'fallback'
};
}
return { summary: aiResult.text, method: 'ai' };
What we use on every project
- Error workflow for monitoring
- Continue on fail for batch processing
- Explicit try/catch for critical paths
- Fallbacks for non-essential features
The goal isn't to prevent errors. It's to handle them without waking anyone up at 3am.
Production-Grade Claude Code in 5 Days
Set up Claude Code the right way - from someone who ships with it daily.
100% satisfaction guarantee. Full refund if you're not happy after the first session.
Related Posts

Claude for Small Business: what's in the plugin (and how to decide)
Claude for Small Business is a plugin for Claude Cowork with 25+ pre-built skills and 8 native integrations. Here's what's in it, how it compares to ChatGPT Team, and a decision tree for picking the right setup.

The 2 prerequisites for Claude Code (you'll regret skipping)
Before you install Claude Code, you need source control (GitHub or similar) and issue tracking (Linear or similar). Here's what each one does, why both matter, and the 10-minute setup to get both running.

A beginner's guide to source control with GitHub
GitHub for beginners – what source control is, the 5 commands that do 90% of the work, branching, pull requests, and the conventions worth stealing from production AGENTS.md files.