All these have their respective pros and cons. Service tracking with only ServiceTrackers is not only hard (with more than a few services), it also requires alot of boilerplate code. First you need to list all the currently available services, and then you need to start a tracker to stay informed about new services being added, removed or modified. With only a few services, this will quickly build up and become a whole bunch of seemingly unnecessary classes, taking up a fair amount of lines.
As for the others, they are either somewhat big or they have performance impacts when the number of bundles and services rises. Declarative Services is a great tool and I use it alot in my bundles but... As I said, I've embedded OSGi (Felix) inside my own application which means that some (most) of my classes are not OSGi aware, meaning that they don't come from a bundle. I can't use DS to bind with these classes (not in an easy way at least).
So, what do we do? The good news is DynamicJava.org's ServiceBinding framework. Just put a jar on your classpath and use the (very trimmed down) binding framework as in
OsgiServiceBinder serviceBinder = new OsgiServiceBinder(context); serviceBinder.bind(this, "addActionListeners", ServiceFilter.forInterface(ActionListener.class.getName()));
This will
- Search for all available services that has registered in to OSGi that they provide the service ActionListener.
- Call addActionListeners with the services it found.
- Continue to call addActionListeners every time a service is added or removed.
As a final comment: Do not use OSGi to register ActionListeners. At least, think hard before doing so. First of all, the framework will not care much for event dispatch thread rules and secondly, the service registry is a very hectic place. Don't make it more so with unnecessary service registrations.
Hi,
ReplyDeleteCan you please let us know where does this OSgi framework get used and what are benefits it offer.
I haven't use this Osgi framework but would keen to know its offering.
Thanks
Javin
What is the difference between Synchronized Collection classes and Concurrent Collection Classes ? When to use what ?
Hi Javin,
ReplyDeleteWhat it is: OSGi is a module system and service platform for Java. Different implementations are Knopflerfish, Apache Felix and Eclipse Equinox. Equinox is the reference implementation if I'm not mistaken (I personally use Felix though).
What it is used for: Eclipse (the IDE) use Equinox to modularize and bring services to the Eclipse platform. If you use Eclipse as your IDE, you might have installed a plugin sometime. When you did, you installed an OSGi bundle.
I use Apache Felix to create a plugin/module-system for my company's core product.
If you're more into the Java EE comunity you propably know about Spring and Glassfish. Both use OSGi to handle modules and services.
Some have used the Android "port" of Felix to create dynamic mobile apps. This is kinda fun because OSGi was originally created to give services to mobile and embedded systems (I think).
What is it's benefits: Actual, real modularization. Richard Hall recently posted a presentation with a focus on the modularization part of OSGi. It is using a litle sarcasm to get the points through. Apart from modularization (and don't be fooled by maven, it is great but not a runtime module system), it also (mainly) provides a service platform. Using services instead of classes as the key abstraction in your code means (among other things) that you will never be bound to a specific implementation.