n8n部署安装(docker)、支持Code in Python (Native)节点

n8n部署安装(docker)、支持Code in Python (Native)节点

前提条件:
docker、docker compose已部署安装,可参考docker和docker compose部署安装

文件目录结构:

n8n/ ├─ docker-compose.yaml ├─ .env ├─ n8n-task-runners.json 

一、部署安装

1.镜像拉取

docker pull docker.n8n.io/n8nio/n8n #如果下载不下来,可用国内镜像,但是这个镜像名字要和国内镜像网址上的名字一致,比如国内轩辕镜像用的是 docker pull n8nio/n8n 

2.创建docker-compose.yaml配置文件

version:'3'services:n8n:image: n8nio/n8n container_name: n8n restart: always ports:-"5678:5678"env_file:- .env environment:# 开启 task runners- N8N_RUNNERS_ENABLED=true # 使用 external 模式(必须)- N8N_RUNNERS_MODE=external # runner 通信- N8N_RUNNERS_AUTH_TOKEN=super-secret-token - N8N_RUNNERS_TIMEOUT=300 - N8N_RUNNERS_BROKER_LISTEN_ADDRESS=0.0.0.0 - N8N_NATIVE_PYTHON_RUNNER=true # 基本设置- GENERIC_TIMEZONE=Asia/Shanghai - N8N_SECURE_COOKIE=false volumes:- n8n_data:/home/node/.n8n depends_on:- n8n-runner n8n-runner:image: n8nio/runners:latest container_name: n8n-runner restart: always environment:- N8N_RUNNERS_AUTH_TOKEN=super-secret-token - N8N_RUNNERS_GRACEFUL_SHUTDOWN_TIMEOUT=30 - N8N_RUNNERS_TASK_BROKER_URI=http://n8n:5679- N8N_RUNNERS_STDLIB_ALLOW=* volumes:- runner_data:/data - ./n8n-task-runners.json:/etc/n8n-task-runners.json volumes:n8n_data:runner_data:

3.创建.env文件

N8N_BASIC_AUTH_ACTIVE=true N8N_BASIC_AUTH_USER=admin N8N_BASIC_AUTH_PASSWORD=admin123 # change_this_to_random_string需要进行替换,生成方式:在宿主机执行openssl rand -hex 16即可得到N8N_ENCRYPTION_KEY=change_this_to_random_string 

4.创建n8n-task-runners.json文件

{"task-runners":[{"runner-type":"javascript","workdir":"/home/runner","command":"/usr/local/bin/node","args":["--disallow-code-generation-from-strings","--disable-proto=delete","/opt/runners/task-runner-javascript/dist/start.js"],"health-check-server-port":"5681","allowed-env":["PATH","GENERIC_TIMEZONE","NODE_OPTIONS","N8N_RUNNERS_AUTO_SHUTDOWN_TIMEOUT","N8N_RUNNERS_TASK_TIMEOUT","N8N_RUNNERS_MAX_CONCURRENCY","N8N_SENTRY_DSN","N8N_VERSION","ENVIRONMENT","DEPLOYMENT_NAME"],"env-overrides":{"NODE_FUNCTION_ALLOW_BUILTIN":"crypto","NODE_FUNCTION_ALLOW_EXTERNAL":"moment","N8N_RUNNERS_HEALTH_CHECK_SERVER_HOST":"0.0.0.0"}},{"runner-type":"python","workdir":"/home/runner","command":"/opt/runners/task-runner-python/.venv/bin/python","args":["-m","src.main"],"health-check-server-port":"5682","allowed-env":["PATH","N8N_RUNNERS_LAUNCHER_LOG_LEVEL","N8N_RUNNERS_AUTO_SHUTDOWN_TIMEOUT","N8N_RUNNERS_TASK_TIMEOUT","N8N_RUNNERS_MAX_CONCURRENCY","N8N_RUNNERS_STDLIB_ALLOW","N8N_SENTRY_DSN","N8N_VERSION","ENVIRONMENT","DEPLOYMENT_NAME"],"env-overrides":{"PYTHONPATH":"/opt/runners/task-runner-python","N8N_RUNNERS_EXTERNAL_ALLOW":""}}]}

5.启动运行

docker compose up -d

浏览器访问:http://ip:5678

二、FAQ

1.Error: Mismatching encryption keys. The encryption key in the settings file /home/node/.n8n/config does not match the N8N_ENCRYPTION_KEY env var. Please make sure both keys match

原因:新配置的 N8N_ENCRYPTION_KEY 和 n8n 已存储在配置文件中的旧密钥不匹配,导致 n8n 启动失败。这是因为你之前未配置密钥时,n8n 自动生成了临时密钥并保存在 /home/node/.n8n/config 文件中,现在新密钥和旧密钥冲突了。

步骤 1:找到旧加密密钥

进入 n8n 数据卷目录,查看配置文件中的旧密钥:

# 1. 找到 n8n 数据卷的实际挂载路径 docker volume inspect n8n_n8n_data | grep Mountpoint # 输出示例:"Mountpoint": "/var/lib/docker/volumes/n8n_n8n_data/_data" # 2. 进入该目录,查看 config 文件(替换为你查到的 Mountpoint 路径) cd /var/lib/docker/volumes/n8n_n8n_data/_data cat config 

