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


Java ConstraintItem類代碼示例

本文整理匯總了Java中org.apache.helix.model.ConstraintItem的典型用法代碼示例。如果您正苦於以下問題:Java ConstraintItem類的具體用法?Java ConstraintItem怎麽用?Java ConstraintItem使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: setConstraints

import org.apache.helix.model.ConstraintItem; //導入依賴的package包/類
private static void setConstraints(ZKHelixAdmin admin, int numPartitions) {

        logger.info("pause cluster");
        admin.enableCluster("PistachiosCluster", false);
        // setting partition constraints
        logger.info("setting per partition state transition constraints to 1");
        try {
            for (int constraintId = 0; constraintId < numPartitions; constraintId++) {
                java.util.HashMap<ConstraintAttribute, String>  attributes = new java.util.HashMap<ConstraintAttribute, String>();
                attributes.put(ConstraintAttribute.RESOURCE, "PistachiosResource");
                attributes.put(ConstraintAttribute.PARTITION, "PistachiosResource_"+constraintId);
                logger.info("setting per partition for {} state transition constraints to 1", "PistachiosResource_"+constraintId);
                admin.setConstraint("PistachiosCluster", ConstraintType.STATE_CONSTRAINT, "PistachiosPartitionTransitionConstraint" + constraintId,
                   new ConstraintItem(attributes,"1"));
            }

        } catch(Exception e) {
            logger.info("setting state transition constraints error, roll back and exit", e);
        }
        logger.info("resume cluster");
        admin.enableCluster("PistachiosCluster", true);
  }
 
開發者ID:lyogavin,項目名稱:Pistachio,代碼行數:23,代碼來源:PistachiosFormatter.java

示例2: setConstraint

import org.apache.helix.model.ConstraintItem; //導入依賴的package包/類
@Override
public void setConstraint(String clusterName, final ConstraintType constraintType,
    final String constraintId, final ConstraintItem constraintItem) {
  BaseDataAccessor<ZNRecord> baseAccessor = new ZkBaseDataAccessor<ZNRecord>(_zkClient);

  Builder keyBuilder = new Builder(clusterName);
  String path = keyBuilder.constraint(constraintType.toString()).getPath();

  baseAccessor.update(path, new DataUpdater<ZNRecord>() {
    @Override
    public ZNRecord update(ZNRecord currentData) {
      ClusterConstraints constraints = currentData == null
          ? new ClusterConstraints(constraintType)
          : new ClusterConstraints(currentData);

      constraints.addConstraintItem(constraintId, constraintItem);
      return constraints.getRecord();
    }
  }, AccessOption.PERSISTENT);
}
 
開發者ID:apache,項目名稱:helix,代碼行數:21,代碼來源:ZKHelixAdmin.java

示例3: setConstraint

import org.apache.helix.model.ConstraintItem; //導入依賴的package包/類
/**
 * set constraint
 * @param clusterName
 * @param constraintType
 * @param constraintId
 * @param constraintAttributesMap : csv-formated constraint key-value pairs
 */
public void setConstraint(String clusterName, String constraintType, String constraintId,
    String constraintAttributesMap) {
  if (clusterName == null || constraintType == null || constraintId == null
      || constraintAttributesMap == null) {
    throw new IllegalArgumentException(
        "fail to set constraint. missing clusterName|constraintType|constraintId|constraintAttributesMap");
  }

  ConstraintType type = ConstraintType.valueOf(constraintType);
  ConstraintItemBuilder builder = new ConstraintItemBuilder();
  Map<String, String> constraintAttributes =
      HelixUtil.parseCsvFormatedKeyValuePairs(constraintAttributesMap);
  ConstraintItem constraintItem = builder.addConstraintAttributes(constraintAttributes).build();
  _admin.setConstraint(clusterName, type, constraintId, constraintItem);
}
 
開發者ID:apache,項目名稱:helix,代碼行數:23,代碼來源:ClusterSetup.java

示例4: selectConstraints

import org.apache.helix.model.ConstraintItem; //導入依賴的package包/類
/**
 * constraints are selected in the order of the following rules: 1) don't select
 * constraints with CONSTRAINT_VALUE=ANY; 2) if one constraint is more specific than the
 * other, select the most specific one 3) if a message matches multiple constraints of
 * incomparable specificity, select the one with the minimum value 4) if a message
 * matches multiple constraints of incomparable specificity, and they all have the same
 * value, select the first in alphabetic order
 */
