當前位置: 首頁>>代碼示例>>Java>>正文


Java ZooKeeper.getChildren方法代碼示例

本文整理匯總了Java中org.apache.zookeeper.ZooKeeper.getChildren方法的典型用法代碼示例。如果您正苦於以下問題:Java ZooKeeper.getChildren方法的具體用法?Java ZooKeeper.getChildren怎麽用?Java ZooKeeper.getChildren使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.zookeeper.ZooKeeper的用法示例。


在下文中一共展示了ZooKeeper.getChildren方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getTree

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
public static String[] getTree(ZooKeeper zk,String path) throws Exception{
 if(zk.exists(path, false) == null){
  return new String[0];
 }
 List<String> dealList = new ArrayList<String>();
 dealList.add(path);
 int index =0;
 while(index < dealList.size()){
  String tempPath = dealList.get(index);
  List<String> children = zk.getChildren(tempPath, false);
  if(tempPath.equalsIgnoreCase("/") == false){
   tempPath = tempPath +"/";
  }
  Collections.sort(children);
  for(int i = children.size() -1;i>=0;i--){
   dealList.add(index+1, tempPath + children.get(i));
  }
  index++;
 }
 return (String[])dealList.toArray(new String[0]);
}
 
開發者ID:hungki,項目名稱:tbschedule-wed,代碼行數:22,代碼來源:ZKTools.java