config 文件中找到 encryptionKey 字段,示例:

{ "encryptionKey": "abc123def456ghi789jkl000mnop111qrs", "instanceId": "xxx" } 

复制 encryptionKey 后的字符串(这就是旧密钥)。

步骤 2:将旧密钥配置为 N8N_ENCRYPTION_KEY

修改.env文件的此处配置,重启即可。

2.Problem in node ‘Code in Python (Native)‘ Security violations detected

这个报错 “Security violations detected” 的原因是:n8n 的 Python Code 节点默认禁用了外部模块的导入,属于安全限制。

解决方法:

检查docker-compose.yaml文件是否有N8N_RUNNERS_STDLIB_ALLOW=*./n8n-task-runners.json:/etc/n8n-task-runners.json配置

n8n-task-runners.json文件内容是否正确。

参考链接:

  • https://jishuzhan.net/article/2007720869788434434
  • https://community.n8n.io/t/libraries-desallowed-in-n8n-code-node-n8n-cloud/203666/12

Read more

Flutter 三方库 web_ffi 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、透明、全场景的 Web 浏览器 FFI(外部函数接口)与 WebAssembly 跨平台调用引擎

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 web_ffi 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、透明、全场景的 Web 浏览器 FFI(外部函数接口)与 WebAssembly 跨平台调用引擎 在鸿蒙(OpenHarmony)系统的 Web 浏览器环境(Webview/Ohos Browser)开发高性能 Web 应用时,如何调用现有的 C/C++ 算法库(Wasm 格式)且能保持与原生 HAP 环境下的 dart:ffi 接口完全一致?web_ffi 为开发者提供了一套工业级的、基于 JS 绑定的

By Ne0inhk
Flutter 组件 ignorium 的适配 鸿蒙Harmony 实战 - 驾驭代码生成忽略审计、实现鸿蒙端构建产物精准管理与资源泄露防护方案

Flutter 组件 ignorium 的适配 鸿蒙Harmony 实战 - 驾驭代码生成忽略审计、实现鸿蒙端构建产物精准管理与资源泄露防护方案

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 ignorium 的适配 鸿蒙Harmony 实战 - 驾驭代码生成忽略审计、实现鸿蒙端构建产物精准管理与资源泄露防护方案 前言 在鸿蒙(OpenHarmony)生态的超大规模工程开发中,代码生成(Code Generation)技术(如 build_runner)是提效的利器,但同时也带来了一个令人头疼的并发症:构建产物的急剧膨胀。面对动辄数千个生成的 .g.dart、.fb.dart 以及各种缓存占位文件。如果缺乏一套严密的忽略审计机制,不仅会导致 IDE 索引变慢、IDE 搜索结果被垃圾信息淹没,更严重的是,某些带有敏感信息的生成代码可能会被误提交到仓库中。 我们需要一种“逻辑可控”的构建过滤器。 ignorium 是一套专为代码生成与静态分析设计的忽略路径审计引擎。它允许你通过定义严密的模式规则。精确控制哪些生成文件应该被存留,哪些应该在构建后立即从宿主机环境抹除。

By Ne0inhk
Flutter for OpenHarmony:Flutter 三方库 gql_http_link — 开启鸿蒙端的 GraphQL 高效请求链路(适配鸿蒙 HarmonyOS Next ohos)

Flutter for OpenHarmony:Flutter 三方库 gql_http_link — 开启鸿蒙端的 GraphQL 高效请求链路(适配鸿蒙 HarmonyOS Next ohos)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net。 Flutter for OpenHarmony:Flutter 三方库 gql_http_link — 开启鸿蒙端的 GraphQL 高效请求链路(适配鸿蒙 HarmonyOS Next ohos) 前言 在现代前端开发中,相比于传统的 RESTful API,GraphQL 以其精准的数据获取能力(Query exactly what you need)极大地提升了前后端数据交互的效率。尤其是在需要频繁对接复杂后端、减少网络负载的鸿蒙跨平台应用中,GraphQL 更是不可或缺。 在 Flutter for OpenHarmony 开发中,构建一条稳定、高效的请求链路是成功的基石。gql_http_link 库作为 gql 生态的核心组件,

By Ne0inhk
Flutter for OpenHarmony: Flutter 三方库 flutter_chat_types 构建鸿蒙端标准化即时通讯数据模型(IM 开发基石)

Flutter for OpenHarmony: Flutter 三方库 flutter_chat_types 构建鸿蒙端标准化即时通讯数据模型(IM 开发基石)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在开发 OpenHarmony 的即时通讯(IM)应用时,如何定义一套稳定、可扩展的消息模型(Message Schema)是所有业务的起点。如果每个开发者都从零开始定义 Text, Image, File 等消息类型,不仅浪费时间,还难以兼容社区中丰富的 IM UI 组件库(如 flutter_chat_ui)。 flutter_chat_types 提供了这一问题的终极标准答案。它定义了一套纯粹、强类型且符合行业通向规范的消息对象模型,让你的鸿蒙应用能以最快速度搭建起专业的聊天协议底层。 一、核心消息体系结构 flutter_chat_types 定义了一个分层明确、高度解耦的消息树。 Message (基础消息类) TextMessage (文本) ImageMessage (图图片)

By Ne0inhk