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提供了大量能使我们快速便捷地处理数据的函数和方法。

相关推荐
yzx9910133 小时前
实时数据处理实战:使用 Apache Flink 消费 Kafka 数据并进行窗口聚合
flink·kafka·apache
Shepherd061921 小时前
【IT 实战】Apache 反向代理 UniFi Controller 的终极指北(解决白屏、502、400 错误)
运维·网络·apache·it·unifi
额1291 天前
CentOS 7 安装apache部署discuz导入数据库表
数据库·centos·apache
qzhqbb1 天前
Nginx/Apache 访问规则
运维·nginx·apache
HashData酷克数据2 天前
# Apache Cloudberry 2.1.0 版本前瞻:内核、PXF 与备份生态持续演进
apache
D愿你归来仍是少年2 天前
Apache Spark 第 8 章:Structured Streaming 流处理
大数据·spark·apache
努力的lpp3 天前
小迪安全第8天:基础入门-算法分析 & 传输加密 & 数据格式 & 密文存储 & 代码混淆 & 逆向保护
服务器·网络·apache
爱人间3 天前
apache-tomcat-8.5.72启动控制台乱码解决方案
java·tomcat·apache
XDHCOM3 天前
Apache Mesos科普,提升资源利用率与系统扩展性的开源平台
开源·apache