Gardien de zoo - API

ZooKeeper a une liaison API officielle pour Java et C. La communauté ZooKeeper fournit une API non officielle pour la plupart des langages (.NET, python, etc.). À l'aide de l'API ZooKeeper, une application peut se connecter, interagir, manipuler des données, coordonner et finalement se déconnecter d'un ensemble ZooKeeper.

L'API ZooKeeper dispose d'un riche ensemble de fonctionnalités pour obtenir toutes les fonctionnalités de l'ensemble ZooKeeper de manière simple et sûre. L'API ZooKeeper fournit des méthodes synchrones et asynchrones.

L'ensemble ZooKeeper et l'API ZooKeeper se complètent complètement dans tous les aspects et bénéficient aux développeurs d'une grande manière. Parlons de la liaison Java dans ce chapitre.

Principes de base de l'API ZooKeeper

L'application interagissant avec l'ensemble ZooKeeper est appelée ZooKeeper Client ou simplement Client.

Znode est le composant principal de l'ensemble ZooKeeper et l'API ZooKeeper fournit un petit ensemble de méthodes pour manipuler tous les détails de znode avec l'ensemble ZooKeeper.

Un client doit suivre les étapes ci-dessous pour avoir une interaction claire et propre avec l'ensemble ZooKeeper.

  • Connectez-vous à l'ensemble ZooKeeper. L'ensemble ZooKeeper attribue un ID de session au client.

  • Envoyez régulièrement des pulsations au serveur. Sinon, l'ensemble ZooKeeper expire l'ID de session et le client doit se reconnecter.

  • Obtenez / définissez les znodes tant qu'un ID de session est actif.

  • Déconnectez-vous de l'ensemble ZooKeeper, une fois toutes les tâches terminées. Si le client est inactif pendant une période prolongée, l'ensemble ZooKeeper déconnectera automatiquement le client.

Liaison Java

Laissez-nous comprendre l'ensemble le plus important d'API ZooKeeper dans ce chapitre. La partie centrale de l'API ZooKeeper estZooKeeper class. Il fournit des options pour connecter l'ensemble ZooKeeper dans son constructeur et dispose des méthodes suivantes -

  • connect - se connecter à l'ensemble ZooKeeper

  • create - créer un znode

  • exists - vérifier si un znode existe et ses informations

  • getData - obtenir des données d'un znode particulier

  • setData - définir les données dans un znode particulier

  • getChildren - obtenir tous les sous-nœuds disponibles dans un znode particulier

  • delete - obtenir un znode particulier et tous ses enfants

  • close - fermer une connexion

Connectez-vous à l'ensemble ZooKeeper

La classe ZooKeeper fournit des fonctionnalités de connexion via son constructeur. La signature du constructeur est la suivante -

ZooKeeper(String connectionString, int sessionTimeout, Watcher watcher)

Où,

  • connectionString - Hôte de l'ensemble ZooKeeper.

  • sessionTimeout - délai d'expiration de la session en millisecondes.

  • watcher- un objet implémentant l'interface «Watcher». L'ensemble ZooKeeper renvoie l'état de la connexion via l'objet observateur.

Créons une nouvelle classe d'assistance ZooKeeperConnection et ajoutez une méthode connect. leconnect crée un objet ZooKeeper, se connecte à l'ensemble ZooKeeper, puis retourne l'objet.

Ici CountDownLatch est utilisé pour arrêter (attendre) le processus principal jusqu'à ce que le client se connecte à l'ensemble ZooKeeper.

L'ensemble ZooKeeper répond à l'état de la connexion via le Watcher callback. Le rappel Watcher sera appelé une fois que le client se connectera à l'ensemble ZooKeeper et que le rappel Watcher appellera lecountDown méthode de la CountDownLatch pour libérer le verrou, await dans le processus principal.

Voici le code complet pour se connecter à un ensemble ZooKeeper.

Codage: 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();
   }
}

Enregistrez le code ci-dessus et il sera utilisé dans la section suivante pour connecter l'ensemble ZooKeeper.

Créer un Znode

La classe ZooKeeper fournit create methodpour créer un nouveau znode dans l'ensemble ZooKeeper. La signature ducreate la méthode est la suivante -

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

Où,

  • path- Chemin Znode. Par exemple, / myapp1, / ​​myapp2, / myapp1 / mydata1, myapp2 / mydata1 / myanothersubdata

  • data - données à stocker dans un chemin znode spécifié

  • acl- liste de contrôle d'accès du nœud à créer. L'API ZooKeeper fournit une interface statiqueZooDefs.Idspour obtenir une partie de la liste acl de base. Par exemple, ZooDefs.Ids.OPEN_ACL_UNSAFE renvoie une liste d'acl pour les znodes ouverts.

  • createMode- le type de nœud, éphémère, séquentiel ou les deux. C'est unenum.

Créons une nouvelle application Java pour vérifier le createfonctionnalité de l'API ZooKeeper. Créer un fichierZKCreate.java. Dans la méthode principale, créez un objet de typeZooKeeperConnection et appelez le connect méthode pour se connecter à l'ensemble ZooKeeper.

La méthode connect renverra l'objet ZooKeeper zk. Maintenant, appelez lecreate méthode de zk objet avec personnalisé path et data.

