[ 
https://issues.apache.org/jira/browse/QPID-3256?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13067898#comment-13067898
 ] 

Cliff Jansen commented on QPID-3256:
------------------------------------

I wanted to see the patch run through Steve's nightly review board automated 
build and test.

It started failing precisely at the same time I did the checkin to trunk, not a 
good sign.  That plus the recent mingw build problem makes me wonder if it is a 
good idea to add it to the release at this time.  The person who reported the 
JIRA has an earlier version of the patch that works for him.

But I can't say for sure if there is a problem.  It may be differences between 
my setup and Steve's, i.e. Xp versus WS2008, or different versions of boost or 
Visual Studio, or 32 vs 64 bit.  Or the Riverace build may be failing for some 
unrelated reason.

> Application which uses Qpid (in my case Excel) hangs on shutdown
> ----------------------------------------------------------------
>
>                 Key: QPID-3256
>                 URL: https://issues.apache.org/jira/browse/QPID-3256
>             Project: Qpid
>          Issue Type: Bug
>          Components: C++ Client
>    Affects Versions: 0.8, 0.10
>         Environment: OS: Windows.
> Qpid is assembled as DLL. 
>            Reporter: Eugene
>            Assignee: Cliff Jansen
>             Fix For: 0.13
>
>         Attachments: qpid-3256-3.patch, qpid-3256.patch
>
>
> Hi All
> I encountered with strange behavior on shutdown when using qpid 0-8 and 0-10. 
> When I use qpid in standalone console-application everything is ok. But when 
> I use qpid in DLL which is loaded into Excel (as RTD module), Excel hangs on 
> shutdown. 
> I found out that in standalone application on shutdown I have next stack:
>       qpidclientd.dll!qpid::client::`anonymous 
> namespace'::IOThread::~IOThread()  Line 138    C++
>       qpidclientd.dll!`qpid::client::`anonymous 
> namespace'::theIO'::`2'::`dynamic atexit destructor for 'io''()  + 0xd bytes  
> C++
>       qpidclientd.dll!_CRT_INIT(void * hDllHandle=0x60080000, unsigned long 
> dwReason=0, void * lpreserved=0x00000001)  Line 449       C
>       qpidclientd.dll!__DllMainCRTStartup(void * hDllHandle=0x60080000, 
> unsigned long dwReason=0, void * lpreserved=0x00000001)  Line 560 + 0x11 
> bytes        C
>       qpidclientd.dll!_DllMainCRTStartup(void * hDllHandle=0x60080000, 
> unsigned long dwReason=0, void * lpreserved=0x00000001)  Line 510 + 0x11 
> bytes C
>       ntdll.dll!77b79960()    
>       [Frames below may be incorrect and/or missing, no symbols loaded for 
> ntdll.dll] 
>       ntdll.dll!77b9a516()    
>       ntdll.dll!77b9a3b8()    
>       kernel32.dll!77657363()         
>       msvcr90d.dll!__crtExitProcess(int status=0)  Line 732   C
>       msvcr90d.dll!doexit(int code=0, int quick=0, int retcaller=0)  Line 644 
> + 0x9 bytes     C
>       msvcr90d.dll!exit(int code=0)  Line 412 + 0xd bytes     C
>       Test.exe!__tmainCRTStartup()  Line 599  C
>       Test.exe!mainCRTStartup()  Line 403     C
>       kernel32.dll!77653677()         
>       ntdll.dll!77b79f02()    
>       ntdll.dll!77b79ed5()    
> And in this state all threads of application have been already terminated. 
> The only thread is:
> 1     >       21720   Main Thread     Main Thread     
> qpid::client::`anonymous namespace'::IOThread::~IOThread        Normal  0
> so code from file ConnectionImpl.cpp works well:
> ~IOThread() {
>         std::vector<Thread> threads;
>         {
>             ScopedLock<Mutex> l(threadLock);
>             if (poller_)
>                 poller_->shutdown();
>             t.swap(threads);
>         }
>         for (std::vector<Thread>::iterator i = threads.begin(); i != 
> threads.end(); ++i) {
>             i->join();
>         }
>     }
> BUT in Excel I get stack:
> qpidclientd.dll!qpid::client::`anonymous namespace'::IOThread::~IOThread()  
> Line 130  C++
>       qpidclientd.dll!`qpid::client::`anonymous 
> namespace'::theIO'::`2'::`dynamic atexit destructor for 'io''()  + 0xd bytes  
> C++
>       qpidclientd.dll!_CRT_INIT(void * hDllHandle=0x07700000, unsigned long 
> dwReason=0, void * lpreserved=0x00000000)  Line 449       C
>       qpidclientd.dll!__DllMainCRTStartup(void * hDllHandle=0x07700000, 
> unsigned long dwReason=0, void * lpreserved=0x00000000)  Line 560 + 0x11 
> bytes        C
>       qpidclientd.dll!_DllMainCRTStartup(void * hDllHandle=0x07700000, 
> unsigned long dwReason=0, void * lpreserved=0x00000000)  Line 510 + 0x11 
> bytes C
>       ntdll.dll!77b79960()    
>       [Frames below may be incorrect and/or missing, no symbols loaded for 
> ntdll.dll] 
>       ntdll.dll!77ba1525()    
>       ntdll.dll!77b81231()    
>       KernelBase.dll!77281da7()       
>       ole32.dll!75bb9562()    
>       ole32.dll!75bb9593()    
>       ole32.dll!75bb95a7()    
>       ole32.dll!75bb98bf()    
>       ole32.dll!75bb9805()    
>       ole32.dll!75bb9a8c()    
>       EXCEL.EXE!2f3811e9()    
>       EXCEL.EXE!2f6933e8()    
>       EXCEL.EXE!2f32a5af()    
>       EXCEL.EXE!2f34894a()    
>       EXCEL.EXE!2f670001()    
>       MSO.DLL!65bc6ed5()      
>       MSO.DLL!65c26a34()      
>       MSO.DLL!65c30305()      
>       MSO.DLL!65bc910c()      
>       MSO.DLL!65c4f420()      
>       MSO.DLL!65bbf161()      
>       comctl32.dll!7233463d()         
>       user32.dll!762971be()   
>       user32.dll!76297d31()   
>       user32.dll!76297dfa()   
>       EXCEL.EXE!2f324572()    
>       EXCEL.EXE!2f324534()    
>       EXCEL.EXE!2f324441()    
>       MSO.DLL!65b78116()      
>       MSO.DLL!65ba1fd0()      
>       EXCEL.EXE!2f30424b()    
>       msvcr90.dll!749936c5()  
>       msvcr90.dll!749938b3()  
>       msvcr90.dll!749938c5()  
>       msvcr90.dll!749ac40c()  
>       msvcr90.dll!749b028d()  
>       msvcr90.dll!749b04f3()  
>       EXCEL.EXE!2f303f0a()    
>       kernel32.dll!77653677()         
>       ntdll.dll!77b79f02()    
>       ntdll.dll!77b79ed5()    
> And threads:
> 0             24016   Worker Thread   _threadstartex  _threadstartex  Normal  > 0
> 0     >       22928   Main Thread     Main Thread     
> qpid::client::`anonymous namespace'::IOThread::~IOThread        Normal  0
> 0             20224   RPC Thread      RPC Callback Thread     77b5fd21        
> Normal  0
> 0             16492   Worker Thread   Win32 Thread    77b61ed6        Normal  > 0
> 0             19948   Worker Thread   Win32 Thread    77b600ed        Normal  > 0
> 0             20524   Worker Thread   Win32 Thread    77b61ed6        Normal  > 0
> 0             20532   Worker Thread   Win32 Thread    77b5f861        Normal  > 0
> 0             21500   Worker Thread   Win32 Thread    77b5f861        Normal  > 0
> 0             21848   Worker Thread   Win32 Thread    77b61ed6        Normal  > 0
> 0             22152   Worker Thread   Win32 Thread    77b5f861        Normal  > 0
> 0             22164   Worker Thread   Win32 Thread    77b5f8e9        Normal  > 0
> 0             22300   Worker Thread   Win32 Thread    77b5f861        Normal  > 0
> 0             22360   Worker Thread   Win32 Thread    77b61ed6        Normal  > 0
> 0             23316   Worker Thread   Win32 Thread    77b5f861        Normal  > 0
> 0             23556   Worker Thread   Win32 Thread    77b5f8e9        Normal  > 0
> 0             23700   Worker Thread   Win32 Thread    77b5f861        Normal  > 0
> 0             23912   Worker Thread   Win32 Thread    77b5f8e9        Normal  > 0
> 0             24276   Worker Thread   Win32 Thread    77b5f861        Normal  > 0
> 0             24308   Worker Thread   Win32 Thread    77b5f861        Normal  > 0
> 0             24424   Worker Thread   Win32 Thread    77b600ed        Normal  > 0
> 0             24452   Worker Thread   Win32 Thread    77b5f8e9        Normal  > 0
> 0             24520   Worker Thread   Win32 Thread    77b61ed6        Normal  > 0
> As result this code (below) hangs application(Excel):
> ~IOThread() {
>         std::vector<Thread> threads;
>         {
>             ScopedLock<Mutex> l(threadLock);
>             if (poller_)
>                 poller_->shutdown();
>             t.swap(threads);
>         }
>         for (std::vector<Thread>::iterator i = threads.begin(); i != 
> threads.end(); ++i) 
>         {
>             i->join();-- APPLICATION HANGS HERE !!!!
>         }
>     }
> I suppose it occurs because of qpid tries to wait of thread completing from 
> _DllMainCRTStartup which is called with PROCESS_DETACH.
> To work around it I modified function IOThread::sub():
>    void sub() {
>               std::vector<Thread> threads;
>               {
>                   ScopedLock<Mutex> l(threadLock);
>                 --connections; 
>               
>                 if (connections == 0){
>                       if (poller_){
>                               poller_->shutdown();
>                               poller_.reset();
>                               t.swap(threads);
>                       }
>                 }
>                }
>              for (std::vector<Thread>::iterator i = threads.begin(); i != 
> threads.end(); ++i) {
>                i->join();
>            }
>          }
> But I don't think it is a good solution.
> Could you help me to solve this problem?
> Thanks

--
This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira

        

---------------------------------------------------------------------
Apache Qpid - AMQP Messaging Implementation
Project:      http://qpid.apache.org
Use/Interact: mailto:[email protected]

Reply via email to