com.aspectran.core.service.AbstractServiceController Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aspectran-core Show documentation
Show all versions of aspectran-core Show documentation
Aspectran Core APIs and Implementation
/*
* Copyright (c) 2008-2019 The Aspectran Project
*
* 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 com.aspectran.core.service;
import com.aspectran.core.util.logging.Log;
import com.aspectran.core.util.logging.LogFactory;
import java.util.ArrayList;
import java.util.List;
/**
* The Class AbstractServiceController.
*/
public abstract class AbstractServiceController implements ServiceController {
private final Log log = LogFactory.getLog(getClass());
private final Object lock = new Object();
private final List derivedServices;
private ServiceStateListener serviceStateListener;
/** Flag that indicates whether this service is active */
private volatile boolean active;
public AbstractServiceController(boolean derivable) {
if (derivable) {
derivedServices = new ArrayList<>(5);
} else {
derivedServices = null;
}
}
@Override
public String getServiceName() {
return getClass().getSimpleName();
}
@Override
public void setServiceStateListener(ServiceStateListener serviceStateListener) {
this.serviceStateListener = serviceStateListener;
}
protected void joinDerivedService(ServiceController serviceController) {
if (derivedServices == null) {
throw new UnsupportedOperationException("Derived service control not supported");
}
derivedServices.add(serviceController);
}
protected void clearDerivedService() {
if (derivedServices != null) {
derivedServices.clear();
}
}
/**
* Returns whether this service is derived from another root service.
*
* @return whether this service is derived
*/
protected abstract boolean isDerived();
protected abstract void doStart() throws Exception;
protected abstract void doPause() throws Exception;
protected abstract void doPause(long timeout) throws Exception;
protected abstract void doResume() throws Exception;
protected abstract void doStop() throws Exception;
protected Object getLock() {
return lock;
}
@Override
public void start() throws Exception {
synchronized (lock) {
if (active) {
throw new IllegalStateException(getServiceName() + " is already started");
}
if (!isDerived()) {
log.info("Starting the " + getServiceName());
doStart();
if (derivedServices != null) {
for (ServiceController serviceController : derivedServices) {
serviceController.start();
}
}
}
log.info(getServiceName() + " started successfully");
if (serviceStateListener != null) {
serviceStateListener.started();
}
active = true;
}
}
@Override
public void restart() throws Exception {
synchronized (lock) {
if (!isDerived()) {
if (!active) {
throw new IllegalStateException(getServiceName() + " is not yet started");
}
log.info("Restarting the " + getServiceName());
} else {
if (active) {
throw new IllegalStateException(getServiceName() + " should never be run separately");
}
active = true;
}
if (serviceStateListener != null) {
serviceStateListener.paused();
}
if (!isDerived()) {
if (derivedServices != null) {
for (ServiceController serviceController : derivedServices) {
serviceController.stop();
}
}
active = false;
doStop();
doStart();
active = true;
if (derivedServices != null) {
for (ServiceController serviceController : derivedServices) {
serviceController.start();
}
}
}
log.info(getServiceName() + " restarted successfully");
if (serviceStateListener != null) {
serviceStateListener.restarted();
}
}
}
@Override
public void restart(String message) throws Exception {
restart();
}
@Override
public void pause() throws Exception {
synchronized (lock) {
if (!active) {
log.warn(getServiceName() + " is not yet started");
return;
}
if (!isDerived()) {
if (derivedServices != null) {
for (ServiceController serviceController : derivedServices) {
serviceController.pause();
}
}
}
doPause();
log.info(getServiceName() + " is paused");
if (serviceStateListener != null) {
serviceStateListener.paused();
}
}
}
@Override
public void pause(long timeout) throws Exception {
synchronized (lock) {
if (!active) {
log.warn(getServiceName() + " is not yet started");
return;
}
if (!isDerived()) {
if (derivedServices != null) {
for (ServiceController serviceController : derivedServices) {
serviceController.pause(timeout);
}
}
}
doPause(timeout);
log.info(getServiceName() + " is paused and will resume after " + timeout + " ms");
if (serviceStateListener != null) {
serviceStateListener.paused(timeout);
}
}
}
@Override
public void resume() throws Exception {
synchronized (lock) {
if (!active) {
log.warn(getServiceName() + " is not yet started");
return;
}
doResume();
if (!isDerived()) {
if (derivedServices != null) {
for (ServiceController serviceController : derivedServices) {
serviceController.resume();
}
}
}
log.info(getServiceName() + " is resumed");
if (serviceStateListener != null) {
serviceStateListener.resumed();
}
}
}
@Override
public void stop() {
synchronized (lock) {
if (!active) {
log.debug(getServiceName() + " is already stopped");
return;
}
if (serviceStateListener != null) {
try {
serviceStateListener.stopped();
} catch (Exception e) {
log.warn(e.getMessage(), e);
}
}
if (!isDerived()) {
if (derivedServices != null) {
for (ServiceController serviceController : derivedServices) {
serviceController.stop();
}
}
try {
log.info("Stopping the " + getServiceName());
doStop();
log.info(getServiceName() + " stopped successfully");
} catch (Exception e) {
log.error(getServiceName() + " was not stopped normally", e);
}
} else {
log.info(getServiceName() + " stopped successfully");
}
active = false;
}
}
@Override
public boolean isActive() {
synchronized (lock) {
return active;
}
}
@Override
public boolean isBusy() {
return false;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy