使用n8n构建自动化工作流:从数据库查询到邮件通知的使用指南
n8n是一款强大的开源工作流自动化工具,可以帮助你将各种服务和应用程序连接起来,创建复杂的自动化流程。下面我将详细介绍一个实用的n8n用例:从MySQL数据库查询数据并发送邮件通知,包括使用场景、搭建步骤和节点部署方法。
使用场景
场景描述:假设你是一家电商公司的运营人员,需要每天上午10点检查库存量低于警戒值的商品,并自动发送邮件通知采购部门及时补货。
工作流功能:
-
定时触发工作流(每天上午10点)
-
连接MySQL数据库查询库存数据
-
筛选出库存量低于警戒值的商品
-
将查询结果格式化为易读的HTML表格
-
通过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零成本搭建(适合生产环境)
-
在Supabase创建数据库项目,记录连接信息
-
在GitHub创建仓库并添加简单的Dockerfile
-
在Railway部署项目,关联GitHub仓库
-
设置环境变量(数据库连接、加密密钥等)
-
配置自定义域名(可选)
2. 创建工作流
-
登录n8n后,点击"Add workflow"创建新工作流
-
点击右上角的"Workflow settings"设置工作流名称和描述
部署节点与配置
以下是完整的工作流节点配置步骤:
节点1:Cron定时触发器
-
从左侧面板拖拽"Cron"节点到画布
-
配置属性:
-
Mode: Every Day
-
Hour: 10
-
Minute: 0
-
-
这个节点会在每天上午10点自动触发工作流
节点2:MySQL数据库查询
-
添加"MySQL"节点并连接到Cron节点
-
点击"Create new credential"配置数据库连接:
-
Host: 数据库服务器地址
-
Database: 数据库名称
-
User: 数据库用户名
-
Password: 数据库密码
-
Port: 3306(默认)
-
-
在Operation中选择"Select"
-
在Query中填写SQL语句:
sql
SELECT product_id, product_name, current_stock, alert_stock FROM products WHERE current_stock < alert_stock
节点3:IF条件判断(可选)
-
添加"IF"节点连接到MySQL节点
-
配置条件判断是否有低库存商品:
-
条件1:
{{$node["MySQL"].json["length"] > 0}} -
这样当查询结果为空时,工作流会终止而不发送空邮件
-
节点4:HTML格式化
-
添加"Function"节点连接到IF节点(True分支)
-
编写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:邮件发送
-
添加"Email (SMTP)"节点连接到Function节点
-
点击"Create new credential"配置SMTP服务:
-
User: 发件邮箱
-
Password: 邮箱密码或授权码
-
Host: SMTP服务器地址(如smtp.gmail.com)
-
Port: 465(SSL)或587(TLS)
-
Secure: true(SSL)或false(TLS)
-
-
配置邮件内容:
-
From: 发件人邮箱
-
To: 收件人邮箱(如proxy@tiktoksim.com)
-
Subject: "每日代理IP报告 - {{$now.format('YYYY-MM-DD')}}"
-
Email Type: HTML
-
Message:
{{$node["Function"].json["html"]}}
-
测试与调试
-
点击右上角的"Execute workflow"手动测试工作流
-
检查每个节点的输出是否符合预期:
-
MySQL节点应返回查询结果
-
Function节点应生成正确的HTML
-
Email节点应成功发送邮件
-
-
在节点的"Options"中启用"Always Output Data"可以查看节点处理的数据
高级优化
1. 分批处理大数据
如果查询结果很多,可以使用"SplitInBatches"节点分批发送邮件,避免单封邮件过大:
-
在MySQL和Function节点之间添加"SplitInBatches"节点
-
设置Batch Size为10(每封邮件包含10条记录)
-
将Email节点连接到SplitInBatches节点
2. 错误处理
-
添加"Error Trigger"节点捕获工作流中的错误
-
配置错误通知方式(如发送到Slack或另一封邮件)
3. 数据持久化
-
使用Supabase作为n8n的数据库(替代默认的SQLite)
-
配置环境变量:
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,可以:
-
在Railway的项目设置中添加所有必要的环境变量
-
配置自定义域名(如n8n.tiktoksim.com)
-
设置N8N_ENCRYPTION_KEY环境变量,确保凭证加密安全
-
启用EXECUTIONS_DATA_PRUNE自动清理旧数据,防止数据库过大
扩展应用
这个基础工作流可以进一步扩展:
-
多通知渠道:添加Slack、企业微信等通知方式
-
自动补货:连接采购系统API,当库存低于警戒值时自动创建采购订单
-
数据分析:将查询结果保存到Google Sheets或Notion,形成历史记录
-
AI增强:使用MCP节点接入大模型,让AI分析库存趋势并给出补货建议
总结
通过这个用例,我们展示了如何使用n8n构建一个完整的自动化工作流,从数据库查询到邮件通知。n8n的强大之处在于:
-
可视化编排:无需编写复杂代码即可连接各种服务
-
丰富的节点库:支持数百种常见应用和服务
-
灵活部署:可以在本地Docker运行,也可以部署到云平台
-
扩展性强:可以通过社区节点或自定义代码扩展功能
相关文章:
使用n8n构建自动化工作流:从数据库查询到邮件通知的使用指南
n8n是一款强大的开源工作流自动化工具,可以帮助你将各种服务和应用程序连接起来,创建复杂的自动化流程。下面我将详细介绍一个实用的n8n用例:从MySQL数据库查询数据并发送邮件通知,包括使用场景、搭建步骤和节点部署方法。 使用场…...
Python爬虫与代理IP:高效抓取数据的实战指南
目录 一、基础概念解析 1.1 爬虫的工作原理 1.2 代理IP的作用 二、环境搭建与工具选择 2.1 Python库准备 2.2 代理IP选择技巧 三、实战步骤分解 3.1 基础版:单线程免费代理 3.2 进阶版:多线程付费代理池 3.3 终极版:Scrapy框架自动…...
Unity 将Excel表格中的数据导入到Mysql数据表中
1.Mysql数据表users如下: 2.即将导入的Excel表格如下: 3.代码如下: using System; using System.Data; using System.IO; using Excel; using MySql.Data.MySqlClient; using UnityEngine; using UnityEditor;public class ImportExcel {// …...
JavsScript 原型链
解决构造函数浪费内存的问题 每一个构造函数都有一个属性prototype属性,指向一个原型对象 原型是构造函数的一个属性 prototype 给数组类型扩展 正常代码: prototype中的this指向为调用对象 所以 基本关系:构造函数产生两个部分&…...
MySQL 索引:深度解析与高效使用
MySQL 索引:深度解析与高效使用 引言 MySQL 是一种广泛使用的开源关系型数据库管理系统,其强大的功能和性能使其成为众多应用程序的首选数据库。在 MySQL 中,索引是提高查询效率的关键因素之一。本文将深入探讨 MySQL 索引的概念、类型、创建、优化以及注意事项,帮助您更…...
消息中间件RabbitMQ02:账号的注册、点对点推送信息
一、默认用户登录和账号注册 1.登录 安装好了RMQ之后,我们可以访问如下地址: RabbitMQ Management 输入默认的管理员密码,4.1.0的管理员账号和密码是: guest guest 2.添加账号 consumer consumer 添加成功后: 角色…...
大语言模型的评估指标
目录 一、混淆矩阵 1. 混淆矩阵的结构(二分类为例) 2.从混淆矩阵衍生的核心指标 3.多分类任务的扩展 4. 混淆矩阵的实战应用 二、分类任务核心指标 1. Accuracy(准确率) 2. Precision(精确率) 3. …...
Python 设计模式:模板模式
1. 什么是模板模式? 模板模式是一种行为设计模式,它定义了一个操作的算法的骨架,而将一些步骤延迟到子类中。模板模式允许子类在不改变算法结构的情况下,重新定义算法的某些特定步骤。 模板模式的核心思想是将算法的固定部分提取…...
HSTL详解
一、HSTL的基本定义 HSTL(High-Speed Transceiver Logic) 是一种针对高速数字电路设计的差分信号接口标准,主要用于高带宽、低功耗场景(如FPGA、ASIC、高速存储器接口)。其核心特性包括: 差分信号传输&…...
好用————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实时视频目标检测
目录 实现讲解效果展示完整代码 本文作为上篇博客的延续,在之前实现了图片推理的基础上,进一步介绍如何进行视频推理。 实现讲解 首先,我们需要对之前的 predict_and_show_image 函数进行拆分,将图像显示与推理器(pre…...
CentOS的安装以及网络配置
CentOS的下载 在学习docker之前,我们需要知道的就是docker是运行在Linux内核之上的,所以我们需要Linux环境的操作系统,当然了你也可以选择安装ubuntu等操作系统,如果你不想在本机安装的话还可以考虑买阿里或者华为的云服务器&…...
【初级】前端开发工程师面试100题(一)
本题库共计包含100题,考察html,css,js,以及react,vue,webpack等基础知识掌握情况。 HTML基础篇 说说你对HTML语义化的理解? 语义化就是用合适的标签表达合适的内容,比如<header&…...
eplan许可证与防火墙安全软件冲突
在使用EPLAN电气设计软件时,有时会遇到许可证与防火墙或安全软件之间的冲突。这种冲突可能导致许可证无法激活或软件无法正常运行,给用户带来诸多不便。本文将为您解析EPLAN许可证与防火墙/安全软件冲突的原因,并提供解决方案,帮助…...
「Java EE开发指南」用MyEclipse开发EJB 3无状态会话Bean(二)
本教程介绍在MyEclipse中开发EJB 3无状态会话bean,由于JPA实体和EJB 3实体非常相似,因此本教程不涉及EJB 3实体Bean的开发。在本教程中,您将学习如何: 创建EJB 3项目创建无状态会话bean部署并测试bean 在上文中(点击…...
Stable Diffusion秋叶整合包V4独立版Python本地API连接指南
秋叶整合包V4独立版Python本地API连接指南 秋叶整合的Stable Diffusion V4独立版支持通过Python调用本地API实现自动化图像生成。以下是具体操作流程及注意事项: 一、启用API服务 启动器配置 • 在秋叶启动器的 高级选项 中添加以下参数: --api --liste…...
小程序 GET 接口两种传值方式
前言 一般 GET 接口只有两种URL 参数和路径参数 一:URL 参数(推荐方式) 你希望请求: https://serve.zimeinew.com/wx/products/info?id5124接口应该写成这样,用 req.query.id 取 ?id5124: app.get(&…...
深度学习在DOM解析中的应用:自动识别页面关键内容区块
摘要 本文介绍了如何在爬取东方财富吧(https://www.eastmoney.com)财经新闻时,利用深度学习模型对 DOM 树中的内容区块进行自动识别和过滤,并将新闻标题、时间、正文等关键信息分类存储。文章聚焦爬虫整体性能瓶颈,通…...
PyQt6实例_pyqtgraph多曲线显示工具_代码分享
目录 概述 效果 代码 返回结果对象 字符型横坐标 通用折线图工具 工具主界面 使用举例 概述 1 分析数据遇到需要一个股票多个指标对比或一个指标多个股票对比,涉及到同轴多条曲线的显示,所以开发了本工具。 2 多曲线显示部分可以当通用工具使…...
Linux网络编程 多线程Web服务器:HTTP协议与TCP并发实战
问题解答 TCP是如何防止SYN洪流攻击的? 方式有很多种,我仅举例部分: 1、调整内核参数 我们知道SYN洪流攻击的原理就是发送一系列无法完成三次握手的特殊信号,导致正常的能够完成三次握手的信号因为 连接队列空间不足ÿ…...
【Vulkan 入门系列】创建帧缓冲、命令池、命令缓存,和获取图片(六)
这一节主要介绍创建帧缓冲(Framebuffer),创建命令池,创建命令缓存,和从文件加载 PNG 图像数据,解码为 RGBA 格式,并将像素数据暂存到 Vulkan 的 暂存缓冲区中。 一、创建帧缓冲 createFramebu…...
【Git】fork 和 branch 的区别
在 Git 中,“fork” 和 “branch” 是两个不同的概念,它们用于不同的场景并且服务于不同的目的。理解这两者的区别对于有效地使用 Git 进行版本控制非常重要。 1. Fork(分叉) 定义 Fork 是指在 GitHub、GitLab 等代码托管平台上…...
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...
java将pdf转换成word
1、jar包准备 在项目中新增lib目录,并将如下两个文件放入lib目录下 aspose-words-15.8.0-jdk16.jar aspose-pdf-22.9.jar 2、pom.xml配置 <dependency><groupId>com.aspose</groupId><artifactId>aspose-pdf</artifactId><versi…...
ubuntu下gcc/g++安装及不同版本切换
1. 查看当前gcc版本 $ gcc --version# 查看当前系统中已安装版本 $ ls /usr/bin/gcc*2. 安装新版本gcc $ sudo apt-get update# 这里以版本12为依据(也可以通过源码方式安装,请自行Google!) $ sudo apt-get install -y gcc-12 g…...
缓存与内存;缺页中断;缓存映射:组相联
文章目录 内存(RAM)与缓存(Cache)Memory Management Unit缺页中断 多级缓存缓存替换策略缓存的映射方式 内存(RAM)与缓存(Cache) 缓存: CPU 内部或非常靠近的高速存储&a…...
FPGA入门学习Day1——设计一个DDS信号发生器
目录 一、DDS简介 (一)基本原理 (二)主要优势 (三)与传统技术的对比 二、FPGA存储器 (一)ROM波形存储器 (二)RAM随机存取存储器 (三&…...
微信小程序拖拽排序有效果图
效果图 .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"--…...
elasticsearch 查询检索
一、查询方式列举 1、多维度查询 关键词:bool must match {"query": {"bool": {"must": [{"match": {"server_name": "www.test.com"}},{"range": { //时间查询"createTime": …...
WT2000T专业录音芯片:破解普通录音设备信息留存、合规安全与远程协作三大难题
在快节奏的现代商业环境中,会议是企业决策、创意碰撞和战略部署的核心场景。然而,传统会议记录方式常面临效率低、信息遗漏、回溯困难等痛点。如何确保会议内容被精准记录并高效利用?会议室专用录音芯片应运而生,以智能化、高保真…...
