當前位置: 首頁>>代碼示例>>Java>>正文


Java EventBus.consumer方法代碼示例

本文整理匯總了Java中io.vertx.core.eventbus.EventBus.consumer方法的典型用法代碼示例。如果您正苦於以下問題:Java EventBus.consumer方法的具體用法?Java EventBus.consumer怎麽用?Java EventBus.consumer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在io.vertx.core.eventbus.EventBus的用法示例。


在下文中一共展示了EventBus.consumer方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: start

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
@Override
public void start() throws Exception {
    JsonObject config = config();
    String gremlinServerConfigPath = config.getString("gremlinServerConfigPath");
    Server.single.init(gremlinServerConfigPath).start();
    client = Client.single.start();
    eventBusAddr = config.getString("eventBusAddress");

    EventBus eventBus = vertx.eventBus();
    eventBus.consumer(eventBusAddr, event -> {
        String body = (String) event.body();
        logger.info("received from the eventbus of {} : {}", eventBusAddr, body);
        GremlinMessage gremlinMessage = Json.decodeValue(body, GremlinMessage.class);
        List<Object> submit;
        try {
            submit = client.submit(gremlinMessage.getGremlinScript(), null, gremlinMessage.getParambindings());
            String result = Json.encode(submit);
            event.reply(result);
        } catch (Exception e) {
            logger.error("can't execute script : " + gremlinMessage.getGremlinScript() + " because: " + e.getMessage(), e);
        }
    });
}
 
開發者ID:openmg,項目名稱:vertx-gremlin,代碼行數:24,代碼來源:VertxGremlinServer.java

示例2: start

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
@Override
public void start() {
    final EventBus bus = this.vertx.eventBus();
    bus.<JsonObject>consumer(ID.Addr.REGISTRY_START, result -> {
        final JsonObject data = result.body();
        final String name = data.getString(Registry.NAME);
        final HttpServerOptions options =
                new HttpServerOptions(data.getJsonObject(Registry.OPTIONS));
        final String[] uris =
                data.getString(Registry.URIS).split(Strings.COMMA);
        final Set<String> uriData = new TreeSet<>(Arrays.asList(uris));
        // Write the data to registry.
        this.registry.registryHttp(name, options, Etat.RUNNING);
        this.registry.registryRoute(name, options, uriData);

        LOGGER.info(Info.MICRO_REGISTRY_CONSUME, getClass().getSimpleName(),
                name, ID.Addr.REGISTRY_START);
    });
}
 
開發者ID:silentbalanceyh,項目名稱:vertx-zero,代碼行數:20,代碼來源:ZeroHttpRegistry.java

示例3: registerSynonyms

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
private void registerSynonyms() {
    EventBus eventBus = vertx.eventBus();

    eventBus.consumer(WordnetAddresses.SYNONYMS.getAddress(), (Handler<Message<String>>) message -> {
        String body = message.body();

        IDictionary dictionary = dictionaryCache.getDictionary();

        IIndexWord idxWord = dictionary.getIndexWord(body, POS.NOUN);
        IWordID wordID = idxWord.getWordIDs().get(0); // 1st meaning
        IWord word = dictionary.getWord(wordID);
        ISynset synset = word.getSynset();

        List<String> synonyms = synset.getWords().stream().map(IWord::getLemma).collect(Collectors.toList());

        message.reply(new JsonArray(synonyms));
    });
}
 
開發者ID:bpark,項目名稱:chlorophytum-semantics,代碼行數:19,代碼來源:WordnetVerticle.java

示例4: registerSingleConfigEntryProvider

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
/**
 * Registers a handler for accessing single configuration keys (input: String, reply type: String). If no
 * config value is present the consumer will reply with a NOT_FOUND failure.
 * @param address the event bus address to register.
 * @param eventBus the event bus.
 * @return the consumer registered.
 */
