我正在尝试使用 Configuration Admin 将配置信息传递给捆绑包。我正在使用基于 OSGI 的 Equinox 实现的声明性服务。首先,因为我找不到 Config Admin 的 Equinox 实现,所以我已经安装了 felix 实现,所以如果有人建议我在哪里可以获得 Equinox 版本,那就太好了。
我的主要问题是:我在运行程序时不断收到以下错误。似乎一个空的“配置”对象正在传递给我的更新方法。
osgi> !SESSION 2014-08-10 06:54:09.862 -----------------------------------------------
eclipse.buildId=unknown
java.version=1.7.0_51
java.vendor=Oracle Corporation
BootLoader constants: OS=win32, ARCH=x86, WS=win32, NL=en_US
Command-line arguments: -dev file:C:/Users/Desktop/OSGI/eclipseee/workspace1/.metadata/.plugins/org.eclipse.pde.core/configurator/dev.properties -os win32 -ws win32 -arch x86 -consoleLog -console
!ENTRY org.apache.felix.configadmin 4 0 2014-08-10 07:09:52.639
!MESSAGE Cannot use configuration de.services.logger.mtinylogger for [org.osgi.service.cm.ManagedService, id=33, bundle=11/initial@reference:file:../workspace1/de.services.logger.mtinylogger/]: No visibility to configuration bound to initial@reference:file:../workspace1/de.init.configurator/
我制作了一个配置器包,它创建了配置对象,它的激活方法(由声明性服务调用)中的主要内容是:
protected void activate(BundleContext bundleContext) throws IOException
{
//Retrieve a reference to the Configuration Admin service
ServiceReference serviceReference = bundleContext.getServiceReference(ConfigurationAdmin.class.getName());
if(serviceReference != null)
{
ConfigurationAdmin configAdmin = (ConfigurationAdmin) bundleContext.getService(serviceReference);
if(configAdmin != null)
{
Configuration configuration = configAdmin.getConfiguration("de.services.logger.mtinylogger");
//Update configuration object
Dictionary<String, Object> configProperties = new Hashtable<String, Object>();
configProperties.put("port", 8080);
configuration.update(configProperties);
}
实现 managedServices 的包内的更新方法如下:
@Override
@SuppressWarnings( { "rawtypes", "unchecked" } )
public void updated( Dictionary configuration ) throws ConfigurationException
{
if( configuration != null ) {
System.out.println(configuration.get("port"));
}
else
System.out.println("configuration is equal to 'null ");
}
奇怪的是,当我停止并启动正在更新的包时,它总是显示“配置等于 null”,就好像我还没有创建配置对象一样。我在这里想念什么?我花了将近 2 周的时间试图解决运行配置管理员的问题,但这占用了我太多时间。我真的很感激有关此的一些信息。发送!!
编辑:这里我添加了注册 ManagedService 类的“激活”方法。
protected void activate( BundleContext ctx )
{
Dictionary< String, Object > properties = new Hashtable< String, Object >();
//properties.put( Constants.SERVICE_PID, ctx.getBundle().getSymbolicName() );//optionally
properties.put( Constants.SERVICE_PID, "de.services.logger.mtinylogger" );
mService = ctx.registerService( ManagedService.class.getName(), this, properties );
}