看了http://developer.51cto.com/art/200909/154863.htm 真心感到,最强大最有组织的技术网站还是 51cto,牛人应该也是最多的。
以前逛51cto的比较少,罪过。。。。
吐槽:
参照http://developer.51cto.com/art/200909/154757.htm来搭建基于osgi的spring dm环境, 不过实在是搞不定,费心费力,几个月过去了的今天,终于搞定了—— 真tm坑爹,原来里面的spring dm版本是1.0.2
而这个版本下载不了,从而找不到文章里面描述
org.springframeork.bundle.spring.aop 等等jar
下载了2.0 也找到‘对应’的jar,作为plugin 导入进来,却,无论如何不能达到描述的效果,不能使dm生效,后面干脆把lib下的所有的jar全部导入,这样却就ok,内牛满面!
构建osgi - spring dm:(其实主要就是准备好jar。)
A下载Spring DM框架spring-osgi-2.0.zip,
B 解压抽取dist下面的jar:Spring DM提供的三个OSGi专用的Spring套件/JAR:
1. org.springframeork.osgi.bundle.extender
2. org.springframeork.osgi.bundle.core
3. org.springframeork.osgi.bundle.io
以plugin 方式导入F:\ws\spring-osgi-2\spring-osgi-2.0.0.M1\dist的上面的三个jar,
C 同样方式导入F:\ws\spring-osgi-2\spring-osgi-2.0.0.M1\lib 下面所有的jar, 其实不用导入jetty相关的,不过导入也是没关系的。
简单来说,这样就可以了! 不过启动后可能会出现:
osgi> log4j:WARN No appenders could be found for logger (org.springframework.osgi.extender.internal.boot.ChainActivator). log4j:WARN Please initialize the log4j system properly.
这是由于没配置好osgi log框架引起的。后面接着配置osgi log
Osgi Spring Dm的机制
对于Spring动态模型,在启动时,org.springframeork.osgi.bundle.extender 查询所有处于解析(resolved)状态以了解它们是否由Spring提供(Springpowered)。如果套件具有Spring-Context 清单头(manifest header),或者在其 META-INF/spring 文件夹中包含 XML 文件,extender 套件将认为该套件是由Spring提供的
各个基本spring dm jar的作用:
1 Osgi Spring Dm是直接基于org.eclipse.osgi_3.4.0.v2-xxx.jar的, 和其他osgi bundler 不发生关系。 和Activator没关系
就是说, Activator启动是否成功,跟Osgi Spring Dm是否能够运行没有关系。
2 如果Osgi Spring Dm 环境没搭建好(相关jar未导入),或者 META-INF/spring 配置有误,或者 META-INF/spring 里面的bean对应的类找不到,则 , Osgi Spring Dm框架不会生效。 —— 如果此时,osgi log也没有配好,则看不到任何dm输出,这是非常非常坑爹的。——没有任何输出,导致我 都不知道到底哪里出了问题。。。
3 如果Osgi Spring Dm 环境配置好了, 则META-INF/spring 文件夹中包含的 XML 文件自动生效。
osgi> log4j:WARN No appenders could be found for logger (org.springframework.osgi.extender.internal.boot.ChainActivator). log4j:WARN Please initialize the log4j system properly. start osgi ! Hello Spring World!! toString :: first name : aa -- last name :bb
另外参见:
http://chenjumin.iteye.com/blog/819070