वास्तविक समय अनुप्रयोग (ट्विटर)

आइए हम नवीनतम ट्विटर फ़ीड और उसके हैशटैग प्राप्त करने के लिए वास्तविक समय एप्लिकेशन का विश्लेषण करें। इससे पहले, हमने काफ्का के साथ स्टॉर्म और स्पार्क का एकीकरण देखा है। दोनों परिदृश्यों में, हमने काफ्का पारिस्थितिकी तंत्र को संदेश भेजने के लिए एक काफ्का निर्माता (सीएलआई का उपयोग करके) बनाया। फिर, तूफ़ान और चिंगारी पूर्णांक में कफ़्का उपभोक्ता का उपयोग करके संदेशों को पढ़ता है और इसे क्रमशः तूफान और स्पार्क पारिस्थितिकी तंत्र में इंजेक्ट करता है। तो, व्यावहारिक रूप से हमें एक काफ़्का निर्माता बनाने की आवश्यकता है, जो चाहिए -

  • "ट्विटर स्ट्रीमिंग एपीआई" का उपयोग करके ट्विटर फ़ीड पढ़ें,
  • फ़ीड की प्रक्रिया करें,
  • हैशटैग निकालें और
  • इसे काफ्का को भेजें।

एक बार जब हैशटैग काफ्का, तूफान से प्राप्त कर रहे हैं / स्पार्क एकीकरण सूचनाओं-एनीमेशन प्राप्त करते हैं और तूफान / स्पार्क पारिस्थितिकी तंत्र को भेजें।

ट्विटर स्ट्रीमिंग एपीआई

"ट्विटर स्ट्रीमिंग एपीआई" को किसी भी प्रोग्रामिंग भाषा में एक्सेस किया जा सकता है। "Twitter4j" एक खुला स्रोत है, अनौपचारिक जावा पुस्तकालय, जो "ट्विटर स्ट्रीमिंग एपीआई" को आसानी से एक्सेस करने के लिए जावा आधारित मॉड्यूल प्रदान करता है। "Twitter4j" ट्वीट्स को एक्सेस करने के लिए एक श्रोता आधारित रूपरेखा प्रदान करता है। "ट्विटर स्ट्रीमिंग एपीआई" का उपयोग करने के लिए, हमें ट्विटर डेवलपर खाते के लिए साइन इन करना होगा और निम्नलिखित प्राप्त करना चाहिएOAuth प्रमाणीकरण विवरण।

  • Customerkey
  • CustomerSecret
  • AccessToken
  • AccessTookenSecret

डेवलपर अकाउंट बन जाने के बाद, “twitter4j” जार फ़ाइलों को डाउनलोड करें और इसे जावा क्लास पथ में रखें।

पूरा ट्विटर काफ्का निर्माता कोडिंग (KafkaTwitterProducer.java) नीचे सूचीबद्ध है -

import java.util.Arrays;
import java.util.Properties;
import java.util.concurrent.LinkedBlockingQueue;

import twitter4j.*;
import twitter4j.conf.*;

import org.apache.kafka.clients.producer.Producer;
import org.apache.kafka.clients.producer.KafkaProducer;
import org.apache.kafka.clients.producer.ProducerRecord;

