All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.logicbus.backend.server.LogicBusApp Maven / Gradle / Ivy

There is a newer version: 1.6.17
Show newest version
package com.logicbus.backend.server;

import java.util.HashMap;
import java.util.Map;

import javax.servlet.ServletContext;

import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.exception.ExceptionUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.alogic.event.Event;
import com.alogic.event.EventBus;
import com.alogic.metrics.Fragment;
import com.alogic.metrics.stream.MetricsHandlerFactory;
import com.alogic.xscript.ExecuteWatcher;
import com.alogic.xscript.LogicletContext;
import com.alogic.xscript.Script;
import com.alogic.xscript.doc.XsObject;
import com.alogic.xscript.doc.json.JsonObject;
import com.anysoft.stream.Handler;
import com.anysoft.util.DefaultProperties;
import com.anysoft.util.IOTools;
import com.anysoft.util.PropertiesConstants;
import com.anysoft.util.Settings;
import com.anysoft.util.XmlTools;
import com.anysoft.util.resource.ResourceFactory;
import com.anysoft.webloader.WebApp;
import com.logicbus.backend.AccessController;
import com.logicbus.backend.IpAndServiceAccessController;
import com.logicbus.backend.ServantFactory;
import com.logicbus.backend.bizlog.BizLogger;
import com.logicbus.backend.daemon.DaemonServer;


