Building a First n8n Workflow: A Step-by-Step Tutorial
Step-by-step tutorial for building a GitHub-to-Slack notification workflow in n8n with conditional routing and logging.
The Bottom Line: A basic n8n workflow connecting a webhook trigger to a conditional branch and two output actions can be built and tested in under 30 minutes; n8n's visual canvas and built-in execution log make debugging straightforward for first-time users.
Building Your First n8n Workflow: A Step-by-Step Tutorial
n8n is a powerful workflow automation platform that gives teams visual building and code-level control in one tool. This tutorial walks you through building a first real workflow from scratch.
What We Will Build
We will create a workflow that monitors a GitHub repository for new issues and sends a formatted notification to a Slack channel with issue details. This is a practical, real-world automation that many development teams use.
Workflow Architecture
Here is the overall flow of our automation:
flowchart TD
A[GitHub Trigger: New Issue Created] --> B[Extract Issue Details]
B --> C{Is it a bug?}
C -->|Yes| D[Format Bug Alert Message]
C -->|No| E[Format General Notification]
D --> F[Send to #bugs Slack Channel]
E --> G[Send to #general Slack Channel]
F --> H[Log to Google Sheet]
G --> H[Log to Google Sheet]
Prerequisites
Before starting, make sure you have:
- n8n installed either self-hosted (Docker recommended) or a cloud account at app.n8n.cloud
- GitHub account with a repository to monitor
- Slack workspace with permission to install apps
- Google account for the Google Sheets logging step (optional)
Step 1: Set Up the GitHub Trigger
Every n8n workflow starts with a trigger node. This is the event that kicks off the automation.
- Open n8n and click Add workflow
- Click the + button to add a first node
- Search for GitHub Trigger and select it
- Click Create new credential and authenticate with your GitHub account
- Configure the trigger:
- Repository Owner: your GitHub username or organization
- Repository Name: the repo organizations want to monitor
- Events: select Issues and check opened
- Click Listen for Test Event and create a test issue in your repo to capture sample data
The trigger node will now fire every time a new issue is created in your repository.
Step 2: Extract and Transform Issue Data
Add a Set node to extract the fields we need:
- Click + after the GitHub Trigger node
- Add a Set node
- Configure the following fields:
- title:
{{ $json.issue.title }} - body:
{{ $json.issue.body }} - author:
{{ $json.issue.user.login }} - url:
{{ $json.issue.html_url }} - labels:
{{ $json.issue.labels.map(l => l.name).join(", ") }} - is_bug:
{{ $json.issue.labels.some(l => l.name === "bug") }}
- title:
This step normalizes the GitHub webhook data into a clean format for the rest of the workflow.
Step 3: Add Conditional Routing
We want bug reports to go to a dedicated channel. Add an IF node:
- Click + after the Set node
- Add an IF node
- Set the condition: is_bug equals true
- This creates two output branches: true (bugs) and false (other issues)
Step 4: Configure Slack Notifications
Add two Slack nodes, one for each branch:
Bug Alert (True branch)
- Click + on the true output
- Add a Slack node
- Connect your Slack workspace credential
- Configure:
- Channel: #bugs (or your bug channel)
- Message Text: Format a rich message:
:bug: *New Bug Report*
*Title:* {{ $json.title }}
*Author:* {{ $json.author }}
*Labels:* {{ $json.labels }}
*Link:* {{ $json.url }}
{{ $json.body }}
General Notification (False branch)
- Click + on the false output
- Add another Slack node
- Configure similarly but send to #general with a different emoji:
:clipboard: *New Issue*
*Title:* {{ $json.title }}
*Author:* {{ $json.author }}
*Link:* {{ $json.url }}
Step 5: Log to Google Sheets (Optional)
Add a Google Sheets node after both Slack nodes to maintain a log:
- Add a Merge node to combine both branches
- Add a Google Sheets node
- Connect your Google account
- Select the spreadsheet and worksheet
- Map columns: Date, Title, Author, Type (bug/other), URL
This creates an automatic issue log that the team can reference.
Step 6: Test and Activate
- Click Execute Workflow to run a test with the sample data from Step 1
- Verify each node executed successfully (green checkmarks)
- Check your Slack channels for the test notification
- Check your Google Sheet for the logged entry
- Fix any field mapping issues
- Toggle the workflow to Active in the top-right corner
Error Handling
Add error handling to make the workflow production-ready:
- Click on any node and select Settings
- Enable Continue on Fail for non-critical nodes (like the Google Sheets logging)
- Add an Error Trigger workflow that sends you a notification if the main workflow fails
- Set up retry logic for transient API failures
Next Steps
Now that organizations have a working workflow:
- Add more triggers: Monitor pull requests, comments, or releases
- Enrich notifications: Add assignee information, milestone details, or priority labels
- Build related workflows: Auto-assign issues based on labels, create Jira tickets from GitHub issues, or generate weekly summary reports
- Explore the n8n community: Browse 1,000+ workflow templates at n8n.io/workflows for inspiration
This pattern of trigger, transform, route, and action applies to virtually any automation users will build. The concepts transfer directly to more complex workflows.
Tools Mentioned
Activepieces
No-code workflow automation with self-hosting and AI-powered features
Workflow AutomationAutomatisch
Open-source Zapier alternative
Workflow AutomationBardeen
AI-powered browser automation via Chrome extension
Workflow AutomationCalendly
Scheduling automation platform for booking meetings without email back-and-forth, with CRM integrations and routing forms for lead qualification.
Workflow AutomationRelated Guides
Migrating 23 Make Scenarios to Self-Hosted n8n: a 3-Week Breakdown
Anonymized retrospective of a DTC ecommerce brand migrating 23 Make scenarios to a self-hosted n8n instance over three weeks. Tooling cost dropped from $348/month on Make Teams to roughly $12/month on a Hetzner VPS, but credential and webhook recreation consumed about 40% of total project time.
Trigger.dev vs Inngest 2026: OSS Durable Runners Compared
Trigger.dev (2022, London) is a fully Apache 2.0 durable runner with task-based authoring, machine-size selection, and first-class self-host. Inngest (2021, San Francisco) is a developer-first event-driven step platform with an open-source dev server and a managed cloud (50K step runs/month free, $20/month Hobby). This 2026 comparison covers license, programming model, pricing, observability, and self-host options.
Inngest vs Temporal 2026: Durable Functions vs Durable Workflows
Inngest (2021, San Francisco) is a developer-first durable functions platform with TypeScript and Python SDKs, 50,000 step runs/month free, and Hobby pricing from $20/month. Temporal (2019) is the heavyweight durable workflow engine with seven-language SDK coverage, Cassandra-backed scale, and Cloud pricing from roughly $200/month at low volume or $2.5-4.5K/month self-host. This 2026 comparison covers programming model, pricing, scale ceiling, and operational footprint.
Related Rankings
Best Durable Workflow Engines for Production in 2026
A ranked list of the best durable workflow engines for production deployments in 2026. Durable workflow engines persist execution state to a database so that long-running workflows survive process restarts, deployments, and infrastructure failures. The ranking covers Temporal, Prefect, Apache Airflow, Camunda, Windmill, and n8n. Tools were evaluated on production reliability, developer experience, scalability, open-source health, and documentation quality. The shortlist intentionally mixes code-first engines (Temporal, Prefect, Airflow) with hybrid visual platforms (Camunda, Windmill, n8n) to reflect how production teams actually choose workflow engines in 2026.
Best No-Code Automation Platforms in 2026
A ranked list of no-code automation platforms in 2026. The ranking covers visual workflow builders that allow non-engineering teams to connect SaaS apps, route data, and add conditional logic without writing code. Entries cover proprietary cloud platforms (Zapier, Make, Pipedream, IFTTT) and open-source visual builders (n8n, Activepieces). Scoring reflects integration breadth, pricing accessibility, visual editor ease, reliability and error handling, and self-hosting availability.
Common Questions
What are the best automation tools for solo founders in 2026?
Solo founders in 2026 get the most value from Zapier or Make (broad SaaS glue), n8n self-hosted (free, unlimited runs), Pipedream (generous free tier with code steps), Notion automations, and Lindy or Relay.app (AI agents for inbox and meetings). Free tiers cover most pre-revenue workflows.
What are the best automation tools for finance and AP teams in 2026?
Finance and AP teams in 2026 most often combine UiPath or Power Automate (RPA for legacy ERPs and invoice extraction), Workato (audit-friendly iPaaS), and Zapier or Make (lightweight task automation) alongside built-in tools such as NetSuite SuiteFlow. Selection depends on ERP, audit requirements, and invoice volume.
What are the best AI-native automation tools in 2026?
The leading AI-native automation tools in 2026 are Lindy and Relevance AI (agent builders), Gumloop (visual agent workflows), Relay.app (human-in-the-loop AI workflows), Bardeen (browser AI agents), and CrewAI (multi-agent code framework). "AI-native" here means the LLM is the orchestrator, not a step inside a traditional workflow.
What are the best workflow automation tools for technical writers in 2026?
Technical writers in 2026 typically combine Mintlify or ReadMe (docs-as-code platforms), n8n or Zapier (publishing automation), GitHub Actions (CI for docs), and Notion or Coda (drafting and review). The strongest setups treat docs as code with an automation layer for screenshots, link checks, and changelog publishing.