public static MessageConsumer<String> registerSingleConfigEntryProvider(String address, EventBus eventBus){
    MessageConsumer<String> consumer = eventBus.consumer(address);
    consumer.handler(h -> {
        String key = (String) h.body();
        if (key == null) {
            h.fail(HttpResponseStatus.BAD_REQUEST.code(), "Missing config key.");
        } else {
            String value = ConfigurationProvider.getConfiguration().getOrDefault(key, null);
            if (value != null) {
                h.reply(value);
            } else {
                h.fail(HttpResponseStatus.NOT_FOUND.code(), "Config key not found: " + key);
            }
        }
    });
    return consumer;
}
 
開發者ID:apache,項目名稱:incubator-tamaya-sandbox,代碼行數:25,代碼來源:TamayaConfigurationProducer.java

示例5: registerMultiConfigEntryProvider

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
/**
 * Registers a handler for accessing multiple configuration keys (input: String[] (Json),
 * reply type: Map<String,String></String,String> (Json).
 * @param address the event bus address to register.
 * @param eventBus the event bus.
 * @return the consumer registered.
 */
public static MessageConsumer<String> registerMultiConfigEntryProvider(String address, EventBus eventBus){
    MessageConsumer<String> consumer = eventBus.consumer(address);
    consumer.handler(h -> {
        String val = h.body();
        Configuration config = ConfigurationProvider.getConfiguration();
        Map<String,String> entries = new TreeMap<>();
        if(val!=null){
            String[] sections = Json.decodeValue(val, String[].class);
            for (String section : sections) {
                if(section!=null) {
                    entries.putAll(config.with(ConfigurationFunctions.section(section)).getProperties());
                }
            }
        }else{
            entries.putAll(config.getProperties());
        }
        h.reply(Json.encode(entries));
    });
    return consumer;
}
 
開發者ID:apache,項目名稱:incubator-tamaya-sandbox,代碼行數:28,代碼來源:TamayaConfigurationProducer.java

示例6: run

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
@Override
public void run(AsyncResultHandler<Void> startupHandler, Handler<DuplexStream<Buffer, Buffer>> duplexStreamHandler) {
    final EventBus eventBus = vertx.eventBus();
    inputConsumer = eventBus.consumer(configObj.getString("input.address"));
    outputPublisher = eventBus.publisher(configObj.getString("output.address"));
    completePublisher = eventBus.publisher(configObj.getString("complete.address"));
    closePublisher = eventBus.publisher(configObj.getString("close.address"));

    final EventBusClosableWriteStream eventBusStream = new EventBusClosableWriteStream(inputConsumer, outputPublisher);
    final DuplexStream<Buffer, Buffer> duplexStream = new DuplexStream<>(inputConsumer.bodyStream(), eventBusStream);
    duplexStream
            .closeHandler(v -> {
                closePublisher.write(Buffer.buffer("Closed"));
            })
            .writeCompleteHandler(pack -> {
                completePublisher.write(Buffer.buffer("Ok"));
            });
    vertx.runOnContext(v -> {
        duplexStreamHandler.handle(duplexStream);
    });
    startupHandler.handle(Future.succeededFuture());
}
 
開發者ID:wired-mind,項目名稱:usher,代碼行數:23,代碼來源:EventBusInput.java

示例7: register

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
/**
 * Register the proxy handle on the event bus.
 *
 * @param eventBus the event bus
 * @param address the proxy address
 */
public MessageConsumer<JsonObject> register(EventBus eventBus, String address, List<Function<Message<JsonObject>, Future<Message<JsonObject>>>> interceptors) {
  Handler<Message<JsonObject>> handler = this::handle;
  if (interceptors != null) {
    for (Function<Message<JsonObject>, Future<Message<JsonObject>>> interceptor : interceptors) {
      Handler<Message<JsonObject>> prev = handler;
      handler = msg -> {
        Future<Message<JsonObject>> fut = interceptor.apply(msg);
        fut.setHandler(ar -> {
          if (ar.succeeded()) {
            prev.handle(msg);
          } else {
            ReplyException exception = (ReplyException) ar.cause();
            msg.fail(exception.failureCode(), exception.getMessage());
          }
        });
      };
    }
  }
  consumer = eventBus.consumer(address, handler);
  return consumer;
}
 
