使用n8n构建自动化工作流:从数据库查询到邮件通知的使用指南

news2025/4/24 23:08:36

n8n是一款强大的开源工作流自动化工具,可以帮助你将各种服务和应用程序连接起来,创建复杂的自动化流程。下面我将详细介绍一个实用的n8n用例:从MySQL数据库查询数据并发送邮件通知,包括使用场景、搭建步骤和节点部署方法。

使用场景

场景描述:假设你是一家电商公司的运营人员,需要每天上午10点检查库存量低于警戒值的商品,并自动发送邮件通知采购部门及时补货。

工作流功能

  1. 定时触发工作流(每天上午10点)

  2. 连接MySQL数据库查询库存数据

  3. 筛选出库存量低于警戒值的商品

  4. 将查询结果格式化为易读的HTML表格

  5. 通过SMTP服务发送邮件给采购部门

这个自动化流程可以节省每天手动查询和发送邮件的时间,确保补货通知及时准确。

搭建步骤

1. 部署n8n

n8n有多种部署方式,以下是两种常见方法:

方法一:使用Docker快速部署(适合本地测试)

bash

docker run -it --rm --name n8n -p 5678:5678 -v ~/.n8n:/home/node/.n8n docker.n8n.io/n8nio/n8n

部署完成后,访问 http://localhost:5678 即可进入n8n界面。

方法二:使用Railway和Supabase零成本搭建(适合生产环境)
  1. 在Supabase创建数据库项目,记录连接信息

  2. 在GitHub创建仓库并添加简单的Dockerfile

  3. 在Railway部署项目,关联GitHub仓库

  4. 设置环境变量(数据库连接、加密密钥等)

  5. 配置自定义域名(可选)

2. 创建工作流

  1. 登录n8n后,点击"Add workflow"创建新工作流

  2. 点击右上角的"Workflow settings"设置工作流名称和描述

部署节点与配置

以下是完整的工作流节点配置步骤:

节点1:Cron定时触发器

  1. 从左侧面板拖拽"Cron"节点到画布

  2. 配置属性:

    • Mode: Every Day

    • Hour: 10

    • Minute: 0

  3. 这个节点会在每天上午10点自动触发工作流

节点2:MySQL数据库查询

  1. 添加"MySQL"节点并连接到Cron节点

  2. 点击"Create new credential"配置数据库连接:

    • Host: 数据库服务器地址

    • Database: 数据库名称

    • User: 数据库用户名

    • Password: 数据库密码

    • Port: 3306(默认)

  3. 在Operation中选择"Select"

  4. 在Query中填写SQL语句:

    sql

    SELECT product_id, product_name, current_stock, alert_stock 
    FROM products 
    WHERE current_stock < alert_stock

节点3:IF条件判断(可选)

  1. 添加"IF"节点连接到MySQL节点

  2. 配置条件判断是否有低库存商品:

    • 条件1: {{$node["MySQL"].json["length"] > 0}}

    • 这样当查询结果为空时,工作流会终止而不发送空邮件

节点4:HTML格式化

  1. 添加"Function"节点连接到IF节点(True分支)

  2. 编写JavaScript代码将查询结果格式化为HTML表格:

javascript

const items = $input.all();

let html = `
  <h2>低库存商品警报</h2>
  <p>以下商品需要及时补货:</p>
  <table border="1" cellpadding="5" cellspacing="0">
    <tr>
      <th>商品ID</th>
      <th>商品名称</th>
      <th>当前库存</th>
      <th>警戒库存</th>
    </tr>
`;

items.forEach(item => {
  html += `
    <tr>
      <td>${item.product_id}</td>
      <td>${item.product_name}</td>
      <td>${item.current_stock}</td>
      <td>${item.alert_stock}</td>
    </tr>
  `;
});

html += `</table>`;

return [{ html }];

节点5:邮件发送

  1. 添加"Email (SMTP)"节点连接到Function节点

  2. 点击"Create new credential"配置SMTP服务:

    • User: 发件邮箱

    • Password: 邮箱密码或授权码

    • Host: SMTP服务器地址(如smtp.gmail.com)

    • Port: 465(SSL)或587(TLS)

    • Secure: true(SSL)或false(TLS)

  3. 配置邮件内容:

    • From: 发件人邮箱

    • To: 收件人邮箱(如proxy@tiktoksim.com)

    • Subject: "每日代理IP报告 - {{$now.format('YYYY-MM-DD')}}"

    • Email Type: HTML

    • Message: {{$node["Function"].json["html"]}}

测试与调试

  1. 点击右上角的"Execute workflow"手动测试工作流

  2. 检查每个节点的输出是否符合预期:

    • MySQL节点应返回查询结果

    • Function节点应生成正确的HTML

    • Email节点应成功发送邮件

  3. 在节点的"Options"中启用"Always Output Data"可以查看节点处理的数据

高级优化

1. 分批处理大数据

