日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

用GDB排查Python程序故障

發布時間:2023/12/20 python 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 用GDB排查Python程序故障 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

?

某Team在用Python開發一些代碼,涉及子進程以及設法消除僵尸進程的需求。實踐中他們碰上Python程序非預期退出的現象。最初他們決定用GDB調試Python解釋器,查看exit()的源頭。我聽了之后,覺得這個問題應該用別的調試思路。幫他們排查這次程序故障時,除去原始問題,還衍生了其他問題。

?

這次的問題相比西安研發中心曾經碰上的Python信號處理問題,有不少基礎知識、先驗知識是共用的,此處不做再普及,感興趣的同學可以翻看我以前發過的文章。

下文是一次具體的調試、分析記錄。為了簡化現場、方便調試,已將原始問題、衍生問題濃縮成DebugPythonWithGDB_6.py、DebugPythonWithGDB_7.py。

$ vi DebugPythonWithGDB_6.py

?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 #!/usr/bin/env python # -*- encoding: utf-8 -*- import?sys,os,signal,subprocess,shlex,traceback def?on_SIGCHLD(signum,frame): ? ?print"[on_SIGCHLD" ? ?sys.stdout.write("signum ?= %u\n"%signum) ? ?traceback.print_stack(frame) ? ?print?os.waitpid(-1,os.WNOHANG) ? ?""" ? ?try : ? ? ? ?print os.waitpid( -1, os.WNOHANG ) ? ?except OSError : ? ? ? ?sys.stdout.write( 'Line[%u]: OSError\n' % sys.exc_info()[2].tb_lineno ) ? ?""" ? ?print"on_SIGCHLD]" def?do_more(count): ? ?print'[do_more() begin %u]'%count ? ?os.system(r'printf "Child ? = %u\n" $$;/bin/sleep 1') ? ?""" ? ?# ? ?# 這里存在競爭條件,可以增加觸發OSError異常的概率 ? ?# ? ?os.system( r'printf "Child???=%u\n" $$;/bin/sleep 1' ) ? ?os.system( r'printf "Child???=%u\n" $$;/bin/sleep 1' ) ? ?os.system( r'printf "Child???=%u\n" $$;/bin/sleep 1' ) ? ?os.system( r'printf "Child???=%u\n" $$;/bin/sleep 1' ) ? ?""" ? ?print'[do_more() end %u]'%count def?main(prog,args): ? ?if0==len(args): ? ? ? ?print'Usage: %s '%prog ? ?else: ? ? ? ?sys.stdout.write("Parent ?= %u\n"%os.getpid()) ? ? ? ?# ? ? ? ?# 本例中,即使有下列代碼,Ctrl-C仍然無效。 ? ? ? ?# ? ? ? ?signal.signal(signal.SIGINT,signal.SIG_DFL) ? ? ? ?# ? ? ? ?# signal.signal( signal.SIGCHLD, signal.SIG_IGN ) ? ? ? ?# ? ? ? ?signal.signal(signal.SIGCHLD,on_SIGCHLD) ? ? ? ?# ? ? ? ?count???=0 ? ? ? ?whileTrue: ? ? ? ? ? ?# ? ? ? ? ? ?# 本例中父進程只是一個調度框架,不需要與子進程進行通信,因此不 ? ? ? ? ? ?# 需要特別處理"stdin=None, stdout=None, stderr=None"。 ? ? ? ? ? ?# ? ? ? ? ? ?child???=subprocess.Popen??\ ? ? ? ? ? ?( ? ? ? ? ? ? ? ?# ? ? ? ? ? ? ? ?# 不要直接用args[0].split(),它在處理單、雙引號時不是我們 ? ? ? ? ? ? ? ?# 期望的行為。考慮這種例子,ls -l "/tmp/non exist" ? ? ? ? ? ? ? ?# ? ? ? ? ? ? ? ?shlex.split(args[0]), ? ? ? ? ? ? ? ?# ? ? ? ? ? ? ? ?# all file descriptors except 0, 1 and 2 will be closed ? ? ? ? ? ? ? ?# before the child process is executed ? ? ? ? ? ? ? ?# ? ? ? ? ? ? ? ?close_fds???=True, ? ? ? ? ? ? ? ?cwd?? ? ? ??="/tmp" ? ? ? ? ? ?) ? ? ? ? ? ?sys.stdout.write("Child ? = %u\n"%child.pid) ? ? ? ? ? ?# ? ? ? ? ? ?# child.send_signal( signal.SIGTERM ) ? ? ? ? ? ?# child.terminate() ? ? ? ? ? ?# ? ? ? ? ? ?child.kill() ? ? ? ? ? ?# ? ? ? ? ? ?# child.wait() ? ? ? ? ? ?# ? ? ? ? ? ?do_more(count) ? ? ? ? ? ?count??+=1 if'__main__'==__name__: ? ?try: ? ? ? ?main(os.path.basename(sys.argv[0]),sys.argv[1:]) ? ?except?KeyboardInterrupt: ? ? ? ?pass

?

?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 $python?DebugPythonWithGDB_6.py'python -c "import time;time.sleep(3600)"' Parent??=10244 Child???=10245 [do_more()begin0] [on_SIGCHLD signum??=17 ?File"DebugPythonWithGDB_6.py",line81,in ? ?main(os.path.basename(sys.argv[0]),sys.argv[1:]) ?File"DebugPythonWithGDB_6.py",line76,inmain ? ?do_more(count) ?File"DebugPythonWithGDB_6.py",line20,indo_more ? ?print'[do_more() begin %u]'%count (10245,9) on_SIGCHLD] Child???=10246 [on_SIGCHLD signum??=17 ?File"DebugPythonWithGDB_6.py",line81,in ? ?main(os.path.basename(sys.argv[0]),sys.argv[1:]) ?File"DebugPythonWithGDB_6.py",line76,inmain ? ?do_more(count) ?File"DebugPythonWithGDB_6.py",line21,indo_more ? ?os.system(r'printf "Child ? = %u\n" $$;/bin/sleep 1') Traceback(most?recent?call?last): ?File"DebugPythonWithGDB_6.py",line81,in ? ?main(os.path.basename(sys.argv[0]),sys.argv[1:]) ?File"DebugPythonWithGDB_6.py",line76,inmain ? ?do_more(count) ?File"DebugPythonWithGDB_6.py",line21,indo_more ? ?os.system(r'printf "Child ? = %u\n" $$;/bin/sleep 1') ?File"DebugPythonWithGDB_6.py",line10,inon_SIGCHLD ? ?print?os.waitpid(-1,os.WNOHANG) OSError:[Errno10]No?childprocesses

?

流程進入on_SIGCHLD(),但os.waitpid()拋出OSError異常。幫助里寫的是,如果系統調用waitpid()返回-1,就拋出異常: An OSError is raised with the value of errno when the syscall returns -1. 10245號子進程在on_SIGCHLD()里waitpid()成功,(10245, 9)中的9表示該進程是被SIGKILL干掉的,符合預期。 10246號子進程是do_more()里的os.system()產生的shell進程,它結束時向10244號父進程投遞了SIGCHLD信號。on_SIGCHLD()里waitpid()時,已經在別處wait*()過,10246號子進程已經徹底消失,系統調用waitpid()返回-1,Python函數os.waitpid()拋出異常。 整個過程非常復雜,用偽代碼描述如下:

?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 do_more() ? ?os.system() ? ? ? ?posix_system()?? ? ? ? ?// posixmodule.c ? ? ? ? ? ?__libc_system()?? ??// weak_alias (__libc_system, system) ? ? ? ? ? ? ? ?do_system()?? ??// sysdeps/posix/system.c ? ? ? ? ? ? ? ? ? ?/* ? ? ? ? ? ? ? ? ? ? * SIG_IGN ? ? ? ? ? ? ? ? ? ? * ? ? ? ? ? ? ? ? ? ? * Ctrl-C暫時失效 ? ? ? ? ? ? ? ? ? ? */ ? ? ? ? ? ? ? ? ? ?sigaction(SIGINT,&sa,&intr) ? ? ? ? ? ? ? ? ? ?/* ? ? ? ? ? ? ? ? ? ? * 屏蔽(阻塞)SIGCHLD信號 ? ? ? ? ? ? ? ? ? ? */ ? ? ? ? ? ? ? ? ? ?sigaddset(&sa.sa_mask,SIGCHLD) ? ? ? ? ? ? ? ? ? ?sigprocmask(SIG_BLOCK,&sa.sa_mask,&omask) ? ? ? ? ? ? ? ? ? ?fork() ? ? ? ? ? ? ? ? ? ? ? ?子進程(10246號子進程) ? ? ? ? ? ? ? ? ? ? ? ? ? ?/* ? ? ? ? ? ? ? ? ? ? ? ? ? ? * 恢復原有SIGINT信號處理方式 ? ? ? ? ? ? ? ? ? ? ? ? ? ? */ ? ? ? ? ? ? ? ? ? ? ? ? ? ?sigaction(SIGINT,&intr,(structsigaction *)NULL) ? ? ? ? ? ? ? ? ? ? ? ? ? ?/* ? ? ? ? ? ? ? ? ? ? ? ? ? ? * 調用"sh -c ..." ? ? ? ? ? ? ? ? ? ? ? ? ? ? */ ? ? ? ? ? ? ? ? ? ? ? ? ? ?execve() ? ? ? ? ? ? ? ? ? ? ? ? ? ?[shell子進程結束,向DebugPythonWithGDB_6.py投遞SIGCHLD] ? ? ? ? ? ? ? ? ? ? ? ? ? ?[由于SIGCHLD信號已被屏蔽(阻塞),其保持在內核態的未決信號鏈上] ? ? ? ? ? ? ? ? ? ? ? ?父進程(10244號父進程) ? ? ? ? ? ? ? ? ? ? ? ? ? ?/* ? ? ? ? ? ? ? ? ? ? ? ? ? ? * 同步調用,會阻塞。不是在信號句柄中異步調用。 ? ? ? ? ? ? ? ? ? ? ? ? ? ? * ? ? ? ? ? ? ? ? ? ? ? ? ? ? * 10246號子進程在此被wait*()回收后徹底消失 ? ? ? ? ? ? ? ? ? ? ? ? ? ? */ ? ? ? ? ? ? ? ? ? ? ? ? ? ?waitpid(pid,&status,0) ? ? ? ? ? ? ? ? ? ? ? ? ? ?/* ? ? ? ? ? ? ? ? ? ? ? ? ? ? * 恢復原有SIGINT信號處理方式 ? ? ? ? ? ? ? ? ? ? ? ? ? ? */ ? ? ? ? ? ? ? ? ? ? ? ? ? ?sigaction(SIGINT,&intr,(structsigaction *)NULL) ? ? ? ? ? ? ? ? ? ? ? ? ? ?/* ? ? ? ? ? ? ? ? ? ? ? ? ? ? * 取消對SIGCHLD的屏蔽(阻塞) ? ? ? ? ? ? ? ? ? ? ? ? ? ? */ ? ? ? ? ? ? ? ? ? ? ? ? ? ?sigprocmask(SIG_SETMASK,&omask,(sigset_t *)NULL) ? ? ? ? ? ? ? ? ? ? ? ? ? ?[SIGCHLD信號的屏蔽(阻塞)被取消] ? ? ? ? ? ? ? ? ? ? ? ? ? ?[DebugPythonWithGDB_6.py的C級信號句柄signal_handler()安排"延遲調用"后返回] ? ? ? ? ? ? ? ? ? ? ? ? ? ?[DebugPythonWithGDB_6.py的on_SIGCHLD()此時并未得到執行,因為built-in函數os.system()尚未返回] /* * built-in函數os.system()返回后,10244號父進程開始處理"延遲調用",調用 * Python級信號句柄。這個SIGCHLD信號是10246號子進程投遞過來的。 * * DebugPythonWithGDB_6.py的on_SIGCHLD()得到執行 */ on_SIGCHLD() ? ?/* ? ? * 調用waitpid( -1, &status, WNOHANG ),試圖處理10246號子進程。 ? ? * ? ? * 10246號子進程已為前述waitpid( pid, &status, 0 )所處理,此處系統調用 ? ? * 返回-1,導致os.waitpid()拋出OSError異常。 ? ? */ ? ?os.waitpid(-1,os.WNOHANG)

?

整個過程之所以如此復雜,主要是因為Python的信號處理機制比較復雜,讓已經非常復雜的Linux信號機制再添變數。參看:

?

1 2 2.50Python解釋器進行調試》22.0Linux信號機制》

?

就本例而言,為了確保DebugPythonWithGDB_6.py不因OSError異常而終止,只需在on_SIGCHLD()中調用os.waitpid()時捕捉OSError異常:

?

1 2 3 4 5 def?on_SIGCHLD(signum,frame): ? ?try: ? ? ? ?print?os.waitpid(-1,os.WNOHANG) ? ?except?OSError: ? ? ? ?sys.stdout.write('Line[%u]: OSError\n'%sys.exc_info()[2].tb_lineno)

?

前述觀點有些是動態調試得到,有些是靜態分析得到。有人可能問了,為什么不攔截Python進程的C級信號句柄,查看SIGCHLD信號源,以此確認10246號子進程可能被回收兩次?其實我最初也想這么干來著,但這是行不通的,因為Python的C級信號句柄signal_handler()是那種最原始的單形參信號句柄,不是高大上的三形參信號句柄。 用GDB調試Python解釋器:

?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 # gdb -q -ex "b *signal_handler" -ex r --args /usr/bin/python2.7-dbg DebugPythonWithGDB_6.py '/usr/bin/python2.7-dbg -c "import time;time.sleep(3600)"' ... Breakpoint1at0x8216f2d:file../Modules/signalmodule.c,line185. Starting?program:/usr/bin/python2.7-dbg?DebugPythonWithGDB_6.py/usr/bin/python2.7-dbg\-c\\"import\time\;time.sleep\(3600\)\" [Thread?debugging?using?libthread_db?enabled] Using?host?libthread_db?library"/lib/i386-linux-gnu/i686/cmov/libthread_db.so.1". Parent??=10284 Child???=10288 [do_more()begin0] Child???=10289 Breakpoint1,signal_handler(sig_num=17)at../Modules/signalmodule.c:185 185?? ??{ (gdb)py-bt #10 Frame 0xb7c20034, for file DebugPythonWithGDB_6.py, line 21, in do_more (count=0) ? ?os.system(r'printf "Child ? = %u\n" $$;/bin/sleep 1') #13 Frame 0xb7cb37dc, for file DebugPythonWithGDB_6.py, line 76, in main (prog='DebugPythonWithGDB_6.py', args=['/usr/bin/python2.7-dbg -c "import time;time.sleep(3600)"'], count=0, child=) ? ?do_more(count) #16 Frame 0xb7cbe49c, for file DebugPythonWithGDB_6.py, line 81, in ?() ? ?main(os.path.basename(sys.argv[0]),sys.argv[1:]) (gdb)bt7 #0 ?signal_handler (sig_num=17) at ../Modules/signalmodule.c:185 #1 ? #2 ?0xb7fdcd3c in __kernel_vsyscall () #3 ?0xb7db25eb in __sigprocmask (how=how@entry=2, set=0x0, set@entry=0xbffff0d4, oset=oset@entry=0x0) at ../sysdeps/unix/sysv/linux/sigprocmask.c:57 #4 ?0xb7dc2084 in do_system (line=line@entry=0xb7cbf9e4 "printf \"Child ? = %u\\n\" $$;/bin/sleep 1") at ../sysdeps/posix/system.c:161 #5 ?0xb7dc2380 in __libc_system (line=line@entry=0xb7cbf9e4 "printf \"Child ? = %u\\n\" $$;/bin/sleep 1") at ../sysdeps/posix/system.c:184 #6 ?0xb7fa9bfb in system (line=0xb7cbf9e4 "printf \"Child ? = %u\\n\" $$;/bin/sleep 1") at pt-system.c:28 (More?stack?frames?follow...)

?

查看#4的system.c:161,這個位置已經在waitpid( pid, &status, 0 )之后: sigprocmask( SIG_SETMASK, &omask, (sigset_t *)NULL ) 其作用是取消對SIGCHLD的屏蔽(阻塞)。 此時內存布局如下:

?

1 2 3 4 5 6 7 8 9 10 11 12 內存高址方向 fpstate?? ? ? ??// ESP+0x2DC output/x *(struct _fpstate *)($esp+0x2dc) retcode?? ? ? ??// ESP+0x2D4 x/3i $esp+0x2d4 extramask?? ? ??// ESP+0x2D0 x/1wx $esp+0x2d0 fpstate_unused??// ESP+0x60 output/x *(struct _fpstate *)($esp+0x60) sigcontext_ia32// ESP+8 output/x *(struct sigcontext *)($esp+8) sig?? ? ? ? ? ??// ESP+4 信號值,信號句柄第一形參 pretcode?? ? ? ?// ESP RetAddr=__kernel_sigreturn ? ? ? ? ? ? ? ?// hexdump $esp 0x2dc 內存低址方向

?

?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 (gdb)x/2wa$esp 0xbfffea6c:?? ??0xb7fdcd18??0x11 (gdb)x/3i$esp+0x2d4 ??0xbfffed40:??pop ? ?eax ??0xbfffed41:??mov ? ?eax,0x77 ??0xbfffed46:??int?? ?0x80 (gdb)output/x *(structsigcontext *)($esp+8) { ?gs=0x33, ?__gsh=0x0, ?fs=0x0, ?__fsh=0x0, ?es=0x7b, ?__esh=0x0, ?ds=0x7b, ?__dsh=0x0, ?edi=0xb7f2a000, ?esi=0x8, ?ebp=0x1, ?esp=0xbfffeff0, ?ebx=0x2, ?edx=0x0, ?ecx=0xbffff0d4, ?eax=0x0, ?trapno=0x1, ?err=0x0, ?eip=0xb7fdcd3c, ?cs=0x73, ?__csh=0x0, ?eflags=0x246, ?esp_at_signal=0xbfffeff0, ?ss=0x7b, ?__ssh=0x0, ?fpstate=0xbfffed50, ?oldmask=0x0, ?cr2=0x0 }

?

因為是單形參信號句柄,沒有siginfo,無法在用戶態獲知信號源。但我分析此時的信號源不是10289號子進程,而是10288號子進程。10288產生SIGCHLD時,SIGCHLD信號已被屏蔽(阻塞),只能保持在內核態的未決信號鏈上。之后待10289產生SIGCHLD時,sigpending.signal中相應位已經置位,10289產生的SIGCHLD被丟棄,不會進入內核態的未決信號鏈。SIGCHLD信號的屏蔽(阻塞)被取消后,從內核態的未決信號鏈上取出10288產生的SIGCHLD進行處理。于是斷點命中。 如果完全理解了前述實驗結果及分析,就會發現DebugPythonWithGDB_6.py存在競爭條件。subprocess.Popen()對應的子進程投遞SIGCHLD信號時,父進程有兩種可能:

?

1 2 1)os.system()調用sigprocmask(SIG_BLOCK,&sa.sa_mask,&omask)之前 2)os.system()調用sigprocmask(SIG_BLOCK,&sa.sa_mask,&omask)之后