開發者ID:vert-x3,項目名稱:vertx-service-proxy,代碼行數:28,代碼來源:ProxyHandler.java

示例8: startListening

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
@Override
public SFDCVerticle startListening() {
	this.logger.info("Start listening:" + this.getClass().getName());
	// Listen on the event bus
	final EventBus eb = this.vertx.eventBus();
	this.consumer = eb.consumer(this.getConsumerConfig().getEventBusAddress());
	this.logger.info(this.getClass().getName() + " listening on " + this.consumer.address());
	this.consumer.handler(this::processIncoming);
	// Done
	this.listening = true;
	return this;
}
 
開發者ID:Stwissel,項目名稱:vertx-sfdc-platformevents,代碼行數:13,代碼來源:AbstractSFDCConsumer.java

示例9: startListening

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
@Override
public SFDCVerticle startListening() {
	this.logger.info("Start listening:" + this.getClass().getName());
	// Listen on the event bus
	final EventBus eb = this.vertx.eventBus();
	this.dedupConsumer = eb.consumer(Constants.BUS_DEDUP_PREFIX + this.getDedupConfig().getInstanceName());
	this.logger.info(this.getClass().getName() + " listening on " + this.dedupConsumer.address());
	this.dedupConsumer.handler(this::processIncoming);
	// Done
	this.listening = true;
	return this;
}
 
開發者ID:Stwissel,項目名稱:vertx-sfdc-platformevents,代碼行數:13,代碼來源:AbstractSFDCDedupVerticle.java

示例10: start

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
@Override
public void start() {
    final EventBus bus = this.vertx.eventBus();
    bus.<JsonObject>consumer(ID.Addr.IPC_START, result -> {
        final JsonObject data = result.body();
        final ServidorOptions options = new ServidorOptions(data);
        // Write the data to registry.
        this.registry.registryRpc(options, Etat.RUNNING);
        this.registry.registryIpcs(options, Tunnel.IPCS.keySet());

        LOGGER.info(Info.MICRO_REGISTRY_CONSUME, getClass().getSimpleName(),
                options.getName(), ID.Addr.IPC_START);
    });
}
 
開發者ID:silentbalanceyh,項目名稱:vertx-zero,代碼行數:15,代碼來源:ZeroRpcRegistry.java

示例11: scheduling

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
static void scheduling(Vertx vertx) {
	EventBus eventBus = vertx.eventBus();
	// Consumer of the timer events
	MessageConsumer<JsonObject> consumer = eventBus.consumer("scheduler:timer");
	// Listens and prints timer events. When timer completes stops the Vertx 
	consumer.handler (
		message -> {
			JsonObject event = message.body();
			if (event.getString("event").equals("complete")) {
				System.out.println("completed");
				vertx.close();
			}
			else {
				System.out.println(event);
			}
	  	}
	);
	// Create new timer
	eventBus.send (
		"chime",
		(new JsonObject()).put("operation", "create").put("name", "scheduler:timer")
			.put("publish", false).put("max count", 3)
			.put("description", (new JsonObject()).put("type", "interval").put("delay", 1)),
		ar -> {
			if (ar.succeeded()) {
				System.out.println("Scheduling started: " + ar.result().body());
			}
			else {
				System.out.println("Message failed: " + ar.cause());
				vertx.close();
			}
		}
	);
}
 
開發者ID:LisiLisenok,項目名稱:ChimeJavaExample,代碼行數:35,代碼來源:Main.java