如果查询结果很多,可以使用"SplitInBatches"节点分批发送邮件,避免单封邮件过大:

  1. 在MySQL和Function节点之间添加"SplitInBatches"节点

  2. 设置Batch Size为10(每封邮件包含10条记录)

  3. 将Email节点连接到SplitInBatches节点

2. 错误处理

  1. 添加"Error Trigger"节点捕获工作流中的错误

  2. 配置错误通知方式(如发送到Slack或另一封邮件)

3. 数据持久化

  1. 使用Supabase作为n8n的数据库(替代默认的SQLite)

  2. 配置环境变量:

    env

    DB_TYPE=postgresdb
    DB_POSTGRESDB_DATABASE=your_db_name
    DB_POSTGRESDB_HOST=your_supabase_host
    DB_POSTGRESDB_PORT=5432
    DB_POSTGRESDB_USER=postgres
    DB_POSTGRESDB_PASSWORD=your_password

    这样可以确保工作流数据和凭证在重启后不会丢失

部署到生产环境

如果使用Railway部署n8n,可以:

  1. 在Railway的项目设置中添加所有必要的环境变量

  2. 配置自定义域名(如n8n.tiktoksim.com)

  3. 设置N8N_ENCRYPTION_KEY环境变量,确保凭证加密安全

  4. 启用EXECUTIONS_DATA_PRUNE自动清理旧数据,防止数据库过大

扩展应用

这个基础工作流可以进一步扩展:

  1. 多通知渠道:添加Slack、企业微信等通知方式

  2. 自动补货:连接采购系统API,当库存低于警戒值时自动创建采购订单

  3. 数据分析:将查询结果保存到Google Sheets或Notion,形成历史记录

  4. AI增强:使用MCP节点接入大模型,让AI分析库存趋势并给出补货建议

总结

通过这个用例,我们展示了如何使用n8n构建一个完整的自动化工作流,从数据库查询到邮件通知。n8n的强大之处在于:

  1. 可视化编排:无需编写复杂代码即可连接各种服务

  2. 丰富的节点库:支持数百种常见应用和服务

  3. 灵活部署:可以在本地Docker运行,也可以部署到云平台

  4. 扩展性强:可以通过社区节点或自定义代码扩展功能

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2342004.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python爬虫与代理IP:高效抓取数据的实战指南

目录 一、基础概念解析 1.1 爬虫的工作原理 1.2 代理IP的作用 二、环境搭建与工具选择 2.1 Python库准备 2.2 代理IP选择技巧 三、实战步骤分解 3.1 基础版&#xff1a;单线程免费代理 3.2 进阶版&#xff1a;多线程付费代理池 3.3 终极版&#xff1a;Scrapy框架自动…

Unity 将Excel表格中的数据导入到Mysql数据表中

1.Mysql数据表users如下&#xff1a; 2.即将导入的Excel表格如下&#xff1a; 3.代码如下&#xff1a; using System; using System.Data; using System.IO; using Excel; using MySql.Data.MySqlClient; using UnityEngine; using UnityEditor;public class ImportExcel {// …

JavsScript 原型链

解决构造函数浪费内存的问题 每一个构造函数都有一个属性prototype属性&#xff0c;指向一个原型对象 原型是构造函数的一个属性 prototype 给数组类型扩展 正常代码&#xff1a; prototype中的this指向为调用对象 所以 基本关系&#xff1a;构造函数产生两个部分&…

消息中间件RabbitMQ02:账号的注册、点对点推送信息

一、默认用户登录和账号注册 1.登录 安装好了RMQ之后&#xff0c;我们可以访问如下地址&#xff1a; RabbitMQ Management 输入默认的管理员密码&#xff0c;4.1.0的管理员账号和密码是&#xff1a; guest guest 2.添加账号 consumer consumer 添加成功后&#xff1a; 角色…

大语言模型的评估指标

目录 一、混淆矩阵 1. 混淆矩阵的结构&#xff08;二分类为例&#xff09; 2.从混淆矩阵衍生的核心指标 3.多分类任务的扩展 4. 混淆矩阵的实战应用 二、分类任务核心指标 1. Accuracy&#xff08;准确率&#xff09; 2. Precision&#xff08;精确率&#xff09; 3. …

好用————python 库 下载 ,整合在一个小程序 UIUIUI

上图~ import os import time import threading import requests import subprocess import importlib import tkinter as tk from tkinter import ttk, messagebox, scrolledtext from concurrent.futures import ThreadPoolExecutor, as_completed from urllib.parse im…

OpenVINO教程(五):实现YOLOv11+OpenVINO实时视频目标检测

目录 实现讲解效果展示完整代码 本文作为上篇博客的延续&#xff0c;在之前实现了图片推理的基础上&#xff0c;进一步介绍如何进行视频推理。 实现讲解 首先&#xff0c;我们需要对之前的 predict_and_show_image 函数进行拆分&#xff0c;将图像显示与推理器&#xff08;pre…

