文档章节

APDPlat的系统启动和关闭流程剖析

杨尚川
 杨尚川
发布于 2014/02/03 01:49
字数 931
阅读 414
收藏 4

 APDPlat接管了Spring的启动关闭权,为各种运行其上的开源框架和类库的无缝集成提供了支持。

 

当然,大家都知道,一个JAVA EE Web应用的入口点是web.xml,APDPlat当然也不例外,我们看看APDPlat是如何接管Spring的启动关闭权的:

 

<listener>
	<description>经过定制的spring监听器</description>
	<listener-class>org.apdplat.platform.spring.APDPlatContextLoaderListener</listener-class>
</listener>

 

/**
 * 自定义Spring的ContextLoaderListener
 * @author 杨尚川
 */
public class APDPlatContextLoaderListener extends ContextLoaderListener {    
    @Override
    public void contextInitialized(ServletContextEvent event) {
        //接管系统的启动
        SystemListener.contextInitialized(event);
        super.contextInitialized(event);
    }
    @Override
    public void contextDestroyed(ServletContextEvent event) {
        //接管系统的关闭
        SystemListener.contextDestroyed(event);
        super.contextDestroyed(event);
    }
}

 

在Spring启动和关闭之前,都会先调用org.apdplat.module.system.service.SystemListener来做预处理。

 

这只是接管启动和关闭权,关于无缝集成所做的定制请看org.apdplat.platform.spring、org.apdplat.platform.struts、org.apdplat.platform.compass这三个包里面的类,这里不做说明。

 

本文主要分析SystemListener在系统启动和关闭的时候都分别做了什么处理。

 

系统启动流程:

 

1、获取ContextPath

 

contextPath=sce.getServletContext().getContextPath();

 

public static String getContextPath() {
 return contextPath;
}

 

在部署APDPlat的时候,可能会有两种情况:一是部署在ROOT目录下,ContextPath为空,则地址为http://192.168.0.100;二是部署在非ROOT目录下,假设ContextPath为APDPlat_Web,则地址为http://192.168.0.100/APDPlat_Web。前端EXT JS和JSP以及后台服务在处理绝对路径和记录日志等情况的时候需要知道ContextPath的值,该值在系统启动的时候从应用服务器中获得,保存为静态变量,并通过静态方法暴露给系统使用。

 

2、获取RealPath

 

basePath=sce.getServletContext().getRealPath("/");
FileUtils.setBasePath(basePath);

 

整个APDPlat系统中的文件操作都以basePath为基础,通过basePath的值,我们可以得知Web应用存放在服务器上面的本地磁盘绝对路径,如:D:\Workspaces\NetBeansProjects\APDPlat2.5\APDPlat_Web\target\APDPlat_Web-2.5\,这样我们就可以对Web应用中的所有文件进行IO操作。

 

3、改变系统属性user.dir的值

 

userDir=FileUtils.getAbsolutePath("/WEB-INF/classes/data/");
System.setProperty("user.dir", userDir);

 

把user.dir重新指定到Web应用的/WEB-INF/classes/data/目录,此目录会存放索引文件,初始导入的数据文件。

 

4、为spring的配置做预处理

 

public static void prepareForSpring(){
	//供spring扫描组件用
	String basePackage=PropertyHolder.getProperty("basePackages");
	String localBasePackage=PropertyHolder.getProperty("basePackages.local");
	if(StringUtils.isNotBlank(localBasePackage)){
		basePackage=basePackage+","+localBasePackage;
	}
	System.setProperty("basePackage", basePackage);        
}

 

这里为用户在项目中自定义扫描组件的范围提供支持,用户可在config.local.properties配置文件中定义变量basePackages.local的值为自己的包名称。

 

5、注册模块

 

Enumeration<URL> ps = Thread.currentThread().getContextClassLoader().getResources("META-INF/services/module.xml");

 

根据模块描述文件module.xml识别类路径下的所有模块,注册模块,提取web资源和数据,为后续的组件扫描、模块初始化、数据库同步做准备。

 

6、解析所有的dic.xml文件,并生成供客户端EXT JS调用的文件

 

DictionaryGenerator.generateDic(basePath);

 

7、记录服务器启动日志(如启用)

 

//保存服务器启动日志
BufferLogCollector.collect(runingTime);

 

8、启动内存监视线程(如启用)

 

int circle=PropertyHolder.getIntProperty("monitor.memory.circle");
memoryMonitorThread=new MemoryMonitorThread(circle);
memoryMonitorThread.start();

 

 

 

系统关闭流程:

 

1、记录用户注销日志(如启用)

 

UserLoginListener.forceAllUserOffline();

 

2、记录服务器关闭日志(如启用)

 

//保存服务器关闭日志
BufferLogCollector.collect(runingTime);

 

3、停止内存监视线程(如启用)

 

memoryMonitorThread.running=false;
memoryMonitorThread.interrupt();

 

4、处理缓冲区中的日志

 

//在关闭系统之前,处理缓冲区中的日志
BufferLogCollector.close();

 

5、卸载JDBC驱动

 

    private static void deregisterDrivers() {
        Enumeration<Driver> drivers=DriverManager.getDrivers();
        while(drivers.hasMoreElements()){
            Driver driver=drivers.nextElement();
            try {
                DriverManager.deregisterDriver(driver);
            } catch (SQLException e) {
                LOG.warn("卸载JDBC驱动失败:"+driver, e);
                LOG.warn("Fail to uninstall JDBC driver:"+driver, e, Locale.ENGLISH);
            }
        }
    }

 

APDPlat托管在Github

© 著作权归作者所有

杨尚川

杨尚川

粉丝 1103
博文 220
码字总数 1624053
作品 12
东城
架构师
私信 提问
APDPlat如何自动建库建表并初始化数据?

APDPlat共支持10种数据库:DB2、DERBY、H2、HSQL、INFORMIX、MYSQL、ORACLE、POSTGRESQL、SQLSERVER、SYBASE。 数据库的默认配置信息在文件APDPlatCore/src/main/resources/org/apdplat/db.p...

杨尚川
2014/02/08
360
0
基于word分词提供的文本相似度算法来实现通用的网页相似度检测

实现代码:基于word分词提供的文本相似度算法来实现通用的网页相似度检测 运行结果: 检查的博文数:128 1、检查博文:192本软件著作用词分析(五)用词最复杂99级,相似度分值:Simple=0.96...

杨尚川
2015/05/28
1K
0
应用级产品开发平台 - APDPlat

APDPlat快速体验 APDPlat入门指南 APDPlat专题文章 APDPlat是Application Product Development Platform(应用级产品开发平台)的缩写。 APDPlat提供了应用容器、多模块架构、代码生成、安装...

杨尚川
2012/10/30
6.7K
0
APDPlat拓展搜索之集成ElasticSearch

APDPlat充分利用Compass的OSEM和ORM integration特性,提供了简单易用且功能强大的内置搜索特性。 APDPlat的内置搜索,在设计简洁优雅的同时,还具备了强大的实时搜索能力,用户只需用注解的...

杨尚川
2014/02/01
292
2
APDPlat的日志国际化实现方式

APDPlat使用slf4j来做日志框架,由于slf4j不支持国际化日志,所以APDPlat使用自定义的APDPlatLogger类来支持国际化日志。使用方法如下: 1、构造日志对象 private static final APDPlatLogg...

杨尚川
2014/01/29
257
0

没有更多内容

加载失败,请刷新页面

加载更多

搭建高可用MongoDB集群(分片)

搭建高可用MongoDB集群(分片) MongoDB基础请参考:https://blog.51cto.com/kaliarch/2044423 MongoDB(replica set)请参考:https://blog.51cto.com/kaliarch/2044618 一、概述 1.1 背景 ......

linjin200
3分钟前
0
0
CDH6.0.1集成tez-0.9.1计算引擎

参考文章: https://www.jianshu.com/p/9fb9f32e1f0f https://www.baidu.com/link?url=OgpwasnZi7H1dySN2T111sseEWDBaCCTC3DFV61G7756YbrkJCA8Y3UFaueyqnfN&wd=&eqid=daeb8b3500049cf3000000......

Sheav
5分钟前
0
0
Vue内置指令的使用

v-model(数据绑定) v-model常用于表单数据的双向绑定,它本质上是一个语法糖。它主要的有两种应用: 在文本框、多行文本、input的下拉框、单选按钮、复选框中的应用 <div id="app"> ...

凌兮洛
5分钟前
0
0
外部来源应用检查-烦死了,终于找到解决设置了

Android 连接usb调试应用的时候: 华为关闭方法:1、设置-安全-更多安全设置,关掉外部来源应用检查。2、设置-系统-开发人员选项-关闭“监控ADB安装应用” 不知道OPPO 怎么关闭的?...

QGlaunch
6分钟前
0
0
6个K8s日志系统建设中的典型问题,你遇到过几个?

作者 | 元乙 阿里云日志服务数据采集客户端负责人,目前采集客户端 logtail 在集团百万规模部署,每天采集上万应用数 PB 数据,经历多次双 11、双 12 考验。 导读:随着 K8s 不断更新迭代,使...

阿里云官方博客
8分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部