示例12: registerNameFinder

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
private void registerNameFinder() {

        EventBus eventBus = vertx.eventBus();

        eventBus.consumer(NlpAddresses.PERSONNAME.getAddress(), (Handler<Message<String[]>>) message -> {
            String[] tokens = message.body();

            List<PersonName> names = new ArrayList<>();

            Span nameSpans[] = nameFinder.find(tokens);
            double[] spanProbs = nameFinder.probs(nameSpans);


            for (int i = 0; i < nameSpans.length; i++) {
                Span nameSpan = nameSpans[i];
                int start = nameSpan.getStart();
                int end = nameSpan.getEnd() - 1;
                String name;
                if (start == end) {
                    name = tokens[start];
                } else {
                    name = tokens[start] + " " + tokens[end];
                }
                double probability = spanProbs[i];
                String[] nameTokens = Arrays.copyOfRange(tokens, start, end + 1);

                names.add(new PersonName(name, nameTokens, probability));
            }

            message.reply(names);
        });

    }
 
開發者ID:bpark,項目名稱:chlorophytum-semantics,代碼行數:34,代碼來源:NlpVerticle.java

示例13: registerConfigurationInjector

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
/**
 * Registers a handler for configuring any objects sent via the message bus using Tamaya's injection API.
 * @param address the event bus address to register.
 * @param eventBus the event bus.
 * @return the consumer registered.
 */
public static MessageConsumer<Object> registerConfigurationInjector(String address, EventBus eventBus){
    MessageConsumer<Object> consumer = eventBus.consumer(address);
    consumer.handler(h -> {
        Object o = h.body();
        if(o==null){
            h.fail(HttpResponseStatus.BAD_REQUEST.code(), "Required object to configure is missing.");
        }else {
            ConfigurationInjection.getConfigurationInjector().configure(o);
            h.reply("OK");
        }
    });
    return consumer;
}
 
開發者ID:apache,項目名稱:incubator-tamaya-sandbox,代碼行數:20,代碼來源:TamayaConfigurationProducer.java

示例14: start

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
@Override
public void start() throws Exception {

    EventBus eb = vertx.eventBus();

    producer = this.createKafkaProducer();
    LOGGER.info("Created consumer");

    eb.consumer(Constants.EVENTBUS_ADDRESS, message -> {

        try {
            MultiMap multiMap = message.headers();
            String topic = multiMap.get(Constants.TOPIC);
            String messageKey = multiMap.get(Constants.MESSAGE_KEY);

            Integer messageBody = (Integer)message.body();
            LOGGER.info("Sending body: " + messageBody);

            Future<RecordMetadata> future = producer.send(new ProducerRecord<>(topic, messageKey, createMessage(messageBody)));
            RecordMetadata meta = future.get();

            // Now send back reply
            message.reply("OK");
        } catch (Exception exc) {
            LOGGER.error(exc);
        }
    });

    LOGGER.info("Receiver ready!");
}
 
開發者ID:SaschaMoellering,項目名稱:ingestion-service,代碼行數:31,代碼來源:KafkaVerticle.java

示例15: start

import io.vertx.core.eventbus.EventBus; //導入方法依賴的package包/類
@Override
public void start() throws Exception {

    EventBus eb = vertx.eventBus();
    kinesisAsyncClient = createClient();

    eb.consumer(Constants.EVENTBUS_ADDRESS, message -> {

        try {
            MultiMap multiMap = message.headers();
            String partitionKey = multiMap.get(Constants.MESSAGE_KEY);
            Integer randomId = (Integer)message.body();

            LOGGER.info("Sending body: " + randomId + " from KinesisVerticle");

            byte [] byteMessage = createMessage(randomId);
            ByteBuffer buf = ByteBuffer.wrap(byteMessage);

            sendMessageToKinesis(buf, partitionKey);

            // Now send back reply
            message.reply("OK");
        }
        catch (KinesisException exc) {
            LOGGER.error(exc);
        }
    });

    LOGGER.info("Receiver ready!");
}
 
開發者ID:SaschaMoellering,項目名稱:ingestion-service,代碼行數:31,代碼來源:KinesisVerticle.java


注:本文中的io.vertx.core.eventbus.EventBus.consumer方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。