/* * Copyright 1999-2015 dangdang.com. * <p> * 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. * </p> */ package com.dangdang.ddframe.job.lite.internal.listener; import com.dangdang.ddframe.job.lite.api.listener.ElasticJobListener; import com.dangdang.ddframe.job.lite.internal.config.RescheduleListenerManager; import com.dangdang.ddframe.job.lite.internal.election.ElectionListenerManager; import com.dangdang.ddframe.job.lite.internal.failover.FailoverListenerManager; import com.dangdang.ddframe.job.lite.internal.guarantee.GuaranteeListenerManager; import com.dangdang.ddframe.job.lite.internal.instance.ShutdownListenerManager; import com.dangdang.ddframe.job.lite.internal.instance.TriggerListenerManager; import com.dangdang.ddframe.job.lite.internal.sharding.MonitorExecutionListenerManager; import com.dangdang.ddframe.job.lite.internal.sharding.ShardingListenerManager; import com.dangdang.ddframe.job.lite.internal.storage.JobNodeStorage; import com.dangdang.ddframe.job.reg.base.CoordinatorRegistryCenter; import java.util.List; /** * 作业注册中心的监听器管理者. * * @author zhangliang */ public final class ListenerManager { private final JobNodeStorage jobNodeStorage; private final ElectionListenerManager electionListenerManager; private final ShardingListenerManager shardingListenerManager; private final FailoverListenerManager failoverListenerManager; private final MonitorExecutionListenerManager monitorExecutionListenerManager; private final ShutdownListenerManager shutdownListenerManager; private final TriggerListenerManager triggerListenerManager; private final RescheduleListenerManager rescheduleListenerManager; private final GuaranteeListenerManager guaranteeListenerManager; private final RegistryCenterConnectionStateListener regCenterConnectionStateListener; public ListenerManager(final CoordinatorRegistryCenter regCenter, final String jobName, final List<ElasticJobListener> elasticJobListeners) { jobNodeStorage = new JobNodeStorage(regCenter, jobName); electionListenerManager = new ElectionListenerManager(regCenter, jobName); shardingListenerManager = new ShardingListenerManager(regCenter, jobName); failoverListenerManager = new FailoverListenerManager(regCenter, jobName); monitorExecutionListenerManager = new MonitorExecutionListenerManager(regCenter, jobName); shutdownListenerManager = new ShutdownListenerManager(regCenter, jobName); triggerListenerManager = new TriggerListenerManager(regCenter, jobName); rescheduleListenerManager = new RescheduleListenerManager(regCenter, jobName); guaranteeListenerManager = new GuaranteeListenerManager(regCenter, jobName, elasticJobListeners); regCenterConnectionStateListener = new RegistryCenterConnectionStateListener(regCenter, jobName); } /** * 开启所有监听器. */ public void startAllListeners() { electionListenerManager.start(); shardingListenerManager.start(); failoverListenerManager.start(); monitorExecutionListenerManager.start(); shutdownListenerManager.start(); triggerListenerManager.start(); rescheduleListenerManager.start(); guaranteeListenerManager.start(); jobNodeStorage.addConnectionStateListener(regCenterConnectionStateListener); } }