?

情況1)會觸發OSError異常,情況2)不會觸發OSError異常。執行: $ python DebugPythonWithGDB_6.py ‘python -c “import time;time.sleep(3600)”‘ 有時會因OSError異常而終止,有時就一直循環執行下去。出現這種差異,正是競爭環境的表征。 小結一下: 假設針對SIGCHLD安裝了Python級信號句柄,其調用os.waitpid( -1, os.WNOHANG )回收子進程。如果別處會調用os.system(),則必須在os.waitpid()外側捕捉OSError異常。不建議這種方式的混用。 對waitpid()的分析到此就結束了,說點調試過程中出現的其他問題。 意外地發現Ctrl-C無法終止情況2),而我已經調用: signal.signal( signal.SIGINT, signal.SIG_DFL ) 這是因為do_system()中一上來就調用了:

?

1 2 sa.sa_handler???=SIG_IGN; sigaction(SIGINT,&sa,&intr);

?

導致Ctrl-C暫時失效,直至do_system()結束。假設DebugPythonWithGDB_6.py已經出 現情況2),查看它的信號處理方式:

?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 # ps auwx | grep python root?? ??10355??0.0??0.5???8116??5812pts/0?? ?S+???15:57???0:00pythonDebugPythonWithGDB_6.py?python-c"import time;time.sleep(3600)" root?? ??10389??0.0??0.0?? ? ?0?? ??0pts/0?? ?Z+???15:57???0:00[python] root?? ??10393??0.0??0.0???2936???852pts/1?? ?R+???15:57???0:00grep?python # stap -DMAXACTION=10000 -g /usr/share/doc/systemtap-doc/examples/process/psig.stp -x 10355 10355:???python HUP ? ? ?default INT?? ? ?ignored?? ?// 不是預期的default QUIT ? ??ignored ILL ? ? ?default TRAP ? ??default ABRT ? ??default BUS ? ? ?default FPE ? ? ?default KILL ? ??default USR1 ? ??default SEGV ? ??default USR2 ? ??default PIPE ? ??ignored ALRM ? ??default TERM ? ??default STKFLT ??default CHLD ? ??blocked,caught0x818a480??0 ...

?

上面顯示SIGINT的處理方式是ignored,其實是ignored、default交叉出現,但我們 基本上不可能看到default。 $ vi DebugPythonWithGDB_7.py

?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 #!/usr/bin/env python # -*- encoding: utf-8 -*- import?sys,os,subprocess,shlex,traceback def?do_more(count): ? ?print'[do_more() begin %u]'%count ? ?os.system(r'printf "Child ? = %u\n" $$;/bin/sleep 1') ? ?print'[do_more() end %u]'%count def?main(prog,args): ? ?if0==len(args): ? ? ? ?print'Usage: %s '%prog ? ?else: ? ? ? ?sys.stdout.write("Parent ?= %u\n"%os.getpid()) ? ? ? ?count???=0 ? ? ? ?whileTrue: ? ? ? ? ? ?child???=subprocess.Popen??\ ? ? ? ? ? ?( ? ? ? ? ? ? ? ?shlex.split(args[0]), ? ? ? ? ? ? ? ?close_fds???=True, ? ? ? ? ? ? ? ?cwd?? ? ? ??="/tmp" ? ? ? ? ? ?) ? ? ? ? ? ?sys.stdout.write("Child ? = %u\n"%child.pid) ? ? ? ? ? ?child.kill() ? ? ? ? ? ?do_more(count) ? ? ? ? ? ?count??+=1 if'__main__'==__name__: ? ?try: ? ? ? ?main(os.path.basename(sys.argv[0]),sys.argv[1:]) ? ?except?KeyboardInterrupt: ? ? ? ?pass

?

$ python DebugPythonWithGDB_7.py ‘python -c “import time;time.sleep(3600)”‘ DebugPythonWithGDB_7.py沒有顯式調用wait(),它一直循環執行下去。我以為subprocess.Popen()會生成一堆僵尸進程。從另一個終端查看相關進程,發現始終只有一個僵尸進程,很快就被回收了。這個現象挺奇特,只能假設有隱式wait()存在。

?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 # gdb -q -ex "b *waitpid" -ex r --args /usr/bin/python2.7-dbg DebugPythonWithGDB_7.py '/usr/bin/python2.7-dbg -c "import time;time.sleep(3600)"' ... Parent??=14508 Child???=14512 [do_more()begin0] Child???=14513 [do_more()end0] Breakpoint1,waitpid()at../sysdeps/unix/syscall-template.S:81 81?? ? ?T_PSEUDO(SYSCALL_SYMBOL,SYSCALL_NAME,SYSCALL_NARGS) (gdb)py-bt #4 Frame 0xb7c21034, for file /usr/lib/python2.7/subprocess.py, line 1363, in _internal_poll (self=, _deadstate=2147483647, _waitpid=, _WNOHANG=1, _os_error=, _ECHILD=10) ? ?pid,sts=_waitpid(self.pid,_WNOHANG) #8 Frame 0xb7c6549c, for file /usr/lib/python2.7/subprocess.py, line 762, in __del__ (self=, _maxint=2147483647) ? ?self._internal_poll(_deadstate=_maxint) #18 Frame 0xb7cb37dc, for file DebugPythonWithGDB_7.py, line 22, in main (prog='DebugPythonWithGDB_7.py', args=['/usr/bin/python2.7-dbg -c "import time;time.sleep(3600)"'], count=1, child=) ? ?cwd?? ? ? ??="/tmp" #21 Frame 0xb7cbe49c, for file DebugPythonWithGDB_7.py, line 31, in ?() ? ?main(os.path.basename(sys.argv[0]),sys.argv[1:]) (gdb)bt9 #0 ?waitpid () at ../sysdeps/unix/syscall-template.S:81 #1 ?0x081f80a3 in posix_waitpid (self=0x0, args=(14512, 1)) at ../Modules/posixmodule.c:6207 #2 ?0x080bc300 in PyCFunction_Call (func=, arg=(14512, 1), kw=0x0) at ../Objects/methodobject.c:81 #3 ?0x08149d0b in call_function (pp_stack=0xbfffebd4, oparg=2) at ../Python/ceval.c:4033 #4 ?0x081454ec in PyEval_EvalFrameEx (f=Frame 0xb7c21034, for file /usr/lib/python2.7/subprocess.py, line 1363, in _internal_poll (self=, _deadstate=2147483647, _waitpid=, _WNOHANG=1, _os_error=, _ECHILD=10), throwflag=0) at ../Python/ceval.c:2679 #5 ?0x08147a77 in PyEval_EvalCodeEx (co=0xb7c60448, globals={'STDOUT': -2, '_has_poll': True, 'gc': , 'check_call': , 'mswindows': False, 'select': , 'list2cmdline': , '__all__': ['Popen', 'PIPE', 'STDOUT', 'call', 'check_call', 'check_output', 'CalledProcessError'], 'errno': , '_demo_posix': , '__package__': None, 'PIPE': -1, '_cleanup': , '_eintr_retry_call': , 'call': , '__doc__': 'subprocess - Subprocesses with accessible I/O streams\n\nThis module allows you to spawn processes, connect to their\ninput/output/error pipes, and obtain their return codes. ?This module\nintends to replace several older modules and functions:\n\nos.system\nos.spawn*\nos.popen*\npopen2.*\ncommands.*\n\nInformation about how the subprocess module can be used to replace these\nmodules and functions can be found below.\n\...(truncated), locals=0x0, args=0xb7c655e4, argcount=1, kws=0xb7c655e8, kwcount=1, defs=0xb7c73a20, defcount=5, closure=0x0) at ../Python/ceval.c:3265 #6 ?0x0814a1e5 in fast_function (func=, pp_stack=0xbfffeef4, n=3, na=1, nk=1) at ../Python/ceval.c:4129 #7 ?0x08149e93 in call_function (pp_stack=0xbfffeef4, oparg=256) at ../Python/ceval.c:4054 #8 ?0x081454ec in PyEval_EvalFrameEx (f=Frame 0xb7c6549c, for file /usr/lib/python2.7/subprocess.py, line 762, in __del__ (self=, _maxint=2147483647), throwflag=0) at ../Python/ceval.c:2679 (More?stack?frames?follow...)

?

調用棧回溯表明:

查看: /usr/lib/python2.7/subprocess.py:1363

?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 try: ? ?_waitpid(self.pid,_WNOHANG) ? ?... except?_os_error?ase: ? ?... ? ?ife.errno==_ECHILD: ? ? ? ?# ? ? ? ?# This happens if SIGCLD is set to be ignored or waiting for child ? ? ? ?# processes has otherwise been disabled for our process. This ? ? ? ?# child is dead, we can't get the status. ? ? ? ?# ? ? ? ?# http://bugs.python.org/issue15756 ? ? ? ?# ? ? ? ?...

?

考慮這種情形,調用subprocess.Popen()之前做過如下動作之一:

?

1 2 signal.signal(signal.SIGCHLD,signal.SIG_IGN) signal.signal(signal.SIGCHLD,on_SIGCHLD)

?

_internal_poll()調用_waitpid()時,在外側捕捉了_os_error異常,就是對付上述可能。subprocess.Popen()不是built-in函數,對應很多條PVM指令,不像os.system()是built-in函數,對應單條PVM指令。前者執行過程中,Python級信號句柄on_SIGCHLD()有很大機會得到執行,_internal_poll()調用_waitpid(),遭遇_os_error異常的可能性不低。 Popen()對象的析構函數自動調用wait*(),于是Popen()對象離開作用域時自動回收子進程。 Python能夠改變變量作用域的是def、class、lamda、global。下面這些并不涉及作用域變更:

?

1 2 3 if/elif/else try/except/finally for/while

?

DebugPythonWithGDB_7.py中Popen()對象的作用域是main()。盡管沒有離開作用域,但對child變量的重新賦值會觸發對前一個Popen()對象的析構。這就解釋了為什么始終只有一個僵尸進程。 回顧原始問題與衍生問題,再次表明,掌握對Python解釋器的調試技術可以快速排查眾多看似神秘實則基礎的程序故障。

轉載于:https://www.cnblogs.com/zengkefu/p/5647388.html

總結

以上是生活随笔為你收集整理的用GDB排查Python程序故障的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

