gpt4 book ai didi

java - Felix 未启动 bundle

转载 作者:行者123 更新时间:2023-11-30 01:57:01 24 4
gpt4 key购买 nike

无法将包加载到 felix 中。我下载了Felix 6.0.1,运行使用

> java -jar bin/felix.jar
____________________________
Welcome to Apache Felix Gogo

g!

我在 eclipse 中创建一个 MavenProject TestA:

  1. 我按照提供的方式添加了对 felix (6.0.1) 的依赖项。
  2. 我在 TestA/src/main/java/testa/impl/Activator.java 中创建了一个类。
  3. 我将 testa.impl.Activator 类扩展为 org.osgi.framework.BundleActivator
  4. 我覆盖了 public void start(BundleContext bc) throws Exception 以打印出 Hello World!

这是java源代码:

package testa.impl;

import org.osgi.framework.BundleActivator;
import org.osgi.framework.BundleContext;

public class Activator implements BundleActivator {

public void start(BundleContext arg0) throws Exception {
System.out.println("Hello World!");
}

public void stop(BundleContext arg0) throws Exception {
System.out.println("stop");
}
}

这是我的pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>test</groupId>
<artifactId>testa</artifactId>
<version>0.0.1-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>org.apache.felix</groupId>
<artifactId>org.apache.felix.main</artifactId>
<version>6.0.1</version>
<scope>provided</scope>
</dependency>
</dependencies>
<build>
<defaultGoal>clean install org.apache.felix:maven-bundle-plugin:bundle</defaultGoal>
</build>
</project>

然后我使用 mvn 编译为 jar 并使用

加载
g! install file:/C:/xxx/TestA/target/testa-0.0.1-SNAPSHOT.jar                              
Bundle ID: 20

然后我使用 lb 列出所有 bundle

g! lb                                                                                                           15:51:56
START LEVEL 1
ID|State |Level|Name
0|Active | 0|System Bundle (6.0.1)|6.0.1
1|Active | 1|jansi (1.17.1)|1.17.1
2|Active | 1|JLine Bundle (3.7.0)|3.7.0
3|Active | 1|Apache Felix Bundle Repository (2.0.10)|2.0.10
4|Active | 1|Apache Felix Gogo Command (1.0.2)|1.0.2
5|Active | 1|Apache Felix Gogo JLine Shell (1.1.0)|1.1.0
6|Active | 1|Apache Felix Gogo Runtime (1.1.0)|1.1.0
20|Installed | 1|testa (0.0.1.SNAPSHOT)|0.0.1.SNAPSHOT
g!

无论如何,我使用 start 启动 bundle :

g! start 20
g!

我预计会打印“Hello World”,但什么也没显示!

我现在很困惑,并尝试查明 bundle 是否真的已经启动。

g! lb                                                                                                           15:51:56
START LEVEL 1
ID|State |Level|Name
0|Active | 0|System Bundle (6.0.1)|6.0.1
1|Active | 1|jansi (1.17.1)|1.17.1
2|Active | 1|JLine Bundle (3.7.0)|3.7.0
3|Active | 1|Apache Felix Bundle Repository (2.0.10)|2.0.10
4|Active | 1|Apache Felix Gogo Command (1.0.2)|1.0.2
5|Active | 1|Apache Felix Gogo JLine Shell (1.1.0)|1.1.0
6|Active | 1|Apache Felix Gogo Runtime (1.1.0)|1.1.0
20|Active | 1|testa (0.0.1.SNAPSHOT)|0.0.1.SNAPSHOT
g! 15:51:58

它已启动,但我的代码尚未执行。

问题

为什么控制台上没有打印Hello World

最佳答案

Hello World 不会打印在控制台上,因为您创建的 jar 实际上不是一个包。奇怪的是,felix 允许您启动一个 list 中没有任何 OSGI 相关信息的 jar。我不清楚启动这样的 bundle 意味着什么?也许这些类(class)会发布,也许不会。

大多数java框架都会扫描jar中的文件并使用反射或字节码分析来查找相关的类。对于普通框架,扫描 jar 的开销仅在启动时产生一次。OSGI 被设计为轻量级,也可用于移动设备。此外,由于 OSGI 中的包可以来来去去,因此他们设计了一种更有效的方法。OSGI 包将元数据存储在 list 中。这是一个简单的文本文件,始终位于同一位置(在 jar 中):“META-INF/MANIFEST.MF”。如果您使用 zip 工具检查 jar 中的文件,您应该看到如下内容:

Manifest-Version: 1.0
Archiver-Version: Plexus Archiver
Created-By: Apache Maven
Built-By: Peter Rader
Build-Jdk: 1.8.0_111

为了将来的 OSGI 故障排除,我建议您检查(并发布)创建的 list 。

有效的 OSGI list 如下所示:

Manifest-Version: 1.0
Archiver-Version: Plexus Archiver
Created-By: Apache Maven
Built-By: Peter Rader
Build-Jdk: 1.8.0_111
Bundle-Name: testa
Bundle-SymbolicName: testa.impl
Bundle-Version: 1.0.0
Bundle-Activator: testa.impl.Activator
Import-Package: org.osgi.framework

当 felix 读取此 list 时,它使用“Bundle-Activator”条目来查找激活器(如果有)。替换 list , bundle 应该可以正常部署。
只需在相对于 jar 的位置创建一个名为“META-INF/MANIFEST.MF”的文本文件,其中包含上述文本。接下来用以下 linux 命令(或您最喜欢的 zip 工具)替换 jar 中的 list 文件:

zip testa-0.0.1-SNAPSHOT.jar -u META-INF/*

zip 命令的预期输出:

updating: META-INF/MANIFEST.MF (deflated 36%)

请务必打开带有 zip 文件的 jar 并检查内容是否已更改。现在,如果您安装并启动该 bundle ,它应该打印“Hello World!”。

虽然这解决了问题,但这不是一个非常干净的解决方案。
jar 规范对于 list 中的条目应如何格式化有一些相当奇怪的规则:
https://docs.oracle.com/javase/7/docs/technotes/guides/jar/jar.html#Manifest_Specification
最值得注意的是:

No line may be longer than 72 bytes (not characters), in its UTF8-encoded form.
If a value would make the initial line longer than this,
it should be continued on extra lines (each starting with a single SPACE).

因此,您不想手动编辑此文件。正如其他人所说,您有多种选择来自动生成 OSGI list 。和以前一样,您可以检查生成的 jar 中的 list 以验证它是否正确生成。

关于java - Felix 未启动 bundle ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54072205/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com