Set<ConstraintItem> selectConstraints(Set<ConstraintItem> items,
    Map<ConstraintAttribute, String> attributes) {
  Map<String, ConstraintItem> selectedItems = new HashMap<String, ConstraintItem>();
  for (ConstraintItem item : items) {
    // don't select constraints with CONSTRAINT_VALUE=ANY
    if (item.getConstraintValue().equals(ConstraintValue.ANY.toString())) {
      continue;
    }

    String key = item.filter(attributes).toString();
    if (!selectedItems.containsKey(key)) {
      selectedItems.put(key, item);
    } else {
      ConstraintItem existingItem = selectedItems.get(key);
      if (existingItem.match(item.getAttributes())) {
        // item is more specific than existingItem
        selectedItems.put(key, item);
      } else if (!item.match(existingItem.getAttributes())) {
        // existingItem and item are of incomparable specificity
        int value = valueOf(item.getConstraintValue());
        int existingValue = valueOf(existingItem.getConstraintValue());
        if (value < existingValue) {
          // item's constraint value is less than that of existingItem
          selectedItems.put(key, item);
        } else if (value == existingValue) {
          if (item.toString().compareTo(existingItem.toString()) < 0) {
            // item is ahead of existingItem in alphabetic order
            selectedItems.put(key, item);
          }
        }
      }
    }
  }
  return new HashSet<ConstraintItem>(selectedItems.values());
}
 
開發者ID:apache,項目名稱:helix,代碼行數:44,代碼來源:MessageThrottleStage.java

示例5: throttle

import org.apache.helix.model.ConstraintItem; //導入依賴的package包/類
private List<Message> throttle(Map<String, Integer> throttleMap, ClusterConstraints constraint,
    List<Message> messages, final boolean needThrottle) {

  List<Message> throttleOutputMsgs = new ArrayList<Message>();
  for (Message message : messages) {
    Map<ConstraintAttribute, String> msgAttr = ClusterConstraints.toConstraintAttributes(message);

    Set<ConstraintItem> matches = constraint.match(msgAttr);
    matches = selectConstraints(matches, msgAttr);

    boolean msgThrottled = false;
    for (ConstraintItem item : matches) {
      String key = item.filter(msgAttr).toString();
      if (!throttleMap.containsKey(key)) {
        throttleMap.put(key, valueOf(item.getConstraintValue()));
      }
      int value = throttleMap.get(key);
      throttleMap.put(key, --value);

      if (needThrottle && value < 0) {
        msgThrottled = true;

        if (LOG.isDebugEnabled()) {
          // TODO: printout constraint item that throttles the message
          LOG.debug("message: " + message + " is throttled by constraint: " + item);
        }
      }
    }
    if (!msgThrottled) {
      throttleOutputMsgs.add(message);
    }
  }

  return throttleOutputMsgs;
}
 
開發者ID:apache,項目名稱:helix,代碼行數:36,代碼來源:MessageThrottleStage.java

示例6: containsConstraint

import org.apache.helix.model.ConstraintItem; //導入依賴的package包/類
private boolean containsConstraint(Set<ConstraintItem> constraints, ConstraintItem constraint) {
  for (ConstraintItem item : constraints) {
    if (item.toString().equals(constraint.toString())) {
      return true;
    }
  }
  return false;
}
 
開發者ID:apache,項目名稱:helix,代碼行數:9,代碼來源:TestMessageThrottleStage.java

示例7: build

import org.apache.helix.model.ConstraintItem; //導入依賴的package包/類
public ConstraintItem build() {
  // TODO: check if constraint-item is valid
  return new ConstraintItem(_attributes, _constraintValue);
}
 
開發者ID:apache,項目名稱:helix,代碼行數:5,代碼來源:ConstraintItemBuilder.java

示例8: setConstraint

import org.apache.helix.model.ConstraintItem; //導入依賴的package包/類
@Override public void setConstraint(String clusterName,
    ClusterConstraints.ConstraintType constraintType, String constraintId,
    ConstraintItem constraintItem) {

}
 
