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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

Python 和 C/C++ 拓展程序的性能优化

發布時間:2024/10/8 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python 和 C/C++ 拓展程序的性能优化 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

背景

在 MegEngine imperative runtime 的早期開發中,我們面臨著一些的性能優化問題。除了一些已知需要重構的地方(早期設計時為了開發效率而犧牲性能的妥協),還存在一些未知的性能問題需要用 profiler 進行觀測和分析才能發現。

MegEngine 的 imperative runtime 是一個由 Python 和 C/C++ 編寫的模塊,對于這類程序,各種 profiler 多到令人眼花繚亂。在調研各種 profiler 的過程中,我們也踩了不少的坑,比如發現兩個 profiler 對同一個程序的 profiling 結果差異巨大,我們起初懷疑其中一個 profiler 的準確性有問題,最后發現是兩者的觀測對象不同,其中一個只 profiling 程序的 CPU time,而另一個 profiling wall clock time。

雖然一些這樣的信息在文檔的某些角落里能夠找到,但很多使用者可能在踩了坑之后才會注意到。如果一開始能找到一篇介紹各種 profiler 的特點、優勢、不足和使用場景的文章,我們可能會節省不少時間。

因此本文嘗試對這些經驗進行總結,希望能夠給初次使用這些工具的讀者一些參考。性能優化是一個十分廣泛的話題,它涉及 CPU 、內存、磁盤、網絡等方面,本文主要關注 Python 及 C/C++ 拓展程序在 CPU 上的性能優化,文章主要圍繞著下面三個問題展開:

  • Python 及 C/C++ 拓展程序的常見的優化目標有哪些

  • 常見工具的能力范圍和局限是什么,給定一個優化目標我們應該如何選擇工具

  • 各種工具的使用方法和結果的可視化方法

除此之外,本文還會介紹一些性能優化中需要了解的基本概念,并在文章末尾以 MegEngine 開發過程中的一個性能優化的實際案例來展示一個優化的流程。

基本概念

本節介紹性能優化中的一些基礎概念:


wall clock time, CPU time 和 off-CPU time

衡量程序性能最直接的標準就是程序的運行時間,但僅僅知道程序的運行時間很難指導我們如何把程序優化地更快,我們想要更進一步地了解這段時間之內到底發生了什么。

Linux 系統上的 time 命令能夠告訴我們一些粗糙的信息,我們在命令行里輸出下面的命令來測量檢查某個文件的CRC校驗碼的運行時間:

time cksum <some_file>

以我的電腦(MacBook Pro 2018)為例,得到了以下輸出:

8.22s user 1.06s system 96% cpu 9.618 total

這段文字告訴了我們時間都花在了哪里:

  • 總時間 9.618s

  • user 時間 8.22s

  • system 時間 1.06s

其中user和system的含義是user CPU time和system CPU time, 之所以會把 CPU 的執行時間分為兩個部分,是因為程序在運行時除了執行程序本身代碼和一些庫的代碼,還會調用操作系統提供的函數(即系統調用,程序運行系統調用時有更高的權限),因此程序運行時通常會處于兩種狀態: 用戶態和內核態: 內核態指的是 CPU 在運行系統調用時的狀態,而用戶態就是 CPU 運行非系統調用(即用戶自己的代碼或一些庫)時的狀態。

因此上面提到的 user CPU time 指的是用戶態所花費的時間,而 system CPU time 指的是內核態花費的時間。

我們發現 user CPU time + system CPU time = 8.22s + 1.06s = 9.28s?并不等于總時間9.618s,這是因為這條命令執行的時間內,程序并不是總是在CPU上執行,還有可能處于睡眠、等待等狀態,比如等待文件從磁盤加載到內存等。這段時間既不算在 user CPU time 也不算在 system CPU time內。我們把程序在CPU上執行的時間 (即user CPU time + system CPU time) 稱為 CPU time (或on-CPU time), 程序處于睡眠等狀態的時間稱為 off-CPU time (or blocked time),程序實際運行的時間稱為wall clock time(字面意思是墻上時鐘的時間,也就是真實世界中流逝的時間),對于一個給定的線程:?wall clock time = CPU time + off-CPU time。

通常在計算密集型(CPU intensive)的任務中 CPU time 會占據較大的比重,而在 I/O 密集型(I/O intensive)任務中 off-CPU time 會占據較大的比重。搞清楚 CPU time 和 off-CPU time 的區別對性能優化十分重要,比如某個程序的性能瓶頸在 off-CPU time 上,而我們選擇了一個只觀測 CPU time 的工具,那么很難找到真正的性能瓶頸,反之亦然。


性能觀測工具

我們知道了一個線程執行過程中的 CPU time ?和 off-CPU time,如果要對程序的性能進行優化,這些還遠遠不夠,我們需要進一步知道 CPU time 的時間段內,CPU 上到底發生了哪些事情、這些事情分別消耗了多少時間、在哪里導致了線程被 block 住了、分別 block 了多久等。我們需要性能觀測工具來獲得這些詳細的信息。通常情況下我們也將稱這種觀測工具稱為profiler。

不同的觀測對象對應著不同的 profiler,僅就 CPU 而言,profiler 也數不勝數。

按照觀測范圍來分類,CPU 上的 profiler 大致可以分為兩大類: 進程級(per-process, 某些地方也叫做應用級)和系統級 (system wide),其中:

  • 進程級只觀測一個進程或線程上發生的事情

  • 系統級不局限在某一個進程上,觀測對象為整個系統上運行的所有程序

需要注意的是,某些工具既能觀測整個系統也支持觀測單個進程,比如 perf,因此這樣的工具同時屬于兩個類別。

按照觀測方法來分類,大致可以分為 event based 和 sampling based 兩大類。其中:

  • event based: 在一個指定的event集合上進行,比如進入或離開某個/某些特定的函數、分配內存、異常的拋出等事件。event based profiler 在一些文章中也被稱為 tracing profiler 或 tracer

  • sampling based: 以某一個指定的頻率對運行的程序的某些信息進行采樣,通常情況下采樣的對象是程序的調用棧

即使確定了我們優化的對象屬于上述的某一個類別,仍然有更細粒度的分類。在選擇工具之前要搞清楚具體的優化對象是什么,單個 profiler 一般無法滿足我們所有的需求,針對不同的優化對象 (比如 Python 線程、C/C++線程等) 我們需要使用不同的 profiler。并且,對于同一個優化對象,如果我們關注的信息不同,也可能需要使用不同的 profiler。


Python進程模型

本文主要關注 Python(包括 C/C++ 拓展) 程序的優化,一個典型的 Python 和 C/C++ 拓展程序的進程如下圖所示:

一個 Python 進程必須包含一個 Python 主線程,可能包含若干個 Python 子線程和若干個 C/C++ 子線程。因此我們進一步把優化對象細分為三類:

  • Python 線程中的 Python 代碼

  • Python 線程中的 C/C++ 拓展代碼

  • C/C++ 線程

這里的 Python 線程具體指 CPython 解釋器線程,而 C/C++ 線程指不包含 Python 調用棧的 C/C++ 線程。

profiler的分類和選擇

我們從以下兩個角度對profiler進行刻畫:

  • 是否支持 profiling time、off-CPU time 和 wall clock time (CPU time + off-CPU time)

  • 是否支持 profiling C/C ++ stack

  • 是否能夠從 CPython 解釋器的調用棧中解析出 Python 調用棧

