我在 OSGi 声明式服务组件中遇到了不满意的引用问题:
<?xml version="1.0" encoding="UTF-8"?>
<scr:component xmlns:scr="http://www.osgi.org/xmlns/scr/v1.1.0"
name="com.mycompany.foo.Service"
immediate="true"
activate="activate"
deactivate="deactivate">
<implementation class="com.mycompany.foo.Service"/>
<!-- Other references -->
<reference
interface="org.osgi.service.http.HttpService"
name="HttpService"
cardinality="1..1"
policy="static"
bind="setHttpService"
unbind="unsetHttpService"/>
</scr:component>
我从 Eclipse 启动 OSGi 应用程序,控制台显示服务处于以下Unsatisfied
状态:
osgi> ls
All Components:
ID State Component Name Located in bundle
6 Unsatisfied com.mycompany.foo.Service com.mycompany.foo(bid=18)
该comp
命令报告原因是对以下内容的不满意引用org.osgi.service.http
:
osgi> comp 6
Component[
name = com.mycompany.foo.Service
...
state = Unsatisfied
references = {
...
Reference[name = HttpService, interface = org.osgi.service.http.HttpService, policy = static, cardinality = 1..1, target = null, bind = setHttpService, unbind = unsetHttpService]
}
located in bundle = com.mycompany.foo_1.2.3 [18]
]
Dynamic information :
*The component is NOT satisfied
The following references are not satisfied:
Reference[name = HttpService, interface = org.osgi.service.http.HttpService, policy = static, cardinality = 1..1, target = null, bind = setHttpService, unbind = unsetHttpService]
Component configurations :
Configuration properties:
component.name = com.mycompany.foo.Service
component.id = 6
Instances:
但是org.osgi.service.http
可用,如packages
命令所示:
osgi> p org.osgi.service.http
org.osgi.service.http; version="1.2.1"<org.eclipse.osgi.services_3.2.100.v20100503 [54]>
com.mycompany.foo_1.2.3 [18] imports
org.eclipse.equinox.http.registry_1.1.1.R36x_v20101103 [46] imports
org.eclipse.equinox.http.servlet_1.1.0.v20100503 [47] imports
org.eclipse.equinox.http.servletbridge_1.0.200.v20100503 [48] imports
我尝试从服务文档中删除引用,并且服务组件已正确实例化和激活,但没有必要的HttpService
部分。
非常感谢任何进一步排除故障的帮助。