OSGi 学习(一)
从基础开始,先来说说OSGi的基本理念。
OSGi通过隔离底层classloader,强制应用在设计的时候就考虑模块化,并且基于白板模式来支持服务的注册与订阅。
在OSGi中,模块可以等价理解为bundle,在bundle的基础上,提供了相应的生命周期的管理。同时,为了在多个bundle之间可以进行友好的合作,提供了内部注册中心,基于白板模式支持了服务的注册与订阅。
还有一些基础的概念,比如:片段、插件依赖、包导入导出、以及远程服务等。
这里只细说远程服务,其余的随便google下就好了。
1.为什么需要远程服务呢?
理由其实很简单,一个系统不会仅仅只需要系统内部可以正常工作,往往还需要和外围系统进行对接。而且,随着负载规模的加大,我们还希望分布式部署,支持各种协议的的通讯等。
2.远程服务的理念?
OSGi的远程服务规范中有相应的描述,如下图:
Framework A与Framework B是2个系统,A发布远程服务,提供了一系列的属性;B引用该远程服务,通过一系列属性进行过滤。A、B之间通过某种传输协议进行通讯。那么B如何找到A呢?答案就是通过外部的注册中心。
如下草图:
目前,对于OSGi的远程服务有两种实现。一种是eclipse的ECF;一种是apache的CXF。这两种基本上都是基于某一种RPC的机制来实现远程服务的。
那么,其实可以看出来,OSGi的远程服务本质上就是一个外部的SOA体系(之前内部的注册中心的服务体系可以理解为一个JVM内部的SOA)。在逻辑层面,外部和内部没有过多的区别,都有注册中心,都是基于白板模式注册与订阅服务。那么,比较大的区别在于远程服务,需要加入新的特性。比如:负载均衡,路由,黑白名单,权重设置,调用统计等治理手段。
远程服务实现的选择?
OSGi没有约束具体的通讯方式,本质上,只需要支持将合适的数据传输到远端,远端可以进行正确的解析并返回响应就可以满足远程服务的基本要求了。那么,根据应用场景,可以选择合适的RPC通讯方式。
现有的实现,包括:webservice,xml-RPC等。性能一般,但是是工业标准,和第三方对接也比较方便。除此之外,还可以尝试dubbo-RPC。当然,dubbo不仅仅是一个RPC框架,还包括一系列的治理功能,而且包含一系列的扩展协议支持,通用的远程服务协议都已经支持。
选择的需要考虑的问题
基本上一个应用迁移到OSGi都会或多或少的遇到classloader的问题,这需要熟悉OSGi的相关机制以及应用的实现机制后才能解决。不过一旦解决,分布式系统的部署与开发就降低了相当多的门槛。
现有的这些,足够了吗?
考虑到和第三方对接的各种场景,以及RPC的使用限制。可以得出一个初步的结论,RPC的远程服务,适合内部系统之间的通讯。和外部系统的通讯需要更通用,更少侵入的方式。目前流行的REST服务很好的满足了这点。
采用http协议,基于已有的有限动词,将指定名词的状态进行合适的切换(其实可以简单的看做是一个有限状态机,不过换了一套更花哨的说法而已)。而这些,不用像RPC一样,服务端服务接口发生变化,需要更新客户端的lib。REST不需要或者只需要提供一个新的url通知到客户端即可。那么,这样一来,在支持OSGi远程服务基础上的vrigo容器的价值就得到体现。
OSGi 学习(一)的更多相关文章
- 【Todo】OSGi学习
经常听到.见到OSGi这个名字.那么就单开一篇文章记录一下对OSGi的学习吧. 主要是做一些概念上面的学习.暂时不打算深入实践. 主要参考:http://www.osgi.com.cn/article ...
- OSGI学习总结
最近的一项研究了解了一下OSGI技术,感觉OSGI尽管有一定的学习难度.可是终于掌握和推广之后将是一项对系统开发比較实用的技术.在此和大家分享一下自己的感悟. 1.什么是OSGI OSGI直译为&qu ...
- OSGi学习-总结
本文是osgi实战一书的前几章读书总结 1. OSGi简介 Java缺少对高级模块化的支持,为了弥补Java在模块化方面的不足,大多数管理得当的项目都会要求建立一整套技术,包括: 适应逻辑结构的编程 ...
- osgi学习
Bundle可以被动态地安装.启动.停止和卸载.Bundle是服务(Service)和组件(Component)的载体.在OSGi中,每个Bundle都有自己独立于其他Bundle的ClassLoad ...
- OSGi 学习(二)
上一篇说了很多虚的东西,现在说点别的. OSGi系统的独立环境下的项目结构以及启动脚本. 先说项目结构,基于equinox的OSGi容器的项目结构如下所示: bin中定义启动脚本,停止脚本之类的. c ...
- OSGi 学习之路(4) - osgi的模块化 java在模块化的局限性
底层代码可见性控制 Java提供了private,public,protected和package private(无修饰符)这四种访问控制级别,不过这仅仅提供了底层的OO数据封装特性.包这个概念确实 ...
- Liferay7 BPM门户开发之38: OSGi模块化Bndtools、Maven、Gradle开发构建入门
前言 OSGi是目前动态模块系统的事实上的工业标准,它适用于任何需要模块化.面向服务.面向组件的应用程序.Eclipse如此庞大和复杂的插件体系,就是基于OSGi.Liferay也是基于OSGi.OS ...
- OSGI.NET 学习笔记--架构篇
关于osgi.net ,想必大家也听说过,以下是自己在学习osgi.net 过程中整理出来的内容,供大家学习参与使用. 1. UIOSP 开放工厂框架架构 开放工厂所有插件基于OSGi.NET面向服 ...
- OSGI.NET 学习笔记--应用篇
关于osgi.net ,想必大家也听说过,以下是自己在学习osgi.net 过程中整理出来的内容,供大家学习参与使用. 1. OSGI.NET 与UIOSP OSGi是Open Service Ga ...
随机推荐
- Away 3D 之 交互和渐变----Interactivity and Tweening
在这个教程中,你将学会如何创建一个地板对象,本教程中的地板是可交互的并且能够移动小方块到鼠标的点击的地方. 1. 设置场景: 你正在创建的场景包含了一个平面,地板和一个看起来像一个饰品的方块,还有一个 ...
- Java-note-字符串转换为基本值
Integer.parseInt() and Double.parse.double() 例: Integer.parseInt("123") 得到常量123
- 《一步一步写嵌入式操作系统》读书笔记1—Skyeye介绍、安装和HelloWorld
2013-11-14 最近在看<一步一步写嵌入式操作系统>,感觉此书甚好,许多地方讲得很清楚.可操作性强,计划边读边实践边写笔记,希望能够逐步熟悉嵌入式操作系统底层的东西,最终剪裁出一套实 ...
- Apache Rewrite常用设置说明
例子: RewriteEngine on 打开引擎 RewriteRule test.html /test.php [L] RewriteRule test.html?$ /tianqi.php?s1 ...
- OpenStack的Resize和冷迁移代码解析及改进
原文:http://www.hengtianyun.com/download-show-id-79.html OpenStack的Resize(升级)功能,我们可以改变虚拟机的CPU核数.内存及磁盘大 ...
- Navicat 远程连接SQL Server 2014 Express 报08001错误
场景:Navicat 远程连接SQL Server 2014 Express 报08001错误,经查验防火墙端口1434,1433已经打开 过程:1. 一开始觉得是连接名称问题,使用IP地址或者主机名 ...
- Jquery类级别与对象级别插件开发
jQuery插件的开发包括两种: 一种是类级别的插件开发,即给jQuery添加新的全局函数,相当于给jQuery类本身添加方法.jQuery的全局函数就是属于jQuery命名空间的函数,另一种是对象级 ...
- 【转】Nginx系列(二)--模块化
原博文出于: http://blog.csdn.net/liutengteng130/article/details/46700977 感谢! 高度模块化的设计设Nginx架构的基础.在Nginx中 ...
- Spring Autowiring by Type
In Spring, "Autowiring by Type" means, if data type of a bean is compatible with the data ...
- Spring EL ternary operator (if-then-else) example
Spring EL supports ternary operator , perform "if then else" conditional checking. For exa ...