我們介紹將介紹6個profiler,分別為 py-spy、cProfile、pyinstrument、perf、systemtap和eu-stack。為了方便大家進行選擇,我們按照上面介紹的特征,把這些profiler分成了4類并總結在了下面的表格中 :

分別表示支持、不完全支持和不支持

表格中第一種是純 Python profiler,只能觀測 Python 線程中 Python 函數的調用棧,適合優化純 Python 代碼時使用,本文將介紹 CProfile(Python的built-in profiler)和pyinstrument(第三方Python profiler),這類profiler還有很多,比如scalene、line-profiler、pprofile等,由于這些profiler在能力上差異不大,因此這里就不一一介紹了。

第二類是 Python 線程 profiler,與第一類的主要區別是除了能夠觀測Python 線程里的 Python 調用棧,還能觀測 c/c++ 拓展的調用棧,這一類只介紹 py-spy。

第三類是系統級 profiler,我們主要用來觀測 Python 線程中的 C/C++ 拓展的調用棧和純 C/C++ 線程,這類 profiler 雖然能夠觀測 CPython 解釋器的調用棧,但由于不是專為 Python 設計的 profiler,不會去解析 Python 函數的調用棧,因此不太適合觀測 Python stack。這一類工具我們將介紹 perf 和 systemtap。

最后一類是對第三類的補充,由于第三類介紹的兩個工具都無法在wall clock time (CPU time + off-CPU time) 上觀測程序,eu-stack可以在wall clock time上采樣程序的C/C++調用棧,因此可以作為這種場景下的profiler。

表格中的 overhead 指 profiler 運行時對被 profiling 程序的影響, overhead 越大 profiling 的結果準確度越低。需要注意的是,任何 profiler 都無法做到絕對的準確,profiler 本身對程序帶來的影響、采樣的隨機性等都會對結果造成影響,我們不應該將 profiling 結果作為程序運行時的實際情況,而應該將其視為一種對實際情況的估計(這種估計甚至是有偏的)。

除了 profiler,我們還需要一些工具來對 profiling 的結果進行可視化來分析性能瓶頸。與 profiler 不同的是,可視化工具一般具有較強通用性,一種廣泛使用的工具是火焰圖 (flamegraph),本文將介紹 flamegraph 的使用方法,除此之外還會介紹一個火焰圖的改進版工具: speedscope。

由于 profiler 的介紹里需要引用可視化工具,因此接下來我們先介紹可視化工具,再介紹 profiler。

可視化工具

flamegraph

火焰圖 (flamegraph) 是一個功能強大的可視化 profiling 結果的工具。它即可以對多種 profiler 的輸出進行處理,也可以對處理后的結果進行可視化。它能夠處理不同平臺上的十多種 profiler 的原始輸出,除了能夠可視化 cpu 上的 profiling 結果,它也可以對一些內存 profiler 的輸出結果進行可視化。

flamegraph 的使用流程一般是對 profiler 的原始輸出結果進行處理,之后再生成一個 SVG?文件,可以在瀏覽器里打開,效果如下:

flamegraph 的主要功能就是顯示 profiler 采樣的調用棧的頻率分布,圖中縱向堆起來的代表調用棧,調用棧中的矩形塊的寬度代表該函數運行時被采到的頻率(某個執行路徑的時間占比與它被采樣到的概率成正比,因此采樣頻率近似等于該執行路徑的時間占比)。通過觀察火焰圖,我們可以看到程序都有哪些執行路徑,以及每個執行路徑的時間占比,然后對時間占比較大的性能瓶頸(或"熱點")進行優化,來達到優化性能的目的。

如果想深入了解 flamegraph,可以參考作者的主頁或 github repo:

homepage:

http://www.brendangregg.com/flamegraphs.html

githubrepo:

https://github.com/brendangregg/FlameGraph

speedscope

另外一個值得介紹的工具是 speedscope。speedscope 的使用方法和 flamegraph 類似,且兼容 flamegraph 的輸出格式。

與 flamegraph 相比,speedscope 在兩個方面具有優勢: 1) speedscope 在可視化效果、交互性等方面表現十分優秀,2) speedscope 運行時的開銷比 SVG 低很多,同時開很多窗口也不會造成明顯卡頓。因此,我們推薦把 speedscope 與 flamegraph 結合在一起使用: 用 flamegraph 來處理不同工具的輸出數據,用 speedscope 進行可視化。

speedscope 是一個 web app,作者提供了一個可以直接使用的地址: https://www.speedscope.app/, 我們也可以在本地部署,但更前者更方便。本文主要以 speedscope 來可視化 profiling 結果,下面簡單介紹一下它的使用方法:

進入https://www.speedscope.app/中,打開 json 格式的 profiling 結果 (我們會在下面各種 profiler 的使用方法中介紹如何將結果轉為這種json)。可以看到以下界面?(與flamegraph的一個不同之處是speedscope的調用棧是倒過來的):

左上角可以選擇三種模式:

  • Time Order: 即時間軸模式,從左到右代表時間的方向,中間每一列代表改時刻采樣的調用棧

  • Left Heavy: 按照調用棧函數的時間占比(采樣次數占比來估計時間占比)進行展示,即調用棧的每一層都按照左側時間多右側時間短的順序來排序。點擊任何一個調用棧中的函數:

    (1)可以在圖中左下角看到該函數在當前調用棧(This Instance)的總開銷(Total) 和自身開銷(Self),以及該函數在所有出現過的調用棧(All Instances)中的總開銷(Total)和自身開銷(Self), 圖中的整數代表被采樣的次數,百分比為被采樣的占比(近似等于時間占比)。

    (2)圖下方的白色框內是該函數的調用棧。

  • Sandwich:用函數的總開銷和自身開銷來排序,點擊函數可以看到該函數的調用者和被調用者

更詳細的介紹可以參考speedscope的官方repo:?

https://github.com/jlfwong/speedscope

性能觀測工具

接下來我們介紹幾個在Python和C/C++拓展程序的優化過程中常用的profiler。我們將介紹每種profiler的優點和局限,大家應該根據自己的實際需求來選擇合適的工具。

py-spy

py-spy 是一個 sampling based profiler, 它的 profiling 的對象是 Python 及 C/C++? 拓展的調用棧。py-spy 的 overhead 中等,對運行的程序速度影響不算太大。且本身支持直接輸出 speedscope 和 flamegraph 格式的結果。

repo: https://github.com/benfred/py-spy

可以直接使用pip進行安裝:

?pip install py-spy

使用方法:

# 基本使用方法:

py-spy record --format speedscope -o output.json --native -- python3 xxx.py

# =====

# 主要參數:

# --format: 輸出格式,默認是flamegraph,推薦使用speedscope格式

# --output: 輸出文件名

# --native: 是否采樣C/C++調用棧,不加--native只會對Python調用棧進行采樣

# =====

# 其他參數

# --rate:????????? 采樣頻率,默認值為100,打開--native會增大overhead,建議打開--native時調低--rate

# --subprocesses:? 是否對子進程進行采樣,默認為否

# --gil:?????????? 是否只對拿到Python GIL的線程進行采樣

# --threads:?????? 在輸出中顯示thread id

# --idle:????????? 是否對idle(即off-CPU time)的thread進行采樣,默認為否,根據具體場景選擇是否打開