CentOS的安装以及网络配置

CentOS的下载 在学习docker之前&#xff0c;我们需要知道的就是docker是运行在Linux内核之上的&#xff0c;所以我们需要Linux环境的操作系统&#xff0c;当然了你也可以选择安装ubuntu等操作系统&#xff0c;如果你不想在本机安装的话还可以考虑买阿里或者华为的云服务器&…

「Java EE开发指南」用MyEclipse开发EJB 3无状态会话Bean(二)

本教程介绍在MyEclipse中开发EJB 3无状态会话bean&#xff0c;由于JPA实体和EJB 3实体非常相似&#xff0c;因此本教程不涉及EJB 3实体Bean的开发。在本教程中&#xff0c;您将学习如何&#xff1a; 创建EJB 3项目创建无状态会话bean部署并测试bean 在上文中&#xff08;点击…

深度学习在DOM解析中的应用:自动识别页面关键内容区块

摘要 本文介绍了如何在爬取东方财富吧&#xff08;https://www.eastmoney.com&#xff09;财经新闻时&#xff0c;利用深度学习模型对 DOM 树中的内容区块进行自动识别和过滤&#xff0c;并将新闻标题、时间、正文等关键信息分类存储。文章聚焦爬虫整体性能瓶颈&#xff0c;通…

PyQt6实例_pyqtgraph多曲线显示工具_代码分享

目录 概述 效果 代码 返回结果对象 字符型横坐标 通用折线图工具 工具主界面 使用举例 概述 1 分析数据遇到需要一个股票多个指标对比或一个指标多个股票对比&#xff0c;涉及到同轴多条曲线的显示&#xff0c;所以开发了本工具。 2 多曲线显示部分可以当通用工具使…

Linux网络编程 多线程Web服务器:HTTP协议与TCP并发实战

问题解答 TCP是如何防止SYN洪流攻击的&#xff1f; 方式有很多种&#xff0c;我仅举例部分&#xff1a; 1、调整内核参数 我们知道SYN洪流攻击的原理就是发送一系列无法完成三次握手的特殊信号&#xff0c;导致正常的能够完成三次握手的信号因为 连接队列空间不足&#xff…

Qt 下载的地址集合

Qt 下载离线安装包 download.qt.io/archive/qt/5.14/5.14.2/ Qt 6 安装下载在线安装包 Index of /qt/official_releases/online_installers/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror

ubuntu下gcc/g++安装及不同版本切换

1. 查看当前gcc版本 $ gcc --version# 查看当前系统中已安装版本 $ ls /usr/bin/gcc*2. 安装新版本gcc $ sudo apt-get update# 这里以版本12为依据&#xff08;也可以通过源码方式安装&#xff0c;请自行Google&#xff01;&#xff09; $ sudo apt-get install -y gcc-12 g…

FPGA入门学习Day1——设计一个DDS信号发生器

目录 一、DDS简介 &#xff08;一&#xff09;基本原理 &#xff08;二&#xff09;主要优势 &#xff08;三&#xff09;与传统技术的对比 二、FPGA存储器 &#xff08;一&#xff09;ROM波形存储器 &#xff08;二&#xff09;RAM随机存取存储器 &#xff08;三&…

微信小程序拖拽排序有效果图

效果图 .wxml <view class"container" style"--w:{{w}}px;" wx:if"{{location.length}}"><view class"container-item" wx:for"{{list}}" wx:key"index" data-index"{{index}}"style"--…

WT2000T专业录音芯片:破解普通录音设备信息留存、合规安全与远程协作三大难题

在快节奏的现代商业环境中&#xff0c;会议是企业决策、创意碰撞和战略部署的核心场景。然而&#xff0c;传统会议记录方式常面临效率低、信息遗漏、回溯困难等痛点。如何确保会议内容被精准记录并高效利用&#xff1f;会议室专用录音芯片应运而生&#xff0c;以智能化、高保真…

【Python 学习笔记】 pip指令使用

系列文章目录 pip指令使用 文章目录 系列文章目录前言安装配置使用pip 管理Python包修改pip下载源 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 当前文章记录的是我在学习过程的一些笔记和思考&#xff0c;可能存在有误解的地方&#xff0c;仅供大家…

C# 文件读取

文件读取是指使用 C# 程序从计算机文件系统中获取文件内容的过程。将存储在磁盘上的文件内容加载到内存中&#xff0c;供程序处理。主要类型有&#xff1a;文本文件读取&#xff08;如 .txt, .csv, .json, .xml&#xff09;&#xff1b;二进制文件读取&#xff08;如 .jpg, .pn…

leetcode125.验证回文串

class Solution {public boolean isPalindrome(String s) {s s.replaceAll("[^a-zA-Z0-9]", "").toLowerCase();for(int i0,js.length()-1;i<j;i,j--){if(s.charAt(i)!s.charAt(j))return false;}return true;} }