2025 AI基础设施风向标,不看必后悔!#AI基础设施峰会 了解详情
写点什么

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:133227
用户头像

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

关注

评论

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

选择FastAPI或Flask:Python Web开发框架的终极指南

Apifox

Python flask 框架 web开发 FastApi

【我和openGauss的故事】openEuler20.03上编译安装opengauss-5.0.0

daydayup

【我和openGauss的故事】openGauss 5.0.0企业版两节点CM高可用实践

daydayup

山东布谷科技直播系统源码热点分析:不同芯片实现高质量编码与渲染视频的GPU加速功能

山东布谷科技

分享实录 | 将 NGINX 打造成功能强大的 API 网关(上)

NGINX开源社区

nginx 微服务 k8s API api 网关

Java中final、finally和finalize的区别

java易二三

Java 程序员 计算机 final

上云简单又不简单,华为云云耀云服务器L实例的用户体验究竟如何?

平平无奇爱好科技

OpenGauss与NVM

daydayup

明道云联合Kyligence结合示范性场景应用

明道云

【我和openGauss的故事】openGauss集群故障节点替换操作

daydayup

GitOps 与 DevOps:了解关键差异,为企业做出最佳选择

SEAL安全

DevOps 运维 gitops 企业号 8 月 PK 榜

云耀云服务器L实例:简单上云,智能不卡顿,性能遥遥领先

平平无奇爱好科技

内卷和躺平之外,职场还有其他选择

老张

职场成长

上云没那么难,华为云云耀云服务器L实例助力中小企业和开发者开启上云第一步

平平无奇爱好科技

一文详述流媒体传输网络MediaUni

阿里云CloudImagine

云计算 视频云

英特尔CEO称AI PC时代于今秋开启 联想将首批发布

E科讯

【我和openGauss的故事】openGauss容灾集群搭建过程代码学习记录

daydayup

Java日记——使用强大的Elastisearch搜索引擎

java易二三

Java 编程 程序员 计算机

【我和openGauss的故事】在vm中安装openEuler及使用yum安装openGauss

daydayup

移动云操作系统改造技术实践分享,跨操作系统云主机迁移优化(一)

openEuler

Linux centos 操作系统 迁移 openEuler

NKD:容器云集群与 OS 一体化运维利器

openEuler

Linux Kubernetes 云原生 操作系统 openEuler

SpringBoot3之Web编程

Java 架构 springboot SpringBoot3

javascript对象基础

timerring

JavaScript

BenchmarkSQL 5.0 压测 openGauss 5.0.0 案例分享

daydayup

鸿蒙智联再出发,携手伙伴共赢空间智能化,创造无限可能

HarmonyOS开发者

HarmonyOS

三步建站,两倍性能!云耀云服务器L实例开启简单上云第一步!

平平无奇爱好科技

【我和openGauss的故事】SpringBoot连接openGauss项目实战

daydayup

【我与openGauss的故事系列】openGauss 5.0.0全密态数据库应用小试

daydayup

OSGi 4.2发布了_Java_Alex Blewitt_InfoQ精选文章