Apache Camel使用教程一

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


前言

最近研究EIP,以前了解过Apache Camel,但是一直是不入门状态,闹不清楚其中的概念和用法,遂决定写一系列博客,记录下"""骆驼"的概念和使用API,一来熟悉使用,二来做个API留存,以后一旦有需要,直接查询博客,CTL+CV哈哈。

注:文中大部分代码样例来源:https://blog.csdn.net/column/details/19378.html,不过改博主已停止更新好多年,网页也打不开,但是吃水不忘挖井人,还是要申明下的,嘿嘿


一、骆驼-HelloWord?

按照惯例,首先还是上一段helloword代码

c 复制代码
public class APPHelloWorld01 extends RouteBuilder {
 public static void main(String[] args) throws Exception {
        ModelCamelContext camelContext = new DefaultCamelContext();
        camelContext.start();
        camelContext.addRoutes(new APPHelloWorld01());
        synchronized (APPHelloWorld01.class) {
            APPHelloWorld01.class.wait();
        }
    }
    @Override
    public void configure() throws Exception {
        // 在本代码段之下随后的说明中,会详细说明这个构造的含义
        from("jetty:http://127.0.0.1:8282/doHelloWorld").process(new HttpProcessor())
                .to("log:helloworld?showExchangeId=true");
    }
    public class HttpProcessor implements Processor {

        public void process(Exchange exchange) throws Exception {
            // 因为很明确消息格式是http的,所以才使用这个类
            // 否则还是建议使用org.apache.camel.Message这个抽象接口
            HttpMessage message = (HttpMessage) exchange.getIn();
            InputStream bodyStream = (InputStream) message.getBody();
            String inputContext = IOUtils.toString(bodyStream,"UTF-8");
            bodyStream.close();

            // 存入到exchange的out区域
            if (exchange.getPattern() == ExchangePattern.InOut) {
                Message outMessage = exchange.getOut();
                outMessage.setBody(inputContext + " || out");
            }
        }
    }
    }

测试

二、骆驼-组件

1.Choice Camel

代码如下(示例):

c 复制代码
//Processor 样例
public class Process implements Processor {
    @Override
    public void process(Exchange exchange) throws Exception {
        InputStream body = exchange.getIn().getBody(InputStream.class);
        String inputContext = IOUtils.toString(body, "UTF-8");
        if (exchange.getPattern() == ExchangePattern.InOut) {
            Message outMessage = exchange.getOut();
            outMessage.setBody(inputContext + " || 被Process04处理");
        }
    }
}
//提取json数据样例
JsonPathExpression jsonPathExpression = new JsonPathExpression("$.data.orgId");
jsonPathExpression.setResultType(String.class);
//一、从header读取值判断
from("jetty:http://0.0.0.0:8282/choiceCamel").process(new Process01())
                // 将orgId属性的值存储 exchange in Message的header中,以便后续进行判断
                .setHeader("orgId", jsonPathExpression)
                .choice()
                .when(header("orgId").isEqualTo("yuanbao")).process(new Process02())
                .when(header("orgId").isEqualTo("yinwenjie")).process(new Process03())
                .otherwise().process(new Process04())
                .endChoice();
//二、从body读取字符串判断
from("jetty:http://0.0.0.0:8080/choiceCamel").process(new Process())
                .choice()
                .when(body().contains("xiao")).process(new Process())
                .when(body().contains("da")).process(new Process())
                .otherwise().process(new Process())
                .endChoice();
//三、读取Json文件,对文件内容进行转换,接着判断对应字段值。body是关键字
        from("file:./jsonfile?noop=true")
                .unmarshal().json(JsonLibrary.Jackson, User.class)
                .choice()
                .when().simple("${body.name} == 'xiao'").process(new Process())
                .when().simple("${body.name} == 'da'").process(new Process())
                .otherwise().process(new Process07())
                .endChoice();   

//四、读取文件根据文件名称判断 (不过,这个也可以用file组件中的filter属性来做(效率比这个好))
from("file:./simple?noop=true")
                .unmarshal().json(JsonLibrary.Jackson, Order.class)
                .choice()
                .when(header("CamelFileName").isEqualTo("simple.json")).process(new Process05())
                .when(header("CamelFileName").isEqualTo("simple2.json")).process(new Process06())
                .otherwise().process(new Process07())
                .endChoice();

2.Dynamic Camel

代码如下(示例):

c 复制代码
data = pd.read_csv(
    'https://labfile.oss.aliyuncs.com/courses/1283/adult.data.csv')
print(data.head())

该处使用的url网络请求的数据。


总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

相关推荐
Ulyanov18 小时前
Apache Kafka在雷达仿真数据流处理中的应用
分布式·python·kafka·apache·雷达电子战
anzhxu1 天前
防火墙安全策略(基本配置)
服务器·php·apache
小郑加油1 天前
python学习Day6-7天:条件判断与基本综合应用
java·服务器·apache
架构源启3 天前
深度解析:Spring Boot + Apache OpenNLP 构建企业级 NLU 系统
spring boot·后端·apache
SeaTunnel3 天前
深度解析 Apache SeaTunnel 核心引擎三大技术创新:高可靠异步持久化与 CDC 架构优化实战
大数据·数据库·架构·apache·seatunnel
DolphinScheduler社区3 天前
第 8 篇|Apache DolphinScheduler 与 Flink Spark 数据引擎的边界、协同与最佳实践
大数据·flink·spark·开源·apache·海豚调度·大数据工作流调度
Apache IoTDB4 天前
Apache IoTDB V2.0.8 发布|新增模型并发推理,优化同步配置与安全加固
安全·apache·iotdb
蓝魔Y4 天前
Apache—Kafka实践
分布式·kafka·apache
Pocker_Spades_A5 天前
时序数据库选型指南:容量规划与压测方法(以 Apache IoTDB 为例)
apache·时序数据库·iotdb
云计算老刘6 天前
Keepalived + LVS(DR)+ Apache + NFS
apache·lvs