今天在群里遇到个需求:项目是7*24小时的,要扩展一些需求,不能停服务,意思是想动态部署jar包,问我有啥想法没。
我想了一下,水平集群扩展呗(显然不太现实,也别扭),程序上无非就是classloader动态加载class,我初步设想是起个程序监听一下,有jar包加进来,就扫描jar包循环loader class,其中当然还有些细节问题,加载完后怎么调用,可以用反射+配置文件,大体思路就是这样,但是总觉得怪怪的。
午饭时候突然拍大腿想到一个东西,不是有OSGI么,整体架构用OSGI显然不行,还没那水平,能不能局部小用呢,网上搜了一下,果然有这样的用法,在web应用中启动osgi内核。
在应用中加入启动osgi的listener.
网上[url]http://www.iteye.com/topic/509152[/url]
抄了些代码记录一下,没准以后用可以参考
这时可以通过控制台进行osgi命令操作。
我想了一下,水平集群扩展呗(显然不太现实,也别扭),程序上无非就是classloader动态加载class,我初步设想是起个程序监听一下,有jar包加进来,就扫描jar包循环loader class,其中当然还有些细节问题,加载完后怎么调用,可以用反射+配置文件,大体思路就是这样,但是总觉得怪怪的。
午饭时候突然拍大腿想到一个东西,不是有OSGI么,整体架构用OSGI显然不行,还没那水平,能不能局部小用呢,网上搜了一下,果然有这样的用法,在web应用中启动osgi内核。
在应用中加入启动osgi的listener.
网上[url]http://www.iteye.com/topic/509152[/url]
抄了些代码记录一下,没准以后用可以参考
public class OsgiListener implements ServletContextListener {
private Logger logger = LoggerFactory.getLogger(getClass());
public void contextDestroyed(ServletContextEvent event) {
try {
EclipseStarter.shutdown();
OsgiBundlesContext.clear();
logger.info("osgi 停止完成");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
@Override
public void contextInitialized(ServletContextEvent arg0) {
// TODO Auto-generated method stub
try {
ClassLoader loader = OsgiListener.class.getClassLoader();
EclipseStarter.startup(new String[] { "-console" }, null);
BundleContext context = EclipseStarter.getSystemBundleContext();
OsgiBundlesContext.setOsgiContxt(context);
logger.info("osgi 启动完成");
//注意设置ClassLoader,不然在非osgi后续类加载中(有些会用当前线程的类加载器,而此时类加载器已经被OSGI修改???)会使用到osgi的类加载器
Thread.currentThread().setContextClassLoader(loader);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
这时可以通过控制台进行osgi命令操作。