public class KafkaTwitterProducer {
   public static void main(String[] args) throws Exception {
      LinkedBlockingQueue<Status> queue = new LinkedBlockingQueue<Sta-tus>(1000);
      
      if(args.length < 5){
         System.out.println(
            "Usage: KafkaTwitterProducer <twitter-consumer-key>
            <twitter-consumer-secret> <twitter-access-token>
            <twitter-access-token-secret>
            <topic-name> <twitter-search-keywords>");
         return;
      }
      
      String consumerKey = args[0].toString();
      String consumerSecret = args[1].toString();
      String accessToken = args[2].toString();
      String accessTokenSecret = args[3].toString();
      String topicName = args[4].toString();
      String[] arguments = args.clone();
      String[] keyWords = Arrays.copyOfRange(arguments, 5, arguments.length);

      ConfigurationBuilder cb = new ConfigurationBuilder();
      cb.setDebugEnabled(true)
         .setOAuthConsumerKey(consumerKey)
         .setOAuthConsumerSecret(consumerSecret)
         .setOAuthAccessToken(accessToken)
         .setOAuthAccessTokenSecret(accessTokenSecret);

      TwitterStream twitterStream = new TwitterStreamFactory(cb.build()).get-Instance();
      StatusListener listener = new StatusListener() {
        
         @Override
         public void onStatus(Status status) {      
            queue.offer(status);

            // System.out.println("@" + status.getUser().getScreenName() 
               + " - " + status.getText());
            // System.out.println("@" + status.getUser().getScreen-Name());

            /*for(URLEntity urle : status.getURLEntities()) {
               System.out.println(urle.getDisplayURL());
            }*/

            /*for(HashtagEntity hashtage : status.getHashtagEntities()) {
               System.out.println(hashtage.getText());
            }*/
         }
         
         @Override
         public void onDeletionNotice(StatusDeletionNotice statusDeletion-Notice) {
            // System.out.println("Got a status deletion notice id:" 
               + statusDeletionNotice.getStatusId());
         }
         
         @Override
         public void onTrackLimitationNotice(int numberOfLimitedStatuses) {
            // System.out.println("Got track limitation notice:" + 
               num-berOfLimitedStatuses);
         }

         @Override
         public void onScrubGeo(long userId, long upToStatusId) {
            // System.out.println("Got scrub_geo event userId:" + userId + 
            "upToStatusId:" + upToStatusId);
         }      
         
         @Override
         public void onStallWarning(StallWarning warning) {
            // System.out.println("Got stall warning:" + warning);
         }
         
         @Override
         public void onException(Exception ex) {
            ex.printStackTrace();
         }
      };
      twitterStream.addListener(listener);
      
      FilterQuery query = new FilterQuery().track(keyWords);
      twitterStream.filter(query);

      Thread.sleep(5000);
      
      //Add Kafka producer config settings
      Properties props = new Properties();
      props.put("bootstrap.servers", "localhost:9092");
      props.put("acks", "all");
      props.put("retries", 0);
      props.put("batch.size", 16384);
      props.put("linger.ms", 1);
      props.put("buffer.memory", 33554432);
      
      props.put("key.serializer", 
         "org.apache.kafka.common.serializa-tion.StringSerializer");
      props.put("value.serializer", 
         "org.apache.kafka.common.serializa-tion.StringSerializer");
      
      Producer<String, String> producer = new KafkaProducer<String, String>(props);
      int i = 0;
      int j = 0;
      
      while(i < 10) {
         Status ret = queue.poll();
         
         if (ret == null) {
            Thread.sleep(100);
            i++;
         }else {
            for(HashtagEntity hashtage : ret.getHashtagEntities()) {
               System.out.println("Hashtag: " + hashtage.getText());
               producer.send(new ProducerRecord<String, String>(
                  top-icName, Integer.toString(j++), hashtage.getText()));
            }
         }
      }
      producer.close();
      Thread.sleep(5000);
      twitterStream.shutdown();
   }
}

संकलन

निम्नलिखित कमांड का उपयोग करके एप्लिकेशन को संकलित करें -

javac -cp “/path/to/kafka/libs/*”:”/path/to/twitter4j/lib/*”:. KafkaTwitterProducer.java

क्रियान्वयन

दो कंसोल खोलें। ऊपर संकलित एप्लिकेशन को चलाएं जैसा कि नीचे एक कंसोल में दिखाया गया है।

java -cp “/path/to/kafka/libs/*”:”/path/to/twitter4j/lib/*”:
. KafkaTwitterProducer <twitter-consumer-key>
<twitter-consumer-secret>
<twitter-access-token>
<twitter-ac-cess-token-secret>
my-first-topic food

स्पार्क / स्टॉर्म के किसी एक अनुप्रयोग को पिछले अध्याय में एक और जीत-दहेज में चलाएं। ध्यान देने वाली मुख्य बात यह है कि उपयोग किया जाने वाला विषय दोनों ही मामलों में समान होना चाहिए। यहाँ, हमने "my-first-topic" विषय नाम के रूप में उपयोग किया है।

उत्पादन

इस एप्लिकेशन का आउटपुट कीवर्ड और ट्विटर के वर्तमान फीड पर निर्भर करेगा। एक नमूना आउटपुट नीचे (तूफान एकीकरण) निर्दिष्ट किया गया है।

. . .
food : 1
foodie : 2
burger : 1
. . .