This is likely related to:

    https://issues.apache.org/jira/browse/FELIX-2913

Which was ultimately impacted by the following changes for framework 3.2.0:

    https://issues.apache.org/jira/browse/FELIX-2748

We need to think about this a little bit to see if there is an alternative (more loose way) to achieve what was implemented in FELIX-2748, because it is definitely necessary.

-> richard

On 4/18/11 17:07, Pierre De Rop wrote:
Hi everyone;

It seems that I can't stop anymore the framework from the Gogo shell, when
typing Ctrl-C ?
I'm using the following bundles, including latest web console:

g! lb
START LEVEL 1
    ID|State      |Level|Name
     0|Active     |    0|System Bundle (3.2.0)
     1|Active     |    1|Apache Felix Bundle Repository (1.6.2)
     2|Active     |    1|Apache Felix Configuration Admin Service (1.2.8)
     3|Active     |    1|Apache Felix Gogo Command (0.8.0)
     4|Active     |    1|Apache Felix Gogo Runtime (0.8.0)
     5|Active     |    1|Apache Felix Gogo Shell (0.8.0)
     6|Active     |    1|Apache Felix Http Jetty (2.2.0)
     7|Active     |    1|Apache Felix Log Service (1.0.1)
     8|Active     |    1|Apache Felix Metatype Service (1.0.4)
     9|Active     |    1|Apache Felix Shell Service (1.4.2)
    10|Active     |    1|Apache Felix Web Management Console (3.1.8)

And when I type "Ctrl-C", the shell is hanging, and does not exit.

In the following jstack dump (taken after having typed "Ctrl-C" on gogo
shell), jetty seems to be blocked while
stopping:  (see the thread "Jetty HTTP Service") ?

->

Full thread dump Java HotSpot(TM) Server VM (19.0-b09 mixed mode):

"Attach Listener" daemon prio=10 tid=0x796f7000 nid=0xb65 runnable
[0x00000000]
    java.lang.Thread.State: RUNNABLE

"FelixShutdown" prio=10 tid=0x08d97400 nid=0xb57 in Object.wait()
[0x79176000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa24455f0>  (a java.lang.Integer)
     at java.lang.Object.wait(Object.java:485)
     at
org.apache.felix.framework.StartLevelImpl.setStartLevelAndWait(StartLevelImpl.java:129)
     - locked<0xa24455f0>  (a java.lang.Integer)
     at
org.apache.felix.framework.Felix$SystemBundleActivator.stop(Felix.java:4537)
     at
org.apache.felix.framework.util.SecureAction.stopActivator(SecureAction.java:651)
     at org.apache.felix.framework.Felix.stopBundle(Felix.java:2226)
     at org.apache.felix.framework.Felix$3.run(Felix.java:876)
     at java.lang.Thread.run(Thread.java:662)

"Felix Shutdown Hook" prio=10 tid=0x7a019c00 nid=0xb56 in Object.wait()
[0x79125000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2ad2bc8>  (a org.apache.felix.framework.util.ThreadGate)
     at org.apache.felix.framework.util.ThreadGate.await(ThreadGate.java:79)
     - locked<0xa2ad2bc8>  (a org.apache.felix.framework.util.ThreadGate)
     at org.apache.felix.framework.Felix.waitForStop(Felix.java:916)
     at org.apache.felix.main.Main$1.run(Main.java:271)

"SIGINT handler" daemon prio=10 tid=0xb6afd000 nid=0xb54 in Object.wait()
[0x791c7000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2ae4190>  (a org.apache.felix.main.Main$1)
     at java.lang.Thread.join(Thread.java:1186)
     - locked<0xa2ae4190>  (a org.apache.felix.main.Main$1)
     at java.lang.Thread.join(Thread.java:1239)
     at
java.lang.ApplicationShutdownHooks.runHooks(ApplicationShutdownHooks.java:79)
     at
java.lang.ApplicationShutdownHooks$1.run(ApplicationShutdownHooks.java:24)
     at java.lang.Shutdown.runHooks(Shutdown.java:79)
     at java.lang.Shutdown.sequence(Shutdown.java:123)
     at java.lang.Shutdown.exit(Shutdown.java:168)
     - locked<0x7a6b18c8>  (a java.lang.Class for java.lang.Shutdown)
     at java.lang.Terminator$1.handle(Terminator.java:35)
     at sun.misc.Signal$1.run(Signal.java:195)
     at java.lang.Thread.run(Thread.java:662)

"Timer-0" daemon prio=10 tid=0x7a002400 nid=0xb46 in Object.wait()
[0x79218000]
    java.lang.Thread.State: TIMED_WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2326b40>  (a java.util.TaskQueue)
     at java.util.TimerThread.mainLoop(Timer.java:509)
     - locked<0xa2326b40>  (a java.util.TaskQueue)
     at java.util.TimerThread.run(Timer.java:462)

"23738549@qtp-2545159-0" prio=10 tid=0x7a003400 nid=0xb44 in Object.wait()
[0x792ba000]
    java.lang.Thread.State: TIMED_WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa21c2ca8>  (a
org.mortbay.thread.QueuedThreadPool$PoolThread)
     at
org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:626)
     - locked<0xa21c2ca8>  (a org.mortbay.thread.QueuedThreadPool$PoolThread)

"Jetty HTTP Service" daemon prio=10 tid=0x79e7c400 nid=0xb43 in
Object.wait() [0x7930b000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2ad3d90>  (a [Ljava.lang.Object;)
     at java.lang.Object.wait(Object.java:485)
     at org.apache.felix.framework.Felix.acquireBundleLock(Felix.java:4930)
     - locked<0xa2ad3d90>  (a [Ljava.lang.Object;)
     at
org.apache.felix.framework.Felix.removeServiceListener(Felix.java:2844)
     at
org.apache.felix.framework.BundleContextImpl.removeServiceListener(BundleContextImpl.java:256)
     at org.osgi.util.tracker.ServiceTracker.close(ServiceTracker.java:391)
     - locked<0xa2a47118>  (a
org.apache.felix.http.base.internal.listener.HttpSessionAttributeListenerManager)
     at
org.apache.felix.http.base.internal.HttpServiceController.unregister(HttpServiceController.java:144)
     at
org.apache.felix.http.base.internal.DispatcherServlet.destroy(DispatcherServlet.java:54)
     at
org.mortbay.jetty.servlet.ServletHolder.destroyInstance(ServletHolder.java:318)
     at
org.mortbay.jetty.servlet.ServletHolder.doStop(ServletHolder.java:289)
     at
org.mortbay.component.AbstractLifeCycle.stop(AbstractLifeCycle.java:76)
     - locked<0xa208b1d0>  (a java.lang.Object)
     at
org.mortbay.jetty.servlet.ServletHandler.doStop(ServletHandler.java:174)
     - locked<0xa206fb78>  (a org.mortbay.jetty.servlet.ServletHandler)
     at
org.mortbay.component.AbstractLifeCycle.stop(AbstractLifeCycle.java:76)
     - locked<0xa206fbe0>  (a java.lang.Object)
     at
org.mortbay.jetty.handler.HandlerWrapper.doStop(HandlerWrapper.java:142)
     at
org.mortbay.jetty.servlet.SessionHandler.doStop(SessionHandler.java:125)
     at
org.mortbay.component.AbstractLifeCycle.stop(AbstractLifeCycle.java:76)
     - locked<0xa2011050>  (a java.lang.Object)
     at
org.mortbay.jetty.handler.HandlerWrapper.doStop(HandlerWrapper.java:142)
     at
org.mortbay.jetty.handler.ContextHandler.doStop(ContextHandler.java:591)
     at
org.mortbay.component.AbstractLifeCycle.stop(AbstractLifeCycle.java:76)
     - locked<0xa2011058>  (a java.lang.Object)
     at
org.mortbay.jetty.handler.HandlerWrapper.doStop(HandlerWrapper.java:142)
     at org.mortbay.jetty.Server.doStop(Server.java:283)
     at
org.mortbay.component.AbstractLifeCycle.stop(AbstractLifeCycle.java:76)
     - locked<0xa1dae120>  (a java.lang.Object)
     at
org.apache.felix.http.jetty.internal.JettyService.stopJetty(JettyService.java:127)
     at
org.apache.felix.http.jetty.internal.JettyService.run(JettyService.java:300)
     at java.lang.Thread.run(Thread.java:662)

"Gogo shell" daemon prio=10 tid=0x79e6e800 nid=0xb42 runnable [0x7935c000]
    java.lang.Thread.State: RUNNABLE
     at java.io.FileInputStream.readBytes(Native Method)
     at java.io.FileInputStream.read(FileInputStream.java:199)
     at java.io.BufferedInputStream.fill(BufferedInputStream.java:218)
     at java.io.BufferedInputStream.read(BufferedInputStream.java:237)
     - locked<0xa2a43158>  (a java.io.BufferedInputStream)
     at
org.apache.felix.gogo.runtime.threadio.ThreadInputStream.read(ThreadInputStream.java:77)
     at org.apache.felix.gogo.shell.Console.getLine(Console.java:117)
     at org.apache.felix.gogo.shell.Console.run(Console.java:53)
     at org.apache.felix.gogo.shell.Shell.console(Shell.java:203)
     at org.apache.felix.gogo.shell.Shell.gosh(Shell.java:128)
     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
     at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
     at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
     at java.lang.reflect.Method.invoke(Method.java:597)
     at org.apache.felix.gogo.runtime.Reflective.method(Reflective.java:136)
     at
org.apache.felix.gogo.runtime.CommandProxy.execute(CommandProxy.java:82)
     at org.apache.felix.gogo.runtime.Closure.executeCmd(Closure.java:469)
     at
org.apache.felix.gogo.runtime.Closure.executeStatement(Closure.java:395)
     at org.apache.felix.gogo.runtime.Pipe.run(Pipe.java:108)
     at org.apache.felix.gogo.runtime.Closure.execute(Closure.java:183)
     at org.apache.felix.gogo.runtime.Closure.execute(Closure.java:120)
     at
org.apache.felix.gogo.runtime.CommandSessionImpl.execute(CommandSessionImpl.java:89)
     at org.apache.felix.gogo.shell.Activator.run(Activator.java:75)
     at java.lang.Thread.run(Thread.java:662)

"CM Event Dispatcher" daemon prio=10 tid=0x79e77400 nid=0xb41 in
Object.wait() [0x793ad000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2a6a310>  (a java.util.LinkedList)
     at java.lang.Object.wait(Object.java:485)
     at org.apache.felix.cm.impl.UpdateThread.run(UpdateThread.java:76)
     - locked<0xa2a6a310>  (a java.util.LinkedList)
     at java.lang.Thread.run(Thread.java:662)

"CM Configuration Updater" daemon prio=10 tid=0x79e5ac00 nid=0xb40 in
Object.wait() [0x793fe000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2a67c30>  (a java.util.LinkedList)
     at java.lang.Object.wait(Object.java:485)
     at org.apache.felix.cm.impl.UpdateThread.run(UpdateThread.java:76)
     - locked<0xa2a67c30>  (a java.util.LinkedList)
     at java.lang.Thread.run(Thread.java:662)

"FelixPackageAdmin" daemon prio=10 tid=0xb6ad0000 nid=0xb3f in Object.wait()
[0x7955c000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2a683b0>  (a
org.apache.felix.framework.PackageAdminImpl)
     at java.lang.Object.wait(Object.java:485)
     at
org.apache.felix.framework.PackageAdminImpl.run(PackageAdminImpl.java:350)
     - locked<0xa2a683b0>  (a org.apache.felix.framework.PackageAdminImpl)
     at java.lang.Thread.run(Thread.java:662)

"FelixStartLevel" daemon prio=10 tid=0x79680c00 nid=0xb3e waiting for
monitor entry [0x795ad000]
    java.lang.Thread.State: BLOCKED (on object monitor)
     at org.osgi.util.tracker.ServiceTracker.close(ServiceTracker.java:380)
     - waiting to lock<0xa2a47118>  (a
org.apache.felix.http.base.internal.listener.HttpSessionAttributeListenerManager)
     at
org.apache.felix.http.base.internal.HttpServiceController.unregister(HttpServiceController.java:144)
     at
org.apache.felix.http.base.internal.AbstractHttpActivator.doStop(AbstractHttpActivator.java:52)
     at
org.apache.felix.http.jetty.internal.JettyActivator.doStop(JettyActivator.java:39)
     at
org.apache.felix.http.base.internal.AbstractActivator.stop(AbstractActivator.java:47)
     at
org.apache.felix.framework.util.SecureAction.stopActivator(SecureAction.java:651)
     at org.apache.felix.framework.Felix.stopBundle(Felix.java:2226)
     at org.apache.felix.framework.Felix.setActiveStartLevel(Felix.java:1202)
     at
org.apache.felix.framework.StartLevelImpl.run(StartLevelImpl.java:264)
     at java.lang.Thread.run(Thread.java:662)

"FelixDispatchQueue" prio=10 tid=0x79623800 nid=0xb3d in Object.wait()
[0x795fe000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2a93b20>  (a java.util.ArrayList)
     at java.lang.Object.wait(Object.java:485)
     at
org.apache.felix.framework.util.EventDispatcher.run(EventDispatcher.java:924)
     - locked<0xa2a93b20>  (a java.util.ArrayList)
     at
org.apache.felix.framework.util.EventDispatcher.access$000(EventDispatcher.java:54)
     at
org.apache.felix.framework.util.EventDispatcher$1.run(EventDispatcher.java:106)
     at java.lang.Thread.run(Thread.java:662)

"Low Memory Detector" daemon prio=10 tid=0xb6a98c00 nid=0xb3b runnable
[0x00000000]
    java.lang.Thread.State: RUNNABLE

"CompilerThread1" daemon prio=10 tid=0xb6a97000 nid=0xb3a waiting on
condition [0x00000000]
    java.lang.Thread.State: RUNNABLE

"CompilerThread0" daemon prio=10 tid=0xb6a95000 nid=0xb39 waiting on
condition [0x00000000]
    java.lang.Thread.State: RUNNABLE

"Signal Dispatcher" daemon prio=10 tid=0xb6a93400 nid=0xb38 runnable
[0x00000000]
    java.lang.Thread.State: RUNNABLE

"Finalizer" daemon prio=10 tid=0xb6a83c00 nid=0xb37 in Object.wait()
[0x79f7d000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2a94078>  (a java.lang.ref.ReferenceQueue$Lock)
     at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:118)
     - locked<0xa2a94078>  (a java.lang.ref.ReferenceQueue$Lock)
     at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:134)
     at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:159)

"Reference Handler" daemon prio=10 tid=0xb6a82400 nid=0xb36 in Object.wait()
[0x79bb2000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2a201a0>  (a java.lang.ref.Reference$Lock)
     at java.lang.Object.wait(Object.java:485)
     at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:116)
     - locked<0xa2a201a0>  (a java.lang.ref.Reference$Lock)

"main" prio=10 tid=0xb6a04000 nid=0xb32 in Object.wait() [0xb6b69000]
    java.lang.Thread.State: WAITING (on object monitor)
     at java.lang.Object.wait(Native Method)
     - waiting on<0xa2ad2bc8>  (a org.apache.felix.framework.util.ThreadGate)
     at org.apache.felix.framework.util.ThreadGate.await(ThreadGate.java:79)
     - locked<0xa2ad2bc8>  (a org.apache.felix.framework.util.ThreadGate)
     at org.apache.felix.framework.Felix.waitForStop(Felix.java:916)
     at org.apache.felix.main.Main.main(Main.java:295)

"VM Thread" prio=10 tid=0xb6a7fc00 nid=0xb35 runnable

"GC task thread#0 (ParallelGC)" prio=10 tid=0xb6a0b400 nid=0xb33 runnable

"GC task thread#1 (ParallelGC)" prio=10 tid=0xb6a0cc00 nid=0xb34 runnable

"VM Periodic Task Thread" prio=10 tid=0xb6a9a800 nid=0xb3c waiting on
condition

JNI global references: 1409

Is there an issue here ?

thanks for your help;
/pierre

Reply via email to