Apache Camel继承Spring Boot 实现文件远程复制和转移
pom.xml
<dependency>
<groupId>org.apache.camel</groupId>
<artifactId>camel-ftp</artifactId>
<version>2.18.0</version>
</dependency>
URI的格式
ftp://[username@]hostname[:port]/directoryname[?options]
sftp://[username@]hostname[:port]/directoryname[?options]
ftps://[username@]hostname[:port]/directoryname[?options]
如果未提供端口号,Camel将根据协议提供默认值(ftp = 21,sftp = 22,ftps = 2222)。
例:
ftp://173.5.206.53:2121/MHE/?username=ftpAdmin&password=123456&binary=true&passiveMode=true&delete=true&delay=60000 注:ftp的路径必须是 当前ip:端口 + 当前账号密码登陆进去的目录往下走(不能往上走,没权限),路径才会生效,否则不会报错,也不会进行文件操作
配置文件信息:
#文件压缩本地地址(备份)
ftp.local.backups.dir=file:D:/gz/backups?move=delete&delay=30s
#大数据服务器地址(备份)
ftp.bigdata.backups.adress=sftp://218.984.130.146:51268/../apps/chinamobile/bigdata/dataConsistencyRepair/backups/?username=root&password=Redoor2018@net123&delay=30s #大数据服务器修复地址(运维存放文件夹,使用后存放到备份文件中)
ftp.bigdatarepair.adress=sftp://218.984.130.146:51268/../apps/chinamobile/bigdata/bigdatarepair/?username=root&password=Redoor2018@net123&move=/apps/chinamobile/bigdata/bigdatarepair/backups&delay=30s
#本地文件修复地址(复制到自定义文件夹)
ftp.local.repair=file:D:/localrepair #对比大数据差异文件存放地址(通知运维)
ftp.bigdatadifference.adress=sftp://218.984.130.146:51268/../apps/chinamobile/bigdata/difference/?username=root&password=Redoor2018@net123&delay=30s camel.springboot.main-run-controller=true
文件实现文件复制,转移:
/**
* 远程文件监听和拉取
*/
@Component
public class DownLoadRouteBuilder extends RouteBuilder{ private Logger log = Logger.getLogger(DownLoadRouteBuilder.class); /**
* 文件压缩本地地址
*/
@Value("${ftp.local.dir}")
private String localFileDir; /**
* 大数据服务器地址
*/
@Value("${ftp.bigdata.adress}")
private String bigDataServer; /**
* 文件压缩本地地址(上传备份)
*/
@Value("${ftp.local.backups.dir}")
private String localFileDirBackups; /**
* 大数据服务器地址(上传备份)
*/
@Value("${ftp.bigdata.backups.adress}")
private String bigDataBackupsServer; /**
* 本地文件修复地址
*/
@Value("${ftp.local.repair}")
private String localRepair;
/**
* 大数据服务器修复地址
*/
@Value("${ftp.bigdatarepair.adress}")
private String bigDataRepairServer; /**
* 对比大数据差异文件存放地址
*/
@Value("${ftp.bigdatadifference.adress}")
private String bigdatadifference; @Override
public void configure() throws Exception {
//文件上传大数据
from(localFileDir).to(bigDataServer).process("transferDataProcessToBigData");
//文件上传大数据(上传备份) 备份文件不存redis有一份就好
from(localFileDirBackups).to(bigDataBackupsServer).process("transferDataProcessToBigData"); //修复文件拉取
from(bigDataRepairServer).to(localRepair).process("transferDataProcessBigDataRepairToLocal");
//对比大数据差异文件存放地址
from(bigdatadifference).to(bigdatadifference).process("transferDataProcessToBigDataDifference"); System.out.println("file download ok...");
log.info("远程文件监听和拉取 已启动.......");
} }
文件复制获取信息:
文件远程复制和移动以后,本对象中可以显示
文件一:
/**
* 监听本地修复文件
*/
@Component
public class TransferDataProcessBigDataRepairToLocal implements Processor{ private Logger log = Logger.getLogger(TransferDataProcessBigDataRepairToLocal.class); @Autowired
private RepairRedisUtil repairRedisUtil;
/**
* 本地文件修复地址
*/
@Value("${ftp.local.repair}")
private String localRepair; /**
* redis工具类
*/
@Autowired
RedisUtils redisUtils; /**
* 读取GZ压缩文件,多线程
*/
@Autowired
AsyncService asyncService; @Override
public void process(Exchange exchange) throws Exception {
GenericFileMessage<RandomAccessFile> inFileMessage = (GenericFileMessage<RandomAccessFile>) exchange.getIn();
String fileName = inFileMessage.getGenericFile().getFileName();//文件名
String splitTag = File.separator;//系统文件分隔符
String absolutePath = localRepair + splitTag + fileName;
System.out.println(absolutePath);//文件的绝对路径
System.out.println("read file and push to falcon..."); System.out.println("准备修复文件!");
//文件的绝对路径去掉:file:
String filePath = absolutePath.substring(absolutePath.indexOf("file:")+"file:".length()); //创建redisKey 项目名称,模块名称,功能名称,自定义名称
String bigdatarepair = redisUtils.buildRedisKey("OneLink","DataConsistencyRepair","bigdatarepair","list"); //文件名称解析并进行redis缓存
DataRepairCacheModel dataRepairModel = repairRedisUtil.getFileInfo(fileName);
//获取缓存key
String cacheKey = repairRedisUtil.getDataRepairCacheKey(dataRepairModel.getBusinessCode());
//文件名称缓存
repairRedisUtil.CacheRepairData(cacheKey,dataRepairModel,0); }
}
文件二:
/**
* 监听大数据服务器是否上传成功
*/
@Component
public class TransferDataProcessToBigData implements Processor{ private Logger log = Logger.getLogger(TransferDataProcessToBigData.class); /**
* redis工具类
*/
@Autowired
RedisUtils redisUtils; /**
* 大数据服务器地址
*/
@Value("${ftp.bigdata.adress}")
private String bigDataServer; @Override
public void process(Exchange exchange) throws Exception {
GenericFileMessage<RandomAccessFile> inFileMessage = (GenericFileMessage<RandomAccessFile>) exchange.getIn();
String fileName = inFileMessage.getGenericFile().getFileName();//文件名
String splitTag = File.separator;//系统文件分隔符
System.out.println(bigDataServer + splitTag + fileName);//文件的绝对路径
System.out.println("read file and push to falcon..."); //添加:判断redis是否存在,不存在就删除,存在就不管 //创建redisKey 项目名称,模块名称,功能名称,自定义名称
String redisName = redisUtils.buildRedisKey("OneLink","DataConsistencyRepair","upload","List");
//获取
Map<String, DataUploadModel> stringObjectMap = (Map<String, DataUploadModel>) JSON.parseObject((String)redisUtils.get(redisName),Map.class); //删除
stringObjectMap.remove(fileName); //将集合存入缓存中
redisUtils.set(redisName, JSONObject.toJSONString(stringObjectMap)); log.info("文件信息:"+fileName+"上传大数据服务器成功!");
log.info("文件信息:"+fileName+"从redis删除标记!");
}
}
文件三:
/**
* 对比大数据差异文件存放地址监听
*/
@Component
public class TransferDataProcessToBigDataDifference implements Processor{ private Logger log = Logger.getLogger(TransferDataProcessToBigDataDifference.class); /**
* redis工具类
*/
@Autowired
RedisUtils redisUtils;
@Autowired
private Task task; /**
* 对比大数据差异文件存放地址
*/
@Value("${ftp.bigdatadifference.adress}")
private String bigdatadifference; @Override
public void process(Exchange exchange) throws Exception {
GenericFileMessage<RandomAccessFile> inFileMessage = (GenericFileMessage<RandomAccessFile>) exchange.getIn();
String fileName = inFileMessage.getGenericFile().getFileName();//文件名
String splitTag = File.separator;//系统文件分隔符
System.out.println(bigdatadifference + splitTag + fileName);//文件的绝对路径
System.out.println("read file and push to falcon...");
task.send();
System.out.println("给运维发送邮件!");
}
}
官方API文档:http://camel.apache.org/ftp2.html
Apache Camel继承Spring Boot 实现文件远程复制和转移的更多相关文章
- Apache Camel 与 Spring Boot 集成,通过FTP定时采集、处理文件 (转)
1.概要: 本项目主要是通过在Spring平台上配置Camel.FTP,实现定时从FTP服务器下载文件到本地.解析文件.存入数据库等功能. 2.搭建空项目: Spring Boot有几种自动生成空项目 ...
- Apache Camel,Spring Boot 实现文件复制,转移 (转)
基本框架 Apache Camel Spring Boot Maven 开发过程 1.新建一个POM(quickstart)项目,在POM文件中添加Camel和Spring Boot的依赖 <p ...
- Spring Boot入门——文件上传与下载
1.在pom.xml文件中添加依赖 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="ht ...
- 51. spring boot属性文件之多环境配置【从零开始学Spring Boot】
原本这个章节是要介绍<log4j多环境不同日志级别的控制的>但是没有这篇文章做基础的话,学习起来还是有点难度的,所以我们先一起了解下spring boot属性文件之多环境配置,当然文章中也 ...
- spring boot:单文件上传/多文件上传/表单中多个文件域上传(spring boot 2.3.2)
一,表单中有多个文件域时如何实现说明和文件的对应? 1,说明和文件对应 文件上传页面中,如果有多个文件域又有多个相对应的文件说明时, 文件和说明如何对应? 我们在表单中给对应的file变量和text变 ...
- Spring Boot属性文件配置文档(全部)
This sample file is meant as a guide only. Do not copy/paste the entire content into your applicatio ...
- spring 及 spring boot 资源文件配置
Spring配置文件引入xml文件: <import resource=" " />标签使用总结 https://www.cnblogs.com/javahr/p/83 ...
- spring boot实现文件上传下载
spring boot 引入”约定大于配置“的概念,实现自动配置,节约了开发人员的开发成本,并且凭借其微服务架构的方式和较少的配置,一出来就占据大片开发人员的芳心.大部分的配置从开发人员可见变成了相对 ...
- 【Spring Boot】Spring Boot之使用Alibaba Cloud Toolkit(Idea插件)本地一键部署Spring Boot项目到远程服务器
一.Alibaba Cloud Toolkit(Idea插件)的安装 1)Alibaba Cloud Toolkit 介绍 Cloud Toolkit 是本地 IDE 插件,帮助开发者更高效地开发.测 ...
随机推荐
- JavaSE_01_Exception类
1.1 异常概念 指的是程序在执行过程中,出现的非正常的情况,最终会导致JVM的非正常停止. 在Java等面向对象的编程语言中,异常本身是一个类,产生异常就是创建异常对象并抛出了一个异常对象.Java ...
- leyou_04_vue.js的ajax请求方式
1.异步查询数据,自然是通过ajax查询,大家首先想起的肯定是jQuery.但jQuery与MVVM的思想不吻合,而且ajax只是jQuery的一小部分.因此不可能为了发起ajax请求而去引用这么大的 ...
- Nginx 的常用命令
nginx命令,先来一波基本操作: start nginx // 启动Nginx nginx -t // 测试配置文件 nginx -v // 查看Nginx版本 nginx -V // 查看Ngin ...
- 转:PLL 锁相环
原地址:http://fangjian0518.blog.163.com/blog/static/559196562011210103455430/ PLL的作用? 答:LPC2000系列ARM内部 ...
- Python爬虫笔记【一】模拟用户访问之webdriver用户登入——第三次(8)
经过post方法之后,因为有动态的value值所以再此回到用webdriver的解决上,但是在下载图片上会打开新打开一个链接,导致与网页图片不同即验证码同步问题,没办法只能想了一个笨法子,网页截图,唉 ...
- 2019.10.30 csp-s模拟测试94 反思总结
头一次做图巨的模拟题OWO 自从上一次听图巨讲课然后骗了小礼物以后一直对图巨印象挺好的233 T1: 对于XY取对数=Y*log(x) 对于Y!取对数=log(1*2*3*...*Y)=log1+lo ...
- css 一行或多行文字溢出以...的形式隐藏
一行文字溢出以...形式隐藏 我需要隐藏... css代码如下: white-space:nowrap; text-overflow:ellipsis; overflow:hidden; 多行文字溢出 ...
- Leetcode89. Gray Code格雷编码
给定一个代表编码总位数的非负整数 n,打印其格雷编码序列.格雷编码序列必须以 0 开头. 示例 1: 输入: 2 输出: [0,1,3,2] 解释: 00 - 0 01 - 1 11 - 3 10 - ...
- Lvs 环境搭建 vbox搭建centos6.9 vbox设置 centos上安装nginx
1.现在vbox上虚拟出3个虚拟机,分别为负载均衡器(Load Balance).实际服务器1(Real server1).实际服务器2(Real Server2) 要点: :vbox系统网络连接方式 ...
- Zookeeper 扫盲
Zookeeper 扫盲 :disappointed_relieved: 配置文件详解: tickTime:基本事件单元,以毫秒为单位,这个时间作为 Zookeeper 服务器之间或客户端之间维持心跳 ...