Hello Claus, Guillaume, Ioannis and Christian, Thanks guys, your response times were truly impressive (you're all a genuine credit to Apache and your respective companies). When I returned to it, my issue was quickly resolved thanks to your advice =)
One thing I found is that the actual resolution is to hostname and not IP (which makes sense given cloud environments), I hadn't set these machines up properly (so their names only worked locally). Don't seem to be able to create an account on Fusesource's Jira, so can't add this as a comment to FABRIC-266. Best regards, Caspar On 25 September 2012 07:13, Claus Ibsen <claus.ib...@gmail.com> wrote: > Hi > > This issue was also discussed recently at the Fuse Forums > http://fusesource.com/forums/thread.jspa?threadID=4262&tstart=0 > > Where the solution was posted as well, eg to change localhost to the ip > address. > We have logged a ticket to get the example improved for a future release. > > > > On Mon, Sep 24, 2012 at 5:40 PM, Caspar MacRae <ear...@gmail.com> wrote: > > > > Hello, > > > > I'm looking to move our distributed services (currently using Camel's JMS > > remoting) to a dOSGi solution. I won't be looking at ECF (simply because > > they don't seem to publish up-to-date maven artifacts), so that leaves > Fuse > > Fabric and Karaf Cellar. > > > > Apologies for the length of this mail, what follows is a log of the > steps I > > took with Fabric, in the hope that somebody can spot something. > > > > Thought I'd try to get something working in FuseESB before porting in > back > > to Karaf 2.2.x. > > > > So far I've burnt a bit of time with Fabric but not made any progress > (tried > > trunk and fuse-fabric-7.0.0.fuse-061, currently looking at > > fuse-fabric-7.0.1.fuse-084). I suspect I'm doing something stupid or > have > > missed something vital out. > > > > Starting with the simplest distributed case I've got a features.xml and 3 > > simple bundles; a service interface bundle, a client bundle and a service > > implementation bundle. I've ensured the client and service work in a > single > > instance, but am a bit stumped as to how to get this running over fabric. > > > > The service imp exports the property "service.exported.interfaces" as "*" > > and the interface implied by the asterisk is available to both service > imp > > and client bundles (i.e. deployed to both instances). > > > > On both boxes I've temporarily instructed iptables to open all ports and > I'm > > running the fusefabric command as root. > > > > > > # On box1 (provider): > > > > tar -xzf /data/share/fuse-fabric-7.0.1.fuse-084.tar.gz > > cd fuse-fabric-7.0.1.fuse-084/ > > sudo ./bin/fusefabric > > > > > > # On box1's Karaf shell: > > > > log:set TRACE net.earcam > > log:set TRACE org.fusesource.fabric.dosgi > > features:install fabric-commands fabric-dosgi fabric-configadmin > > fabric-zookeeper-commands > > # Line above logs exception as Zookeeper not created or ensembled - > assuming > > safe to ignore > > > > fabric:create --clean root # Causes exception 1 (see below), again > > assuming this is safe to ignore > > > > fabric:profile-create --parents dosgi dosgi-provider > > fabric:profile-edit --repositories > > > mvn:net.earcam.example.hello/net.earcam.example.hello.feature/0.0.1-SNAPSHOT/xml/features > > dosgi-provider > > fabric:profile-edit --features hello-server dosgi-provider > > > > fabric:container-create --profile dosgi-provider --parent root > > dosgi-provider > > > > fabric:container-list # Shows success > > > > fabric:container-connect dosgi-provider # Connects fine, can see > > ..example.hello bundles installed > > log:set TRACE net.earcam > > log:set TRACE org.fusesource.fabric.dosgi > > > > > > # ------ > > > > # On box2 (consumer): > > > > tar -xzf /data/share/fuse-fabric-7.0.1.fuse-084.tar.gz > > cd fuse-fabric-7.0.1.fuse-084/ > > sed -i s/karaf.name=root/karaf.name=vm-mint1/ etc/system.properties > > sudo ./bin/fusefabric > > > > # On box2's Karaf shell: > > > > log:set TRACE net.earcam > > log:set TRACE org.fusesource.fabric.dosgi > > features:install fabric-commands fabric-dosgi fabric-configadmin > > fabric-zookeeper-commands > > > > fabric:join 10.39.216.49 # The IP of box1 > > > > fabric:profile-create --parents dosgi dosgi-consumer > > fabric:profile-edit --repositories > > > mvn:net.earcam.example.hello/net.earcam.example.hello.feature/0.0.1-SNAPSHOT/xml/features > > dosgi-consumer > > fabric:profile-edit --features hello-client dosgi-consumer > > > > fabric:container-create --profile dosgi-consumer --parent vm-mint1 > > dosgi-consumer > > > > fabric:container-list # Shows success > > > > fabric:container-connect dosgi-consumer # Connects fine, can see > > ..example.hello bundles installed > > log:set TRACE net.earcam > > log:set TRACE org.fusesource.fabric.dosgi > > > > > > > > # ------ > > > > The "provision status" is "success" for all when running container-list > and > > I can connect to the two new containers dosgi-provider and > dosgi-consumer. > > > > On box2, in the dosgi-consumer container, I can see the remote service > > exported from box1, and it disappears/appears as I stop/start the > exporting > > service bundle on box1. > > > > The imported service has "correct looking" properties: > > component.id = 2 > > component.name = net.earcam.example.hello.server.HelloService > > endpoint.framework.uuid = b5806ad9-7849-4aaf-adf7-56ba1e6538e3 > > endpoint.id = 2008920412-47095-1348493938958-0-3 > > fabric.address = tcp://localhost:44462 > > objectClass = net.earcam.example.hello.api.GreetingService > > service.id = 246 > > service.imported = true > > service.imported.configs = fabric-dosgi > > service.pid = net.earcam.example.hello.server.HelloService > > > > > > > > # Exception 1, seen on both boxes: > > > > java.lang.NullPointerException > > at org.fusesource.fabric.dosgi.impl.Manager.destroy(Manager.java:175) > > at org.fusesource.fabric.dosgi.Activator.destroy(Activator.java:46) > > at sun.reflect.NativeMethodAccessorImpl.invoke0(Native > > Method)[:1.6.0_33] > > at > > > sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)[:1.6.0_33] > > at > > > sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)[:1.6.0_33] > > at java.lang.reflect.Method.invoke(Method.java:597)[:1.6.0_33] > > at > > > org.apache.aries.blueprint.utils.ReflectionUtils.invoke(ReflectionUtils.java:225)[10:org.apache.aries.blueprint:0.3.1.fuse-70-084] > > at > > > org.apache.aries.blueprint.container.BeanRecipe.invoke(BeanRecipe.java:838)[10:org.apache.aries.blueprint:0.3.1.fuse-70-084] > > at > > > org.apache.aries.blueprint.container.BeanRecipe.destroy(BeanRecipe.java:743)[10:org.apache.aries.blueprint:0.3.1.fuse-70-084] > > at > > > org.apache.aries.blueprint.container.BlueprintRepository.destroy(BlueprintRepository.java:295)[10:org.apache.aries.blueprint:0.3.1.fuse-70-084] > > at > > > org.apache.aries.blueprint.container.BlueprintContainerImpl.destroyComponents(BlueprintContainerImpl.java:673)[10:org.apache.aries.blueprint:0.3.1.fuse-70-084] > > at > > > org.apache.aries.blueprint.container.BlueprintContainerImpl.destroy(BlueprintContainerImpl.java:826)[10:org.apache.aries.blueprint:0.3.1.fuse-70-084] > > at > > > org.apache.aries.blueprint.container.BlueprintExtender.destroyContext(BlueprintExtender.java:255)[10:org.apache.aries.blueprint:0.3.1.fuse-70-084] > > at > > > org.apache.aries.blueprint.container.BlueprintExtender.bundleChanged(BlueprintExtender.java:247)[10:org.apache.aries.blueprint:0.3.1.fuse-70-084] > > at > > > org.apache.aries.blueprint.container.BlueprintExtender$BlueprintBundleTrackerCustomizer.modifiedBundle(BlueprintExtender.java:471)[10:org.apache.aries.blueprint:0.3.1.fuse-70-084] > > at > > > org.osgi.util.tracker.BundleTracker$Tracked.customizerModified(BundleTracker.java:495)[karaf.jar:2.2.5.fuse-70-084] > > at > > > org.osgi.util.tracker.BundleTracker$Tracked.customizerModified(BundleTracker.java:1)[karaf.jar:2.2.5.fuse-70-084] > > at > > > org.osgi.util.tracker.AbstractTracked.track(AbstractTracked.java:238)[karaf.jar:2.2.5.fuse-70-084] > > at > > > org.osgi.util.tracker.BundleTracker$Tracked.bundleChanged(BundleTracker.java:457)[karaf.jar:2.2.5.fuse-70-084] > > at > > > org.apache.felix.framework.util.EventDispatcher.invokeBundleListenerCallback(EventDispatcher.java:870)[org.apache.felix.framework-4.0.3.fuse-70-084.jar:] > > at > > > org.apache.felix.framework.util.EventDispatcher.fireEventImmediately(EventDispatcher.java:791)[org.apache.felix.framework-4.0.3.fuse-70-084.jar:] > > at > > > org.apache.felix.framework.util.EventDispatcher.fireBundleEvent(EventDispatcher.java:515)[org.apache.felix.framework-4.0.3.fuse-70-084.jar:] > > at > > > org.apache.felix.framework.Felix.fireBundleEvent(Felix.java:4431)[org.apache.felix.framework-4.0.3.fuse-70-084.jar:] > > at > > > org.apache.felix.framework.Felix.stopBundle(Felix.java:2532)[org.apache.felix.framework-4.0.3.fuse-70-084.jar:] > > at > > > org.apache.felix.framework.BundleImpl.stop(BundleImpl.java:983)[org.apache.felix.framework-4.0.3.fuse-70-084.jar:] > > at > > > org.fusesource.fabric.agent.DeploymentAgent.updateDeployment(DeploymentAgent.java:709)[102:org.fusesource.fabric.fabric-agent:7.0.1.fuse-084] > > at > > > org.fusesource.fabric.agent.DeploymentAgent.doUpdate(DeploymentAgent.java:415)[102:org.fusesource.fabric.fabric-agent:7.0.1.fuse-084] > > at > > > org.fusesource.fabric.agent.DeploymentAgent$1.run(DeploymentAgent.java:225)[102:org.fusesource.fabric.fabric-agent:7.0.1.fuse-084] > > at > > > java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)[:1.6.0_33] > > at > > > java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)[:1.6.0_33] > > at > java.util.concurrent.FutureTask.run(FutureTask.java:138)[:1.6.0_33] > > at > > > java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)[:1.6.0_33] > > at > > > java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)[:1.6.0_33] > > at java.lang.Thread.run(Thread.java:662)[:1.6.0_33] > > > > > > > > > > # Exception 2, seen on box2: > > > > 2012-09-24 15:16:00,142 | INFO | spatch-DEFAULT-1 | TransportPool > > | 67 - org.fusesource.fabric.fabric-dosgi - 7.0.1.fuse-084 | Transport > > failure > > java.net.ConnectException: Connection refused > > at sun.nio.ch.SocketChannelImpl.checkConnect(Native > > Method)[:1.7.0_07] > > at > > > sun.nio.ch.SocketChannelImpl.finishConnect(SocketChannelImpl.java:692)[:1.7.0_07] > > at > > > org.fusesource.fabric.dosgi.tcp.TcpTransport$5.run(TcpTransport.java:483)[67:org.fusesource.fabric.fabric-dosgi:7.0.1.fuse-084] > > at > > > org.fusesource.hawtdispatch.internal.NioDispatchSource$3.run(NioDispatchSource.java:228)[78:org.fusesource.hawtdispatch.hawtdispatch:1.9.0] > > at > > > org.fusesource.hawtdispatch.internal.SerialDispatchQueue.run(SerialDispatchQueue.java:84)[78:org.fusesource.hawtdispatch.hawtdispatch:1.9.0] > > at > > > org.fusesource.hawtdispatch.internal.pool.SimpleThread.run(SimpleThread.java:77)[78:org.fusesource.hawtdispatch.hawtdispatch:1.9.0] > > 2012-09-24 15:16:00,147 | INFO | agent-1-thread-1 | DeploymentAgent > > | 63 - org.fusesource.fabric.fabric-agent - 7.0.1.fuse-084 | Done. > > > > > > # After which the logs are filled with: > > > > 2012-09-24 15:18:14,435 | INFO | nana.local:2181) | ClientCnxn > > | 54 - org.fusesource.fabric.fabric-linkedin-zookeeper - 7.0.1.fuse-084 | > > Opening socket connection to server banana.local/10.39.216.49:2181 > > 2012-09-24 15:18:14,436 | INFO | nana.local:2181) | ZooKeeperSaslClient > > | 54 - org.fusesource.fabric.fabric-linkedin-zookeeper - 7.0.1.fuse-084 | > > Client will not SASL-authenticate because the default JAAS configuration > > section 'Client' could not be found. If you are not using SASL, you may > > ignore this. On the other hand, if you expected SASL to work, please fix > > your JAAS configuration. > > 2012-09-24 15:18:14,437 | INFO | nana.local:2181) | ClientCnxn > > | 54 - org.fusesource.fabric.fabric-linkedin-zookeeper - 7.0.1.fuse-084 | > > Socket connection established to banana.local/10.39.216.49:2181, > initiating > > session > > 2012-09-24 15:18:14,438 | INFO | nana.local:2181) | ClientCnxn > > | 54 - org.fusesource.fabric.fabric-linkedin-zookeeper - 7.0.1.fuse-084 | > > Unable to read additional data from server sessionid 0x139f880728d0005, > > likely server has closed socket, closing socket connection and attempting > > reconnect > > > > > > From what I've read the SASL messages are safe to ignore, but exception 2 > > looks related to the problem - I don't think it's a configuration issue > with > > the OSes, the SocketChannel fails to connect but all ports are open and I > > can telnet remotely to that ip on port 2181. > > > > The code I'm using can be found here > > https://dl.dropbox.com/u/2465717/net.earcam.example.hello.tgz (just a > simple > > maven project). > > > > > > I'd be very grateful if anyone has a suggestions as to the cause, an RTFM > > with link, or a pointer to a working example, etc. > > > > > > thanks, > > > > Best regards, > > Caspar > > > > > > > > > > -- > Claus Ibsen > ----------------- > Red Hat, Inc. > FuseSource is now part of Red Hat > Email: cib...@redhat.com > Web: http://fusesource.com > Twitter: davsclaus > Blog: http://davsclaus.com > Author of Camel in Action: http://www.manning.com/ibsen >