0

0

Apache Camel如何定义一个从FTP接收XML的路由

月夜之吻

月夜之吻

发布时间:2026-02-25 08:52:02

|

520人浏览过

|

来源于php中文网

原创

camel ftp组件通过轮询而非监听获取xml文件,需配置filename匹配、move避免重复、consumer.delay控制间隔,binary=true和charset=utf-8保障xml完整性,onexception处理解析异常,connecttimeout等参数提升连接稳定性。

apache camel如何定义一个从ftp接收xml的路由

ftp 组件监听目录并拉取 XML 文件

Camel 的 ftp 组件本质是基于 Apache Commons Net 实现的,它不“监听”文件系统事件(比如 inotify),而是轮询(polling):定期列出远程目录,对比上次获取的文件名,决定是否拉取新文件。XML 只是文件内容类型,Camel 不会自动解析或校验,你得自己处理。

关键点:

  • fileName 参数控制匹配规则,推荐用 fileName=.*\.xml(注意双反斜杠转义)
  • movepreMove 必须设置,否则重复拉取同一文件(默认不移动,下次轮询还会看到)
  • consumer.delay 决定轮询间隔(毫秒),太短易被 FTP 服务器限流,太长则延迟高
  • 用户名密码不能明写在 URI 中,应通过 password 属性或 org.apache.camel.component.file.remote.RemoteFileConfiguration 注入
from("ftp://user@ftp.example.com/inbox?password=secret&binary=false&fileName=.*\.xml&consumer.delay=30000&move=done/${file:name}")
    .to("log:received-xml?showBody=true");

避免 XML 解析失败导致路由中断

FTP 拉取的文件可能不完整(如上传中)、编码异常、或根本不是合法 XML。Camel 默认遇到 Exception 会停止该 Exchange,并可能影响后续轮询(取决于错误处理器配置)。必须显式捕获并处理解析异常。

推荐做法:

HIX.AI
HIX.AI

HIX.AI是一个多功能的一体化AI写作助手,集成了120多种AI写作工具,支持50多种语言,能够满足各种写作需求。

下载
  • onException 捕获 org.xml.sax.SAXParseExceptionjava.io.IOException
  • 使用 handled(true) 防止重试和死信队列干扰主流程
  • 把出错文件移到 error/ 目录,保留原始内容便于人工排查
onException(SAXParseException.class, IOException.class)
    .handled(true)
    .to("file:error?fileName=${file:name}.failed");

from("ftp://...")
    .convertBodyTo(String.class) // 确保是 String,避免 InputStream 导致 SAX 解析失败
    .to("xslt:strip-namespace.xsl") // 可选:预处理命名空间
    .unmarshal().jacksonXml(); // 或用 .jaxb(),但需提前定义类

FTP 连接不稳定时的重试与超时控制

企业级 FTP 服务器常有连接空闲断开、LIST 超时、PASV 模式失败等问题。Camel 的 ftp 组件底层复用连接,但默认不重试失败的 LIST 或 RETR 命令。

必须显式配置:

  • connectTimeoutsoTimeout(单位毫秒),建议都设为 30000
  • maximumReconnectAttempts 控制连接级重试次数(非单个文件)
  • stepwise 设为 false 可绕过某些 FTP 服务器的路径切换问题
  • 若用被动模式(PASV)失败,尝试加 passiveMode=true 并确认防火墙放行数据端口范围
from("ftp://user@ftp.example.com/inbox?password=secret&connectTimeout=30000&soTimeout=30000&maximumReconnectAttempts=3&stepwise=false&passiveMode=true&fileName=.*\.xml")

生产环境必须关闭 binary=false 吗?

不是必须,但强烈建议设为 true。FTP 协议本身区分 ASCII 和 binary 模式:binary=false(即 ASCII 模式)会触发换行符转换(CRLF ↔ LF),而 XML 对换行和空白敏感——尤其是带 xml:space="preserve" 的节点或 CDATA 段。一旦被改写,unmarshal().jacksonXml() 会直接抛 SAXParseException

唯一例外是明确知道远端 XML 全为 Unix 风格换行且无 CDATA,且你愿意承担风险。否则一律用:

  • binary=true
  • charset=UTF-8(显式声明,避免平台默认 charset 干扰)
from("ftp://user@ftp.example.com/inbox?password=secret&binary=true&charset=UTF-8&fileName=.*\.xml")
FTP 路由真正难的不是语法,而是对协议行为的理解:它不保证原子性,不通知变更,也不校验内容。你得自己补上幂等性(靠 idempotentRepository)、完整性(加 MD5 校验)、以及失败隔离(别让一个坏 XML 卡住整条轮询线程)。

相关文章

路由优化大师
路由优化大师

路由优化大师是一款及简单的路由器设置管理软件,其主要功能是一键设置优化路由、屏广告、防蹭网、路由器全面检测及高级设置等,有需要的小伙伴快来保存下载体验吧!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1934

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2109

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1135

2024.11.28

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

391

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

348

2023.10.25

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

720

2023.08.10

常见的编码方式
常见的编码方式

常见的编码方式有ASCII编码、Unicode编码、UTF-8编码、UTF-16编码、GBK编码等。想了解更多编码方式相关内容,可以阅读本专题下面的文章。

635

2023.10.24

a和A对应的ASCII码数值
a和A对应的ASCII码数值

a的ascii码是65,a的ascii码是97;ascii码表中,一个字母的大小写数值相差32,一般知道大写字母的ascii码数值,其对应的小写字母的ascii码数值就算出来了,是大写字母的ascii码数值“+32”。想了解更多相关的内容,可阅读本专题下面的相关文章。

2208

2024.10.24

Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

1

2026.02.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
RunnerGo从入门到精通
RunnerGo从入门到精通

共22课时 | 1.8万人学习

尚学堂Mahout视频教程
尚学堂Mahout视频教程

共18课时 | 3.3万人学习

Linux优化视频教程
Linux优化视频教程

共14课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号