Le code de programme complet pour créer un znode est le suivant -

Codage: 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
      }
   }
}

Une fois l'application compilée et exécutée, un znode avec les données spécifiées sera créé dans l'ensemble ZooKeeper. Vous pouvez le vérifier à l'aide de la CLI ZooKeeperzkCli.sh.

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

Exists - Vérifier l'existence d'un Znode

La classe ZooKeeper fournit le exists methodpour vérifier l'existence d'un znode. Il renvoie les métadonnées d'un znode, si le znode spécifié existe. La signature duexists la méthode est la suivante -

exists(String path, boolean watcher)

Où,

  • path - Chemin Znode

  • watcher - valeur booléenne pour spécifier s'il faut regarder un znode spécifié ou non

Créons une nouvelle application Java pour vérifier la fonctionnalité «existe» de l'API ZooKeeper. Créez un fichier «ZKExists.java» . Dans la méthode principale, créez l'objet ZooKeeper, «zk» à l' aide de l' objet «ZooKeeperConnection» . Ensuite, appel « existe » méthode de « ZK » objet à la coutume « chemin » . La liste complète est la suivante -

Codage: 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
      }
   }
}

Une fois l'application compilée et exécutée, vous obtiendrez la sortie ci-dessous.

Node exists and the node version is 1.

getData, méthode

La classe ZooKeeper fournit getDataméthode pour obtenir les données attachées dans un znode spécifié et son état. La signature dugetData la méthode est la suivante -

getData(String path, Watcher watcher, Stat stat)

Où,

  • path - Chemin Znode.

  • watcher - Fonction de rappel de type Watcher. L'ensemble ZooKeeper notifie via le rappel Watcher lorsque les données du znode spécifié changent. Il s'agit d'une notification unique.

  • stat - Renvoie les métadonnées d'un znode.

Créons une nouvelle application Java pour comprendre getDatafonctionnalité de l'API ZooKeeper. Créer un fichierZKGetData.java. Dans la méthode principale, créez un objet ZooKeeperzk en utilisant il ZooKeeperConnectionobjet. Ensuite, appelez legetData méthode de l'objet zk avec chemin personnalisé.

Voici le code de programme complet pour obtenir les données d'un nœud spécifié -

Codage: 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());
      }
   }
}

Une fois l'application compilée et exécutée, vous obtiendrez le résultat suivant

My first zookeeper app

Et l'application attendra une autre notification de l'ensemble ZooKeeper. Modifier les données du znode spécifié à l'aide de la CLI ZooKeeperzkCli.sh.

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

Maintenant, l'application imprimera la sortie suivante et se fermera.

Hello

setData, méthode

La classe ZooKeeper fournit setDataméthode pour modifier les données attachées dans un znode spécifié. La signature dusetData la méthode est la suivante -

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

Où,

  • path - Chemin Znode

  • data - données à stocker dans un chemin znode spécifié.

  • version- Version actuelle du znode. ZooKeeper met à jour le numéro de version du znode chaque fois que les données sont modifiées.

Créons maintenant une nouvelle application Java pour comprendre le setDatafonctionnalité de l'API ZooKeeper. Créer un fichierZKSetData.java. Dans la méthode principale, créez un objet ZooKeeperzk en utilisant le ZooKeeperConnectionobjet. Ensuite, appelez lesetData méthode de zk objet avec le chemin d'accès spécifié, les nouvelles données et la version du nœud.

Voici le code du programme complet pour modifier les données attachées dans un znode spécifié.

Code: 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());
      }
   }
}

Une fois l'application compilée et exécutée, les données du znode spécifié seront modifiées et pourront être vérifiées à l'aide de la CLI ZooKeeper, zkCli.sh.

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

getChildren, méthode

La classe ZooKeeper fournit getChildrenméthode pour obtenir tous les sous-nœuds d'un znode particulier. La signature dugetChildren la méthode est la suivante -

getChildren(String path, Watcher watcher)

Où,

  • path - Chemin Znode.

  • watcher- Fonction de rappel de type «Watcher». L'ensemble ZooKeeper notifiera lorsque le znode spécifié est supprimé ou qu'un enfant sous le znode est créé / supprimé. Ceci est une notification unique.

Codage: 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());
      }

   }

}

Avant d'exécuter le programme, créons deux sous-nœuds pour /MyFirstZnode à l'aide de la CLI ZooKeeper, zkCli.sh.

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

Maintenant, la compilation et l'exécution du programme produiront les znodes créés ci-dessus.

myfirstsubnode
mysecondsubnode

Supprimer un Znode

La classe ZooKeeper fournit deleteméthode pour supprimer un znode spécifié. La signature dudelete la méthode est la suivante -

delete(String path, int version)

Où,

  • path - Chemin Znode.

  • version - Version actuelle du znode.

Créons une nouvelle application Java pour comprendre deletefonctionnalité de l'API ZooKeeper. Créer un fichierZKDelete.java. Dans la méthode principale, créez un objet ZooKeeperzk en utilisant ZooKeeperConnectionobjet. Ensuite, appelez ledelete méthode de zk objet avec le spécifié path et la version du nœud.

Le code de programme complet pour supprimer un znode est le suivant -

Codage: 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
      }
   }
}