io.gravitee.node.container.AbstractNode Maven / Gradle / Ivy
/**
* Copyright (C) 2015 The Gravitee team (http://gravitee.io)
*
* 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 io.gravitee.node.container;
import io.gravitee.common.component.Lifecycle;
import io.gravitee.common.component.LifecycleComponent;
import io.gravitee.common.service.AbstractService;
import io.gravitee.common.util.ListReverser;
import io.gravitee.common.util.Version;
import io.gravitee.node.api.Node;
import io.gravitee.node.management.http.ManagementService;
import io.gravitee.node.plugins.service.ServiceManager;
import io.gravitee.node.reporter.ReporterManager;
import io.gravitee.plugin.core.api.PluginRegistry;
import io.gravitee.plugin.core.internal.PluginEventListener;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import java.lang.management.ManagementFactory;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
/**
* @author David BRASSELY (david.brassely at graviteesource.com)
* @author GraviteeSource Team
*/
public abstract class AbstractNode extends AbstractService implements Node, ApplicationContextAware {
protected final Logger LOGGER = LoggerFactory.getLogger(this.getClass());
protected ApplicationContext applicationContext;
private String hostname;
public AbstractNode() {
try {
hostname = InetAddress.getLocalHost().getHostName();
} catch (UnknownHostException uhe) {
LOGGER.warn("Could not get hostname / IP", uhe);
}
}
protected void doStart() throws Exception {
this.LOGGER.info("{} is now starting...", this.name());
long startTime = System.currentTimeMillis();
List> components = this.components();
Iterator> componentsIte = components.iterator();
while(componentsIte.hasNext()) {
Class extends LifecycleComponent> componentClass = componentsIte.next();
this.LOGGER.info("\tStarting component: {}", componentClass.getSimpleName());
try {
LifecycleComponent lifecyclecomponent = this.applicationContext.getBean(componentClass);
lifecyclecomponent.start();
} catch (Exception var7) {
this.LOGGER.error("An error occurs while starting component {}", componentClass.getSimpleName(), var7);
throw var7;
}
}
long endTime = System.currentTimeMillis();
String processId = ManagementFactory.getRuntimeMXBean().getName();
if(processId.contains("@")) {
processId = processId.split("@")[0];
}
this.LOGGER.info(
"{} id[{}] version[{}] pid[{}] build[{}#{}] jvm[{}/{}/{}] started in {} ms.",
this.name(), this.id(),
Version.RUNTIME_VERSION.MAJOR_VERSION, processId,
Version.RUNTIME_VERSION.BUILD_NUMBER, Version.RUNTIME_VERSION.REVISION,
ManagementFactory.getRuntimeMXBean().getVmVendor(), ManagementFactory.getRuntimeMXBean().getVmName(),
ManagementFactory.getRuntimeMXBean().getVmVersion(), endTime - startTime);
}
protected void doStop() throws Exception {
this.LOGGER.info("{} is stopping", this.name());
ListReverser> components = new ListReverser(this.components());
Iterator var2 = components.iterator();
while(var2.hasNext()) {
Class componentClass = (Class)var2.next();
try {
LifecycleComponent lifecyclecomponent = (LifecycleComponent)this.applicationContext.getBean(componentClass);
if(lifecyclecomponent.lifecycleState() == Lifecycle.State.STARTED) {
this.LOGGER.info("\tStopping component: {}", componentClass.getSimpleName());
lifecyclecomponent.stop();
}
} catch (Exception var5) {
this.LOGGER.error("An error occurs while stopping component {}", componentClass.getSimpleName(), var5);
}
}
this.LOGGER.info("{} stopped", this.name());
}
@Override
public String hostname() {
return hostname;
}
public abstract String name();
@Override
public List> components() {
List> components = new ArrayList<>();
components.add(PluginEventListener.class);
components.add(PluginRegistry.class);
components.add(ServiceManager.class);
components.add(ManagementService.class);
components.add(ReporterManager.class);
return components;
}
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
this.applicationContext = applicationContext;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy