Hello OSGI --- Apache Felix

简介: Apache Felix Felix是一个OSGi版本4规范的Apache实现。 OSGi是一个基于Java的服务平台规范,其目标是被需要长时间运行、动态更新、对运行环境破坏最小化的系统所使用。

Apache Felix

Felix是一个OSGi版本4规范的Apache实现。

OSGi是一个基于Java的服务平台规范,其目标是被需要长时间运行、动态更新、对运行环境破坏最小化的系统所使用。有许多公司(包括Eclipse IDE,它是第一个采用OSGi技术的重要项目)已经使用OSGi去创建其微内核和插件架构,以允许在运行时刻获得好的模块化和动态组装特性。几个其他项目如Apache Directory、Geronimo、Jackrabbit、Spring以及JOnAS也都正在转向采用OSGi。

目前Felix已经实现了OSGI R4规范中的大部分内容。

felix的官方地址为

http://felix.apache.org/site/index.html

想下载felix及它的子工程可以到

http://felix.apache.org/site/downloads.cgi

下载最新版本的felix

安装插件,插件的安装地址是

http://www.ops4j.org/pax/eclipse/update

Felix环境配置

下载felix的最新版本,并且将最新的felix解压到本地路径。

新建一个Java工程

工程名为felix,这个工程名可以随意设置

选择下一步,修改输出路径

复制解压后的felix目录中的内容到工程中。完成后的目录如下所示:

将felix.jar添加到工程的目录中,选择Build Path->Add to Build Path

然后配置Run Configuration

修改配置

点击Run,就可以运行felix,启动后结果如下:

发布应用到Felix中

新建插件工程HelloFelix

完成后修改Activator类,加入两段输出:

 1     /*
 2      * (non-Javadoc)
 3      * @see org.osgi.framework.BundleActivator#start(org.osgi.framework.BundleContext)
 4      */
 5     public void start(BundleContext bundleContext) throws Exception {
 6         Activator.context = bundleContext;
 7         System.out.println("hello felix应用启动!");
 8     }
 9 
10     /*
11      * (non-Javadoc)
12      * @see org.osgi.framework.BundleActivator#stop(org.osgi.framework.BundleContext)
13      */
14     public void stop(BundleContext bundleContext) throws Exception {
15         Activator.context = null;
16         System.out.println("hello felix应用停止!");
17     }

 

完成后选择Export,选择Plug-in Development的Deployable plug-ins and fragments

选择要导出的插件,Destination选项卡的Directory选择Felix环境的物理地址,导出后,会在Felix工程的根目录自动创建一个felix-cache和plugins目录,bundle会默认导出这个目录,单击Finish按钮。

点击完成,得到结果,然后到工程中已经搭建好的环境felix项目中进行刷新,可以看到多出pluglins目录

环境和工程都已经完成,下面安装和卸载一下工程在felix中

启动Felix,在Console中先使用install命令安装bundle,接着使用start命令启动bundle。

启动的时候,start命令后接着那个bundle的启动ID就可以启动bundle。

停止的时候,stop命令后接着那个bundle的ID就可以停止bundle。

最后卸载工程HelloFelix,使用命令uninstall

 

 

 

目录
相关文章
|
应用服务中间件
tomcat开启PID
tomcat开启PID
410 0
|
传感器 编解码 人工智能
一个强大的音视频编解码库-rkmedia的应用
一个强大的音视频编解码库-rkmedia的应用
1071 0
|
Ubuntu 网络协议 关系型数据库
Ubuntu 14.04 LTS 发布 (附新特性介绍及下载镜像站列表)
LTS 是 Ubuntu 的长期支持版,因此 Ubuntu 14.04 支持周期长达 3-5 年。因此 Ubuntu 14.04 是追求稳定的用户和企业的最佳选择。
3312 0
Ubuntu 14.04 LTS 发布 (附新特性介绍及下载镜像站列表)
|
运维 NoSQL Cloud Native
国内独家|阿里云首发MongoDB 8.0,性能提升“快”人一步
阿里云作为MongoDB的最佳战略合作伙伴,在国内独家发布了8.0版本,支撑广大用户进一步提升业务效率。
|
消息中间件 存储 API
|
Java Maven Spring
maven打包插件maven-jar-plugin与spring-boot-maven-plugin
该内容介绍了两个Maven打包插件:`spring-boot-maven-plugin`和`maven-jar-plugin`。`spring-boot-maven-plugin`是Spring Boot项目的默认打包工具,它会包含项目类文件、资源和依赖的jar,但不会解编译依赖。而`maven-jar-plugin`则用于创建普通JAR包,不包含依赖。文中还展示了两个插件打包后的效果差异,并强调了持续练习以掌握这些技能的重要性。
2480 0
|
存储 缓存 网络协议
深入理解Linux网络——内核是如何发送网络包的
一、相关实际问题 1. 查看内核发送数据消耗的CPU时应该看sy还是si 2. 在服务器上查看/proc/softirqs,为什么NET_RX要比NET_TX大得多 3. 发送网络数据的时候都涉及那些内存拷贝操作 4. 零拷贝到底是怎么回事 5. 为什么Kafka的网络性能很突出
|
存储 NoSQL MongoDB
从 MongoDB 到 时序数据库 TDengine,沃太能源实现 18 倍写入性能提升
沃太能源是国内领先储能设备生产厂商,数十万储能终端遍布世界各地。此前使用 MongoDB 存储时序数据,但随着设备测点增加,MongoDB 在存储效率、写入性能、查询性能等方面暴露出短板。经过对比,沃太能源选择了专业时序数据库 TDengine,生产效能显著提升:整体上,数据压缩率超 10 倍、写入性能提升 18 倍,查询在特定场景上也实现了数倍的提升。同时减少了技术架构复杂度,实现了零代码数据接入。本文将对 TDengine 在沃太能源的应用情况进行详解。
695 0
|
Unix Java 编译器
安装gcc
【5月更文挑战第14天】安装gcc。
683 1
|
JSON API 数据格式
从基础到高级,带你深入了解和使用curl命令(四)
本文介绍了如何使用curl命令发送GET和POST请求。发送GET请求的基本语法是`curl [URL]`,加参数时使用`&`连接。添加`-v`参数可显示详细输出。发送POST请求,使用`-X POST -d`传表单数据,或`-d -H "Content-Type: application/json"`发送JSON数据,用`-F "file=@path"`上传文件,`--data-binary`用于上传二进制数据。curl是一个功能强大的HTTP请求工具,适用于各种网络通信需求。