1

我正在尝试使用 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 );
}
4

1 回答 1

6

您的问题不在于您在 Equinox 上使用 Felix 捆绑包。遵循该标准的 OSGi 包可用于任何框架实现。

您的问题是您使用“错误”的方法来创建配置:

configAdmin.getConfiguration("de.services.logger.mtinylogger");

问题是这个方法会隐式地将配置“绑定”到这个包(配置器),因此这个配置真正用于的包将不再看到它。简而言之,用这个替换你的方法:

configAdmin.getConfiguration("de.services.logger.mtinylogger", null);

这样,配置不会被绑定,并且可用于预期目标。

我对绑定的解释相对较短,OSGi 规范(免费提供)更详细地解决了它。

于 2014-08-10T11:30:02.280 回答