We re using Karaf for a number of our applications. We were already using Camel (JMS and Esper) for integration between several different platforms (a JBoss 4.2 instance, a Tomcat and several Felix instances) and as this was working well there was little justification in migrating this too (which would have been cause to consider ServiceMix).
The only reason we have some Felix nodes, is that they re limited in use (on client desktops), rarely need/get updated and I wanted the smallest footprint for these nodes. For anything OSGi on the serverside we re using Karaf.
Karaf provides all of the features you d expect and need for a production environment (see the apache-karaf tag s info). We do our development and testing against standard minimal framework (using pax-exam) but deploy to Karaf.
If you don t need an ESB, JCA, BPEL, etc but want a solid, tunable OSGi container, then Karaf on it s own is more than adequate. (And if you found yourself needing a limited subset of ServiceMix s functionality you can always install these in a Karaf instance).
You can also customise the Karaf distribution as part of a maven build - personally I like have the container as part of the application s build, as I can checkout, build and run the entire setup from the command line in minimal time.
Recently there s a clustering subproject of Karaf called Cellar using HazelCast, I not sure if this applies to ServiceMix too.