# =====

# 例子:

py-spy record -sti --rate 10 --format speedscope --native -o output.json -- python3 xxx.py

# 除了在啟動時運行py-spy,還可以對一個已經運行的python進程進行采樣,如:

py-spy record --format speedscope -o output.json --native --pid 12345

其他功能:

除了 record 子命令外,py-spy 還提供了 top 子命令: 可以在命令行中動態顯示時間開銷最大函數排序; 以及dump子命令: 可以打印一個正在運行的python進程的調用棧。具體使用方法可以參考文檔: https://github.com/benfred/py-spy

py-spy 支持在 CPU time 或 wall clock time (CPU time + off-CPU time)? 上對程序的調用棧進行采樣,采樣的對象是 Python 線程的 python 調用棧或c/c++拓展的調用棧。

py-spy 雖然也能對 C/C++ 線程的調用棧進行采樣,但目前(v0.3.4)會把 Python 調用棧與 C/C++ 調用棧拼在一起,無論兩者是否真正存在調用關系,這樣會使 C/C++ 線程的 profiling 結果在可視化時按照 Python 調用棧進行聚合,導致很難進行分析,因此 py-spy 目前只適合對純 Python 代碼以及 Python 線程上的 C/C++ 拓展(存在 Python 到 C/C++ 的調用關系)進行觀測,不適合觀測獨立的 C/C++ 線程,這是 py-spy 的一個不足之處。

cProfile

cProfile 是一個 event based profiler,它的工作原理是追蹤 Python 解釋器上的每一個 Python 函數調用和時間開銷。cProfile 是 Python 的 built-in profiler,理論上對 Python 的支持度相對較高。cProfile 的局限有很多:

  • 只能觀測純 Python 的函數調用,無法看到 C/C++? 拓展的調用棧

  • 只支持 wall clock time

  • overhead 相對較大

使用方法:

python3 -m cProfile xxx.py

cProfile 的輸出格式是一個table, 如下:

? ?

也可以指定輸出文件:

python3 -m cProfile -o xxx.cprof xxx.py

原始輸出不方便分析,我們需要一些第三方工具來處理輸出數據和可視化,下面介紹兩種方法:

  • 轉成一個 call graph 的圖片

# dependency: gprof2dot, graphviz

# sudo apt install graphviz

# pip3 install gprof2dot

gprof2dot -f pstats xxx.cprof | dot -Tpng -o xxx.png && feh

可視化效果如下:

  • 轉成 flamegraph

# dependency: flameprof

# pip3 install flameprof

flameprof xxx.cprof > flamegraph.svg

更多信息請參考 cProfile 文檔: https://docs.python.org/3/library/profile.html

pyinstrument

pyinstrument 是一個 sampling based profiler,功能上與 cProfile 類似,只支持 Sampling 純 Python 調用棧,類似地只支持 wall clock time,但 overhead 相對 cProfile 低一些,且自帶多種可視化方法。

官方repo地址:?

https://github.com/joerick/pyinstrument

安裝:

pip3 install pyinstrument

使用方法:

python3 -m pyinstrument xxx.py

默認輸出結果在命令行中,如下:

也可以輸出html文件在瀏覽器里查看上面的結果:

python3 -m pyinstrument --html xxx.py

效果如下:

perf

perf 是 Linux 官方的 profiler,可以在 Linux kernel中找到它的源代碼。perf 的功能十分強大,它同時支持對整個操作系統進行觀測,也支持對單個給定的進程進行觀測,除此之外 perf 即可以 trace 指定的 event 也支持對進程的調用棧進行 sampling。perf 運行在內核態,其自身的 overhead 非常低。

安裝perf:

sudo?apt-get?install?linux-tools-common linux-tools-generic linux-tools-`uname?-r`

perf 的版本需要與 Linux kernel 的版本保持一致,安裝命令中的 uname -r?確保了這一點

使用方法:

運行結束后會在當前的目錄下產生一個名為 perf.data 的文件

對結果進行可視化:

可以使用perf自帶的子命令分析profiling結果:

perf report --stdio -i perf.data

我們更推薦將其轉為火焰圖:

對 Linux kernel 版本大于等于 5.8 的用戶,perf 支持直接將結果轉為火焰圖:

perf script report flamegraph -i perf.data

對于 Python 程序的優化,perf 也有一些局限性,因為 perf 不是為 python 定制的 profiler,對 python 的函數調用,perf 采樣的是 CPython 解釋器的調用棧,所以無法直接看到具體的 Python 函數,如下圖所示:

因此 perf 不太適合優化純 Python 代碼,更適合觀測 C/C++ 線程。此外,上面使用的 perf record 命令只會對程序 CPU time 的調用棧進行采樣,如果要對 off-CPU time 進行觀測,需要使用 perf 的 trace 命令,這里就不詳細展開了,具體做法可以參考這篇文章:?

http://www.brendangregg.com/blog/2015-02-26/linux-perf-off-cpu-flame-graph.html

目前為止 perf 還不支持同時對 CPU time 和 off-CPU time 進行觀測,對這兩種情況只能獨立進行分析。

systemtap

systemtap 是一個操作系統的動態追蹤 (dynamic tracing) 工具。它的功能更為強大,我們可以簡單地將 systemtap 視為一個可編程的系統級tracer。systemtap 提供了一個腳本語言,用戶可以編寫腳本來追蹤和監控各種系統調用、用戶態的函數調用等各種自定義事件。因此用戶可以根據自己的需求,編寫腳本來獲得程序運行中的各種需要觀測的信息,systemtap 將會用戶編寫的腳本編譯成c代碼,再編譯成內核模塊,然后加載到正在運行的操作系統內核中。

本文不打算對 systemtap 進行詳細介紹,我們只關注它在 profiling 方面的應用(對systemtap感興趣的讀者可以參考 SystemTap Beginners Guide)此外,本文也不會展示如何編寫腳本來實現一個 profiler,openresty團隊提供了一個systemtap的工具集 (openresty-systemtap-toolkit) 可以直接拿來使用。

接下來我們介紹 systemtap 的安裝和上述工具集的使用方法:

安裝 systemtap :

sudo apt install systemtap systemtap-runtime

除此之外,我們還需要安裝 systemtap 運行時的各種 kernel 依賴:我們可以直接運行? `sudo stap-prep` 來安裝依賴,如果這個命令執行失敗,則需要手動安裝:

sudo apt install kernel-debuginfo-`uname -r`

sudo apt install kernel-debuginfo-common-`uname -r`

sudo apt install kernel-devel-`uname -r`

systemtap 的運行需要 sudo 權限,我們可以運行下面的命令來檢測安裝是否成功:

sudo stap -e 'probe begin { printf("Hello, World!\n"); exit() }'

如果能正常輸出 Hello World 表示安裝成功。

使用 systemtap:

我們需要用到openresty-systemtap-toolkit 提供的兩個工具:sample_gt 和 sample_bt_off_cpu,這兩個工具分別對程序 cpu time 和off-cpu time 的調用棧進行采樣:

與 perf 類似,systemtap 運行在內核態,overhead 非常低。且對于 python 線程,systemtap 采樣的也是 CPython 解釋器的調用棧,因此更適合觀測 C/C++ 線程。

對結果進行可視化:

