基于OSGi实现分布式服务框架历程(二)

在这篇历程中来完成对于JINI的Spike,目标仍然是判断基于JINI实现服务的路由、查找需求的满足度。
JINI是由Sun研究院制定的,其目标就是为了实现分布式的服务,所以在很多地方可以看到它和分布式服务框架是有不少重叠之处的,来先看看它对于需求的满足度,最后再来分析做个总结。
1、怎么实现远程的将服务注册到服务中心?
      在jini中暂时没有找到远程注册服务到服务中心的方法。
      jini的服务需要和服务中心部署在同一台机器上,这个倒是可以通过服务管理中心直接将sar格式的服务部署上去,支持服务的动态管理,不过这是不符合分布式服务框架的需求的。
2、在服务应用端怎么查找服务中心的服务?
      在服务的查找上,Jini采用的方法估计是和JNDI差不多的,不过相对来讲要求就比JNDI高一些,因为它需要依赖它自己的serviceContext才能获取到服务,这点不是很好。
3、有否现成可用的实现?
      目前Jini的实现有好几个,最出名的当然是sun自己的Jini Starter Kit,但对于实现分布式服务框架的话,Newton是个更好的参考。
4、是否支持Cluster?
      由于服务和服务中心是在同一台机器,因此不存在是不是支持Cluster的问题,大不了部署的时候整个cluster中的所有机器都部署一次。
5、可参考的资源有哪些?
      jini可参考的资源主要就是:www.jini.org,通过这里可以找到挺多的jini的资料,比较好的有:
      http://blogs.sun.com/warren/entry/jini_made_easier_writing_a
      http://www.cheiron.org/seven/manual/html/developer/index.html
      http://jan.newmarch.name/java/jini/tutorial/Jini.xml
从服务的注册、查找和路由这三个需求去看,jini能直接满足的就只有查找了,因为我们需要的仅仅是一个注册、路由、查找的机制的框架,而不需要别的附加功能,jini就显得有点和这个需求不是很贴合了,尤其是jini本身就是个功能并不强的服务框架,如果采用它的话会导致还需要进行改造,剥离它的服务那块的机制或者做兼容,而且jini在使用时对于jini本身包的依赖性太强,这对于我们期待的pojo机制而言就挺麻烦了,当然,jini并不是毫无优点,如果大家去看看jini实现框架的那个可视化的服务的监控端,那实在是个很不错的东西,具体了完整的服务生命周期管理(安装、卸载、启动、停止以及目前的运行状态等)的功能。
jndi的简单性和对于需求的贴合性使得它成为了我们用于实现基于OSGi的分布式服务框架的选择。
在选择了jndi作为服务的注册、查找和路由机制后,我们需要逐步的演进基于OSGi的分布式服务框架的设计,在后续的篇章中我们将停留下spike过程,来分析下目前此分布式服务框架的状况。

<< 基于OSGi实现分布式服务框架历程(一)

>> 基于OSGi实现分布式服务框架历程(三)

posted on 2008-01-18 19:24 BlueDavy 阅读(5308) 评论(1)  编辑  收藏 所属分类: OSGi、SOA、SCA

评论

# felix整合openxava框架出现异常,希望大家能帮忙解决!!! 2011-01-13 10:04 小朱


我用的是openxava框架,在本地测试可以成功 ,但是用osgi的felix就出现异常 。下面是正确方法的测试,可以成功!

一 , add方法

@SuppressWarnings("unchecked")
public boolean add(String filedName,String value){

Map map = new HashMap();

map.put(filedName, value);

boolean flag = false;

try {
MapFacade.create("Application",map);

MapFacade.commit();
flag = true;


} catch (Exception e) {
flag = false;
}


return flag;


}

二,测试

public static void main(String[] args) {
ApplicationProvider ap = new ApplicationProvider();

System.out.println(ap.add("description","kebi"));--------------------这里进行方法调用可以成功
}
-------------------------------------------------------------------------

-------------------------------------------------------------------------

经过上面的测试可以把数据存到数据库中去

三, 但是我用osgi的felix客户端调用就会报异常

felix客户端的代码如下(自己手写的):

public class Activator implements BundleActivator { -----------这是felix客户端的激活器代码

private ServiceTracker st;


public void start(BundleContext context) throws Exception {


st = new ServiceTracker(context, ApplicationInterface.class.getName(), null) {


public Object addingService(ServiceReference reference) {


Object result = super.addingService(reference);


ApplicationInterface h = (ApplicationInterface) context.getService(reference);


System.out.println(h.add("description","kaobing"));----------在这里进行调用,后台就出现异常


return "ss";

}

};

st.open();
}

四,异常如下:

警告: 在确定默认 schema (从persistence.xml中读出)时发生错误. 没有缺省的schema.
2011-1-13 0:05:08 org.openxava.annotations.parse.AnnotatedClassParser getManaged
ClassNames
警告: Hibernate连接无法工作, 因此 JPA managed classes 直接从classpath中获取
javax.persistence.PersistenceException: No Persistence provider for EntityManager named default

希望大家能提供帮助,谢谢!!!!!!!!!!



本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/surpassdream/archive/2011/01/13/6133635.aspx  回复  更多评论   


只有注册用户登录后才能发表评论。


网站导航:
 

公告

 









feedsky
抓虾
google reader
鲜果

导航

<2008年1月>
303112345
6789101112
13141516171819
20212223242526
272829303112
3456789

统计

随笔分类

随笔档案

文章档案

Blogger's

搜索

最新评论

阅读排行榜

评论排行榜