/**
 * anyLogicBus基于anyWebLoader的应用
 * 
 * @author duanyy
 * @version 1.2.4.5 [20140709 duanyy]
 * - 增加扩展的配置文件
 * 
 * @version 1.2.5 [20140723 duanyy]
 * - 修正ResourceFactory的bug
 * 
 * @version 1.2.6 [20140807 duanyy] 
* - ServantPool和ServantFactory插件化 * * @version 1.2.6.5 [20140828 duanyy]
* - 增加onInit/onDestroy事件,以便子类更好的进行初始化和销毁.
* * @version 1.2.7 [20140828 duanyy]
* - 重写BizLogger * * @version 1.2.8 [20140914 duanyy]
* - 增加指标收集体系 * * @version 1.2.8.1 [20140919 duanyy]
* - MetricsHandler:getInstance拆分为getClientInstance和getServerInstance * * @version 1.3.0.2 [20141031 duanyy]
* - 增加全局配置文件,变量名为settings.global.master和settings.global.secondary * * @version 1.6.3.37 [20140806 duanyy]
* - 淘汰旧的timer框架,采用新的timer框架
* * @version 1.6.4.35 [20160315 duanyy]
* - AccessController接口变动
* * @version 1.6.4.36 [20160321 duanyy]
* - 增加ketty.web.xml文件,用于替代web.xml中的部分内容
* * @version 1.6.4.38 [20160324 duanyy]
* - 优化WEB退出时的清理工作
* * @version 1.6.5.20 [20160715 duanyy]
* - 服务器启动和关闭时可触发脚本执行
* * @version 1.6.7.9 [20170201 duanyy]
* - 采用SLF4j日志框架输出日志
* * @version 1.6.7.20
* - 改造ServantManager模型,增加服务配置监控机制
* * @version 1.6.8.14
* - 调整init及destroy时各组件的启动次序
* * @version 1.6.11.2 [20171218 duanyy]
* - 将事件处理框架作为内置组件
* * @version 1.6.13.6 [20200629 duanyy]
* - 调整服务器启动时各组件执行的次序;
*/ public class LogicBusApp implements WebApp { /** * a logger of log4j */ protected static Logger logger = LoggerFactory.getLogger(LogicBusApp.class); protected void onInit(Settings settings){ XmlTools.setDefaultEncoding(settings.GetValue("http.encoding","utf-8")); String script = settings.GetValue("script.bootup",""); if (StringUtils.isNotEmpty(script)){ logger.info("Execute script:" + script); try { Script logiclet = Script.create(script, settings); if (logiclet != null){ Map root = new HashMap(); XsObject doc = new JsonObject("root",root); logiclet.execute(doc, doc, new LogicletContext(settings), new ExecuteWatcher.Quiet()); } }catch (Exception ex){ logger.error("Failed to execute script:" + script); logger.error(ExceptionUtils.getStackTrace(ex)); } } //加载daemon事件服务器 String daemonConfig = settings.GetValue("daemon.master", ""); String daemonConfigSecondary = settings.GetValue("daemon.secondary",""); if (StringUtils.isNotEmpty(daemonConfig)){ logger.info("Load and start daemon event servers.."); logger.info("Url = " + daemonConfig); try { DaemonServer daemonServer = DaemonServer.loadFrom(daemonConfig, daemonConfigSecondary, settings); if (daemonServer != null){ daemonServer.start(); settings.registerObject("daemon", daemonServer); } }catch (Exception ex){ logger.error("Can not load and start daemon event servets"); } } //初始化事件处理器 try { settings.registerObject("eventHandler", EventBus.getDefault()); }catch (Exception ex){ logger.error("Failed to create an event handler.", ex); } //初始化AccessController AccessController ac = null; try { ac = AccessController.TheFactory.get(settings); logger.info("AccessController is initialized,module:" + ac.getClass().getName()); } catch (Exception ex) { logger.error("Failed to create an AccessController.", ex); } if (ac == null) { ac = new IpAndServiceAccessController(); ac.configure(settings); logger.error("Using default:" + IpAndServiceAccessController.class.getName()); } settings.registerObject("accessController", ac); String bizLogHome = PropertiesConstants.getString(settings, "bizlog.home", ""); if (bizLogHome == null || bizLogHome.length() <= 0) { logger.info("bizlog.home is not set.Set it to /var/log/bizlog"); settings.SetValue("bizlog.home", "var/log/bizlog"); } BizLogger bizLogger = BizLogger.TheFactory.getLogger(settings); if (bizLogger != null) { logger.info("BizLogger is initialized,module:" + bizLogger.getClass().getName()); settings.registerObject("bizLogger", bizLogger); } else { logger.error("Can not create a bizlogger instance.."); } Handler handler = MetricsHandlerFactory.getClientInstance(); if (handler != null) { logger.info("MetricsHandler is initalized,module:" + handler.getClass().getName()); settings.registerObject("metricsHandler", handler); } else { logger.error("Can not create a metrics handler instance."); } ServantFactory sf = ServantFactory.TheFactory.get(settings); if (sf != null){ logger.info("Servant Factory is initializing,module:" + sf.getClass().getName()); settings.registerObject("servantFactory", sf); }else{ logger.error("Can not create a servant factory instance."); } } @Override public void init(DefaultProperties props,ServletContext sc) { Settings settings = Settings.get(); settings.addSettings(props); // 初始化一些object ClassLoader classLoader = (ClassLoader) sc.getAttribute("classLoader"); if (classLoader == null){ classLoader = LogicBusApp.class.getClassLoader(); } settings.registerObject("classLoader", classLoader); //装入ketty.web.xml String webXml = settings.GetValue("ketty.web", "file:///${ketty.home}/conf/ketty.web.xml"); if (!StringUtils.isEmpty(webXml)){ logger.info("load ketty web xml settings."); logger.info("Url = " + webXml); settings.addSettings(webXml, null, null); logger.info("Load ketty web xml settings..OK!"); } //resourceFactory String rf = settings.GetValue("resource.factory","com.anysoft.util.resource.ResourceFactory"); ResourceFactory resourceFactory = null; try { logger.info("Use resource factory:" + rf); resourceFactory = (ResourceFactory) classLoader.loadClass(rf).getDeclaredConstructor().newInstance(); } catch (Exception e) { logger.error("Can not create instance of :" + rf,e); } if (resourceFactory == null){ resourceFactory = new ResourceFactory(); logger.info("Use default:" + ResourceFactory.class.getName()); } settings.registerObject("ResourceFactory", resourceFactory); //装入全局配置文件 String globalProfile = settings.GetValue("settings.global.master", ""); String globalSecondaryProfile = settings.GetValue("settings.global.secondary",""); if (globalProfile != null && globalProfile.length() > 0){ logger.info("Load global xml settings"); logger.info("Url = " + globalProfile); settings.addSettings(globalProfile, globalSecondaryProfile, resourceFactory); logger.info("Load global xml settings..OK!"); } //装入扩展的配置文件 String extProfile = settings.GetValue("settings.ext.master", ""); String extSecondaryProfile = settings.GetValue("settings.ext.secondary", ""); if (extProfile != null && extProfile.length() > 0){ logger.info("Load ext xml settings"); logger.info("Url = " + extProfile); settings.addSettings(extProfile,extSecondaryProfile,resourceFactory); logger.info("Load xml settings..OK!"); } // 装入配置文件 String profile = settings.GetValue("settings.master", "java:///com/logicbus/backend/server/profile.default.xml#com.logicbus.backend.server.LogicBusApp"); String secodaryProfile = settings.GetValue("settings.secondary", "java:///com/logicbus/backend/server/profile.default.xml#com.logicbus.backend.server.LogicBusApp"); logger.info("Load xml settings.."); logger.info("Url = " + profile); settings.addSettings(profile,secodaryProfile,resourceFactory); logger.info("Load xml settings..OK!"); onInit(settings); } @Override public void start(){ } @Override public void stop(){ } protected void onDestroy(Settings settings){ ServantFactory sf = (ServantFactory)settings.get("servantFactory"); if (sf != null){ logger.info("The servantFactory is closing.."); settings.unregisterObject("servantFactory"); IOTools.close(sf); } BizLogger bizLogger = (BizLogger)settings.get("bizLogger"); if (bizLogger != null){ bizLogger.flush(System.currentTimeMillis()); logger.info("The bizLogger is closing.."); settings.unregisterObject("bizLogger"); IOTools.close(bizLogger); } // since 1.2.8 @SuppressWarnings("unchecked") Handler metricsHandler = (Handler)settings.get("metricsHandler"); if (metricsHandler != null){ metricsHandler.flush(System.currentTimeMillis()); logger.info("The metrics handler is closing.."); settings.unregisterObject("metricsHandler"); IOTools.close(metricsHandler); } settings.unregisterObject("accessController"); DaemonServer daemonServer = (DaemonServer)settings.get("daemon"); if (daemonServer != null){ daemonServer.stop(); } Handler eventHandler = (Handler)settings.get("eventHandler"); if (eventHandler != null){ eventHandler.flush(System.currentTimeMillis()); logger.info("The event handler is closing.."); settings.unregisterObject("eventHandler"); IOTools.close(metricsHandler); } String script = settings.GetValue("script.shutdown",""); if (StringUtils.isNotEmpty(script)){ logger.info("Execute script:" + script); try { Script logiclet = Script.create(script, settings); if (logiclet != null){ Map root = new HashMap(); XsObject doc = new JsonObject("root",root); logiclet.execute(doc, doc, new LogicletContext(settings), new ExecuteWatcher.Quiet()); } }catch (Exception ex){ logger.error("Failed to execute script:" + script); logger.error(ExceptionUtils.getStackTrace(ex)); } } } @Override public void destroy(ServletContext sc) { Settings settings = Settings.get(); onDestroy(settings); settings.unregisterObject("classLoader"); settings.unregisterObject("ResourceFactory"); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy