अपाचे HttpClient - कई धागे

एक बहु-थ्रेडेड प्रोग्राम में दो या अधिक भाग होते हैं जो समवर्ती रूप से चल सकते हैं और प्रत्येक भाग एक ही समय में एक अलग कार्य को उपलब्ध संसाधनों का इष्टतम उपयोग कर संभाल सकता है।

आप मल्टीथ्रेडेड HttpClient प्रोग्राम लिखकर कई थ्रेड्स से अनुरोध निष्पादित कर सकते हैं।

यदि आप लगातार थ्रेड से कई क्लाइंट अनुरोध निष्पादित करना चाहते हैं, तो आपको एक बनाने की आवश्यकता है ClientConnectionPoolManager। इसका एक पूल हैHttpClientConnections और थ्रेड्स से कई अनुरोध करता है।

कनेक्शन प्रबंधक मार्ग के आधार पर कनेक्शन को पूल करता है। यदि प्रबंधक के पास किसी विशेष मार्ग के लिए कनेक्शन हैं, तो यह उन मार्गों में नए कनेक्शन का अनुरोध करता है, जो एक नया कनेक्शन बनाने के बजाय पूल से मौजूदा कनेक्शन को पट्टे पर देता है।

एकाधिक थ्रेड्स से अनुरोध निष्पादित करने के लिए चरणों का पालन करें -

चरण 1 - क्लाइंट कनेक्शन पूल मैनेजर बनाना

क्लाइंट कन्टैंट पूल मैनेजर को तत्काल बनाकर बनाएँ PoolingHttpClientConnectionManager कक्षा।

PoolingHttpClientConnectionManager connManager = new
   PoolingHttpClientConnectionManager();

चरण 2 - कनेक्शन की अधिकतम संख्या निर्धारित करें

का उपयोग कर पूल में कनेक्शन की अधिकतम संख्या निर्धारित करें setMaxTotal() तरीका।

//Set the maximum number of connections in the pool
connManager.setMaxTotal(100);

चरण 3 - एक ClientBuilder वस्तु बनाएँ

बनाओ ClientBuilder का उपयोग करके कनेक्शन प्रबंधक सेट करके ऑब्जेक्ट setConnectionManager() नीचे दिखाए अनुसार विधि -

HttpClientBuilder clientbuilder =
HttpClients.custom().setConnectionManager(connManager);

चरण 4 - HttpGet अनुरोध ऑब्जेक्ट बनाएँ

एक पैरामीटर के रूप में वांछित यूआरआई को उसके निर्माता को पास करके HttpGet वर्ग को तुरंत।

HttpGet httpget1 = new HttpGet("URI1");
HttpGet httpget2 = new HttpGet("URI2");
. . . . . . . . . . . .

चरण 5 - रन विधि को लागू करना

सुनिश्चित करें कि आपने एक वर्ग बनाया है, इसे एक धागा बनाया है (या तो थ्रेड वर्ग का विस्तार करके या रननेबल इंटरफ़ेस को लागू करके) और रन विधि को लागू किया है।

public class ClientMultiThreaded extends Thread {
   public void run() {
      //Run method implementation . . . . . . . . . .
   }
}

चरण 6 - थ्रेड ऑब्जेक्ट बनाएँ

ऊपर बनाई गई थ्रेड क्लास (ClientMultiThreaded) को इंस्टेंट करके थ्रेड ऑब्जेक्ट बनाएँ।

एक HttpClient ऑब्जेक्ट, संबंधित HttpGet ऑब्जेक्ट और, इन थ्रेड्स के लिए ID का प्रतिनिधित्व करने वाला पूर्णांक पास करें।

ClientMultiThreaded thread1 = new ClientMultiThreaded(httpclient,httpget1, 1);
ClientMultiThreaded thread2 = new ClientMultiThreaded(httpclient,httpget2, 2);
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

चरण 7 - थ्रेड्स को प्रारंभ करें और जुड़ें

सभी थ्रेड्स का उपयोग करके प्रारंभ करें start() विधि और शामिल होने का उपयोग करके उन्हें शामिल करें method()

thread1.start();
thread2.start();
. . . . . . . .
thread1.join();
thread2.join();
. . . . . . . . . . . .

चरण 8 - रन विधि कार्यान्वयन

रन विधि के भीतर, अनुरोध निष्पादित करें, प्रतिक्रिया प्राप्त करें और परिणाम प्रिंट करें।

उदाहरण

निम्न उदाहरण कई थ्रेड्स से एक साथ HTTP अनुरोधों के निष्पादन को प्रदर्शित करता है। इस उदाहरण में, हम विभिन्न थ्रेड्स से विभिन्न अनुरोधों को निष्पादित करने की कोशिश कर रहे हैं और स्थिति को प्रिंट करने की कोशिश कर रहे हैं, और प्रत्येक ग्राहक द्वारा पढ़ी जाने वाली बाइट्स की संख्या।

import org.apache.http.HttpEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
import org.apache.http.util.EntityUtils;

public class ClientMultiThreaded extends Thread {
   CloseableHttpClient httpClient;
   HttpGet httpget;
   int id;
 
   public ClientMultiThreaded(CloseableHttpClient httpClient, HttpGet httpget,
   int id) {
      this.httpClient = httpClient;
      this.httpget = httpget;
      this.id = id;
   }
   @Override
   public void run() {
      try{
         //Executing the request
         CloseableHttpResponse httpresponse = httpClient.execute(httpget);

         //Displaying the status of the request.
         System.out.println("status of thread "+id+":"+httpresponse.getStatusLine());

         //Retrieving the HttpEntity and displaying the no.of bytes read
         HttpEntity entity = httpresponse.getEntity();
         if (entity != null) {
            System.out.println("Bytes read by thread thread "+id+":
               "+EntityUtils.toByteArray(entity).length);
         }
      }catch(Exception e) {
         System.out.println(e.getMessage());
      }
   }
      
   public static void main(String[] args) throws Exception {

      //Creating the Client Connection Pool Manager by instantiating the PoolingHttpClientConnectionManager class.
      PoolingHttpClientConnectionManager connManager = new PoolingHttpClientConnectionManager();

      //Set the maximum number of connections in the pool
      connManager.setMaxTotal(100);

      //Create a ClientBuilder Object by setting the connection manager
      HttpClientBuilder clientbuilder = HttpClients.custom().setConnectionManager(connManager);
 
      //Build the CloseableHttpClient object using the build() method.
      CloseableHttpClient httpclient = clientbuilder.build();

      //Creating the HttpGet requests
      HttpGet httpget1 = new HttpGet("http://www.tutorialspoint.com/");
      HttpGet httpget2 = new HttpGet("http://www.google.com/");
      HttpGet httpget3 = new HttpGet("https://www.qries.com/");
      HttpGet httpget4 = new HttpGet("https://in.yahoo.com/");
 
      //Creating the Thread objects
      ClientMultiThreaded thread1 = new ClientMultiThreaded(httpclient,httpget1, 1);
      ClientMultiThreaded thread2 = new ClientMultiThreaded(httpclient,httpget2, 2);
      ClientMultiThreaded thread3 = new ClientMultiThreaded(httpclient,httpget3, 3);
      ClientMultiThreaded thread4 = new ClientMultiThreaded(httpclient,httpget4, 4);

      //Starting all the threads
      thread1.start();
      thread2.start();
      thread3.start();
      thread4.start();

      //Joining all the threads
      thread1.join();
      thread2.join();
      thread3.join();
      thread4.join();
   }
}

उत्पादन

निष्पादित करने पर, उपरोक्त कार्यक्रम निम्नलिखित आउटपुट उत्पन्न करता है -

status of thread 1: HTTP/1.1 200 OK
Bytes read by thread thread 1: 36907
status of thread 2: HTTP/1.1 200 OK
Bytes read by thread thread 2: 13725
status of thread 3: HTTP/1.1 200 OK
Bytes read by thread thread 3: 17319
status of thread 4: HTTP/1.1 200 OK
Bytes read by thread thread 4: 127018