九草视频在线观看 | 久久久久久伊人 | 亚洲精品视频在线观看免费 | 久久精品91久久久久久再现 | 日韩有码中文字幕在线 | 亚洲乱码一区 | 91福利视频一区 | 97超碰人人澡 | 久久夜色电影 | 夜夜躁日日躁狠狠躁 | 最新av观看| 国产精品亚州 | 天天玩天天操天天射 | 久久公开视频 | 精品av网站| 亚洲经典视频 | 亚洲欧美综合精品久久成人 | www夜夜操| 最新一区二区三区 | 婷婷色中文 | 天天精品视频 | 亚洲最大色 | 亚洲一二区精品 | 色综合天天综合 | 久久试看| 久久不射网站 | 狠狠狠色丁香综合久久天下网 | 毛片网免费 | 久久免费a | 中文字幕在线播放一区 | 蜜臀久久99精品久久久无需会员 | 在线视频国产区 | 亚洲精品久久久久久久不卡四虎 | 成人午夜电影免费在线观看 | 中文字幕一区二区三区四区久久 | 2022中文字幕在线观看 | 中文字幕资源在线 | 国产免费成人av | 成人国产综合 | 中文字幕亚洲精品在线观看 | 91新人在线观看 | 精品国产伦一区二区三区免费 | 精品国产视频在线观看 | 色综合亚洲精品激情狠狠 | 国产伦精品一区二区三区在线 | 国产精品久久久久久久久久久久午 | 久久夜色精品国产欧美乱 | 五月天婷亚洲天综合网鲁鲁鲁 | 看毛片网站 | 97高清视频| 二区三区在线视频 | 日韩理论片中文字幕 | 成人黄色中文字幕 | 免费观看的黄色片 | 人成午夜视频 | 亚洲精品中文字幕视频 | 国产精品igao视频网入口 | 亚洲国产资源 | 亚洲激情综合网 | 丰满少妇在线观看资源站 | 国产亚洲精品免费 | 久久激情婷婷 | 色婷婷综合久久久久 | 国产丝袜 | 日日夜夜操av | 亚洲天堂网在线播放 | 一级一片免费视频 | 狠狠狠干狠狠 | 日韩二区三区在线观看 | 亚洲午夜精品在线观看 | 国内外成人在线 | 91九色综合| 国产色视频123区 | 色狠狠综合天天综合综合 | 欧美性做爰猛烈叫床潮 | 日韩欧美国产激情在线播放 | 日韩免费一区二区三区 | 98超碰人人 | 玖玖视频网 | avove黑丝| 精品亚洲免a | 欧洲精品久久久久毛片完整版 | 欧美激情精品久久久久久 | 国产一区二区三区 在线 | 国产麻豆精品95视频 | 玖玖在线精品 | 麻豆视频免费看 | 久久久夜色 | 色姑娘综合天天 | 九九免费在线观看视频 | 综合久久综合久久 | 国产精品粉嫩 | 亚州国产精品 | 国产精品久久久久久久久久久久午夜片 | 天天操天天谢 | 国产成人精品在线播放 | 69久久99精品久久久久婷婷 | 天天干夜夜擦 | 91av小视频 | 色综合久久88色综合天天 | 久久久久久网 | 色婷婷伊人 | 久久综合久色欧美综合狠狠 | 97天堂 | 97超碰人人澡 | 国产精品免费人成网站 | 国产精品久久久久国产精品日日 | 99热这里| 欧美日韩中文在线观看 | 久久精品视频网站 | av在线免费播放网站 | 日韩一二三在线 | 天天综合视频在线观看 | 亚洲欧美日韩在线一区二区 | 最新国产精品亚洲 | 999成人网 | 日本中文字幕网 | 国产五码一区 | 国产专区视频 | 国产xvideos免费视频播放 | 黄色精品国产 | 青春草国产视频 | 人人要人人澡人人爽人人dvd | 国产91精品久久久久久 | 成人va视频 | 国产精品久久久久久久免费观看 | 欧美日韩另类视频 | 激情综合狠狠 | 国产在线观看你懂得 | 亚洲精欧美一区二区精品 | 成人av网站在线观看 | 国产精品久久艹 | 久久这里只有精品1 | 青青河边草免费 | 欧美伊人网 | 国产精品成人在线观看 | 久久免费视频精品 | 69精品视频 | 超碰九九| 久精品视频在线观看 | 手机看片国产日韩 | 人人爽人人爽 | 一级免费观看 | 久久精品高清视频 | 激情综合国产 | 日韩在线视频观看免费 | 在线v| 精品国产成人 | 99久久精品免费看国产麻豆 | 亚洲乱码在线观看 | 亚洲精品午夜久久久 | 色资源在线 | 91资源在线| 97色免费视频 | 国产玖玖视频 | 最新中文字幕在线资源 | 51久久夜色精品国产麻豆 | 国产麻豆精品传媒av国产下载 | 99色99| 97人人超碰在线 | 日韩三级视频在线观看 | 激情中文在线 | 在线免费观看视频a | 国产成人精品一区二区三区网站观看 | 国产日本亚洲高清 | 国产又黄又猛又粗 | 日本精品一区二区三区在线观看 | 美女视频免费精品 | 夜夜骑日日操 | 黄色中文字幕 | 2019精品手机国产品在线 | 天天综合久久综合 | 亚洲精品男人天堂 | 日韩在线观看视频在线 | 国产精品日韩在线 | 久碰视频在线观看 | 免费在线观看国产黄 | 日韩有码专区 | 免费国产ww| 中文字幕 在线看 | 国产原创在线 | 久精品视频免费观看2 | 亚洲欧美一区二区三区孕妇写真 | av黄色影院| 久久精品xxx | 午夜精品福利一区二区三区蜜桃 | 久99久久 | 五月天伊人网 | 中文字幕乱码视频 | 国产一二三四在线视频 | 中文亚洲欧美日韩 | 毛片在线播放网址 | 91爱爱电影 | 99在线视频观看 | 激情视频网页 | 久久一视频 | 国产护士在线 | 天天操天天干天天操天天干 | 狠狠狠色丁香婷婷综合久久五月 | 久久婷婷色 | 一级黄色a视频 | 米奇四色影视 | av网站大全免费 | 96久久欧美麻豆网站 | 色婷婷综合久久久久 | 精品国产一区二区三区噜噜噜 | 波多野结衣亚洲一区二区 | 国产+日韩欧美 | 日本中文在线观看 | 精品久久福利 | 亚洲精品乱码久久久久久蜜桃动漫 | 在线观看av国产 | 96精品视频| 97超碰在线久草超碰在线观看 | 99久久精品国产一区二区三区 | 亚洲综合欧美精品电影 | 欧美一级黄色网 | 伊人手机在线 | www.夜夜草 | 字幕网资源站中文字幕 | 91手机电影 | 免费一级片视频 | 日日夜夜天天久久 | 久久不射影院 | 天天草天天干 | 丁香花在线视频观看免费 | 国产色视频网站 | 久久婷婷精品 | 麻豆94tv免费版 | 国产视频在线看 | 欧美日韩国产一区二区在线观看 | 免费看的视频 | 最近免费中文字幕 | 日韩免费电影网 | 成人久久免费 | 国产精品久一 | 国产精品一区二区62 | 欧美久久久久 | 国产在线精品一区二区三区 | 中文字幕在线高清 | 免费91在线观看 | 成人少妇影院yyyy | 中文av不卡| 在线观看免费av网 | www欧美xxxx | 日批在线看 | 久久不卡日韩美女 | 国产色久 | 日本公乱妇视频 | 五月宗合网| 成人免费 在线播放 | 精品久久久久久一区二区里番 | 99精品视频在线观看免费 | 在线精品视频免费播放 | 香蕉视频免费看 | 人人爱爱人人 | 久久国产精品免费 | 欧美乱码精品一区二区 | 日本久久久亚洲精品 | 亚洲1区在线 | 欧美淫视频 | 成人免费看黄 | 在线观看中文av | 国产一区二区在线播放 | 国产精品久久久久久五月尺 | www激情久久 | 天天干天天草天天爽 | 国产精品第72页 | 色五月成人 | 天天干天天做天天操 | 国产一线二线三线性视频 | 丁香婷婷久久久综合精品国产 | 免费在线观看av网站 | www.伊人网.com| 激情网五月 | 黄色免费观看 | 欧美精品中文字幕亚洲专区 | 国产精品在线看 | 国产区免费在线 | 婷婷午夜天 | 在线观看精品一区 | 日韩欧美视频一区 | 亚洲精品综合一二三区在线观看 | 欧美日韩在线精品 | 美女av电影| 亚洲人人爱 | 激情校园亚洲 | 91麻豆高清视频 | 日日夜夜天天射 | 91黄色在线观看 | 中文字幕一区二区三区久久蜜桃 | 综合天堂av久久久久久久 | 亚洲成人黄色在线观看 | 91麻豆精品国产自产在线游戏 | 色婷婷av一区二 | 国产成人三级在线播放 | 国产精品手机在线观看 | 欧美精品久久久久久久亚洲调教 | 免费黄色网止 | 激情欧美xxxx | 免费成人黄色片 | 人人爱在线视频 | 成人四虎影院 | 亚洲欧美视频一区二区三区 | 日本aaaa级毛片在线看 | 亚洲精品国产精品乱码不99热 | 国产香蕉在线 | aaa免费毛片 | 亚洲精品视频网站在线观看 | 在线观看视频国产一区 | 99精品免费 | 日韩一级黄色大片 | 91av中文字幕| 精品一区电影国产 | 黄色aaa级片 | 国产亚洲成av片在线观看 | 成人h视频 | 亚洲资源在线 | 一区二区伦理电影 | 亚洲另类视频在线观看 | 亚洲激情六月 | 免费又黄又爽的视频 | 欧美a√大片 | 精品久久久久久综合 | 99久久精品国 | 黄色亚洲大片免费在线观看 | 天天看天天干 | 成人av电影在线播放 | 特片网久久 | 国产精品手机在线播放 | 久草在线视频首页 | 国语自产偷拍精品视频偷 | 婷婷色狠狠| 黄色大片日本 | 亚洲高清激情 | 亚洲免费av网站 | 亚洲精品资源在线观看 | 狠狠的干狠狠的操 | 免费日韩av片 | av免费电影在线观看 | 久久免费播放 | 国产 日韩 在线 亚洲 字幕 中文 | 九九精品在线观看 | 久久久久久久久免费 | 91手机视频 | 日韩性色 | 久久精品草 | 天天色天天爱天天射综合 | 日韩理论片中文字幕 | 99精品在线观看视频 | 国产精品热 | 青草视频免费观看 | 在线日本v二区不卡 | 亚洲成人国产精品 | 99精品热视频只有精品10 | 最近中文字幕在线中文高清版 | 久久a热6 | 91麻豆精品久久久久久 | 国产高清一级 | 嫩草伊人久久精品少妇av | 亚洲电影影音先锋 | 国产丝袜高跟 | 日韩网站在线免费观看 | 高清av影院 | 麻豆果冻剧传媒在线播放 | 午夜av免费观看 | 91中文字幕网 | 天天草天天草 | 99久久影院 | 日韩在线视频一区二区三区 | 国产精品美女视频网站 | 97综合在线 | 国产视频不卡 | 日韩欧美一区二区不卡 | 激情视频在线观看网址 | 国产精品k频道 | 丰满少妇麻豆av | 91视频 - 88av| 久久99热精品这里久久精品 | 国产又黄又爽又猛视频日本 | 午夜电影 电影 | 黄色录像av | 欧美日韩中文在线视频 | 欧美在线视频精品 | 天天插综合网 | 在线免费观看羞羞视频 | 中文字幕丝袜美腿 | 亚洲黄色高清 | 亚洲精品美女久久久久网站 | 成人小视频免费在线观看 | 精品亚洲免费 | 国产精品免费久久久 | 高清视频一区 | 国产综合在线视频 | 97夜夜澡人人爽人人免费 | 婷婷六月激情 | 国产中文欧美日韩在线 | 欧美日韩一级在线 | 99精彩视频在线观看免费 | 亚洲免费精品视频 | 四虎最新入口 | 午夜精品999 | 日韩高清网站 | 日韩视频免费观看高清完整版在线 | 亚洲综合小说 | 免费成人在线观看视频 | 亚洲国产黄色片 | 亚洲激情在线观看 | 日韩免费大片 | 1024手机基地在线观看 | 视频在线观看国产 | 国产一级a毛片视频爆浆 | 婷婷在线网 | 色偷偷888欧美精品久久久 | 精品国产理论片 | 亚洲免费不卡 | 久久久久久久久久久成人 | 黄色av电影 | 丁香激情婷婷 | 午夜久久久久久久久久久 | 日本精品一区二区在线观看 | 国产午夜精品理论片在线 | 国产精品一区二区久久久久 | 久久综合色天天久久综合图片 | 黄污网| 夜色资源站国产www在线视频 | 国产91丝袜在线播放动漫 | 看全黄大色黄大片 | 免费看国产黄色 | 日本免费一二三区 | 久久精美视频 | 天堂中文在线视频 | 日韩高清二区 | 久久国产精品99久久久久 | av大全在线 | 波多野结衣视频一区二区三区 | 麻豆av一区二区三区在线观看 | 精品国产三级 | 亚洲精品国产成人av在线 | 综合亚洲视频 | 欧美一级性生活 | 四虎成人精品在永久免费 | 日日爱视频 | 黄色a一级视频 | 91av官网| 黄色av电影网 | 日韩精品视频在线免费观看 | 91网页版免费观看 | h动漫中文字幕 | 国产精品美女视频网站 | 特黄免费av | 2020天天干夜夜爽 | 天天爽天天爽天天爽 | 狠狠狠操 | 中文字幕乱码在线播放 | 国产一级免费在线观看 | 日p视频 | 精品一区 精品二区 | 97激情影院 | 黄色在线观看免费 | 日本最新中文字幕 | 91九色精品女同系列 | 日韩一区二区三区观看 | 久久久久久在线观看 | 热久久最新地址 | 欧美黑人xxxx猛性大交 | 国产高清一区二区 | a黄色片 | 中文字幕在线一区二区三区 | 在线看免费 | 黄色一级片视频 | 天天干人人干 | 免费色视频网站 | 国产亚洲视频在线观看 | 国产精品久久久久999 | 2018好看的中文在线观看 | 久久精品日产第一区二区三区乱码 | 久久精品视频观看 | 久久乐九色婷婷综合色狠狠182 | 黄色毛片在线看 | 最近最新最好看中文视频 | 国产精品三级视频 | 久久视频在线观看 | 国产成人一区二区在线观看 | 色天天久久 | www.亚洲精品视频 | 亚洲色图22p | 最近中文字幕视频网 | aa级黄色大片 | 91精品国产成人www | 精品免费久久久久 | 欧美福利片在线观看 | 夜夜爱av | 一区二区精品国产 | 亚洲精品在线免费 | 久久99久久久久久 | 婷婷丁香六月 | 久久免费在线视频 | 天天操天天射天天操 | 国产成人精品综合久久久久99 | 一级黄网| 日韩免费中文字幕 | 992tv人人草 黄色国产区 | 久久国产成人午夜av影院潦草 | 在线观看中文字幕第一页 | 日日干天天爽 | 三级黄色网址 | 超碰人在线 | 亚洲天堂精品视频 | 一区二区三区不卡在线 | 久久精品欧美一区 | 国产精品乱码久久久 | 高清有码中文字幕 | 久久人人爽人人爽 | 五月婷在线视频 | 久久成人高清视频 | 国产精品久久久久久久久久久久午夜片 | 97超级碰碰碰视频在线观看 | 黄色成人在线 | 日韩av黄 | 在线91色| 天天干夜夜 | 天天摸夜夜添 | 欧美成人h版在线观看 | 日韩成人精品一区二区 | 亚洲国产精品成人av | 中文字幕精品三区 | 色综合天天做天天爱 | 国产资源在线视频 | 日本三级久久 | 日韩精品一区二区免费 | 欧美日韩高清在线一区 | 97精品国自产拍在线观看 | 日日干 天天干 | 又黄又刺激的网站 | 国产精品久久久久久久久久不蜜月 | 2018亚洲男人天堂 | 蜜臀av性久久久久av蜜臀妖精 | 欧美一二三专区 | 日本精品视频在线观看 | 毛片网免费 | 免费在线一区二区三区 | 色综合国产| 国产麻豆视频免费观看 | av成人免费 | 国产一级片免费观看 | 东方av免费在线观看 | 中文字幕在线专区 | 中文字幕乱码日本亚洲一区二区 | 国产麻豆精品一区 | 免费视频一二三区 | 国产精品岛国久久久久久久久红粉 | 国产亚洲人成网站在线观看 | 91手机视频在线 | 808电影| 国产精品va| 国产美女无遮挡永久免费 | 天无日天天操天天干 | av成人动漫 | 激情网第四色 | 96看片 | 欧美激情精品久久久 | 国产福利91精品一区二区三区 | 免费91在线 | 国产尤物在线 | 激情欧美一区二区免费视频 | 伊甸园永久入口www 99热 精品在线 | 国产色婷婷精品综合在线手机播放 | 九九九毛片| 久久人人艹 | 国产精品黄网站在线观看 | 成人免费观看完整版电影 | 日本久久91 | 亚洲狠狠婷婷 | 97在线观 | 中国一级片免费看 | 久久好看 | 亚洲在线高清 | 国产麻豆成人传媒免费观看 | 亚洲黄色小说网 | 成人黄色小视频 | 亚洲在线网址 | 国产剧情一区在线 | 亚洲天堂色婷婷 | 久久久久一区二区三区 | 五月亚洲 | 久久成人国产精品一区二区 | 婷婷伊人五月 | 人人狠 | 精品超碰 | 在线观看爱爱视频 | 男女啪啪视屏 | av电影中文字幕在线观看 | 黄网站色视频免费观看 | 91丨九色丨国产在线 | 久久激情精品 | 精品国产一区二区三区久久久蜜月 | 成人免费观看在线视频 | 免费三级大片 | 婷婷伊人网 | 五月婷婷视频在线 | 丁香五月亚洲综合在线 | 中文字幕文字幕一区二区 | 日韩中文字幕视频在线观看 | 日韩在线观看你懂得 | 久久av一区二区三区亚洲 | 亚洲欧美日韩在线一区二区 | av资源在线看 | 五月激情丁香图片 | 国产精品久久久久久久久久妇女 | 久久久久久高潮国产精品视 | 国产96在线视频 | 人人插人人做 | 欧美一区二区三区在线看 | 五月激情丁香婷婷 | 黄色aa久久 | 免费福利视频导航 | 精品乱码一区二区三四区 | 色香蕉视频 | 欧美色精品天天在线观看视频 | 免费看的黄色 | 麻豆超碰 | 欧美日比视频 | 国产福利中文字幕 | 91精品国产成 | 久久艹99 | 欧美一级日韩免费不卡 | 久久精品久久99精品久久 | 精品视频中文字幕 | 有码中文字幕在线观看 | 亚洲高清视频在线播放 | 欧美日韩伦理在线 | 中文字幕永久免费 | 99精品国产福利在线观看免费 | av成年人电影 | 久久综合国产伦精品免费 | 久久久久国产精品免费网站 | 91在线91拍拍在线91 | 日本精品久久久一区二区三区 | 岛国大片免费视频 | 日本精品视频网站 | 黄色三几片 | 国产成人精品一区二区三区福利 | 精品国产一二三四区 | 免费观看性生活大片3 | 国产成人精品三级 | 中文字幕免费播放 | 国产99久久精品一区二区300 | 婷婷在线免费 | 久久久久免费精品国产小说色大师 | 国产精品av久久久久久无 | 丰满少妇一级 | 青青草在久久免费久久免费 | 日韩精品不卡 | 97国产超碰 | 999成人精品 | 99视频在线观看一区三区 | 国产精品久久久久久久久久久免费 | 国产一区二区久久 | 中文字幕在线免费97 | 免费久久99精品国产 | 亚洲国产免费网站 | 中文区中文字幕免费看 | 九九在线精品视频 | 国产一区在线看 | 日韩美女黄色片 | 欧美一级片免费 | 高清av免费看 | 亚洲国产欧美在线人成大黄瓜 | 夜夜嗨av色一区二区不卡 | 日日麻批40分钟视频免费观看 | 亚洲男男gⅴgay双龙 | 久艹在线观看视频 | 欧美日韩在线观看视频 | 91豆麻精品91久久久久久 | 91私密保健| 国产偷国产偷亚洲清高 | 88av网站 | 婷婷丁香激情网 | 天堂av最新网址 | 久久亚洲私人国产精品va | 中日韩在线视频 | 国产精品中文字幕在线 | 色五月激情五月 | 国产原创在线观看 | 超碰人人做| 麻豆视频免费入口 | 免费a级观看 | 亚洲涩涩网 | 99久视频| 日日夜夜免费精品 | 久久理论电影 | 尤物九九久久国产精品的分类 | 2021av在线 | 国产h片在线观看 | 亚洲另类视频 | 国产精品成人国产乱 | 久久久久久久久久亚洲精品 | 蜜臀久久99精品久久久久久网站 | 日韩国产欧美在线播放 | 夜夜躁日日躁狠狠躁 | 日韩中文字幕91 | 亚洲乱亚洲乱亚洲 | 九九国产视频 | 在线免费高清视频 | 又黄又爽的免费高潮视频 | 97香蕉久久国产在线观看 | 97国产视频 | 日韩精品91偷拍在线观看 | 久久永久免费 | 免费网站黄色 | 欧美日韩1区 | 狠狠色噜噜狠狠狠狠2021天天 | 蜜桃视频在线视频 | 国产精品日韩在线观看 | 亚洲视频 视频在线 | 日韩一二三区不卡 | 国产区在线| 91av官网| 天天操夜夜做 | 久久国产一二区 | 日韩天堂在线观看 | 精品国产乱码久久久久久久 | 国产精品中文字幕在线观看 | 亚洲第一av在线 | 丁香九月激情 | 国内综合精品午夜久久资源 | 中文字幕人成一区 | 99精品国产免费久久久久久下载 | 韩国一区二区av | 91视频免费看网站 | 免费看的视频 | 日本女人的性生活视频 | 黄色录像av | 最新在线你懂的 | 久久综合亚洲鲁鲁五月久久 | 中文字幕免费看 | 欧美激精品 | 最近2019年日本中文免费字幕 | 国产美女黄网站免费 | 久久免费视频这里只有精品 | 一区二区三区免费网站 | 亚洲国产97在线精品一区 | 91中文在线观看 | 欧美91在线 | 三级av在线| 日本少妇高清做爰视频 | 精品在线免费观看 | 精品亚洲一区二区三区 | 丁香婷婷久久 | 午夜精品一区二区三区在线 | 日韩一级网站 | 亚洲国产精品一区二区久久,亚洲午夜 | 国产一区二三区好的 | 亚洲最大成人网4388xx | 99久久婷婷国产综合亚洲 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 国产专区在线 | 99riav1国产精品视频 | 色就是色综合 | 天天操夜夜操天天射 | 91成熟丰满女人少妇 | 91福利试看 | 国产区精品视频 | 超碰公开在线观看 | 免费性网站 | 久久99九九99精品 | 久久综合干 | 超碰日韩在线 | www.色午夜| 国产 视频 高清 免费 | 国产又粗又猛又色又黄网站 | 中文字幕高清视频 | 久久久亚洲麻豆日韩精品一区三区 | 国产原创中文在线 | 国产精品网红直播 | 亚洲精品一区中文字幕乱码 | 久久激情电影 | 色瓜| www黄色软件| 99久久这里只有精品 | 日本久久久久久久久 | 青草视频在线 | 久久久久久久久久久精 | 国产亚洲精品成人av久久影院 | 欧美精品视 | 国产视频九色蝌蚪 | 久久99精品国产 | 2022国产精品视频 | 日韩精品免费专区 | 日日躁夜夜躁aaaaxxxx | 在线观看免费日韩 | 人人网av| 十八岁以下禁止观看的1000个网站 | 顶级欧美色妇4khd | 波多野结衣在线观看一区 | 亚洲影视九九影院在线观看 | 天天爽综合网 | 在线视频 你懂得 | 中文字幕 国产精品 | 久久久国产精品网站 | www久久久久 | 最近乱久中文字幕 | 国产免费嫩草影院 | 天堂在线成人 | 欧美成人在线网站 | 欧美日本一二三 | 伊人五月在线 | 日日干天天操 | 欧美一区二区在线免费观看 | 三级黄色欧美 | 久久精品国产成人精品 | 精品国产色 | 中文字幕亚洲欧美日韩2019 | 国产一区二区久久精品 | 欧美日韩另类在线 | 91麻豆视频网站 | 精品久久久久久亚洲综合网站 | 免费手机黄色网址 | 欧美日韩aa | 天堂在线一区二区 | 亚洲国产精品视频 | 国产一级特黄电影 | 亚洲激情在线播放 | 日日干干夜夜 | 久久一区二区三区国产精品 | av资源中文字幕 | 国产精品综合久久久 | 好看av在线 | www.国产在线观看 | 97超碰免费 | 国产成人精品一区二区三区网站观看 | 在线视频一区观看 | av再线观看| 免费精品在线 | 精产嫩模国品一二三区 | 91丨九色丨蝌蚪丨老版 | 色婷婷久久一区二区 | 99久久99| 中文字幕亚洲在线观看 | 天天干天天操天天干 | 久久综合给合久久狠狠色 | 西西4444www大胆无视频 | 日韩中文字幕免费看 | 青青草国产免费 | 国产在线不卡 | 能在线观看的日韩av | 欧美成年黄网站色视频 | 黄p在线播放 | 99精品国产兔费观看久久99 | 天天射天天干 | h文在线观看免费 | 久久免费的精品国产v∧ | 婷婷久久一区 | 欧美日韩xx | 欧美视频www | 黄色av网站在线免费观看 | 国外调教视频网站 | 中文字幕资源在线观看 | 福利视频导航网址 | 国产一区久久久 | 免费看的国产视频网站 | 婷婷在线色 | 99精品免费网 | 精品久久久久久综合 | 国产精品日韩在线观看 | 爱色av.com | 四虎永久视频 | 午夜美女影院 | 成人免费中文字幕 | 波多野结衣一区二区 | 国产69精品久久久久99尤 | 欧美一级日韩三级 | 国产精品国产三级国产不产一地 | 亚洲欧美va | 在线 高清 中文字幕 | 免费在线观看成人小视频 | 免费麻豆网站 | 日韩久久精品一区二区三区 | 99免费看片 | 色视频 在线 | 99久久精品久久亚洲精品 | 日韩精品久久久 | 亚洲精品成人av在线 | 看片网站黄| 日韩欧美在线一区 | 欧美淫aaa免费观看 日韩激情免费视频 | 中文字幕在线影院 | 91久久精 | 99久久精品久久久久久清纯 | 91.精品高清在线观看 | 天天干人人干 | 久久精品福利 | 国产精品网红福利 | 香蕉视频国产在线观看 | 婷婷久久五月天 | 伊人狠狠色丁香婷婷综合 | 婷婷精品国产一区二区三区日韩 | 91在线91 | www.黄色 | 欧美激情视频一区二区三区 | 国产999精品久久久影片官网 | 久久久午夜精品福利内容 | 99色精品视频 | 狠狠干在线 | 国产美女无遮挡永久免费 | 97电影在线 | 国产成人综合在线观看 | 人人看看人人 | 日免费视频 | 91亚洲欧美| 色5月婷婷 | 日韩高清在线不卡 | 国产精品入口传媒 | 日韩一二三区不卡 | www.色综合.com| 91福利小视频 | 激情五月婷婷激情 | 久久怡红院 | 国内精品久久久久影院男同志 | 久久精品小视频 | 人人爽久久久噜噜噜电影 | 99久久国产免费免费 | 亚洲一区二区视频在线播放 | 欧美日韩在线视频观看 | 免费91麻豆精品国产自产在线观看 | 日本久久久久久 | 在线观看免费黄视频 | 久久免费黄色网址 | 久草资源免费 | 成人黄色电影在线播放 | 亚洲97在线 | 国内精品国产三级国产aⅴ久 | 久久久久色 | 国产在线精品区 | 欧美日韩一级久久久久久免费看 | 97视频播放 | 国产精品www | 久操视频在线播放 | 一级一级一片免费 | 视色网站 | 18做爰免费视频网站 | 亚洲成人av在线电影 | 国产一区二区中文字幕 | 超碰av在线免费观看 | 特级西西www44高清大胆图片 | 色91av| 国产午夜精品免费一区二区三区视频 | 国产成人精品一区二区在线观看 | 成人毛片在线观看视频 | 麻豆国产在线视频 | 国产成人在线免费观看 | 中文字幕丝袜制服 | 狠狠色狠狠色综合日日92 | 欧美一级视频免费看 | 亚洲精品乱码久久久一二三 | 啪啪av在线 | 成人a在线观看 | 精品国产一区二区三区在线 | 国产高清中文字幕 | 精品专区一区二区 | 91丨九色丨蝌蚪丰满 | 亚洲无人区小视频 | 日韩精品电影在线播放 | 精品免费久久久久久 | 色夜影院 | 九草在线观看 | 国产一区免费视频 | 日韩区视频 | free. 性欧美.com | 草久久久久久 | 久久激情五月婷婷 | av专区在线 | 国产精品高 | 91桃色免费观看 | 国产小视频精品 | 国产成人久久av | 精品国产自在精品国产精野外直播 | 国产伦理剧 | 午夜12点 | 日韩中文字幕国产 | 亚洲a免费 | 国产一级免费电影 | 人人爱天天操 | 久久久久99精品国产片 | 激情五月激情综合网 | 91久久国产露脸精品国产闺蜜 | 免费观看性生活大片3 | 中文字幕第一页在线播放 | 久久综合9988久久爱 | 欧美另类z0zx | 超碰在线98 | 午夜影院一级 | 超碰在线观看av | 亚洲高清av在线 | 日本最新高清不卡中文字幕 | 五月天色综合 | 成人黄色大片在线免费观看 |