簡體   English   中英

將文件路由到Queue Apache Camel

[英]Route file to Queue Apache Camel

我需要從文件夾中讀取文件並將其放在隊列中。

這是我的代碼:

import java.io.File;

import org.apache.camel.CamelContext;
import org.apache.camel.Exchange;
import org.apache.camel.LoggingLevel;
import org.apache.camel.Processor;
import org.apache.camel.builder.RouteBuilder;
import org.apache.camel.impl.DefaultCamelContext;

public class FileMove{
    public static void main(final String[] arguments) {
        final CamelContext camelContext = new DefaultCamelContext();
        try {
            camelContext.addRoutes(new RouteBuilder() {
                @Override
                public void configure() throws Exception {

                    from("file://E:/TestingWatch1/input?preMove=staging&move=.completed&scheduler=quartz2&scheduler.cron=00+*/1+*+1/1+*+?+*")
                            .routeId("testRoute").process(new Processor() {
                                @Override
                                public void process(Exchange msg) throws Exception {
                                    File file = msg.getIn().getBody(File.class);
                                    String file1 = msg.getIn().getBody(String.class);
                                    System.out.println("" + file + file1);

                                }

                            }).
                            to("file://E:/TestingWatch1/output");
                }
            });
            camelContext.start();
            // Thread.sleep(10*60*1000);
            // camelContext.stop();
        } catch (Exception ex) {
            ex.printStackTrace();
        }
    }
}

我能夠讀取文件和文件內容,但需要將其放在隊列中。

如何使用Java DSL將文件或文件內容移動到隊列中?

謝謝,我找到了解決方案:這是代碼

import java.io.File;

import javax.jms.ConnectionFactory;

import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
import org.apache.camel.CamelContext;
import org.apache.camel.Exchange;
import org.apache.camel.LoggingLevel;
import org.apache.camel.Processor;
import org.apache.camel.builder.RouteBuilder;
import org.apache.camel.component.jms.JmsComponent;
import org.apache.camel.impl.DefaultCamelContext;

public class CopyTest {
    public static void main(final String[] arguments) {
        final CamelContext camelContext = new DefaultCamelContext();
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("admin", "admin",
                ActiveMQConnection.DEFAULT_BROKER_URL);
        camelContext.addComponent("test-jms", JmsComponent.jmsComponentAutoAcknowledge(connectionFactory));
        try {
            camelContext.addRoutes(new RouteBuilder() {
                @Override
                public void configure() throws Exception {

                    from("file://E:/TestingWatch1/input?preMove=staging&move=.completed&scheduler=quartz2&scheduler.cron=00+*/1+*+1/1+*+?+*")
                            .routeId("testRoute").process(new Processor() {
                                @Override
                                public void process(Exchange msg) throws Exception {
                                    File file = msg.getIn().getBody(File.class);
                                    String file1 = msg.getIn().getBody(String.class);
                                    System.out.println("" + file + file1);

                                }

                            }).to("test-jms:queue:testMQDestination").
                            to("file://E:/TestingWatch1/output");
                }
            });
            camelContext.start();
            // Thread.sleep(10*60*1000);
            // camelContext.stop();
        } catch (Exception ex) {
            ex.printStackTrace();
        }
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM