Zookeeper - एपीआई

चिड़ियाघरकीपर के पास जावा और सी के लिए एक आधिकारिक एपीआई बाइंडिंग है। चिड़ियाघरकीपर समुदाय अधिकांश भाषाओं (.NET, अजगर, आदि) के लिए अनौपचारिक एपीआई प्रदान करता है। चिड़ियाघरकीपर एपीआई का उपयोग करना, एक एप्लिकेशन कनेक्ट कर सकता है, बातचीत कर सकता है, डेटा में हेरफेर कर सकता है, समन्वय कर सकता है, और अंत में एक चिड़ियाघर कीपर पहनावा से डिस्कनेक्ट कर सकता है।

ज़ूकीपर एपीआई में एक सरल और सुरक्षित तरीके से ज़ूकेर पहनावे की सभी कार्यक्षमता प्राप्त करने के लिए सुविधाओं का एक समृद्ध सेट है। चिड़ियाघरकीपर एपीआई तुल्यकालिक और अतुल्यकालिक दोनों तरीके प्रदान करता है।

ज़ूकीपर पहनावा और ज़ूकीपर एपीआई पूरी तरह से हर पहलू में एक दूसरे के पूरक हैं और यह डेवलपर्स को शानदार तरीके से लाभान्वित करते हैं। आइए इस अध्याय में जावा बाइंडिंग पर चर्चा करते हैं।

चिड़ियाघरकीपर एपीआई की मूल बातें

ZooKeeper कलाकारों की टुकड़ी के साथ बातचीत के रूप में आवेदन किया जाता है ZooKeeper Client या केवल Client

ज़्नोड ज़ूकेर पहनावा का मुख्य घटक है और ज़ूकेदार एपीआई ज़ूकोड के सभी विवरणों में हेरफेर करने के लिए तरीकों का एक छोटा सा सेट प्रदान करता है।

एक ग्राहक को नीचे दिए गए चरणों का पालन करना चाहिए ताकि चिड़ियाघरकीपर पहनावा के साथ एक स्पष्ट और स्वच्छ बातचीत हो।

  • ज़ूकिपर पहनावा से कनेक्ट करें। ZooKeeper कलाकारों की टुकड़ी ग्राहक के लिए एक सत्र आईडी असाइन करें।

  • समय-समय पर सर्वर को दिल की धड़कन भेजें। अन्यथा, ज़ूकीपर की टुकड़ी सत्र आईडी को समाप्त कर देती है और ग्राहक को फिर से कनेक्ट करने की आवश्यकता होती है।

  • जब तक सत्र ID सक्रिय है, तब तक ज़नोड्स प्राप्त / सेट करें।

  • एक बार सभी कार्य पूर्ण हो जाने के बाद, ज़ूकीपर पहनावा से डिस्कनेक्ट करें। यदि क्लाइंट लंबे समय तक निष्क्रिय है, तो ज़ूकेपर पहनावा स्वचालित रूप से ग्राहक को डिस्कनेक्ट कर देगा।

जावा बाइंडिंग

आइए इस अध्याय में ज़ूकीपर एपीआई के सबसे महत्वपूर्ण सेट को समझें। चिड़ियाघरकीपर एपीआई का केंद्रीय हिस्सा हैZooKeeper class। यह अपने कंस्ट्रक्टर में ज़ूकेर पहनावा को जोड़ने के लिए विकल्प प्रदान करता है और इसके निम्नलिखित तरीके हैं -

  • connect - ज़ूकिपर पहनावा से कनेक्ट करें

  • create - एक znode बनाएँ

  • exists - जाँच करें कि क्या एक znode मौजूद है और इसकी जानकारी

  • getData - एक विशेष znode से डेटा प्राप्त करें

  • setData - एक विशेष ज़्नोड में डेटा सेट करें

  • getChildren - सभी उप-नोड्स को एक विशेष शून्य में उपलब्ध कराएं

  • delete - एक विशेष znode और उसके सभी बच्चों को प्राप्त करें

  • close - एक कनेक्शन बंद करें

ज़ूकिपर एनसेंबल से कनेक्ट करें

चिड़ियाघरकीपर वर्ग अपने कंस्ट्रक्टर के माध्यम से कनेक्शन की कार्यक्षमता प्रदान करता है। निर्माणकर्ता के हस्ताक्षर इस प्रकार हैं -

ZooKeeper(String connectionString, int sessionTimeout, Watcher watcher)

कहाँ पे,

  • connectionString - ज़ूकीपर मेजबान की तरह।

  • sessionTimeout - मिलीसेकंड में सत्र का समय।

  • watcher- "वॉचर" इंटरफ़ेस को लागू करने वाली एक वस्तु। चिड़ियाघर कीपर पहरेदार वस्तु के माध्यम से कनेक्शन की स्थिति देता है।

हम एक नया सहायक वर्ग बनाते हैं ZooKeeperConnection और एक विधि जोड़ें connectconnect विधि एक ZooKeeper ऑब्जेक्ट बनाता है, ZooKeeper कलाकारों की टुकड़ी से जोड़ता है, और फिर ऑब्जेक्ट को वापस करता है।

यहाँ CountDownLatch मुख्य प्रक्रिया को रोकने के लिए प्रयोग किया जाता है (रुको) जब तक कि ग्राहक चिड़ियाघरकीपर पहनावा से न जुड़ जाए।

चिड़ियाघरकीपर पहनावा कनेक्शन की स्थिति के माध्यम से जवाब देता है Watcher callback। एक बार जब ग्राहक ZooKeeper कलाकारों की टुकड़ी के साथ जुड़ता है और वॉकर कॉलबैक कॉल को कॉल करता है, तो वॉचर कॉलबैक कहा जाएगाcountDown की विधि CountDownLatch ताला जारी करने के लिए, await मुख्य प्रक्रिया में।

यहाँ एक चिड़ियाघर कीपर पहनावे के साथ जुड़ने का पूरा कोड है।

कोडिंग: ZooKeeperConnection.java

// import java classes
import java.io.IOException;
import java.util.concurrent.CountDownLatch;

// import zookeeper classes
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.Watcher.Event.KeeperState;
import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.AsyncCallback.StatCallback;
import org.apache.zookeeper.KeeperException.Code;
import org.apache.zookeeper.data.Stat;

public class ZooKeeperConnection {

   // declare zookeeper instance to access ZooKeeper ensemble
   private ZooKeeper zoo;
   final CountDownLatch connectedSignal = new CountDownLatch(1);

   // Method to connect zookeeper ensemble.
   public ZooKeeper connect(String host) throws IOException,InterruptedException {
	
      zoo = new ZooKeeper(host,5000,new Watcher() {
		
         public void process(WatchedEvent we) {

            if (we.getState() == KeeperState.SyncConnected) {
               connectedSignal.countDown();
            }
         }
      });
		
      connectedSignal.await();
      return zoo;
   }

   // Method to disconnect from zookeeper server
   public void close() throws InterruptedException {
      zoo.close();
   }
}

उपरोक्त कोड को सहेजें और इसका उपयोग अगले अनुभाग में चिड़ियाघरकीपर पहनावा को जोड़ने के लिए किया जाएगा।

एक Znode बनाएँ

चिड़ियाघरकीपर वर्ग प्रदान करता है create methodचिड़ियाघरकीपर पहनावा में एक नया ज़नोड बनाने के लिए। के हस्ताक्षरcreate विधि इस प्रकार है -

create(String path, byte[] data, List<ACL> acl, CreateMode createMode)

कहाँ पे,

  • path- ज़नोड मार्ग। उदाहरण के लिए, / myapp1, / ​​myapp2, / myapp1 / mydata1, myapp2 / mydata1 / myanothersubdata

  • data - निर्दिष्ट ज़ोनोड पथ में संग्रहीत करने के लिए डेटा

  • acl- बनाए जाने वाले नोड की एक्सेस कंट्रोल लिस्ट। चिड़ियाघरकीपर एपीआई एक स्थिर इंटरफ़ेस प्रदान करता हैZooDefs.Idsकुछ बुनियादी एसएल सूची प्राप्त करने के लिए। उदाहरण के लिए, ZooDefs.Ids.OPEN_ACL_UNSAFE खुले ज़नॉड्स के लिए acl की सूची देता है।

  • createMode- नोड का प्रकार, या तो अल्पकालिक, अनुक्रमिक, या दोनों। यह एकenum

चेक करने के लिए एक नया जावा एप्लिकेशन बनाते हैं createचिड़ियाघरकीपर एपीआई की कार्यक्षमता। एक फ़ाइल बनाएँZKCreate.java। मुख्य विधि में, प्रकार की एक वस्तु बनाएंZooKeeperConnection और कॉल करें connect ज़ूकीपर पहनावा से जुड़ने की विधि।

कनेक्ट विधि चिड़ियाघरकीपर वस्तु को वापस कर देगी zk। अब, कॉल करेंcreate उसकि विधि zk कस्टम के साथ वस्तु path तथा data

एक znode बनाने के लिए पूरा कार्यक्रम कोड निम्नानुसार है -

कोडिंग: ZKCreate.java

import java.io.IOException;

import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.Watcher.Event.KeeperState;
import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.CreateMode;
import org.apache.zookeeper.ZooDefs;

public class ZKCreate {
   // create static instance for zookeeper class.
   private static ZooKeeper zk;

   // create static instance for ZooKeeperConnection class.
   private static ZooKeeperConnection conn;

   // Method to create znode in zookeeper ensemble
   public static void create(String path, byte[] data) throws 
      KeeperException,InterruptedException {
      zk.create(path, data, ZooDefs.Ids.OPEN_ACL_UNSAFE,
      CreateMode.PERSISTENT);
   }

   public static void main(String[] args) {

      // znode path
      String path = "/MyFirstZnode"; // Assign path to znode

      // data in byte array
      byte[] data = "My first zookeeper app”.getBytes(); // Declare data
		
      try {
         conn = new ZooKeeperConnection();
         zk = conn.connect("localhost");
         create(path, data); // Create the data to the specified path
         conn.close();
      } catch (Exception e) {
         System.out.println(e.getMessage()); //Catch error message
      }
   }
}

एक बार आवेदन को संकलित करने और निष्पादित करने के बाद, चिड़ियाघरकीपर पहनावा में निर्दिष्ट डेटा वाला एक ज़ोनोड बनाया जाएगा। आप चिड़ियाघरकीपर सीएलआई का उपयोग करके इसकी जांच कर सकते हैंzkCli.sh

cd /path/to/zookeeper
bin/zkCli.sh
>>> get /MyFirstZnode

अस्तित्ववादी - एक शून्य की अस्तित्व की जाँच करें

चिड़ियाघरकीपर वर्ग प्रदान करता है exists methodएक znode के अस्तित्व की जांच करने के लिए। यह एक znode का मेटाडेटा लौटाता है, यदि निर्दिष्ट znode मौजूद है। के हस्ताक्षरexists विधि इस प्रकार है -

exists(String path, boolean watcher)

कहाँ पे,

  • path - ज़नोड मार्ग

  • watcher - बूलियन मान निर्दिष्ट ज़ोनोड देखने के लिए या नहीं

आइए हम एक नया जावा एप्लिकेशन बनाते हैं, जो चिड़ियाघर कीपर एपीआई की "मौजूद" कार्यक्षमता की जांच करता है। एक फ़ाइल "ZKExists.java" बनाएँ । मुख्य विधि में, चिड़ियाघर संचालक वस्तु, बनाने "ZK" का उपयोग कर "ZooKeeperConnection" वस्तु। फिर, कस्टम "पथ" के साथ "zk" ऑब्जेक्ट की "मौजूद" पद्धति को कॉल करें । पूरी लिस्टिंग इस प्रकार है -

कोडिंग: ZKExists.java

import java.io.IOException;

import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.Watcher.Event.KeeperState;
import org.apache.zookeeper.data.Stat;

public class ZKExists {
   private static ZooKeeper zk;
   private static ZooKeeperConnection conn;

   // Method to check existence of znode and its status, if znode is available.
   public static Stat znode_exists(String path) throws
      KeeperException,InterruptedException {
      return zk.exists(path, true);
   }

   public static void main(String[] args) throws InterruptedException,KeeperException {
      String path = "/MyFirstZnode"; // Assign znode to the specified path
			
      try {
         conn = new ZooKeeperConnection();
         zk = conn.connect("localhost");
         Stat stat = znode_exists(path); // Stat checks the path of the znode
				
         if(stat != null) {
            System.out.println("Node exists and the node version is " +
            stat.getVersion());
         } else {
            System.out.println("Node does not exists");
         }
				
      } catch(Exception e) {
         System.out.println(e.getMessage()); // Catches error messages
      }
   }
}

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

Node exists and the node version is 1.

getData विधि

चिड़ियाघरकीपर वर्ग प्रदान करता है getDataकिसी निर्दिष्ट ज़नोड और उसकी स्थिति में डेटा संलग्न करने की विधि। के हस्ताक्षरgetData विधि इस प्रकार है -

getData(String path, Watcher watcher, Stat stat)

कहाँ पे,

  • path - ज़नोड मार्ग।

  • watcher - कॉलबैक प्रकार का कार्य Watcher। चिड़ियाघरकीपर पहनावा पहरेदार कॉलबैक के माध्यम से सूचित करेगा जब निर्दिष्ट znode का डेटा बदलता है। यह एक बार की अधिसूचना है।

  • stat - एक ज़नोड का मेटाडेटा लौटाता है।

हमें समझने के लिए एक नया जावा एप्लिकेशन बनाएं getDataचिड़ियाघरकीपर एपीआई की कार्यक्षमता। एक फ़ाइल बनाएँZKGetData.java। मुख्य विधि में, एक चिड़ियाघर कीपर वस्तु बनाएंzk उसका उपयोग कर रहा है ZooKeeperConnectionवस्तु। फिर, कॉल करेंgetData कस्टम पथ के साथ zk वस्तु की विधि।

यहाँ एक निर्दिष्ट नोड से डेटा प्राप्त करने के लिए पूरा कार्यक्रम कोड है -

कोडिंग: ZKGetData.java

import java.io.IOException;
import java.util.concurrent.CountDownLatch;

import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.Watcher.Event.KeeperState;
import org.apache.zookeeper.data.Stat;

public class ZKGetData {

   private static ZooKeeper zk;
   private static ZooKeeperConnection conn;
   public static Stat znode_exists(String path) throws 
      KeeperException,InterruptedException {
      return zk.exists(path,true);
   }

   public static void main(String[] args) throws InterruptedException, KeeperException {
      String path = "/MyFirstZnode";
      final CountDownLatch connectedSignal = new CountDownLatch(1);
		
      try {
         conn = new ZooKeeperConnection();
         zk = conn.connect("localhost");
         Stat stat = znode_exists(path);
			
         if(stat != null) {
            byte[] b = zk.getData(path, new Watcher() {
				
               public void process(WatchedEvent we) {
					
                  if (we.getType() == Event.EventType.None) {
                     switch(we.getState()) {
                        case Expired:
                        connectedSignal.countDown();
                        break;
                     }
							
                  } else {
                     String path = "/MyFirstZnode";
							
                     try {
                        byte[] bn = zk.getData(path,
                        false, null);
                        String data = new String(bn,
                        "UTF-8");
                        System.out.println(data);
                        connectedSignal.countDown();
							
                     } catch(Exception ex) {
                        System.out.println(ex.getMessage());
                     }
                  }
               }
            }, null);
				
            String data = new String(b, "UTF-8");
            System.out.println(data);
            connectedSignal.await();
				
         } else {
            System.out.println("Node does not exists");
         }
      } catch(Exception e) {
        System.out.println(e.getMessage());
      }
   }
}