示例2: testNodeChildrenChanged

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
@Test
public void testNodeChildrenChanged() throws Exception {
    QuorumUtil qu = new QuorumUtil(1);
    qu.startAll();

    EventsWatcher watcher = new EventsWatcher();
    ZooKeeper zk1 = createClient(qu, 1, watcher);
    ZooKeeper zk2 = createClient(qu, 2);

    String path = "/test-children-changed";

    zk1.create(path, new byte[1], ZooDefs.Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);
    zk1.getChildren(path, watcher);
    qu.shutdown(1);
    zk2.create(path + "/children-1", new byte[2],
            ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
    qu.start(1);
    watcher.waitForConnected(TIMEOUT * 1000L);
    watcher.assertEvent(TIMEOUT, EventType.NodeChildrenChanged);

    qu.shutdownAll();
}
 
開發者ID:didichuxing2,項目名稱:https-github.com-apache-zookeeper,代碼行數:24,代碼來源:WatchEventWhenAutoResetTest.java

示例3: getTree

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
private static String[] getTree(ZooKeeper zk, String path) throws Exception{
 if(zk.exists(path, false) == null){
  return new String[0];
 }
 List<String> dealList = new ArrayList<String>();
 dealList.add(path);
 int index =0;
 while(index < dealList.size()){
  String tempPath = dealList.get(index);
  List<String> children = zk.getChildren(tempPath, false);
  if(!"/".equalsIgnoreCase(tempPath)){
   tempPath = tempPath +"/";
  }
  Collections.sort(children);
  for (int i = children.size() - 1; i >= 0; i--) {
   dealList.add(index + 1, tempPath + children.get(i));
  }
  index++;
 }
 return dealList.toArray(new String[0]);
}
 
開發者ID:liuht777,項目名稱:uncode-scheduler,代碼行數:22,代碼來源:ZKTools.java

示例4: init

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
@PostConstruct
public void init() {
	ZooKeeper zkClient = zookeeperConnManager.getZkClient();
	try {
		/* 如果根節點不存在則創建 */
		if (null == zkClient.exists(nodePath, false)) {
			zkClient.create(nodePath, new byte[] {}, Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
		}
		/* 注冊節點 */
		zkClient.getChildren(nodePath, this);
	} catch (KeeperException | InterruptedException e) {
		log.error("error", e);
	}
}
 
開發者ID:yunjiweidian,項目名稱:TITAN,代碼行數:15,代碼來源:WatchAgents.java

示例5: delQuota

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
/**
 * this method deletes quota for a node.
 *
 * @param zk the zookeeper client
 * @param path the path to delete quota for
 * @param bytes true if number of bytes needs to be unset
 * @param numNodes true if number of nodes needs to be unset
 * @return true if quota deletion is successful
 * @throws KeeperException
 * @throws IOException
 * @throws InterruptedException
 */
public static boolean delQuota(ZooKeeper zk, String path,
        boolean bytes, boolean numNodes)
        throws KeeperException, IOException, InterruptedException, MalformedPathException {
    String parentPath = Quotas.quotaZookeeper + path;
    String quotaPath = Quotas.quotaZookeeper + path + "/" + 
            Quotas.limitNode;
    if (zk.exists(quotaPath, false) == null) {
        System.out.println("Quota does not exist for " + path);
        return true;
    }
    byte[] data = null;
    try {
        data = zk.getData(quotaPath, false, new Stat());
    } catch (IllegalArgumentException ex) {
        throw new MalformedPathException(ex.getMessage());
    } catch (KeeperException.NoNodeException ne) {
        System.err.println("quota does not exist for " + path);
        return true;
    }
    StatsTrack strack = new StatsTrack(new String(data));
    if (bytes && !numNodes) {
        strack.setBytes(-1L);
        zk.setData(quotaPath, strack.toString().getBytes(), -1);
    } else if (!bytes && numNodes) {
        strack.setCount(-1);
        zk.setData(quotaPath, strack.toString().getBytes(), -1);
    } else if (bytes && numNodes) {
        // delete till you can find a node with more than
        // one child
        List<String> children = zk.getChildren(parentPath, false);
        /// delete the direct children first
        for (String child : children) {
            zk.delete(parentPath + "/" + child, -1);
        }
        // cut the tree till their is more than one child
        trimProcQuotas(zk, parentPath);
    }
    return true;
}
 
開發者ID:didichuxing2,項目名稱:https-github.com-apache-zookeeper,代碼行數:52,代碼來源:DelQuotaCommand.java

示例6: testSequentialNodeData

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
@Test
public void testSequentialNodeData() throws Exception {
    ZooKeeper zk= null;
    String queue_handle = "/queue";
    try {
        zk = createClient();

        zk.create(queue_handle, new byte[0], Ids.OPEN_ACL_UNSAFE,
                CreateMode.PERSISTENT);
        zk.create(queue_handle + "/element", "0".getBytes(),
                Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT_SEQUENTIAL);
        zk.create(queue_handle + "/element", "1".getBytes(),
                Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT_SEQUENTIAL);
        List<String> children = zk.getChildren(queue_handle, true);
        Assert.assertEquals(children.size(), 2);
        String child1 = children.get(0);
        String child2 = children.get(1);
        int compareResult = child1.compareTo(child2);
        Assert.assertNotSame(compareResult, 0);
        if (compareResult < 0) {
        } else {
            String temp = child1;
            child1 = child2;
            child2 = temp;
        }
        String child1data = new String(zk.getData(queue_handle
                + "/" + child1, false, null));
        String child2data = new String(zk.getData(queue_handle
                + "/" + child2, false, null));
        Assert.assertEquals(child1data, "0");
        Assert.assertEquals(child2data, "1");
    } finally {
        if (zk != null) {
            zk.close();
        }
    }

}
 
開發者ID:didichuxing2,項目名稱:https-github.com-apache-zookeeper,代碼行數:39,代碼來源:ClientTest.java

示例7: run

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
public void run() throws IOException, InterruptedException, KeeperException {
    zk = new ZooKeeper(zkHostPort, sessTimeout, this);
    mknod(assignmentsNode, CreateMode.PERSISTENT);
    mknod(statusNode, CreateMode.EPHEMERAL);
    mknod(reportsNode, CreateMode.PERSISTENT);
    // Now we just start watching the assignments directory
    zk.getChildren(assignmentsNode, true, this, null);
}
 
開發者ID:maoling,項目名稱:fuck_zookeeper,代碼行數:9,代碼來源:InstanceContainer.java

示例8: doVerify

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
@Override
boolean doVerify() throws Exception {
    final ZooKeeper zk = new ZooKeeper(String.format("%s:%d", getHost(), getPort()), 3000,
            watchedEvent -> LOGGER.trace("got event"));
    final List<String> children = zk.getChildren("/brokers/topics", false);
    zk.close();
    for (final String child : children) {
        // checkpoint topic is created if the samza job is up and running
        // checkpointing must be enabled for the samza job
        if (child.contains("checkpoint")) {
            return true;
        }
    }
    return false;
}
 
開發者ID:qingdao81,項目名稱:resource-verifier,代碼行數:16,代碼來源:SamzaResourceVerifier.java

示例9: testNodeDeleted

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
@Test
public void testNodeDeleted() throws Exception {
    QuorumUtil qu = new QuorumUtil(1);
    qu.startAll();

    EventsWatcher watcher = new EventsWatcher();
    ZooKeeper zk1 = createClient(qu, 1, watcher);
    ZooKeeper zk2 = createClient(qu, 2);

    String path = "/test-deleted";

    zk1.create(path, new byte[1], ZooDefs.Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);
    zk1.getData(path, watcher, null);
    qu.shutdown(1);
    zk2.delete(path, -1);
    qu.start(1);
    watcher.waitForConnected(TIMEOUT * 1000L);
    watcher.assertEvent(TIMEOUT, EventType.NodeDeleted);

    zk1.create(path, new byte[1], ZooDefs.Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);
    zk1.exists(path, watcher);
    qu.shutdown(1);
    zk2.delete(path, -1);
    qu.start(1);
    watcher.waitForConnected(TIMEOUT * 1000L);
    watcher.assertEvent(TIMEOUT, EventType.NodeDeleted);

    zk1.create(path, new byte[1], ZooDefs.Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);
    zk1.getChildren(path, watcher);
    qu.shutdown(1);
    zk2.delete(path, -1);
    qu.start(1);
    watcher.waitForConnected(TIMEOUT * 1000L);
    watcher.assertEvent(TIMEOUT, EventType.NodeDeleted);

    qu.shutdownAll();
}
 
開發者ID:didichuxing2,項目名稱:https-github.com-apache-zookeeper,代碼行數:41,代碼來源:WatchEventWhenAutoResetTest.java

示例10: testUpgrade

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
/**
 * test the upgrade
 * @throws Exception
 */
@Test
public void testUpgrade() throws Exception {
    File upgradeDir = new File(testData, "upgrade");
    UpgradeMain upgrade = new UpgradeMain(upgradeDir, upgradeDir);
    upgrade.runUpgrade();
    ZooKeeperServer zks = new ZooKeeperServer(upgradeDir, upgradeDir, 3000);
    SyncRequestProcessor.setSnapCount(1000);
    final int PORT = Integer.parseInt(HOSTPORT.split(":")[1]);
    ServerCnxnFactory f = ServerCnxnFactory.createFactory(PORT, -1);
    f.startup(zks);
    LOG.info("starting up the zookeeper server .. waiting");
    Assert.assertTrue("waiting for server being up",
            ClientBase.waitForServerUp(HOSTPORT, CONNECTION_TIMEOUT));
    ZooKeeper zk = new ZooKeeper(HOSTPORT, CONNECTION_TIMEOUT, this);
    Stat stat = zk.exists("/", false);
    List<String> children = zk.getChildren("/", false);
    Collections.sort(children);
    for (int i = 0; i < 10; i++) {
        Assert.assertTrue("data tree sanity check",
                ("test-" + i).equals(children.get(i)));
    }
    //try creating one node
    zk.create("/upgrade", "upgrade".getBytes(), Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);
    // check if its there
    if (zk.exists("/upgrade", false) == null) {
        Assert.assertTrue(false);
    }

    zk.close();

    // bring down the server
    f.shutdown();
    Assert.assertTrue("waiting for server down",
               ClientBase.waitForServerDown(HOSTPORT,
                       ClientBase.CONNECTION_TIMEOUT));

}
 
開發者ID:maoling,項目名稱:fuck_zookeeper,代碼行數:43,代碼來源:UpgradeTest.java

示例11: checkBookiesUp

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
/**
 * Check that a number of bookies are available
 * @param count number of bookies required
 * @param timeout number of seconds to wait for bookies to start
 * @throws IOException if bookies are not started by the time the timeout hits
 */
int checkBookiesUp(int count, int timeout) throws Exception {
  ZooKeeper zkc = connectZooKeeper();
  try {
    int mostRecentSize = 0;
    for (int i = 0; i < timeout; i++) {
      try {
        List<String> children = zkc.getChildren("/ledgers/available",
                                                false);
        mostRecentSize = children.size();
        // Skip 'readonly znode' which is used for keeping R-O bookie details
        if (children.contains("readonly")) {
          mostRecentSize = children.size() - 1;
        }
        if (LOG.isDebugEnabled()) {
          LOG.debug("Found " + mostRecentSize + " bookies up, "
                    + "waiting for " + count);
          if (LOG.isTraceEnabled()) {
            for (String child : children) {
              LOG.trace(" server: " + child);
            }
          }
        }
        if (mostRecentSize == count) {
          break;
        }
      } catch (KeeperException e) {
        // ignore
      }
      Thread.sleep(1000);
    }
    return mostRecentSize;
  } finally {
    zkc.close();
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:42,代碼來源:BKJMUtil.java

示例12: utestChildren

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
private void utestChildren(int port)
    throws IOException, InterruptedException, KeeperException
{
    ZooKeeper zk =
        new ZooKeeper("127.0.0.1:" + port, CONNECTION_TIMEOUT, this);
    for (int i = 0; i < 10000; i++) {
        zk.getChildren("/" + i, true);
    }
    zk.close();
}
 
開發者ID:l294265421,項目名稱:ZooKeeper,代碼行數:11,代碼來源:OOMTest.java

示例13: waitInLine

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
static String waitInLine(ZooKeeper zookeeper, String lockNode,
                         String placeInLine) throws KeeperException, InterruptedException {

    List<String> children = zookeeper.getChildren(lockNode, false);

    Collections.sort(children);

    if (children.size() == 0) {
        logger.warn("getChildren() returned empty list, but we created a ticket.");
        return acquireLock(zookeeper, lockNode);
    }

    boolean lockingTicketExists = children.get(0).equals(LOCKING_TICKET);
    if (lockingTicketExists) {
        children.remove(0);
    }

    int positionInQueue = -1;
    int i = 0;
    for (String child : children) {
        if (child.equals(placeInLine)) {
            positionInQueue = i;
            break;
        }
        i++;
    }

    if (positionInQueue < 0) {
        throw new RuntimeException(
            "Created node (" + placeInLine + ") not found in getChildren().");
    }

    String placeBeforeUs;
    if (positionInQueue == 0) {
        if (grabTicket(zookeeper, lockNode, LOCKING_TICKET)) {
            releaseTicket(zookeeper, lockNode, placeInLine);
            return LOCKING_TICKET;
        } else {
            placeBeforeUs = LOCKING_TICKET;
        }
    } else {
        placeBeforeUs = children.get(positionInQueue - 1);
    }

    final CountDownLatch latch = new CountDownLatch(1);
    Stat stat = zookeeper.exists(lockNode + "/" + placeBeforeUs, event -> {
        latch.countDown();
    });

    if (stat != null) {
        logger.debug("Watching place in queue before us ({})", placeBeforeUs);
        latch.await();
    }

    return waitInLine(zookeeper, lockNode, placeInLine);
}
 
開發者ID:warlock-china,項目名稱:azeroth,代碼行數:57,代碼來源:ResourceClaim.java

示例14: testDeepChildWatcherAutoResetWithChroot

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
@Test
public void testDeepChildWatcherAutoResetWithChroot() throws Exception {
    ZooKeeper zk1 = createClient();

    zk1.create("/ch1", null, Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);
    zk1.create("/ch1/here", null, Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);
    zk1.create("/ch1/here/we", null, Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);
    zk1.create("/ch1/here/we/are", null, Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);

    MyWatcher watcher = new MyWatcher();
    ZooKeeper zk2 = createClient(watcher, hostPort + "/ch1/here/we");
    zk2.getChildren("/are", true );

    // this should trigger the watch
    zk1.create("/ch1/here/we/are/now", null, Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);
    WatchedEvent e = watcher.events.poll(TIMEOUT, TimeUnit.MILLISECONDS);
    Assert.assertNotNull(e);
    Assert.assertEquals(EventType.NodeChildrenChanged, e.getType());
    Assert.assertEquals("/are", e.getPath());

    MyWatcher childWatcher = new MyWatcher();
    zk2.getChildren("/are", childWatcher);
    
    stopServer();
    watcher.waitForDisconnected(3000);
    startServer();
    watcher.waitForConnected(3000);

    // this should trigger the watch
    zk1.create("/ch1/here/we/are/again", null, Ids.OPEN_ACL_UNSAFE,
            CreateMode.PERSISTENT);
    e = childWatcher.events.poll(TIMEOUT, TimeUnit.MILLISECONDS);
    Assert.assertNotNull(e);
    Assert.assertEquals(EventType.NodeChildrenChanged, e.getType());
    Assert.assertEquals("/are", e.getPath());
}
 
開發者ID:l294265421,項目名稱:ZooKeeper,代碼行數:42,代碼來源:DisconnectedWatcherTest.java

示例15: testSequentialNodeNames

import org.apache.zookeeper.ZooKeeper; //導入方法依賴的package包/類
@Test
public void testSequentialNodeNames()
    throws IOException, InterruptedException, KeeperException
{
    String path = "/SEQUENCE";
    String file = "TEST";
    String filepath = path + "/" + file;

    ZooKeeper zk = null;
    try {
        zk = createClient();
        zk.create(path, new byte[0], Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
        zk.create(filepath, new byte[0], Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT_SEQUENTIAL);
        List<String> children = zk.getChildren(path, false);
        Assert.assertEquals(1, children.size());
        Assert.assertEquals(file + "0000000000", children.get(0));

        zk.create(filepath, new byte[0], Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT_SEQUENTIAL);
        children = zk.getChildren(path, false);
        Assert.assertEquals(2, children.size());
        Assert.assertTrue("contains child 1",  children.contains(file + "0000000001"));

        zk.create(filepath, new byte[0], Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT_SEQUENTIAL);
        children = zk.getChildren(path, false);
        Assert.assertEquals(3, children.size());
        Assert.assertTrue("contains child 2",
                   children.contains(file + "0000000002"));

        // The pattern is holding so far.  Let's run the counter a bit
        // to be sure it continues to spit out the correct answer
        for(int i = children.size(); i < 105; i++)
           zk.create(filepath, new byte[0], Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT_SEQUENTIAL);

        children = zk.getChildren(path, false);
        Assert.assertTrue("contains child 104",
                   children.contains(file + "0000000104"));

    }
    finally {
        if(zk != null)
            zk.close();
    }
}
 
開發者ID:l294265421,項目名稱:ZooKeeper,代碼行數:44,代碼來源:ClientTest.java


注:本文中的org.apache.zookeeper.ZooKeeper.getChildren方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。