zoukankan      html  css  js  c++  java
  • OpenFire源码学习之十四:插件管理

    Plugin管理

    Openfire把插件模块加入到容器分为以下步骤:

    l 通过classloader加载lib目录下载的所有jar

    l 通过classloader加载dir目录下的所有文件

    l 定位和加载module.xml到context

    l 遍历jive模块实体,负荷给定的类作为一个模块,然后启动它

    Openfire插件加载流程图:


    Openfire的插件管理类PluginManager。加载插件的方法是loadPlugin(File pluginDir)这里的参数pluginDir是插件的目录。openfire会读取插件目录里面的pugin.xml文件关于这个文件的详细内容在Plugin接口介绍了。根据该插件的在minServerVersion标识字段与本openfire系统版本是否符合。如果符合则进行下一步,反之return了。Openfire会继续往下侦查插件,查看该插件是否是是另个插件的孩子插件。如果是则PluginLoader会加载该插件的父插件。最后一步一步的加载完整个插件。在上面流程图中有个PluginDevEnvironment类,该类是OpenFire的插件框架的数据模型代码,也就是Jive象征着J2EE的规范一样。

    Openfire提供了加载插件,对应了也提供了卸载插件的方法unloadPlugin()。unloadPlugin方法会根据目录的名称找对应的插件将器删除,但不是把插件的jar文件删掉。留着jar文件的目的就是为了该插件可重新启动。

    在PluginManager类中还有个内部类PluginMonitor。这个类实现了Runnable接口,无疑它是个线程类。它是个监控插件目录的服务类,它会定期检查新插件的jar文件和提取他们然后加载新的插件目录。

    Plugin加载器

    Openfier的插件加载器——PluginClassLoader它会搜索插件目录类和jar文件,然后构建类加载器来加载里面的资源。加载资源如下:

    l 任何在lib下的jar文件会被添加到classpath中

    l 任何在类目录下的的文件也被添加在classpath中

    PluginClassLoader继承了URLClassLoader,此加载器是通过url搜索jar文件和目录加载类和资源。

    addDirectory方法

    该方法会装载插件目录,他会依次加载以下几个目录

    Classes->database->i18n->web->lib

     

    addURLFile方法

    添加给定的URL为这个类装入器的类路径,缓存JAR文件连接,因此它可以卸载后

    缓存配置

    一、缓存配置

    缓存配置信息PluginCacheConfigurator

    ......

    二、登记缓存

    插件的缓存配置信息在PluginCacheRegistry类中:

    public void registerCache(String pluginName, CacheInfo info) {
            extraCacheMappings.put(info.getCacheName(), info);
            List<CacheInfo> caches = pluginCaches.get(pluginName);
    
            if (caches == null) {
                caches = new ArrayList<CacheInfo>();
                pluginCaches.put(pluginName, caches);
            }
    
            caches.add(info);
    
            // Set system properties for this cache
            CacheFactory.setCacheTypeProperty(info.getCacheName(), info.getType().getName());
            CacheFactory.setMaxSizeProperty(info.getCacheName(), getMaxSizeFromProperty(info));
            CacheFactory.setMaxLifetimeProperty(info.getCacheName(), getMaxLifetimeFromProperty(info));
            CacheFactory.setMinCacheSize(info.getCacheName(), getMinSizeFromProperty(info));
        }
    


  • 相关阅读:
    【原】Storm序列化
    【原】Storm学习资料推荐
    【原】Storm实战
    【原】Storm环境搭建
    Autofac基本使用(转载)
    Autofac学习之三种生命周期:InstancePerLifetimeScope、SingleInstance、InstancePerDependency
    RabbitMQ 默认端口号
    RabbitMQ-客户端
    百度地图-生成器
    uploadify 配置后,页面显示无效果
  • 原文地址:https://www.cnblogs.com/huwf/p/4273354.html
Copyright © 2011-2022 走看看