写点什么

OSGi 4.2 发布了

  • 2009-10-02
  • 本文字数:1859 字

    阅读完需:约 6 分钟

近日 OSGi 联盟发布了 OSGi 4.2 规范。虽然早期草案已经发布了,但此次则为最终版。

某些引擎如 Equinox Felix 分别在其 3.5 版和 2.0 版的时候就已经开始兼容 OSGi 4.2 了。然而由于 4.2 版那时还没有发布,这些引擎就不能说兼容于 OSGi 4.2。现在 4.2 版已经发布了,这些团队到底如何来满足规范的要求只是个时间问题了。

此次发布都包含哪些内容呢?InfoQ 此前曾报道过关于草案的相关信息,但现在规范最终版已经发布了,下面就是新版的一些内容:

  • 框架加载(Framework Launching)。虽然我们可以从 Java 应用中运行嵌入式 OSGi 引擎(比如 Equinox 的 Servlet 桥), 但这种方式却将应用与具体的引擎绑定在了一起。借助于包装器(比如 Pax Runner )可以通过相对简单的方式将特定于引擎的内容编码到引擎中来启动。现在可以通过一种透明的机制进行加载了,这意味着可以加载一个 OSGi 运行时而无需担心是哪个运行时。这样我们就可以通过替换启动类路径上的 JAR 文件在 Equinox 及 Felix 下测试应用了。
  • 远程服务(Remote Service。过去叫做分布式 OSGi 及 RFC 119,现在称作远程服务的技术是用于连接多个 OSGi VM 的。远程服务采用了服务的概念(这对于动态 OSGi 应用来说非常关键)并提供了一种机制以将服务公开给远程使用者(使其可以在本地使用远程服务)。并不像其他方式(比如 RMI)那样,远程服务无需实现不同的接口或是抛出受检查的异常。同时它也不会假设万物都会正常工作,而是认为 OSGi 服务是动态的,无论如何服务都能够在 OSGi 环境下抛出并处理异常。
  • Blueprint 服务(Blueprint Service)。对于熟悉 Spring IoC 与 DI 的开发者来说会发现 Blueprint 服务与其有异曲同工之妙。客户端可以根据外部的配置文件来决定连接到哪些服务上,同时还会动态连接这些服务。就像声明式服务那样,你可以约束所用的服务类型(比如强制与否等),但与声明式服务不同的是,在缺少服务的情况下 Blueprint 服务会提供一个相应的代理。在客户端代码与服务进行交互时,客户端会被阻塞住直到定位到服务之后。最后,凭借 Blueprint 服务之类的特性,我们可以避免应用中出现特定于容器的代码,这样无论系统运行在 OSGi 运行时内部还是外部都是大有裨益的。
  • Bundle 跟踪器(Bundle Tracker)。OSGi 早就有了一个服务跟踪器(Service Tracker)用于监控进出的服务,Bundle 跟踪器是对服务器跟踪器概念的一个延伸,用于监控 bundle 的信息。此前服务可以通过 BundleListener 来动态查看进出的 bundle,而 BundleTracker 也达到了同样的高度,就像 ServiceTracker 之于 ServiceListener 一样。我们可以通过这个特性执行动态注册之类的功能,就好象是 Blueprint 服务或声明式服务读取或处理元数据一样。比如说,Web 引擎可能会通过 HttpService 自动扫描新安装的 bundle 和自动注册的 Servlet。
  • 服务钩子(Service Hook)。除了判定当前的服务外,我们还可以拦截服务之间的事件并对其进行过滤。这可用来实现基于角色的许可模型或是根据产品的不同而开启不同的功能集。此外还可以通过拦截另一个 bundle 的事件而提供代理(或是负载平衡)同时又隐藏这些事件,然后用另一种机制进行代理(比如说分布式服务)。监听器钩子可以按需实现这些功能而无需提前注册。
  • 条件许可(****Conditional Permission)。OSGi 4.2 中许可的一大变化是增加了 DENY 访问及允许访问的能力。通过与证书签名的结合,这种方式可以显式指定某个 bundle 的子集上都允许哪些许可权限。这有助于创建安全的 OSGi 平台,可以阻止安装那些未授权的 bundle。

新的规范还有很多其他变化,比如 OSGi bundle 具有了自己的 MIME 类型(application/vnd.osgi.bundle)、指定 Bundle-Icon 及 Bundle-License 的能力、声明式服务的变化以允许更少的许可集合(package 访问能力而非 protected)。DS schema 还支持其他的 XML 元素,这有助于特定于服务的信息的传递。此外,由应用管理员所管理的应用现在可以在完成后获取其返回值了。

Equinox 3.5 已经部分支持 OSGi 4.2 了, Apache Felix 在上月初也已经通过了一个测试集(在 4.2 规范发布前)。我们相信本月底一切都会明朗起来,包括 4.2 规范的官方定论及测试工具集。

InfoQ 就此次新版本的发布请 Paremus 的创建者与 CEO、 Paremus Service Fabric OSGi cloud 的作者 Richard Nicholson 谈谈自己的看法:

“在过去几年中,我们一直从事着分布式 OSGi 系统的构建,非常高兴看到 OSGi 4.2 规范的发布,此次发布引入了标准的远程服务与 Blueprint 服务。”

你认为 OSGi 4.2 中哪些地方最值得关注呢?

查看英文原文: OSGi 4.2 released

2009-10-02 06:133197
用户头像

发布了 88 篇内容, 共 264.3 次阅读, 收获喜欢 8 次。

关注

评论

发布
暂无评论
发现更多内容

KubeEdge发布云原生边缘计算威胁模型及安全防护技术白皮书

华为云开发者联盟

云计算 云原生 安全

深圳哪的培训机构学习大数据开发?

小谷哥

IT远程运维是什么意思?远程运维软件哪个好?

行云管家

IT运维 远程运维 IT远程运维

【微服务测试教程】使用Python测试gRPC接口案例

和牛

测试

Rust 入门指南(rustup, cargo)

王泰

rust

管理区解耦架构见过吗?能帮客户搞定大难题的

华为云开发者联盟

云计算 后端 华为云

全链路灰度在数据库上我们是怎么做的?

阿里巴巴云原生

数据库 阿里云 微服务 云原生 全链路灰度

详解.NET的求复杂类型集合的差集、交集、并集

了不起的程序猿

java 14 java程序员 java编程

语音社交系统——完善有声系统产业链

开源直播系统源码

开源源码 语音直播系统源码 语音直播系统 语音直播系统连麦

与字节、小米、移动云等企业一起揭秘 RocketMQ 实践之道

阿里巴巴云原生

阿里云 RocketMQ 云原生 峰会

参加java培训学习建议选择

小谷哥

兆骑科创创业大赛平台,活动路演,投融资对接

兆骑科创凤阁

应该怎么规划学习web前端培训

小谷哥

“工厂、构造、原型” 设计模式与 JS 继承

掘金安东尼

JavaScript 前端 7月月更

分布式 hdfs-over-ftp 工具实现方案

移动云大数据

阿里云 MSE 支持 Go 语言流量防护

阿里巴巴云原生

Go 阿里云 云原生 云原生微服务

【后端开发】Reactor 模型详解

C++后台开发

reactor 后端开发 网络模型 C/C++后台开发 C/C++开发

极狐GitLab Helm Registry 使用指南

极狐GitLab

git DevOps gitlab 运维 CI/CD

前端培训机构应该如何学习前端开发技术?

小谷哥

A tour of gRPC:05 - gRPC server straming 服务端流

BUG侦探

gRPC RPC protocolBuffer

Rust 入门指南(crate 管理)

王泰

rust

在培训机构学到大数据技术

小谷哥

C#/VB.NET:在PDF中插入文本水印

Geek_249eec

C# PDF VB.NET 水印

数牍 X Rust,那些不得不说的事

Jessica@数牍

联邦学习 隐私计算 数牍科技 rust开发者大会 分布式计算框架

活动速递| Apache Doris 性能优化实战系列直播课程初公开,诚邀您来参加!

SelectDB

数据库 性能优化 数据仓库 OLAP Doris

如何做一个好的大数据平台架构

数据社

签约计划第三季

兆骑科创创新创业大赛人才引进平台,双创赛事高层次人才引进

兆骑科创凤阁

零代码修改,教你Spring Cloud应用轻松接入CSE

华为云开发者联盟

云计算 后端 CSE

融云实时社区解决方案

融云 RongCloud

ApacheCon Asia 2022 启动!7场阿里云大数据+AI议题分享等你围观

阿里云大数据AI技术

人工智能 大数据

不懂就问,快速成为容器服务进阶玩家!

阿里巴巴云原生

阿里云 容器 云原生 训练营

OSGi 4.2发布了_Java_Alex Blewitt_InfoQ精选文章