JmxTriggerManager.java 1.88 KB
Newer Older
liqin's avatar
liqin committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
/*
 * Copyright 2014 LinkedIn Corp.
 *
 * Licensed 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.
 */

package azkaban.jmx;

import azkaban.trigger.TriggerManagerAdapter;
import azkaban.trigger.TriggerManagerAdapter.TriggerJMX;

public class JmxTriggerManager implements JmxTriggerManagerMBean {

  private final TriggerJMX jmxStats;

  public JmxTriggerManager(final TriggerManagerAdapter manager) {
    this.jmxStats = manager.getJMX();
  }

  @Override
  public long getLastRunnerThreadCheckTime() {
    return this.jmxStats.getLastRunnerThreadCheckTime();
  }

  @Override
  public boolean isRunnerThreadActive() {
    return this.jmxStats.isRunnerThreadActive();
  }

  @Override
  public String getPrimaryTriggerHostPort() {
    return this.jmxStats.getPrimaryServerHost();
  }

  // @Override
  // public List<String> getAllTriggerHostPorts() {
  // return new ArrayList<String>(manager.getAllActiveTriggerServerHosts());
  // }

  @Override
  public int getNumTriggers() {
    return this.jmxStats.getNumTriggers();
  }

  @Override
  public String getTriggerSources() {
    return this.jmxStats.getTriggerSources();
  }

  @Override
  public String getTriggerIds() {
    return this.jmxStats.getTriggerIds();
  }

  @Override
  public long getScannerIdleTime() {
    return this.jmxStats.getScannerIdleTime();
  }

  @Override
  public String getScannerThreadStage() {
    return this.jmxStats.getScannerThreadStage();
  }
}