- 论坛徽章:
- 1
|
本帖最后由 jd808 于 2016-01-09 10:48 编辑
- (gdb) info threads
- Id Target Id Frame
- 7 Thread 0x7f82e25eb700 (LWP 24196) "Xgateway" __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 6 Thread 0x7f82e1dea700 (LWP 24197) "Xgateway" __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 5 Thread 0x7f82e15e9700 (LWP 24198) "Xgateway" __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 4 Thread 0x7f82e0de8700 (LWP 24199) "Xgateway" __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 3 Thread 0x7f82e05e7700 (LWP 24200) "Xgateway" __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 2 Thread 0x7f82dfde6700 (LWP 24201) "Xgateway" 0x00007f82e26a948d in nanosleep () at ../sysdeps/unix/syscall-template.S:81
- * 1 Thread 0x7f82e3ea7740 (LWP 24195) "Xgateway" __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- (gdb) thread 1
- [Switching to thread 1 (Thread 0x7f82e3ea7740 (LWP 24195))]
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 135 2: movl %edx, %eax
- (gdb) bt
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- #1 0x00007f82e3a83d32 in _L_lock_791 () from /lib64/libpthread.so.0
- #2 0x00007f82e3a83c38 in __GI___pthread_mutex_lock (mutex=0x1cb04f8) at pthread_mutex_lock.c:64
- #3 0x0000000000415709 in TServer::CloseEvent (this=<optimized out>, conn=0x1cb0370, events=<optimized out>)
- at gateway/src/TServer.cpp:340
- #4 0x00007f82e36001ee in bufferevent_readcb (fd=20, event=<optimized out>, arg=0x1ca4500) at bufferevent_sock.c:196
- #5 0x00007f82e3605849 in event_persist_closure (ev=<optimized out>, base=0x1ca15c0) at event.c:1531
- #6 event_process_active_single_queue (base=base@entry=0x1ca15c0, activeq=0x1badc90, max_to_process=max_to_process@entry=2147483647,
- endtime=endtime@entry=0x0) at event.c:1590
- #7 0x00007f82e36060ff in event_process_active (base=0x1ca15c0) at event.c:1689
- #8 event_base_loop (base=0x1ca15c0, flags=0) at event.c:1912
- #9 0x0000000000414e01 in MultiServer::StartRun (this=0x1c53880) at gateway/src/MultiServer.cpp:329
- #10 0x000000000041ce52 in TControl::Run (this=this@entry=0x7fff7eaf4ab0) at gateway/src/TControl.cpp:30
- #11 0x00000000004060e0 in main (argc=1, argv=0x7fff7eaf4bc8) at gateway/src/node_gateway.cpp:64
- (gdb) thread 3
- [Switching to thread 3 (Thread 0x7f82e05e7700 (LWP 24200))]
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 135 2: movl %edx, %eax
- (gdb) bt
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- #1 0x00007f82e3a83d32 in _L_lock_791 () from /lib64/libpthread.so.0
- #2 0x00007f82e3a83c38 in __GI___pthread_mutex_lock (mutex=0x1cb04f8) at pthread_mutex_lock.c:64
- #3 0x0000000000406869 in TEngine::Base_Client_Lock (this=0x1cad670, send_conn=0x1cb0370, command=0x7f82e05e6bf0 "\031\260!",
- size=52, is_zip=1) at gateway/src/TEngine.cpp:113
- #4 0x000000000040766c in TUserEngine::send_map_xy_client (this=<optimized out>, pcon=<optimized out>, Build_conn=<optimized out>,
- command=<optimized out>, cmdlen=<optimized out>, send_count=<optimized out>) at gateway/src/TUserEngine.cpp:794
- #5 0x00000000004131ec in operator() (__args#4=0x7f82e05e6bac, __args#3=52, __args#2=0x7f82e05e6bf0 "\031\260!", __args#1=0x1cb0370,
- __args#0=<optimized out>, this=0x7f82e05e6bd0) at /usr/include/c++/4.8.2/tr1/functional:2146
- #6 BaseTEngine::CallConnList(std::tr1::function<int (Conn*, Conn*, char const*, int, void*)>, Conn*, char const*, int, void*) (
- this=this@entry=0x1cad670, f=..., ActConn=ActConn@entry=0x1cb0370, command=command@entry=0x7f82e05e6bf0 "\031\260!",
- cmdlen=cmdlen@entry=52, n=n@entry=0x7f82e05e6bac) at gateway/src/BaseTEngine.cpp:166
- #7 0x0000000000409380 in TUserEngine::_MoveXY (this=this@entry=0x1cad670, x=x@entry=211, y=y@entry=2414, pint AddToWriteBuffer(const void *buffer, int len)
- {
- // m_WriteBuf = bufferevent_get_output(m_bev);
- //printf("m_WriteBuf[%p]\n", m_WriteBuf);
- if(fd_type>0 && m_WriteBuf!=NULL) {
- int res = evbuffer_add(m_WriteBuf, buffer, len);
- // int res = bufferevent_write(m_bev, buffer, len);//这个和上面evbuffer_add是一样的
- return res;
- }
- else
- return -1;
- }arameter=1,
- hero_user_id=-1) at gateway/src/TUserEngine.cpp:643
- #8 0x00000000004093f7 in TUserEngine::moveXY (this=this@entry=0x1cad670,
- command=command@entry=0x7f82c8006104 <incomplete sequence \323>, DataLen=DataLen@entry=16) at gateway/src/TUserEngine.cpp:592
- #9 0x000000000040aa76 in TUserEngine::ExecCmd (this=this@entry=0x1cad670, command=0x7f82c8006104 <incomplete sequence \323>,
- DataLen=DataLen@entry=16) at gateway/src/TUserEngine.cpp:174
- #10 0x000000000040af82 in TUserEngine::Process (this=0x1cad670, arg=<optimized out>, pconn=<optimized out>, CMD=<optimized out>,
- CMDlen=<optimized out>) at gateway/src/TUserEngine.cpp:42
- #11 0x0000000000415fe6 in TServer::ThreadProcessD (this=<optimized out>, pcon=0x1cb0370, CMD=<optimized out>, CMDlen=43,
- arg=0x1ca1c90) at gateway/src/TServer.cpp:123
- #12 0x0000000000416279 in TServer::ThreadProcess (this=<optimized out>, arg=<optimized out>) at gateway/src/TServer.cpp:186
- #13 0x0000000000414520 in MultiServer::WorkerLibevent (arg=<optimized out>) at gateway/src/MultiServer.cpp:361
- #14 0x00007f82e3a81df5 in start_thread (arg=0x7f82e05e7700) at pthread_create.c:308
- #15 0x00007f82e26e21ad in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:113
- (gdb) thread 4
- [Switching to thread 4 (Thread 0x7f82e0de8700 (LWP 24199))]
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 135 2: movl %edx, %eax
- (gdb) bt
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- #1 0x00007f82e3a83d32 in _L_lock_791 () from /lib64/libpthread.so.0
- #2 0x00007f82e3a83c38 in __GI___pthread_mutex_lock (mutex=0x1cb04f8) at pthread_mutex_lock.c:64
- #3 0x0000000000406869 in TEngine::Base_Client_Lock (this=0x1caa750, send_conn=0x1cb0370, command=0x7f82e0de7bf0 "\031\260!",
- size=52, is_zip=1) at gateway/src/TEngine.cpp:113
- #4 0x000000000040766c in TUserEngine::send_map_xy_client (this=<optimized out>, pcon=<optimized out>, Build_conn=<optimized out>,
- command=<optimized out>, cmdlen=<optimized out>, send_count=<optimized out>) at gateway/src/TUserEngine.cpp:794
- #5 0x00000000004131ec in operator() (__args#4=0x7f82e0de7bac, __args#3=52, __args#2=0x7f82e0de7bf0 "\031\260!", __args#1=0x1cb0370,
- __args#0=<optimized out>, this=0x7f82e0de7bd0) at /usr/include/c++/4.8.2/tr1/functional:2146
- #6 BaseTEngine::CallConnList(std::tr1::function<int (Conn*, Conn*, char const*, int, void*)>, Conn*, char const*, int, void*) (
- this=this@entry=0x1caa750, f=..., ActConn=ActConn@entry=0x1cb0370, command=command@entry=0x7f82e0de7bf0 "\031\260!",
- cmdlen=cmdlen@entry=52, n=n@entry=0x7f82e0de7bac) at gateway/src/BaseTEngine.cpp:166
- #7 0x0000000000409380 in TUserEngine::_MoveXY (this=this@entry=0x1caa750, x=x@entry=336, y=y@entry=2251, parameter=1,
- hero_user_id=-1) at gateway/src/TUserEngine.cpp:643
- #8 0x00000000004093f7 in TUserEngine::moveXY (this=this@entry=0x1caa750, command=command@entry=0x7f82c0007384 "P\001",
- DataLen=DataLen@entry=16) at gateway/src/TUserEngine.cpp:592
- #9 0x000000000040aa76 in TUserEngine::ExecCmd (this=this@entry=0x1caa750, command=0x7f82c0007384 "P\001", DataLen=DataLen@entry=16)
- at gateway/src/TUserEngine.cpp:174
- #10 0x000000000040af82 in TUserEngine::Process (this=0x1caa750, arg=<optimized out>, pconn=<optimized out>, CMD=<optimized out>,
- CMDlen=<optimized out>) at gateway/src/TUserEngine.cpp:42
- #11 0x0000000000415fe6 in TServer::ThreadProcessD (this=<optimized out>, pcon=0x1cb0370, CMD=<optimized out>, CMDlen=43,
- arg=0x1ca1c40) at gateway/src/TServer.cpp:123
- #12 0x0000000000416279 in TServer::ThreadProcess (this=<optimized out>, arg=<optimized out>) at gateway/src/TServer.cpp:186
- #13 0x0000000000414520 in MultiServer::WorkerLibevent (arg=<optimized out>) at gateway/src/MultiServer.cpp:361
- #14 0x00007f82e3a81df5 in start_thread (arg=0x7f82e0de8700) at pthread_create.c:308
- #15 0x00007f82e26e21ad in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:113
- (gdb) thread 5
- [Switching to thread 5 (Thread 0x7f82e15e9700 (LWP 24198))]
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 135 2: movl %edx, %eax
- (gdb) bt
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- #1 0x00007f82e3a83d4d in _L_lock_840 () from /lib64/libpthread.so.0
- #2 0x00007f82e3a83c6a in __GI___pthread_mutex_lock (mutex=0x1ca4820) at pthread_mutex_lock.c:85
- #3 0x00007f82e3609852 in debug_lock_lock (mode=<optimized out>, lock_=0x1cb0750) at evthread.c:227
- #4 0x00007f82e35f85ac in evbuffer_add (buf=0x1ca4790, data_in=0x1cb1ac0, datlen=79) at buffer.c:1725
- #5 0x00000000004182d7 in AddToWriteBuffer (this=0x1cb0370, this=0x1cb0370, len=<optimized out>, buffer=<optimized out>)
- at gateway/src/../inc/MultiServer.h:232
- #6 socket_send (conn=conn@entry=0x1cb0370, buffer=<optimized out>, size=<optimized out>) at gateway/src/function.cpp:91
- #7 0x00000000004068b3 in TEngine::Base_Client_Lock (this=0x1ca7830, send_conn=0x1cb0370, command=0x7f82e15e8bf0 "\031\260!",
- size=<optimized out>, is_zip=1) at gateway/src/TEngine.cpp:128
- #8 0x000000000040766c in TUserEngine::send_map_xy_client (this=<optimized out>, pcon=<optimized out>, Build_conn=<optimized out>,
- command=<optimized out>, cmdlen=<optimized out>, send_count=<optimized out>) at gateway/src/TUserEngine.cpp:794
- #9 0x00000000004131ec in operator() (__args#4=0x7f82e15e8bac, __args#3=52, __args#2=0x7f82e15e8bf0 "\031\260!", __args#1=0x1cb0370,
- __args#0=<optimized out>, this=0x7f82e15e8bd0) at /usr/include/c++/4.8.2/tr1/functional:2146
- #10 BaseTEngine::CallConnList(std::tr1::function<int (Conn*, Conn*, char const*, int, void*)>, Conn*, char const*, int, void*) (
- this=this@entry=0x1ca7830, f=..., ActConn=ActConn@entry=0x1cb0370, command=command@entry=0x7f82e15e8bf0 "\031\260!",
- cmdlen=cmdlen@entry=52, n=n@entry=0x7f82e15e8bac) at gateway/src/BaseTEngine.cpp:166
- #11 0x0000000000409380 in TUserEngine::_MoveXY (this=this@entry=0x1ca7830, x=x@entry=266, y=y@entry=2315, parameter=1,
- hero_user_id=-1) at gateway/src/TUserEngine.cpp:643
- #12 0x00000000004093f7 in TUserEngine::moveXY (this=this@entry=0x1ca7830, command=command@entry=0x7f82d8003594 "\n\001",
- DataLen=DataLen@entry=16) at gateway/src/TUserEngine.cpp:592
- #13 0x000000000040aa76 in TUserEngine::ExecCmd (this=this@entry=0x1ca7830, command=0x7f82d8003594 "\n\001", DataLen=DataLen@entry=16)
- at gateway/src/TUserEngine.cpp:174
- #14 0x000000000040af82 in TUserEngine::Process (this=0x1ca7830, arg=<optimized out>, pconn=<optimized out>, CMD=<optimized out>,
- CMDlen=<optimized out>) at gateway/src/TUserEngine.cpp:42
- #15 0x0000000000415fe6 in TServer::ThreadProcessD (this=<optimized out>, pcon=0x1cb0370, CMD=<optimized out>, CMDlen=43,
- arg=0x1ca1bf0) at gateway/src/TServer.cpp:123
- #16 0x0000000000416279 in TServer::ThreadProcess (this=<optimized out>, arg=<optimized out>) at gateway/src/TServer.cpp:186
- #17 0x0000000000414520 in MultiServer::WorkerLibevent (arg=<optimized out>) at gateway/src/MultiServer.cpp:361
- #18 0x00007f82e3a81df5 in start_thread (arg=0x7f82e15e9700) at pthread_create.c:308
- ---Type <return> to continue, or q <return> to quit---
- #19 0x00007f82e26e21ad in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:113
- (gdb) thread 6
- [Switching to thread 6 (Thread 0x7f82e1dea700 (LWP 24197))]
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 135 2: movl %edx, %eax
- (gdb) bt
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- #1 0x00007f82e3a83d32 in _L_lock_791 () from /lib64/libpthread.so.0
- #2 0x00007f82e3a83c38 in __GI___pthread_mutex_lock (mutex=0x1cb04f8) at pthread_mutex_lock.c:64
- #3 0x0000000000406869 in TEngine::Base_Client_Lock (this=0x1ca4910, send_conn=0x1cb0370, command=0x7f82e1de9bf0 "\031\260!",
- size=52, is_zip=1) at gateway/src/TEngine.cpp:113
- #4 0x000000000040766c in TUserEngine::send_map_xy_client (this=<optimized out>, pcon=<optimized out>, Build_conn=<optimized out>,
- command=<optimized out>, cmdlen=<optimized out>, send_count=<optimized out>) at gateway/src/TUserEngine.cpp:794
- #5 0x00000000004131ec in operator() (__args#4=0x7f82e1de9bac, __args#3=52, __args#2=0x7f82e1de9bf0 "\031\260!", __args#1=0x1cb0370,
- __args#0=<optimized out>, this=0x7f82e1de9bd0) at /usr/include/c++/4.8.2/tr1/functional:2146
- #6 BaseTEngine::CallConnList(std::tr1::function<int (Conn*, Conn*, char const*, int, void*)>, Conn*, char const*, int, void*) (
- this=this@entry=0x1ca4910, f=..., ActConn=ActConn@entry=0x1cb0370, command=command@entry=0x7f82e1de9bf0 "\031\260!",
- cmdlen=cmdlen@entry=52, n=n@entry=0x7f82e1de9bac) at gateway/src/BaseTEngine.cpp:166
- #7 0x0000000000409380 in TUserEngine::_MoveXY (this=this@entry=0x1ca4910, x=x@entry=405, y=y@entry=2373, parameter=1,
- hero_user_id=-1) at gateway/src/TUserEngine.cpp:643
- #8 0x00000000004093f7 in TUserEngine::moveXY (this=this@entry=0x1ca4910, command=command@entry=0x7f82d0005de4 "\225\001",
- DataLen=DataLen@entry=16) at gateway/src/TUserEngine.cpp:592
- #9 0x000000000040aa76 in TUserEngine::ExecCmd (this=this@entry=0x1ca4910, command=0x7f82d0005de4 "\225\001",
- DataLen=DataLen@entry=16) at gateway/src/TUserEngine.cpp:174
- #10 0x000000000040af82 in TUserEngine::Process (this=0x1ca4910, arg=<optimized out>, pconn=<optimized out>, CMD=<optimized out>,
- CMDlen=<optimized out>) at gateway/src/TUserEngine.cpp:42
- #11 0x0000000000415fe6 in TServer::ThreadProcessD (this=<optimized out>, pcon=0x1cb0370, CMD=<optimized out>, CMDlen=43,
- arg=0x1ca1ba0) at gateway/src/TServer.cpp:123
- #12 0x0000000000416279 in TServer::ThreadProcess (this=<optimized out>, arg=<optimized out>) at gateway/src/TServer.cpp:186
- #13 0x0000000000414520 in MultiServer::WorkerLibevent (arg=<optimized out>) at gateway/src/MultiServer.cpp:361
- #14 0x00007f82e3a81df5 in start_thread (arg=0x7f82e1dea700) at pthread_create.c:308
- #15 0x00007f82e26e21ad in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:113
- (gdb) thread 7
- [Switching to thread 7 (Thread 0x7f82e25eb700 (LWP 24196))]
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- 135 2: movl %edx, %eax
- (gdb) bt
- #0 __lll_lock_wait () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135
- #1 0x00007f82e3a83d32 in _L_lock_791 () from /lib64/libpthread.so.0
- #2 0x00007f82e3a83c38 in __GI___pthread_mutex_lock (mutex=0x1cb04f8) at pthread_mutex_lock.c:64
- #3 0x00000000004158a1 in TServer::AutoCloseEvent (this=<optimized out>, conn=0x1cb0370) at gateway/src/TServer.cpp:525
- #4 0x0000000000416693 in TServer::TimeOutCb (this=this@entry=0x1c53880) at gateway/src/TServer.cpp:500
- #5 0x00000000004167a2 in TServer::TimerCb (this=0x1c53880, arg=0x1cae4f0) at gateway/src/TServer.cpp:443
- #6 0x00000000004144e1 in MultiServer::WorkerTimerEvent (arg=<optimized out>) at gateway/src/MultiServer.cpp:342
- #7 0x00007f82e3a81df5 in start_thread (arg=0x7f82e25eb700) at pthread_create.c:308
- #8 0x00007f82e26e21ad in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:113
复制代码 代码大致是
- int TEngine::Base_Client_Lock(Conn *send_conn,const char* command,int size, int is_zip)
- {
- if(send_conn==NULL)return -1;
- pthread_mutex_lock(&send_conn->UserCMDLock);
- if(send_conn==NULL)
- return -1;
- if(send_conn->is_down==1){
- pthread_mutex_unlock(&send_conn->UserCMDLock);
- return -1;
- }
- int mid=proto->MODLUE_ID<0?proto->MODLUE_ID:9999999;
- if (Client_BuildPact(mid,m_sbuff, command,size, is_zip) == -1)
- {
- pthread_mutex_unlock(&send_conn->UserCMDLock);
- return -1;
- }
- socket_send(send_conn, m_sbuff->buff,m_sbuff->data_size);
- pthread_mutex_unlock(&send_conn->UserCMDLock);
- return 0;
- }
- int socket_send(Conn *conn,const char *buffer, int size)
- {
- // pthread_t pid = pthread_self();
- // printf("%p|%ld,添加到发送缓冲区1\n", conn, pid);
- //pthread_mutex_lock(&conn->GetThread()->send_mutex); //ok
- //pthread_mutex_lock(&conn->send_mutex);
- //printf("%p|%ld,添加到发送缓冲区2\n", conn, pid);
- if (conn != NULL)
- conn->AddToWriteBuffer((void *)buffer, size);
- // printf("%p|%ld,添加成功并返回1\n", conn, pid);
- //pthread_mutex_unlock(&conn->send_mutex);
- //pthread_mutex_unlock(&conn->GetThread()->send_mutex);
- //printf("%p|%ld,添加成功并返回2\n", conn, pid);
-
- return 0;
- }
- int AddToWriteBuffer(const void *buffer, int len)
- {
- // m_WriteBuf = bufferevent_get_output(m_bev);
- //printf("m_WriteBuf[%p]\n", m_WriteBuf);
- if(fd_type>0 && m_WriteBuf!=NULL) {
- int res = evbuffer_add(m_WriteBuf, buffer, len);
- // int res = bufferevent_write(m_bev, buffer, len);//这个和上面evbuffer_add是一样的
- return res;
- }
- else
- return -1;
- }
复制代码 用的是libevent框架,evbuffer_add里面libevent本身有个锁,他锁住不放,会导致上一层的pthread_mutex_unlock(&send_conn->UserCMDLock);不会释放,导致其他线程卡在pthread_mutex_lock(&send_conn->UserCMDLock);锁这里,但问题是,从日志中无法确定evbuffer_add里面的锁为什么不释放,因为他不会导致交叉锁呀,锁都在这个函数里封装好的,而外面想调用evbuffer_add,必须经过pthread_mutex_lock(&send_conn->UserCMDLock);锁,怎么破????? |
|