एक बार एप्लिकेशन को संकलित और निष्पादित करने के बाद, आपको निम्न आउटपुट मिलेगा

My first zookeeper app

और एप्लिकेशन चिड़ियाघरकीपर पहनावा से आगे की अधिसूचना का इंतजार करेगा। ज़ूकेरियर सीएलआई का उपयोग करके निर्दिष्ट ज़्नोड का डेटा बदलेंzkCli.sh

cd /path/to/zookeeper
bin/zkCli.sh
>>> set /MyFirstZnode Hello

अब, एप्लिकेशन निम्न आउटपुट प्रिंट करेगा और बाहर निकल जाएगा।

Hello

सेटडाटा विधि

चिड़ियाघरकीपर वर्ग प्रदान करता है setDataएक निर्दिष्ट znode में संलग्न डेटा को संशोधित करने की विधि। के हस्ताक्षरsetData विधि इस प्रकार है -

setData(String path, byte[] data, int version)

कहाँ पे,

  • path - ज़नोड मार्ग

  • data - निर्दिष्ट ज़ोनोड पथ में संग्रहीत करने के लिए डेटा।

  • version- ज़्नोड का वर्तमान संस्करण। जब भी डेटा में बदलाव होता है, ज़ूकेर ज़्नोड के वर्जन नंबर को अपडेट करता है।

आइए अब समझने के लिए एक नया जावा एप्लिकेशन बनाते हैं setDataचिड़ियाघरकीपर एपीआई की कार्यक्षमता। एक फ़ाइल बनाएँZKSetData.java। मुख्य विधि में, एक चिड़ियाघर कीपर वस्तु बनाएंzk का उपयोग करते हुए ZooKeeperConnectionवस्तु। फिर, कॉल करेंsetData उसकि विधि zk निर्दिष्ट पथ, नए डेटा और नोड के संस्करण के साथ ऑब्जेक्ट।

एक निर्दिष्ट ज़नोड में संलग्न डेटा को संशोधित करने के लिए यहां पूरा कार्यक्रम कोड है।

कोड: ZKSetData.java

import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.Watcher.Event.KeeperState;

import java.io.IOException;

public class ZKSetData {
   private static ZooKeeper zk;
   private static ZooKeeperConnection conn;

   // Method to update the data in a znode. Similar to getData but without watcher.
   public static void update(String path, byte[] data) throws
      KeeperException,InterruptedException {
      zk.setData(path, data, zk.exists(path,true).getVersion());
   }

   public static void main(String[] args) throws InterruptedException,KeeperException {
      String path= "/MyFirstZnode";
      byte[] data = "Success".getBytes(); //Assign data which is to be updated.
		
      try {
         conn = new ZooKeeperConnection();
         zk = conn.connect("localhost");
         update(path, data); // Update znode data to the specified path
      } catch(Exception e) {
         System.out.println(e.getMessage());
      }
   }
}

एक बार आवेदन को संकलित करने और निष्पादित करने के बाद, निर्दिष्ट ज़नोड का डेटा बदल दिया जाएगा और इसे ज़ूकेटर सीएलआई का उपयोग करके चेक किया जा सकता है, zkCli.sh

cd /path/to/zookeeper
bin/zkCli.sh
>>> get /MyFirstZnode

getChildren Method

चिड़ियाघरकीपर वर्ग प्रदान करता है getChildrenकिसी विशेष क्षेत्र के सभी उप-नोड प्राप्त करने की विधि। के हस्ताक्षरgetChildren विधि इस प्रकार है -

