X-Git-Url: http://git.vanrenterghem.biz/R/project-using-kafka-in-R.git/blobdiff_plain/96ee6f0f5f77d9fe656c14c8f6f5a9c6759981f1..9948b03c3477ca42cdff48813f6ed281ad00747a:/kafkaConsumer.R diff --git a/kafkaConsumer.R b/kafkaConsumer.R index a2ca952..8b5e6c7 100644 --- a/kafkaConsumer.R +++ b/kafkaConsumer.R @@ -7,28 +7,29 @@ library(jsonlite) library(dplyr) kafka_rest_proxy <- "http://localhost:8082" +consumer <- 'my_json_consumer' +consumer_instance <- 'my_consumer_instance' +topic <- 'accesslogapache' # Create consumer # See https://docs.confluent.io/current/kafka-rest/docs/intro.html#produce-and-consume-avro-messages -response <- POST(url=paste(kafka_rest_proxy, "consumers", "my_json_consumer", sep="/"), - content_type("application/vnd.kafka.v2+json"), - accept("application/vnd.kafka.v2+json"), - body='{"name": "my_consumer_instance", "format": "json", "auto.offset.reset": "earliest"}') -fromJSON(content(response, "text")) - -response <- POST(url=paste(kafka_rest_proxy, - "consumers", - "my_json_consumer", - "instances", - "my_consumer_instance", +# Create consumer +source("R/CreateKafkaConsumer.R") +consumerDetails <- CreateKafkaConsumer(kafka.rest.proxy = kafka_rest_proxy, consumer = consumer, consumer_instance = consumer_instance) + +# Subscribe it to topic +response <- POST(url=paste(consumerDetails$base_uri, "subscription", sep="/"), content_type("application/vnd.kafka.v2+json"), - body = '{"topics":["accesslogapache"]}') + body = paste0('{"topics":["', + topic, + '"]}') + ) response -# Obtain all messages on the topic -messagesJSON <- GET(url = paste(kafka_rest_proxy,"consumers","my_json_consumer","instances","my_consumer_instance","records", sep = "/"), +# Obtain all (or latest) messages on the topic +messagesJSON <- GET(url = paste(consumerDetails$base_uri,"records", sep = "/"), accept("application/vnd.kafka.json.v2+json"), encode="json") @@ -38,7 +39,8 @@ createPlot(messages$value) Sys.sleep(120) -messagesJSON <- GET(url = paste(kafka_rest_proxy,"consumers","my_json_consumer","instances","my_consumer_instance","records", sep = "/"), +# Obtain latest messages +messagesJSON <- GET(url = paste(consumerDetails$base_uri,"records", sep = "/"), accept("application/vnd.kafka.json.v2+json"), encode="json") @@ -49,5 +51,5 @@ apachelog <- rbind(messages$value,messages2$value) createPlot(apachelog) # Remove the consumer -DELETE(url = paste(kafka_rest_proxy,"consumers","my_json_consumer","instances","my_consumer_instance", sep = "/"), - content_type("application/vnd.kafka.v2+json")) +source("R/DestroyKafkaConsumer.R") +response <- DestroyKafkaConsumer(consumer.base.uri = consumerDetails$base_uri)