Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  package org.apache.helix.monitoring.mbeans;
  
  /*
   * Licensed to the Apache Software Foundation (ASF) under one
   * or more contributor license agreements.  See the NOTICE file
   * distributed with this work for additional information
   * regarding copyright ownership.  The ASF licenses this file
   * to you under the Apache License, Version 2.0 (the
   * "License"); you may not use this file except in compliance
  * with the License.  You may obtain a copy of the License at
  *
  *   http://www.apache.org/licenses/LICENSE-2.0
  *
  * Unless required by applicable law or agreed to in writing,
  * software distributed under the License is distributed on an
  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  * KIND, either express or implied.  See the License for the
  * specific language governing permissions and limitations
  * under the License.
  */
 
 import java.util.Map;
 
 
 public class ResourceMonitor implements ResourceMonitorMBean {
   int _numOfPartitions;
   private static final Logger LOG = Logger.getLogger(ResourceMonitor.class);
 
 
   public ResourceMonitor(String clusterNameString resourceName) {
      = clusterName;
      = resourceName;
   }
 
   @Override
   public long getPartitionGauge() {
     return ;
   }
 
   @Override
   public long getErrorPartitionGauge() {
     return ;
   }
 
   @Override
   public long getDifferenceWithIdealStateGauge() {
   }
 
   @Override
   public String getSensorName() {
     return . + "_" +  + "_" + ;
   }
 
   public void updateExternalView(ExternalView externalViewIdealState idealState) {
     if (externalView == null) {
       .warn("external view is null");
       return;
     }
     String resourceName = externalView.getId();
 
     if (idealState == null) {
       .warn("ideal state is null for " + resourceName);
        = 0;
        = 0;
       return;
     }
 
     assert (resourceName.equals(idealState.getId()));
 
     int numOfErrorPartitions = 0;
     int numOfDiff = 0;
 
     if ( == 0) {
        = idealState.getRecord().getMapFields().size();
     }
 
     // TODO fix this; IdealState shall have either map fields (CUSTOM mode)
     // or list fields (AUDO mode)
     for (PartitionId partitionId : idealState.getPartitionIdSet()) {
       Map<ParticipantIdStateidealRecord = idealState.getParticipantStateMap(partitionId);
       Map<ParticipantIdStateexternalViewRecord = externalView.getStateMap(partitionId);
 
       if (externalViewRecord == null) {
         numOfDiff += idealRecord.size();
         continue;
       }
      for (ParticipantId host : idealRecord.keySet()) {
        if (!externalViewRecord.containsKey(host)
            || !externalViewRecord.get(host).equals(idealRecord.get(host))) {
          numOfDiff++;
        }
      }
      for (ParticipantId host : externalViewRecord.keySet()) {
        if (externalViewRecord.get(host).toString()
            .equalsIgnoreCase(..toString())) {
          numOfErrorPartitions++;
        }
      }
    }
     = numOfErrorPartitions;
     = numOfDiff;
  }
  public long getExternalViewPartitionGauge() {
  }
  public String getBeanName() {
    return  + " " + ;
  }
New to GrepCode? Check out our FAQ X