getChildren(String path, Watcher watcher)

कहाँ पे,

  • path - ज़नोड मार्ग।

  • watcher- "वॉचर" प्रकार का कॉलबैक फ़ंक्शन। चिड़ियाघरकीपर पहनावा सूचित करेगा जब निर्दिष्ट znode हटा दिया जाता है या znode के तहत एक बच्चा बनाया / हटा दिया जाता है। यह एक बार की अधिसूचना है।

कोडिंग: ZKGetChildren.java

import java.io.IOException;
import java.util.*;

import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.Watcher.Event.KeeperState;
import org.apache.zookeeper.data.Stat;

public class ZKGetChildren {
   private static ZooKeeper zk;
   private static ZooKeeperConnection conn;

   // Method to check existence of znode and its status, if znode is available.
   public static Stat znode_exists(String path) throws 
      KeeperException,InterruptedException {
      return zk.exists(path,true);
   }

   public static void main(String[] args) throws InterruptedException,KeeperException {
      String path = "/MyFirstZnode"; // Assign path to the znode
		
      try {
         conn = new ZooKeeperConnection();
         zk = conn.connect("localhost");
         Stat stat = znode_exists(path); // Stat checks the path

         if(stat!= null) {

            //“getChildren” method- get all the children of znode.It has two
            args, path and watch
            List <String> children = zk.getChildren(path, false);
            for(int i = 0; i < children.size(); i++)
            System.out.println(children.get(i)); //Print children's
         } else {
            System.out.println("Node does not exists");
         }

      } catch(Exception e) {
         System.out.println(e.getMessage());
      }

   }

}

प्रोग्राम चलाने से पहले, आइए हम दो उप-नोड्स बनाते हैं /MyFirstZnode ज़ूकिर CLI का उपयोग करते हुए, zkCli.sh

cd /path/to/zookeeper
bin/zkCli.sh
>>> create /MyFirstZnode/myfirstsubnode Hi
>>> create /MyFirstZnode/mysecondsubmode Hi

अब, प्रोग्राम को संकलित करने और चलाने के लिए उपरोक्त बनाए गए ज़नॉड्स का उत्पादन होगा।

myfirstsubnode
mysecondsubnode

एक Znode हटाएँ

चिड़ियाघरकीपर वर्ग प्रदान करता है deleteएक निर्दिष्ट znode को हटाने के लिए विधि। के हस्ताक्षरdelete विधि इस प्रकार है -

delete(String path, int version)

कहाँ पे,

  • path - ज़नोड मार्ग।

  • version - ज़्नोड का वर्तमान संस्करण।

हमें समझने के लिए एक नया जावा एप्लिकेशन बनाएं deleteचिड़ियाघरकीपर एपीआई की कार्यक्षमता। एक फ़ाइल बनाएँZKDelete.java। मुख्य विधि में, एक चिड़ियाघर कीपर वस्तु बनाएंzk का उपयोग करते हुए ZooKeeperConnectionवस्तु। फिर, कॉल करेंdelete उसकि विधि zk निर्दिष्ट के साथ वस्तु path और नोड का संस्करण।

एक znode को हटाने के लिए पूरा कार्यक्रम कोड इस प्रकार है -

कोडिंग: ZKDelete.java

import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.KeeperException;

public class ZKDelete {
   private static ZooKeeper zk;
   private static ZooKeeperConnection conn;

   // Method to check existence of znode and its status, if znode is available.
   public static void delete(String path) throws KeeperException,InterruptedException {
      zk.delete(path,zk.exists(path,true).getVersion());
   }

   public static void main(String[] args) throws InterruptedException,KeeperException {
      String path = "/MyFirstZnode"; //Assign path to the znode
		
      try {
         conn = new ZooKeeperConnection();
         zk = conn.connect("localhost");
         delete(path); //delete the node with the specified path
      } catch(Exception e) {
         System.out.println(e.getMessage()); // catches error messages
      }
   }
}