Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  package org.apache.helix.manager.zk;
  
  /*
   * 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.List;
 
helper class for controller manager
 
 public class ControllerManagerHelper {
   private static Logger LOG = Logger.getLogger(ControllerManagerHelper.class);
 
   final HelixManager _manager;
 
   public ControllerManagerHelper(HelixManager managerList<HelixTimerTaskcontrollerTimerTasks) {
      = manager;
      = controllerTimerTasks;
   }
 
   public void addListenersToController(GenericHelixController controller) {
     try {
      
setup controller message listener and register message handlers
 
       MessageHandlerFactory defaultControllerMsgHandlerFactory =
           new DefaultControllerMessageHandlerFactory();
           defaultControllerMsgHandlerFactory.getMessageType(), defaultControllerMsgHandlerFactory);
       MessageHandlerFactory defaultSchedulerMsgHandlerFactory =
           defaultSchedulerMsgHandlerFactory.getMessageType(), defaultSchedulerMsgHandlerFactory);
       MessageHandlerFactory defaultParticipantErrorMessageHandlerFactory =
           defaultParticipantErrorMessageHandlerFactory.getMessageType(),
 
           defaultParticipantErrorMessageHandlerFactory);

      
setup generic-controller
 
       .addConfigChangeListener(controller);
       .addLiveInstanceChangeListener(controller);
       .addIdealStateChangeListener(controller);
       // no need for controller to listen on external-view
       // _manager.addExternalViewChangeListener(controller);
       .addControllerListener(controller);
     } catch (ZkInterruptedException e) {
       .warn("zk connection is interrupted during HelixManagerMain.addListenersToController(). "
           + e);
     } catch (Exception e) {
       .error("Error when creating HelixManagerContollerMonitor"e);
     }
   }
 
   public void removeListenersFromController(GenericHelixController controller) {
     PropertyKey.Builder keyBuilder = new PropertyKey.Builder(.getClusterName());
    
reset generic-controller
 
     .removeListener(keyBuilder.instanceConfigs(), controller);
     .removeListener(keyBuilder.liveInstances(), controller);
     .removeListener(keyBuilder.idealStates(), controller);
     .removeListener(keyBuilder.controller(), controller);

    
reset controller message listener and unregister all message handlers
 
  }
  public void startControllerTimerTasks() {
    for (HelixTimerTask task : ) {
      task.start();
    }
  }
  public void stopControllerTimerTasks() {
    for (HelixTimerTask task : ) {
      task.stop();
    }
  }
New to GrepCode? Check out our FAQ X