Uploaded image for project: 'Felix'
  1. Felix
  2. FELIX-5467

MultiPropertyFilterIndex is unusable when a service reference contains a lot of values for one key

    XMLWordPrintableJSON

Details

    Description

      Upon addition of a service, the MultiPropertyFilterIndex creates a set of keys using the keys and values of the service reference properties. If the value is an array of values it creates keys for each possible permutation of those values so that the service reference can be retrieved if in the service dependency filter multiple values are specified (e.g. (&(objectClass=SomeClass)(&(a=x)(a=n)(a=y)(b=y)(c=z)))). If there are a lot of values for a key this results in a huge memory consumption, making it impossible to use.
      Now, in my application I always specify just one value in the service filter (e.g. there is a service which has multiple values for property "a" but I only specify one: (&(objectClass=SomeClass)(&(a=x)(b=y)(c=z)))) so I don't need those permutations, but because my property has a lot of values (>10) I cannot use the MultiPropertyFilterIndex causing a significant performance loss.

      I would like to suggest to add the possibility to leave out creating the permutation of values for a service property if you specify so in your filter properties. For instance by preceding the property configuration with '#', e.g. -Dorg.apache.felix.dependencymanager.filterindex=*aspect*;*adapter*;objectClass;objectClass,#a,b,c

      Attachments

        1. Property.java
          2 kB
          Jeroen Daanen
        2. MultiPropertyFilterIndex.java
          18 kB
          Jeroen Daanen

        Activity

          People

            pderop Pierre De Rop
            JeroenDaanen Jeroen Daanen
            Votes:
            0 Vote for this issue
            Watchers:
            2 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: