首页 > 解决方案 > Apache Camel - 创建自定义组件/端点?

问题描述

我需要从 Websocket 消费消息,但是在消费数据之前我必须做一些逻辑,所以我不能使用 Webscoket 组件。

我有一个 java 代码在这个 Websocket 中进行身份验证并订阅一个“传感器”来接收数据。

我可以创建一个使用此代码的骆驼组件,from()并且每次我收到新数据onNext()时骆驼都会启动该过程吗?

WebSocket webSocket = new WebSocket(uri, apiKey, (api, authenthication) -> {
      console.println("Authenticated successfully as " + authenthication.getUserName());
      String[] sensors = {sensorId};
      api.getMetrics(sensors).subscribe(metrics -> {
        Metric[] allMetrics = metrics.get(sensorId);
        Arrays.sort(allMetrics, (metric1, metric2) -> metric1.getId().compareTo(metric2.getId()));
        Metric firstMetric = allMetrics[0];
        console.println("Metric: " + firstMetric.getDisplayName());
        String metricId = firstMetric.getId();
        String[] metric = {metricId};
        api.getUnits(metric).subscribe(units -> {
          Unit unit = units.get(metric[0])[0];
          console.println("Unit: " + unit.getName());
          Instant now = Instant.now();
          Instant aMinuteAgo = now.minus(timeInterval, ChronoUnit.SECONDS);
          Date start = Date.from(aMinuteAgo);
          Date end = Date.from(now);
          api.getData(sensorId, metricId, unit.getId(), emptyMap(), start, end).subscribe(new DisposableObserver<Data>() {

            @Override
            public void onNext(Data data) {
              console.println("Data from last " + timeInterval + " seconds: ");
              console.println(data.getData());
            }

            @Override
            public void onComplete() {
              console.println("Data update:");
              Disposable subscription = api.subscribeData(sensors, metricId, unit.getId()).subscribe(updates -> {
                console.println(updates.getData());
              });

              ScheduledExecutorService scheduler = newSingleThreadScheduledExecutor(daemonThreadFactory);
              scheduler.schedule(subscription::dispose, cancelDelay, SECONDS);
            }

            @Override
            public void onError(Throwable error) {
              error.printStackTrace();
            }
          });
        });
      });
    });
    console.println("Connection was closed by server.");
  }

标签: apache-camel

解决方案


推荐阅读