開發者ID:apache,項目名稱:helix,代碼行數:6,代碼來源:MockHelixAdmin.java

示例9: testAddRemoveMsgConstraint

import org.apache.helix.model.ConstraintItem; //導入依賴的package包/類
@Test
public void testAddRemoveMsgConstraint() {
  String className = TestHelper.getTestClassName();
  String methodName = TestHelper.getTestMethodName();
  String clusterName = className + "_" + methodName;

  System.out.println("START " + clusterName + " at " + new Date(System.currentTimeMillis()));

  HelixAdmin tool = new ZKHelixAdmin(_gZkClient);
  tool.addCluster(clusterName, true);
  Assert.assertTrue(ZKUtil.isClusterSetup(clusterName, _gZkClient), "Cluster should be setup");

  // test admin.getMessageConstraints()
  ClusterConstraints constraints =
      tool.getConstraints(clusterName, ConstraintType.MESSAGE_CONSTRAINT);
  Assert.assertNull(constraints, "message-constraint should NOT exist for cluster: " + className);

  // remove non-exist constraint
  try {
    tool.removeConstraint(clusterName, ConstraintType.MESSAGE_CONSTRAINT, "constraint1");
    // will leave a null message-constraint znode on zk
  } catch (Exception e) {
    Assert.fail("Should not throw exception when remove a non-exist constraint.");
  }

  // add a message constraint
  ConstraintItemBuilder builder = new ConstraintItemBuilder();
  builder.addConstraintAttribute(ConstraintAttribute.RESOURCE.toString(), "MyDB")
      .addConstraintAttribute(ConstraintAttribute.CONSTRAINT_VALUE.toString(), "1");
  tool.setConstraint(clusterName, ConstraintType.MESSAGE_CONSTRAINT, "constraint1",
      builder.build());

  HelixDataAccessor accessor =
      new ZKHelixDataAccessor(clusterName, new ZkBaseDataAccessor<ZNRecord>(_gZkClient));
  PropertyKey.Builder keyBuilder = new PropertyKey.Builder(clusterName);
  constraints =
      accessor.getProperty(keyBuilder.constraint(ConstraintType.MESSAGE_CONSTRAINT.toString()));
  Assert.assertNotNull(constraints, "message-constraint should exist");
  ConstraintItem item = constraints.getConstraintItem("constraint1");
  Assert.assertNotNull(item, "message-constraint for constraint1 should exist");
  Assert.assertEquals(item.getConstraintValue(), "1");
  Assert.assertEquals(item.getAttributeValue(ConstraintAttribute.RESOURCE), "MyDB");

  // test admin.getMessageConstraints()
  constraints = tool.getConstraints(clusterName, ConstraintType.MESSAGE_CONSTRAINT);
  Assert.assertNotNull(constraints, "message-constraint should exist");
  item = constraints.getConstraintItem("constraint1");
  Assert.assertNotNull(item, "message-constraint for constraint1 should exist");
  Assert.assertEquals(item.getConstraintValue(), "1");
  Assert.assertEquals(item.getAttributeValue(ConstraintAttribute.RESOURCE), "MyDB");

  // remove a exist message-constraint
  tool.removeConstraint(clusterName, ConstraintType.MESSAGE_CONSTRAINT, "constraint1");
  constraints =
      accessor.getProperty(keyBuilder.constraint(ConstraintType.MESSAGE_CONSTRAINT.toString()));
  Assert.assertNotNull(constraints, "message-constraint should exist");
  item = constraints.getConstraintItem("constraint1");
  Assert.assertNull(item, "message-constraint for constraint1 should NOT exist");

  System.out.println("END " + clusterName + " at " + new Date(System.currentTimeMillis()));
}
 
開發者ID:apache,項目名稱:helix,代碼行數:62,代碼來源:TestZkHelixAdmin.java

示例10: setConstraint

import org.apache.helix.model.ConstraintItem; //導入依賴的package包/類
@Override
public void setConstraint(String clusterName, ClusterConstraints.ConstraintType constraintType, String constraintId,
    ConstraintItem constraintItem) {
  throw new IllegalStateException("Not implemented");
}
 
開發者ID:linkedin,項目名稱:ambry,代碼行數:6,代碼來源:MockHelixAdmin.java


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