可視化方法與 perf 類似,flamegraph 支持處理 systemtap 的輸出結果:

eu-stack

eu-stack是elfutils(https://sourceware.org/elfutils) 工具集中的一員,它的基礎功能是對一個程序的調用棧進行采樣:

eu-stack -p <pid>?#===== 可以得到類似下面的輸出:#0? 0x00007f5f96bbadd7 __select#1? 0x00007f5f95868278 call_readline#2? 0x0000000000425182 PyOS_Readline#3? 0x00000000004a84aa tok_nextc.cold.140#4? 0x00000000005a7774 tok_get#5? 0x00000000005a8892 parsetok#6? 0x00000000006351bd PyParser_ASTFromFileObject#7? 0x00000000004ad729 PyRun_InteractiveOneObjectEx#8? 0x00000000004afbfe PyRun_InteractiveLoopFlags#9? 0x0000000000638cb3 PyRun_AnyFileExFlags#10 0x0000000000639671 Py_Main#11 0x00000000004b0e40 main#12 0x00007f5f96ac5bf7 __libc_start_main#13 0x00000000005b2f0a _start

與 perf 和 systemtap 不同的地方是,即使程序處于 off-CPU 的狀態, eu-stack 依然可以獲得它的 C/C++ 調用棧。因此我們可以寫一個簡單的腳本對一個線程的調用棧不斷采樣來實現一個 wall clock time 上的sampling based profiler。

一個簡單的 profiler 實現:

eu-stack 執行時不需要 root 權限,運行一次的時間大約幾十毫秒,對程序的影響不算太大。

使用方法:

可視化方法:

flamegraph 里也自帶了一個處理 eu-stack 輸出結果的工具,可以把采集的樣本轉為 flamegraph,同樣也可以在 speedscope 中進行查看:

例子

最后,介紹 MegEngine 開發過程中一個性能優化的真實例子,來展示一個從 profiling 到尋找 bottleneck 再到性能優化的流程。

在 MegEngine 的早期開發中我們發現某個檢測模型在單機8卡數據并行上的訓練速度非常慢,一個 step 的運行時間是單卡的2倍多。我們首先懷疑的是多卡間同步梯度時 All Reduce 的開銷帶來的影響,為了對此進行確認,我們將卡間的梯度同步關閉,使每張卡的訓練相互獨立,發現速度只提升了一點,8卡速度仍是單卡的2倍左右。

由于8卡訓練會啟動8個進程,為了徹底排除8個進程之間可能存在的聯系帶來的干擾,我們將8卡訓練改成啟8個獨立的單卡訓練,發現速度幾乎沒有變化。此外我們還觀察到一個 step 的運行時間與啟動的單卡訓練的數量成正相關,啟2個單卡訓練時速度只慢了一點,4個單卡訓練慢了50%左右。

于是我們懷疑可能是8個進程之間競爭 CPU 資源導致了速度變慢,為了進行確認,我們對每個進程綁定相同數量的 cpu 核,即單進程訓練和8進程訓練中每個進程使用的 CPU 數量保持一致,再一次發現速度幾乎沒有變化,因此8卡速度慢與 CPU 資源競爭應該沒有關系。

簡單的猜測沒有定位到問題,我們打算使用 profiler 來查找。MegEngine 的進程可以簡化為兩個線程: python 主線程和 worker 線程,其中:

  • Python 主線程: 執行 python 訓練腳本,并且向隊列里發送任務

  • worker 線程: 是一個純 C++ 線程,負責從隊列里取任務并且執行

我們首先對 Python 主線程進行了 profiling,由于希望能同時觀測到 C/C++ extension,純 Python profiler 無法滿足我們的需求,因此我們使用了 py-spy ,我們打開了 –idle 選項來使結果包含 off cpu time 上的樣本,最終得到了下面的結果:

我們發現,主線程大約有80%的時間花在了等待上,如上圖中的紅色框所示。有兩個地方是獲取一個 tensor 的 numpy ndarray ,單個地方是獲取一個 tensor 的 shape ,這兩種情況的等待全部都是 sync worker 線程引發的。

MegEngine 中主線程發命令和 worker 執行命令之間是異步進行的,當我們需要獲得一個 tensor 的 numpy ndarray 時,則需要等 worker 在 CUDA 上完成計算并將結果 copy 到 memory 中,因此會觸發 sync 。另一種情況是獲得一個 tensor 的 shape,如果某個算子的輸出的 shape 無法提前推測出來,也需要等 worker 完稱計算才能知道,因此也會觸發 sync。

由此可見主線程的時間幾乎都花在了等待 worker 上,說明 worker 的執行比較慢,真正的問題應該在 worker 線程上。

于是我們打算對 worker 線程進行 profiling,由于 worker 線程是純C/C++ 線程,因此我們可選的工具有 perf、systemtap 和 eu-stack,我們不確定問題出在 CPU time 上還是 off-CPU time 上,為了能夠將兩種狀態下的結果放在一起觀測,我們選擇使用 eu-stack,于是獲得了以下結果:

我們發現 worker 線程居然有85%以上的時間花在了 topk 算子調用 cudaGetDeviceProperties 的地方(圖中的紅色框),查閱文檔后發現這個 api 的 overhead 比較大,且多進程同時調用時會發生 io traffic 競爭,因此 ioctl 在8進程的時間消耗過大。我們隨后修改了 topk 的實現,避免調用 cudaGetDeviceProperties,之后再次測試,發現該模型的速度回復正常:單進程速度提升了約13%,8進程速度提升了1倍以上。

參考資料

  • 《Systems Performance: Enterprise and the Cloud》

  • http://www.brendangregg.com/offcpuanalysis.html

  • http://www.brendangregg.com/flamegraphs.html

  • https://iobservable.net/blog/2013/02/03/profiler-types-and-their-overhead/

  • https://blog.openresty.com.cn/cn/dynamic-tracing/

  • http://qqibrow.github.io/performance-profiling-with-systemtap/

  • https://www.percona.com/blog/2017/04/05/evaluation-of-profiling-tools-for-pmp/

點擊閱讀原文,了解更多MegEngine信息

總結

以上是生活随笔為你收集整理的Python 和 C/C++ 拓展程序的性能优化的全部內容,希望文章能夠幫你解決所遇到的問題。

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

99免费在线视频 | 国内精品久久久久久久久久久久 | 日本中文在线 | 亚洲高清视频在线观看免费 | 在线成人高清电影 | 成人黄色小说网 | 中文字幕av在线电影 | 中文字幕超清在线免费 | av免费网站在线观看 | 九九在线播放 | 欧美va在线观看 | 亚洲天堂网视频在线观看 | 中文字幕精品www乱入免费视频 | 国产99久久精品一区二区永久免费 | 国产真实精品久久二三区 | 国产免费观看高清完整版 | 日韩精品不卡在线观看 | 成人av资源站 | 亚洲综合最新在线 | 伊人六月 | 天天爱天天操天天爽 | 91精品婷婷国产综合久久蝌蚪 | 精品一区电影 | a特级毛片 | 黄色三级免费网址 | 亚洲国产精品成人综合 | 亚洲国产免费 | 色福利网站 | 久久免费视频这里只有精品 | 婷婷久月 | 缴情综合网五月天 | 国产精品久久99综合免费观看尤物 | 丁香六月婷婷综合 | 亚洲成人免费在线 | av高清网站在线观看 | 亚洲精品在线看 | 丁香久久五月 | 久久人人插 | wwwwww色| 91久久丝袜国产露脸动漫 | 日韩 精品 一区 国产 麻豆 | 久久99久久99精品免视看婷婷 | 日韩亚洲国产中文字幕 | 在线观看欧美成人 | 国语自产偷拍精品视频偷 | 欧美日韩高清在线一区 | 国产精品一区二区电影 | www久久com| 国产精品3 | 国产一区二区三区在线 | 国产伦理久久精品久久久久_ | av在线精品 | 天天爽夜夜爽人人爽一区二区 | 免费日韩三级 | japanesefreesexvideo高潮 | 91日韩在线专区 | 婷婷六月丁香激情 | 人人狠 | 在线观看成人一级片 | 在线小视频国产 | 日本一区二区不卡高清 | 亚洲人成综合 | 美女黄网久久 | 日日夜夜狠狠 | 欧美影院久久 | 亚洲精品在线视频观看 | 天天天操天天天干 | 色偷偷人人澡久久超碰69 | 国产麻豆视频免费观看 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 国产精品久久久久免费观看 | a在线一区 | 免费高清在线观看成人 | 看片的网址 | 青春草免费视频 | 久久第四色 | 久草在线精品观看 | 久久大视频 | 国产美女久久 | 国产精品白虎 | 91在线免费视频观看 | 久久久不卡影院 | 91久久精品一区二区二区 | 不卡中文字幕在线 | 久久久免费av | 九九热有精品 | a黄色影院| 亚洲午夜不卡 | 日韩精品一区二区久久 | 国产成人精品久久亚洲高清不卡 | 五月婷婷丁香色 | 久草免费色站 | 最近免费中文字幕 | 在线精品视频在线观看高清 | 亚洲精品美女久久 | 丁香六月婷婷综合 | 欧美日韩高清国产 | 久草观看视频 | 日本在线观看黄色 | 狠狠色丁香九九婷婷综合五月 | 婷婷伊人综合亚洲综合网 | 久久超级碰视频 | 奇米影视8888 | 91福利在线导航 | 精品国产伦一区二区三区免费 | 日韩在线观看一区二区 | 四虎成人精品永久免费av | av丝袜在线| 91尤物在线播放 | 一区av在线播放 | www.久久色 | 久久久久国产精品www | 中文资源在线观看 | av在线播放观看 | 国内精品久久久 | 在线免费视 | 亚洲精品在线视频播放 | 欧美另类xxx| 99视频在线 | 成人av播放 | 91成人精品在线 | 久久九九免费 | 久久久麻豆精品一区二区 | www亚洲视频 | 亚洲精品视频播放 | 干干干操操操 | 国产手机视频在线观看 | 6080yy精品一区二区三区 | 男女激情网址 | 免费观看黄色12片一级视频 | 亚洲国产中文字幕在线观看 | 久久久免费观看视频 | 综合婷婷丁香 | 中文字幕123区| 成人四虎影院 | 成人中文字幕+乱码+中文字幕 | 久久精品国产亚洲精品 | 亚洲视频免费在线 | 免费在线观看污 | 美女啪啪图片 | 国产午夜精品一区二区三区在线观看 | 国产色中涩| 国产精品高清免费在线观看 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 狠狠干狠狠操 | 天天插天天狠天天透 | 一级做a爱片性色毛片www | 欧美福利网站 | 91少妇精拍在线播放 | 亚洲日韩欧美视频 | 成年人免费在线观看网站 | 精品国产美女 | 精品久久影院 | 欧美乱码精品一区二区 | 午夜精品视频在线 | 欧美精品v国产精品v日韩精品 | 欧美精品久久人人躁人人爽 | 在线观看黄色av | 久久99热国产 | av天天澡天天爽天天av | 天天干天天干天天干天天干天天干天天干 | 3d黄动漫免费看 | 国产精品女同一区二区三区久久夜 | 欧美在线99| 国产精品美女久久久久久免费 | 久久精品久久久久 | 久久国产品 | 国产成人久久精品一区二区三区 | 欧美a性| 在线观看黄色 | 成人在线超碰 | 91免费观看 | 国产精品毛片一区视频 | 国产成人99av超碰超爽 | 在线观看日本高清mv视频 | 成 人 黄 色 视频 免费观看 | 欧美日韩国产伦理 | 日本中文字幕系列 | 欧美日韩免费观看一区二区三区 | 中文不卡视频 | 天天操天 | 91视频黄色 | 精品国产乱码久久久久久三级人 | av手机在线播放 | 操夜夜操 | www在线免费观看 | 视频在线观看99 | 久久综合色综合88 | 久久久久电影 | 懂色av一区二区在线播放 | 免费观看成人 | 久久伦理视频 | 日韩精品一区二区不卡 | 热久久这里只有精品 | 91资源在线观看 | 日韩精品一区二区免费 | 精选久久 | 一区二区三区精品久久久 | 久久免费视频3 | www久久久| 91视频成人免费 | 国产成人久久久77777 | 在线观看国产日韩 | 亚洲高清资源 | 日韩电影中文,亚洲精品乱码 | 狠狠色丁香婷婷 | 欧美亚洲精品一区 | 国产香蕉视频 | 少妇视频在线播放 | 日韩三级免费观看 | 99久久久久久久久 | 国产在线毛片 | 国产精品12345 | 五月天婷婷综合 | 欧美在线观看禁18 | 日韩av在线免费看 | 国产精品18久久久久久首页狼 | 在线视频精品 | 精品国产理论片 | 久久不射电影网 | 午夜精品久久久 | 亚洲欧美在线视频免费 | 亚洲尺码电影av久久 | 在线免费av播放 | 久操视频在线播放 | 欧美成人手机版 | 亚洲成aⅴ人在线观看 | 波多野结衣在线视频一区 | 国产一区电影在线观看 | 在线观看网站av | 亚洲欧洲xxxx| 久草在线官网 | 亚州精品视频 | 久久激情视频网 | 日韩av黄| 在线电影播放 | 91超碰免费在线 | 成人欧美一区二区三区黑人麻豆 | 99视频免费 | 中文字幕在线观看网 | 亚洲精品视频在线免费 | 欧美日韩国产亚洲乱码字幕 | 色偷偷88888欧美精品久久 | 欧美福利网址 | 久久这里有 | 国产精品久一 | 精品国产_亚洲人成在线 | 亚洲精品男人的天堂 | 91成人精品一区在线播放 | av千婊在线免费观看 | 国产黄色精品在线 | 亚洲精品自在在线观看 | 久久九九精品 | 久久激情视频网 | 一级淫片a| 激情六月婷婷久久 | 精品少妇一区二区三区在线 | 日韩免费一区 | 国内视频在线观看 | 国产精品精品久久久久久 | 国产激情小视频在线观看 | 欧美精品一区二区在线观看 | 久久这里只精品 | 国产在线p | 国产精品久久久久国产精品日日 | 久久一视频 | 99热精品国产一区二区在线观看 | 草莓视频在线观看免费观看 | av在线8| 91精品久久久久久综合五月天 | 久久这里有精品 | 深爱婷婷久久综合 | 日韩电影一区二区三区在线观看 | 欧美久久久影院 | 久久综合九色综合97_ 久久久 | 天堂在线免费视频 | 日韩久久久久久久久 | 中文永久免费观看 | 六月天综合网 | 久久久久久欧美二区电影网 | 中文字幕精品在线 | 中文字幕第一页在线播放 | 欧美日韩国产免费视频 | 欧美精品久久99 | 91漂亮少妇露脸在线播放 | 97在线观看免费高清完整版在线观看 | 国产视频资源在线观看 | 91精品在线免费 | 婷婷5月色| 久久久久久久久亚洲精品 | 99国内精品| 成人99免费视频 | 国产精品入口麻豆 | 国产a级片免费观看 | 尤物九九久久国产精品的分类 | 免费网站在线观看人 | 国产日韩精品一区二区 | 精品三级av| 国产精品美乳一区二区免费 | 4hu视频| 天天综合91 | 黄色大片中国 | av中文字幕电影 | 亚洲视频每日更新 | 欧美日韩在线视频观看 | 久久免费99 | 在线观看黄 | 国产成人精品一区二区 | 亚洲欧美视频一区二区三区 | 免费观看丰满少妇做爰 | 国产精品av在线 | 午夜精品一区二区三区免费视频 | 国产一区在线视频 | 日日操夜夜操狠狠操 | 日韩在线色 | 日本高清中文字幕有码在线 | 中文字幕在线字幕中文 | 国产亚洲一级高清 | 国产91精品高清一区二区三区 | 国产午夜一级毛片 | 久久久久成人精品 | 一级大片在线观看 | 国产1区在线观看 | 日韩在线观看小视频 | 综合久久综合久久 | 少妇激情久久 | 日韩免费| 999热视频| 国产黄影院色大全免费 | 久久久久综合精品福利啪啪 | 久久免费的视频 | 在线 国产 亚洲 欧美 | 黄色成人av在线 | 黄污网站在线观看 | 国产精品视频专区 | 国产一线二线三线性视频 | 国产一区麻豆 | 91干干干 | 51精品国自产在线 | 亚洲天天在线日亚洲洲精 | 久久毛片网站 | 日韩免费播放 | 91精品国产99久久久久久久 | 免费看黄色大全 | 美女福利视频网 | 91精选在线观看 | 五月婷婷色 | 最新av网站在线观看 | 午夜精品视频一区二区三区在线看 | 天天操夜夜操夜夜操 | 在线视频你懂得 | 99日韩精品 | 色综合久 | 亚洲精品资源在线观看 | 四虎在线视频 | 婷婷五月色综合 | 另类老妇性bbwbbw高清 | 欧美一区二区三区四区夜夜大片 | 91视频91蝌蚪 | 成人av电影免费在线观看 | 九九综合九九 | 丰满少妇在线观看资源站 | 国产精品你懂的在线观看 | 天天色天天干天天色 | 在线日韩av | 久久中文视频 | 久久污视频| 日本爱爱片 | 国产精品一区二区中文字幕 | 天天艹天天爽 | 日本精油按摩3 | 91欧美精品 | 69国产盗摄一区二区三区五区 | 日韩视频一区二区三区 | 综合色亚洲 | 国产黄色片免费 | 亚洲h视频在线 | 国产精品久久久久aaaa九色 | 国产原创在线 | 97精品国自产拍在线观看 | 色吊丝在线永久观看最新版本 | 1024手机在线看 | 亚洲网久久 | 亚洲精品综合一二三区在线观看 | 色狠狠久久av五月综合 | 人人干人人超 | 91九色在线视频 | 九色视频网址 | 91精品视频免费观看 | 国内小视频 | av成人免费| 中文字幕一区av | 国产精品一区二区三区在线播放 | 国产精品视频最多的网站 | 欧美一级高清片 | 国产精品久久久久久久久久久免费 | 波多野结衣资源 | 91免费国产在线观看 | 亚洲国产成人精品在线观看 | 日韩二区三区 | 国产精品亚洲视频 | 9999精品免费视频 | 麻豆一区二区 | avove黑丝| 亚洲综合激情小说 | 91香蕉视频黄色 | 国产+日韩欧美 | 亚洲精品 在线视频 | 日本中文字幕在线一区 | 久久精品国产亚洲精品2020 | 精品少妇一区二区三区在线 | av在线h| 狠狠狠色丁香婷婷综合久久88 | 亚洲最新在线 | 欧美日韩性视频在线 | 97国产电影 | 国产精品日韩欧美一区二区 | 中文字幕在线色 | 亚洲九九九在线观看 | 99草视频| 在线免费观看视频一区二区三区 | 欧美一二区视频 | 久久国产精品免费看 | 91免费黄视频 | 日本精油按摩3 | 国产视频中文字幕在线观看 | 人人看人人 | avav片| 天天干com | av免费在线观 | 草久久精品| 欧美乱码精品一区二区 | 亚洲欧美国产精品久久久久 | 女人18毛片a级毛片一区二区 | 最近中文字幕免费大全 | 99色在线播放 | 久热精品国产 | 久久免费视频5 | 午夜久久久久久久久久久 | 免费视频91 | 国产69精品久久99不卡的观看体验 | 一级欧美日韩 | 久草国产视频 | 99热精品久久 | 黄色在线免费观看网址 | a级国产乱理伦片在线观看 亚洲3级 | 久久人操 | av电影免费看 | 国产精品一区一区三区 | 欧美极品久久 | 麻豆手机在线 | 麻豆传媒电影在线观看 | 99久久精品久久亚洲精品 | 亚洲 成人 一区 | 国产亚洲欧美在线视频 | 黄色tv视频 | 亚洲精品高清在线 | 日韩精品不卡在线观看 | 国产中文字幕视频在线观看 | 国产粉嫩在线 | 久久99深爱久久99精品 | 在线黄色av | 色吊丝在线永久观看最新版本 | 成人三级av| 日韩理论片中文字幕 | 日本 在线 视频 中文 有码 | 久久久久国产精品免费 | 激情丁香 | 四虎最新域名 | www.亚洲在线| 在线免费视频你懂的 | 亚洲精品乱码久久久久久蜜桃不爽 | 欧美日韩国产精品一区二区亚洲 | 久久国产系列 | 五月婷婷激情六月 | 成人在线免费视频观看 | 国产一卡二卡在线 | 日韩欧美网址 | 久草视频首页 | 五月天激情综合网 | 精品理论片 | 日韩在线视频播放 | 天堂av在线免费观看 | 免费观看全黄做爰大片国产 | av线上免费观看 | 亚洲精品国产精品乱码不99热 | 国产91对白在线播 | 伊人官网| 婷婷在线资源 | 91高清一区| 欧美精品v国产精品v日韩精品 | 久草www| 久久久www| 五月婷婷网站 | 成人免费观看视频大全 | 黄色亚洲在线 | www.久久91| 91精品视频在线看 | 人人射人人射 | 欧美久久精品 | 中文字幕日韩一区二区三区不卡 | 日韩aa视频 | 午夜视频在线观看一区二区三区 | 精品视频区 | 欧美伦理一区 | 日韩免费在线网站 | 狠狠操狠狠干天天操 | 亚洲精品小视频 | 激情五月婷婷网 | free. 性欧美.com| 日韩免费视频在线观看 | 国产精品午夜在线观看 | 99久国产| 91在线操 | 在线免费av网 | 韩日av一区二区 | 久久精品网站免费观看 | 欧美激情精品一区 | 伊人五月综合 | 九九三级毛片 | 婷婷国产一区二区三区 | 日韩黄色影院 | 色婷婷综合五月 | 日韩中文在线字幕 | 91亚洲精品久久久蜜桃网站 | 久久er99热精品一区二区三区 | 成人免费影院 | 国产成人三级一区二区在线观看一 | av一级黄| 日日爱网站 | www,黄视频| avlulu久久精品 | 久久国产成人午夜av影院潦草 | 91九色蝌蚪视频 | 免费看一级特黄a大片 | 久久午夜电影 | 91热爆在线观看 | 国产精品永久在线 | 国产精品久久久视频 | 国产精品美女久久久久久网站 | 国产午夜精品一区二区三区在线观看 | 免费看的黄色片 | 视频在线一区二区三区 | 午夜精品久久久久久久99 | 日韩欧美在线中文字幕 | 高清中文字幕av | 五月婷综合 | 久久av高清 | 国产精品观看 | 久久8| 2019免费中文字幕 | 久久国产视屏 | 中文字幕在线观看完整 | 久草在线最新免费 | 91视频最新网址 | 在线免费观看欧美日韩 | 国产精品久久久久久久7电影 | 国产一区二区在线免费视频 | av不卡在线看 | 91亚洲精品国偷拍 | www.夜夜草 | 国模视频一区二区三区 | 国产精品成人自产拍在线观看 | 99久久er热在这里只有精品66 | a成人v在线 | 97超碰在线久草超碰在线观看 | 懂色av一区二区三区蜜臀 | 国产手机在线观看视频 | 亚洲精品高清在线 | 欧美日产在线观看 | 久久国产精品色婷婷 | 日韩中文字幕免费视频 | 69精品在线观看 | 久久精品第一页 | 视频91在线 | 麻豆视频观看 | 成人av网页| 欧美一区在线观看视频 | 中文字幕在线观看免费高清电影 | 99精品色 | 久久久久久久久久久免费 | 狠狠躁日日躁狂躁夜夜躁av | 成人欧美一区二区三区黑人麻豆 | 成人久久精品视频 | 亚洲精品午夜aaa久久久 | 精品欧美乱码久久久久久 | 97视频在线观看免费 | 日韩精品久久久久久久电影竹菊 | 在线观看黄色小视频 | 超薄丝袜一二三区 | 狠狠色丁香婷婷 | 日本中文字幕系列 | 午夜久久久久久久久久久 | 黄网站免费看 | 久久福利国产 | 免费毛片aaaaaa | 亚洲视频aaa | 日韩中文字幕a | 久久艹在线观看 | 国产女人18毛片水真多18精品 | 国产精品18久久久久久vr | 在线观看亚洲视频 | 日日干天天爽 | 国产精品永久在线 | 欧美福利片在线观看 | 色婷婷www | 肉色欧美久久久久久久免费看 | 久久精品99国产 | 91最新地址永久入口 | 午夜视频一区二区 | 亚洲精品一区二区精华 | 亚洲高清在线视频 | 国产高清在线一区 | 最近日韩中文字幕中文 | 亚洲人av免费网站 | 岛国一区在线 | 欧美十八| 婷婷性综合 | 日韩中文字幕国产精品 | 成人在线视频免费观看 | 黄色国产精品 | 五月亚洲综合 | 免费在线观看av的网站 | 亚洲欧洲视频 | 色噜噜在线观看 | 亚洲日本一区二区在线 | 狠狠躁日日躁狂躁夜夜躁 | 麻豆传媒视频在线播放 | 久久夜夜夜 | 国产精品精品国产婷婷这里av | 丁香激情综合国产 | 久草精品在线观看 | 免费看黄色小说的网站 | 五月花丁香婷婷 | 天天色综合三 | 麻豆精品传媒视频 | 久久视频网址 | 日韩在线电影观看 | 五月婷婷一区二区三区 | 国产精品婷婷 | 日日夜操| 91在线操 | 免费在线观看av电影 | 日韩欧美精选 | 欧美一区二区伦理片 | www.com久久久 | 狠狠干,狠狠操 | 亚洲视频免费在线观看 | 免费视频国产 | 91污视频在线 | 天天色天天草天天射 | 久久黄色网 | 三日本三级少妇三级99 | 精品国产人成亚洲区 | 天天摸天天弄 | www.婷婷com | 中文字幕亚洲精品日韩 | 操操操com| 亚洲色五月| 色99中文字幕 | 夜夜爽88888免费视频4848 | 精品一区 在线 | 99在线精品视频观看 | 在线观看色网站 | 视频91 | 91av中文字幕 | 久久久久久久久久久久久久av | 国产一级做a爱片久久毛片a | 国产在线一卡 | 99久久久久 | 天天夜夜亚洲 | 日韩另类在线 | 青草草在线 | 激情久久久久久久久久久久久久久久 | 性色av一区二区三区在线观看 | 91禁在线看 | 国产精品系列在线播放 | 日韩二区三区在线观看 | 正在播放久久 | 欧美一性一交一乱 | 亚洲天天综合 | 黄色综合 | 欧美日韩视频网站 | 国产精品精品国产婷婷这里av | 狠狠色丁香久久婷婷综合五月 | 色网站免费在线观看 | 中文字幕在线视频一区二区 | 久久久精品一区二区 | 亚洲黄色片一级 | 不卡日韩av| www.xxx.性狂虐 | 在线观看亚洲电影 | 日批在线观看 | 日批视频在线观看免费 | 精品影院一区二区久久久 | 97影视| 日本特黄特色aaa大片免费 | 久久久午夜精品福利内容 | 国产精品18久久久久久vr | 亚洲免费av片 | 午夜久久精品 | 欧美日韩在线视频观看 | 国产精品一区二区av | 在线91av| 91一区在线观看 | 亚洲精品成人免费 | 久久伦理电影网 | 久久av影视| 国产精品福利久久久 | 国产精品国产自产拍高清av | 久久综合精品一区 | 精品国自产在线观看 | 久久 地址 | 成年人黄色免费网站 | 81国产精品久久久久久久久久 | 国产又粗又猛又黄 | 综合久久一本 | 成人影视免费 | 97在线视 | 九色视频网站 | 国产精品久久久久久久久久东京 | 久久影视一区 | 久久久久久久久国产 | 国产精品久久久久久久久久三级 | 色婷婷综合久久久中文字幕 | 国产一区二区在线免费视频 | 97成人资源站 | 在线久草视频 | 在线观看日韩一区 | 一区二区三区手机在线观看 | 日韩91在线 | 绯色av一区| 久久精品国产亚洲 | 久久久久久久久免费视频 | 亚洲精品视频在线观看免费视频 | 亚洲综合在线五月 | 国产永久网站 | 综合久久精品 | 99在线免费视频 | 婷婷色 亚洲 | 视频成人永久免费视频 | 黄色视屏免费在线观看 | 激情久久五月 | 欧美性黑人 | 亚洲精品无 | 中文网丁香综合网 | 国产精品成人免费精品自在线观看 | 婷婷色资源| 成人av免费在线观看 | 国产在线观看av | 国产999精品久久久影片官网 | 久久久久久久久久久久影院 | 99久久99久久综合 | 人人爱人人做人人爽 | 精品一区精品二区 | 久久激情视频免费观看 | 97在线观视频免费观看 | 狠狠色丁香婷婷综合久久片 | 欧美成年人在线观看 | 久久99精品久久只有精品 | 久久久久久97三级 | 一级片视频在线 | 成人亚洲欧美 | 黄色av网站在线观看 | 久久久久国产精品视频 | 久久天天躁夜夜躁狠狠躁2022 | 美女黄频 | 亚洲精品视频在线免费 | 久久九九网站 | 天天插天天 | 中文高清av | 久久免费电影网 | 玖草在线观看 | 婷婷丁香狠狠爱 | 久久久久国产一区二区三区四区 | 久草在线手机视频 | 日本久久91 | 国产一区二区三区免费在线观看 | 亚洲日本三级 | 日韩va欧美va亚洲va久久 | 91超级碰碰| 一级性av| av综合站| 国产色黄网站 | 国产一级做a爱片久久毛片a | 亚洲在线激情 | av高清在线观看 | 五月丁色| 人人干人人超 | 激情网在线视频 | 亚洲精品tv | 亚洲精品黄网站 | 色亚洲激情 | 欧美美女视频在线观看 | 日韩r级电影在线观看 | 欧美日韩精品影院 | 色小说av | 中文字幕综合在线 | 四虎影视成人精品国库在线观看 | 日韩在线播放视频 | 国产中文字幕三区 | 特黄一级毛片 | 一区国产精品 | 日韩免费一区 | 丁香婷五月 | 欧美激情综合色综合啪啪五月 | 国产精品久久伊人 | japanesefreesex中国少妇 | 亚洲91中文字幕无线码三区 | 亚洲天堂精品视频在线观看 | 欧美午夜久久 | 91爱爱电影 | 视频在线99| 天天激情综合 | 激情欧美丁香 | 欧美成人在线网站 | 中文字幕之中文字幕 | 欧美日韩高清一区二区 国产亚洲免费看 | 久久久亚洲精品 | 91看片成人 | 精品一区二区三区四区在线 | 少妇bbw搡bbbb搡bbb | 国产色视频一区二区三区qq号 | 成人a级免费视频 | 免费看成人a | 国产精品免费一区二区三区在线观看 | 日韩在线观看a | 天天综合网在线观看 | 免费性网站 | 91成人在线观看高潮 | 99久久久国产精品免费观看 | 91久久精 | 在线观看国产日韩欧美 | 亚洲国产精品电影 | 五月天婷亚洲天综合网精品偷 | 色视频在线免费 | 九九视频精品在线 | 日本99热 | 91免费在线看片 | 亚洲欧美国产日韩在线观看 | 九九热国产视频 | 亚洲视频免费 | 日韩在线视频网站 | 亚洲狠狠婷婷综合久久久 | 亚洲午夜精品福利 | 欧美激情精品久久久久久免费 | 欧美极品xxxx | 婷婷精品国产一区二区三区日韩 | 欧美福利片在线观看 | 精品久久久久免费极品大片 | 蜜桃视频色 | 在线小视频 | 色香蕉网 | 91精品成人久久 | 中文字幕在线一二 | 99热最新地址 | 在线视频黄 | 中文字幕永久免费 | 精品国产伦一区二区三区 | 色香蕉在线 | 久久免费的视频 | 日韩在线免费观看视频 | 天天操天天色天天 | 久久久久北条麻妃免费看 | 在线看v片成人 | 激情深爱.com| 日本中文字幕在线播放 | 日本字幕网 | 精品国产视频在线 | 91av视频在线免费观看 | 丁香六月婷 | 91精品中文字幕 | 天天干视频在线 | 久精品视频免费观看2 | 网站在线观看日韩 | 国产精品久久久久久五月尺 | 国产精品露脸在线 | www.伊人网 | 欧美日韩久久不卡 | 国产对白av | 2021久久 | 久草免费色站 | 亚洲片在线资源 | 亚洲欧美日韩国产一区二区三区 | 天天躁日日躁狠狠躁 | 日韩两性视频 | 在线国产99| 色偷偷av男人天堂 | av国产在线观看 | 久草在线在线精品观看 | 久久精品欧美一区二区三区麻豆 | 五月激情电影 | 97超级碰碰碰碰久久久久 | 成人综合婷婷国产精品久久免费 | 日韩中文字幕网站 | 国产一区二区精品久久 | 黄色午夜网站 | 国产日韩精品一区二区三区在线 | 国产一级免费电影 | 在线观看视频一区二区三区 | 97免费在线观看视频 | 国产探花视频在线播放 | 久久久久久久久艹 | 亚洲免费av网站 | 在线激情av电影 | 久久成人午夜视频 | av天天色 | 亚洲精品高清在线 | 久久免费视频99 | 日本爱爱片 | 日日夜夜添 | 婷婷色狠狠 | 成人免费大片黄在线播放 | 久久精品视频在线 | 国产视频99 | 丁香婷婷在线观看 | 黄色亚洲免费 | 麻豆视频在线观看免费 | 在线观看成人国产 | 日韩中文字幕在线不卡 | 亚洲精品在线一区二区 | 成人国产一区 | av在观看 | 亚洲精品乱码久久久久v最新版 | 成人a免费看 | 日日天天狠狠 | 久久久久久久久久电影 | 99精品欧美一区二区三区黑人哦 | 国产精品乱码久久久久 | 99c视频在线 | 亚洲精品一区二区三区在线观看 | 成人在线观看av | 午夜av一区二区三区 | 亚洲精品乱码久久久久久蜜桃不爽 | 免费国产一区二区视频 | 国产成人av电影在线观看 | 久热电影 | 亚洲欧美综合 | 香蕉视频在线视频 | 久久这里只有精品视频99 | 中文永久免费观看 | 国产69精品久久99不卡的观看体验 | 国产黄色成人av | 久久久91精品国产一区二区三区 | 国产成人高清在线 | 亚洲亚洲精品在线观看 | 久久不卡av | 亚洲资源在线网 | 国产一线在线 | 99草视频在线观看 | av解说在线观看 | 中文字幕在线观看1 | 国产裸体bbb视频 | 91桃花视频| av黄色亚洲 | 人人干网 | 九九视频精品免费 | 成年人网站免费在线观看 | 国产三级精品三级在线观看 | 成人黄色短片 | 婷婷综合五月天 | av成人在线电影 | 日韩.com| 超级碰碰视频 | 成全免费观看视频 | 高清av网| 天天干天天干天天射 | 日韩国产欧美视频 | 激情综合网五月激情 | 在线免费av网站 | 欧美一区日韩一区 | 久草免费电影 | 97成人资源站 | 在线91播放| 亚洲高清激情 | 成人va天堂| 高清精品视频 | 人人射人人爽 | 欧美爽爽爽 | 久久久久久高潮国产精品视 | 91视频网址入口 | 五月开心激情网 | 玖玖视频国产 | 一区二区免费不卡在线 | 久久人人爽人人片av | 亚洲欧美999 | 日本精品久久久久中文字幕 | 久久看片网站 | 日本黄色免费在线 | 六月色婷 | 国产一区二区三区 在线 | 天天夜夜狠狠操 | 午夜电影中文字幕 | 视频一区二区免费 | 国产精品免费一区二区三区在线观看 | 欧美成人一二区 | 国产手机av在线 | 久久爱www. |