精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

為什么我的進(jìn)程被Kill掉了

開發(fā) 前端
有一天我們需要在這臺(tái)機(jī)器上執(zhí)行一項(xiàng)任務(wù),如果這個(gè)任務(wù)也比較耗內(nèi)存,那很可能在執(zhí)行這項(xiàng)任務(wù)時(shí),整臺(tái)機(jī)器的物理內(nèi)存就完全不夠用了,此時(shí),就會(huì)觸發(fā)linux內(nèi)核的oom killing機(jī)制。

[[392359]]

先來看段代碼:

 

這段代碼非常簡單,就是先用mmap的方式,為該進(jìn)程分配10GiB的虛擬內(nèi)存,然后再用page寫的方式,讓操作系統(tǒng)為這10GiB虛擬內(nèi)存,分配對應(yīng)的物理內(nèi)存,最后sleep,等待我們測試。

運(yùn)行下:

 

沒啥問題,和我們預(yù)期的一樣,正常執(zhí)行。

打開另一個(gè)終端,執(zhí)行以下命令,看下它的內(nèi)存占用:

 

上圖中的VSZ指的是虛擬內(nèi)存,RSS指的是物理內(nèi)存,單位都是KiB,所以該進(jìn)程虛擬內(nèi)存和物理內(nèi)存的使用,都約等于10GiB,沒問題。

我們再開個(gè)終端,再執(zhí)行下這個(gè)程序:

 

第二次執(zhí)行這個(gè)程序也沒問題,但奇怪的是,此時(shí)第一次執(zhí)行的那個(gè)程序卻被kill掉了:

 

這是為什么呢?

上面我們說到,該程序的邏輯是分配10GiB的物理內(nèi)存,所以運(yùn)行兩次,也就是要分配20GiB的物理內(nèi)存。

但在我們的測試機(jī)器上,物理內(nèi)存一共才16GiB,所以,運(yùn)行兩個(gè)這樣的進(jìn)程肯定是不行的。

在第二次執(zhí)行該程序,且向操作系統(tǒng)申請物理內(nèi)存時(shí),操作系統(tǒng)會(huì)發(fā)現(xiàn),物理內(nèi)存已經(jīng)沒有了。

此時(shí),為了防止整個(gè)系統(tǒng)crash掉,linux內(nèi)核會(huì)觸發(fā) OOM/Out of Memory killing 機(jī)制,即按照一定的規(guī)則選擇一個(gè)進(jìn)程,將其kill掉,以便回收物理內(nèi)存,以此來保證機(jī)器整體的穩(wěn)定運(yùn)行。

同時(shí),該kill事件,也會(huì)被記錄到內(nèi)核日志中,且可通過dmesg命令等方式查看。

比如上面第一個(gè)進(jìn)程被kill掉的事件記錄如下:

 

看上面紅色字體行,該行是說,進(jìn)程14134因?yàn)閛ut of memory被linux內(nèi)核kill掉了,該進(jìn)程正是上面我們第一次執(zhí)行的那個(gè)程序。

linux內(nèi)核的oom killing機(jī)制,其實(shí)是一種棄車保帥的做法,因?yàn)槿绻覀儾籯ill掉某進(jìn)程,來釋放物理內(nèi)存的話,那很有可能會(huì)導(dǎo)致后續(xù)系統(tǒng)級(jí)別的crash,兩害相權(quán)取其輕,操作系統(tǒng)只能這樣處理,歸根結(jié)底,是我們對進(jìn)程使用物理內(nèi)存的規(guī)劃不足,才導(dǎo)致了這種情況。

那為什么不在第二次執(zhí)行該程序時(shí),在調(diào)用mmap分配虛擬內(nèi)存時(shí)就直接報(bào)錯(cuò),返回?zé)o法分配內(nèi)存呢?

這是因?yàn)椋?jīng)過多年觀察,linux內(nèi)核的開發(fā)人員發(fā)現(xiàn),絕大部分程序在分配了很大的虛擬內(nèi)存之后,在大部分時(shí)間里,并不會(huì)一直使用這么多的物理內(nèi)存。

所以,為了更合理更高效的利用物理內(nèi)存資源,linux內(nèi)核允許虛擬內(nèi)存的overcommit,即,例如在上面執(zhí)行mmap分配虛擬內(nèi)存時(shí),linux內(nèi)核并不會(huì)嚴(yán)格檢查,所有運(yùn)行中的進(jìn)程分配的虛擬內(nèi)存加起來,是否超過了整個(gè)物理內(nèi)存大小。

這也就解釋了為什么上面第二次運(yùn)行該程序時(shí),mmap是沒有報(bào)錯(cuò)的。

但是,雖然mmap的虛擬內(nèi)存分配成功了,但當(dāng)真正使用該內(nèi)存時(shí),比如上面的寫內(nèi)存,此時(shí)要分配物理內(nèi)存,則是有可能失敗的,因?yàn)樘摂M內(nèi)存的overcommit,很可能導(dǎo)致后續(xù)的物理內(nèi)存不足。

如果真的發(fā)生了這種情況,就會(huì)觸發(fā)linux內(nèi)核的oom killing機(jī)制,即linux內(nèi)核中的oom killer會(huì)按一定的規(guī)則,選一個(gè)進(jìn)程,將其kill掉,這個(gè)上面我們已經(jīng)演示過了。

那為什么不kill掉第二個(gè)進(jìn)程,而是kill掉第一個(gè)呢?

這個(gè)和linux內(nèi)核中oom killer的選擇策略有關(guān),我們直接看源碼:

 

當(dāng)進(jìn)程請求操作系統(tǒng)為其分配物理內(nèi)存時(shí),如果此時(shí)物理內(nèi)存已經(jīng)沒有了,則會(huì)觸發(fā)上圖中的out_of_memory函數(shù)。

該函數(shù)中,會(huì)使用select_bad_process選擇要被kill掉的進(jìn)程,然后使用oom_kill_process將其kill掉,來釋放物理內(nèi)存。

在看select_bad_process之前,我們先看下oom_kill_process:

 

該函數(shù)調(diào)用了__oom_kill_process:

 

在上面的函數(shù)中,通過向victim進(jìn)程發(fā)送SIGKILL這個(gè)signal(我們平時(shí)使用的kill -9命令,就是用的這個(gè)signal),將其kill掉,然后該kill事件,會(huì)被記錄到內(nèi)核日志中。

注意,這里記錄的日志格式,正好和我們上面用dmesg輸出的,14134進(jìn)程被kill掉事件日志格式完全一樣。

kill掉進(jìn)程的過程就是這樣,我們再來看下select_bad_process函數(shù)是如何選擇要被kill掉進(jìn)程的:

 

在該函數(shù)中,會(huì)遍歷系統(tǒng)中的所有進(jìn)程,然后使用oom_evaluate_task這個(gè)函數(shù),對各個(gè)進(jìn)程進(jìn)行評(píng)估:

 

oom_evaluate_task函數(shù)中,會(huì)使用oom_badness,計(jì)算某進(jìn)程badness的點(diǎn)數(shù),點(diǎn)數(shù)越高,越容易被kill掉。

如果badness的點(diǎn)數(shù)是LONG_MIN這個(gè)特殊值,則直接跳過該進(jìn)程,即該進(jìn)程不會(huì)成為被kill掉的對象,如果badness點(diǎn)數(shù)小于之前選擇進(jìn)程的badness點(diǎn)數(shù),同樣也跳過該進(jìn)程,即被kill掉的進(jìn)程badness點(diǎn)數(shù)要是最大的。

遍歷中選擇的進(jìn)程,及其badness的點(diǎn)數(shù),會(huì)被賦值到oc->chosen和oc->chosen_points里,oc->chosen最終指向的進(jìn)程,就是上面oom_kill_process里kill掉的進(jìn)程。

我們再來看下badness點(diǎn)數(shù)是如何計(jì)算的:

 

該函數(shù)主體邏輯分成兩部分,一部分是,在某些情況下,該進(jìn)程的badness點(diǎn)數(shù)直接返回LONG_MIN,即不會(huì)被kill掉。

這些情況包括,oom_score_adj的值為OOM_SCORE_ADJ_MIN,即-1000,或者該進(jìn)程已經(jīng)在被kill的過程中了,或者該進(jìn)程在vfork過程中。

該函數(shù)邏輯的另外一部分就是計(jì)算進(jìn)程的badness點(diǎn)數(shù),其大致計(jì)算規(guī)則為:

points = 該進(jìn)程占用的物理內(nèi)存總數(shù) + 總物理內(nèi)存 * oom_score_adj值的千分比。

oom_score_adj的值,是進(jìn)程獨(dú)有的,是可以通過寫 /proc/[pid]/oom_score_adj 的方式調(diào)整的,取值范圍為 -1000 到 1000。

該值越大,進(jìn)程總的badness點(diǎn)數(shù)就會(huì)越大,進(jìn)程也就越容易被kill掉。

該值越小,進(jìn)程總的badness點(diǎn)數(shù)就會(huì)越小,該進(jìn)程也就越不容易被kill掉。

上面我們還提到oom_score_adj有一個(gè)特殊值為OOM_SCORE_ADJ_MIN,即-1000,表示該進(jìn)程不能被kill掉。

各進(jìn)程的oom_score_adj的值默認(rèn)為0。

綜上可知,linux內(nèi)核中oom killer選擇被kill進(jìn)程的方式,就是看各進(jìn)程badness點(diǎn)數(shù)的大小。

默認(rèn)情況下,因?yàn)楦鬟M(jìn)程的oom_score_adj的值都為0,所以進(jìn)程占用的物理內(nèi)存越大,其badness點(diǎn)數(shù)也就越大,其也就越容易被kill掉。

這也就解釋了,為什么上面在第二次執(zhí)行那個(gè)程序時(shí),被kill掉的是第一次執(zhí)行的那個(gè)進(jìn)程,而不是第二次執(zhí)行的進(jìn)程,因?yàn)榈谝淮螆?zhí)行的那個(gè)進(jìn)程,占用的物理內(nèi)存更大。

其實(shí),調(diào)整linux內(nèi)核中oom killer行為的方式有很多,不止修改oom_score_adj值這一種方法。

比如,通過修改 /proc/sys/vm/panic_on_oom 的值,可以讓整個(gè)系統(tǒng)在物理內(nèi)存不夠時(shí),直接panic,而不是選擇性的kill掉某個(gè)進(jìn)程。

比如,通過修改 /proc/sys/vm/overcommit_memory 的值,可以使上面第二次執(zhí)行的測試程序,在使用mmap分配虛擬內(nèi)存時(shí),就直接報(bào)錯(cuò),說內(nèi)存不夠。

比如,通過修改 /proc/[pid]/oom_adj 值的方式,同樣可以達(dá)到修改 /proc/[pid]/oom_score_adj 的目的,不過這個(gè)在內(nèi)核2.6.36版本之后已經(jīng)不推薦使用。

oom killer行為調(diào)整的相關(guān)參數(shù),其具體詳解可以看proc的man文檔:

https://man.archlinux.org/man/proc.5

聊了這么多,那理解linux內(nèi)核的oom killer機(jī)制,對于我們實(shí)際應(yīng)用有哪些幫助呢?

我們假設(shè)以下場景:

假如,我們有一臺(tái)機(jī)器,上面跑著一個(gè)非常重要的服務(wù),比如數(shù)據(jù)庫,或者某個(gè)應(yīng)用進(jìn)程等。

它非常耗內(nèi)存,但是正常情況下,它使用的物理內(nèi)存肯定不會(huì)高于實(shí)際總物理內(nèi)存大小。

有一天我們需要在這臺(tái)機(jī)器上執(zhí)行一項(xiàng)任務(wù),如果這個(gè)任務(wù)也比較耗內(nèi)存,那很可能在執(zhí)行這項(xiàng)任務(wù)時(shí),整臺(tái)機(jī)器的物理內(nèi)存就完全不夠用了,此時(shí),就會(huì)觸發(fā)linux內(nèi)核的oom killing機(jī)制。

又因?yàn)樵诓徽{(diào)整oom_score_adj值的情況下,linux內(nèi)核中的oom killer默認(rèn)kill掉的,就是占用物理內(nèi)存最多的那個(gè)進(jìn)程,一般來說,就是我們數(shù)據(jù)庫進(jìn)程,或其他應(yīng)用進(jìn)程,假設(shè)這個(gè)進(jìn)程又是線上的一個(gè)重要服務(wù),那它被kill掉了,你想一下這會(huì)是多么嚴(yán)重的一個(gè)事故。

那怎么避免呢?

此時(shí),我們就可以使用上面提到的,用于調(diào)整進(jìn)程badness點(diǎn)數(shù)的,oom_score_adj 這個(gè)參數(shù)。

比如,我們可以通過 echo -1000 > /proc/[pid]/oom_score_adj 命令,將oom_score_adj的值設(shè)置為-1000,即該進(jìn)程不能被kill掉。

又比如,還是通過上面的echo命令,將oom_score_adj的值修改為一個(gè)較小的值,來降低它被kill掉的概率。

但是,這些方法其實(shí)都不是完美的解決方式。

雖然該機(jī)器上的這個(gè)重要服務(wù)不被kill掉了,但操作系統(tǒng)為了保證整個(gè)系統(tǒng)不crash,還是會(huì)kill掉其他各種進(jìn)程。

如果那些進(jìn)程不重要還好,萬一重要的話,還是會(huì)相當(dāng)嚴(yán)重的。

甚至,如果操作系統(tǒng)找不到可以kill掉的進(jìn)程,那整個(gè)系統(tǒng)就會(huì)crash,這個(gè)就更嚴(yán)重了。

所以,最好的方式,還是人為去避免物理內(nèi)存不足的情況,在機(jī)器上跑各種程序時(shí),要提前對整個(gè)物理內(nèi)存的使用,有個(gè)規(guī)劃和預(yù)判,最好是能預(yù)留出一些內(nèi)存,以防各種誤操作。

 

好了,該篇文章就講這些內(nèi)容,如果以后你發(fā)現(xiàn)你的進(jìn)程,莫名奇妙就沒有了,可以通過dmesg等方式看下內(nèi)核日志,確定下你的進(jìn)程是否被oom kill掉了。

本文轉(zhuǎn)載自微信公眾號(hào)「卯時(shí)卯刻」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系卯時(shí)卯刻公眾號(hào)。

 

責(zé)任編輯:武曉燕 來源: 卯時(shí)卯刻
相關(guān)推薦

2021-10-08 14:32:33

電腦二進(jìn)制計(jì)算機(jī)

2015-08-04 09:24:50

2012-04-04 22:07:12

Android

2020-08-14 09:11:29

RedisQPS數(shù)據(jù)庫

2012-02-28 09:11:51

語言Lua

2020-07-17 14:06:36

Scrum敏捷團(tuán)隊(duì)

2016-06-14 09:48:19

框架

2013-07-10 09:38:22

OpenStackLinux

2019-08-28 10:53:35

JavaScriptOptional Ch代碼

2020-05-13 09:03:14

Python開發(fā)代碼

2015-03-02 15:13:52

Apple Watch

2015-06-04 11:22:22

前端程序員

2023-07-23 17:19:34

人工智能系統(tǒng)

2012-11-14 20:55:07

容錯(cuò)服務(wù)器選型CIO

2014-09-22 10:06:07

2012-06-18 14:51:09

Python

2019-09-17 15:30:13

Java編程語言

2014-01-17 14:39:18

12306 搶票

2025-02-24 10:36:15

2020-04-09 08:29:50

編程語言事件驅(qū)動(dòng)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

中文字幕五月欧美| 麻豆高清免费国产一区| 亚洲国产天堂久久综合网| 欧美一级片免费播放| 天堂在线中文资源| 日本v片在线高清不卡在线观看| 日韩亚洲精品视频| 国产a级黄色片| 99久久久国产精品免费调教网站| 亚洲女厕所小便bbb| 国产午夜精品一区| 在线免费av片| 国产一区91| 最近2019中文字幕mv免费看 | 欧美激情网站| 国产精品毛片高清在线完整版| 国产精品高清一区二区三区| 不卡av电影在线| 在线一区免费| 亚洲性日韩精品一区二区| 一级黄色大片免费看| 秋霞国产精品| 亚洲va欧美va人人爽| 一区二区三区四区免费视频| 香蕉久久一区二区三区| 精品一区二区在线视频| 日本久久久a级免费| 久久精品一区二区三| 久久中文字幕av| 日韩精品在线影院| 国产成人精品一区二区三区在线观看| 美女写真久久影院| 精品久久久久久久久久| 欧美性猛交内射兽交老熟妇| 又爽又大又黄a级毛片在线视频| 99久久国产综合色|国产精品| 91中文在线视频| 亚洲中文无码av在线| 中日韩男男gay无套| 欧美xxxx18性欧美| 久久噜噜色综合一区二区| 国产精品一区二区av日韩在线| 欧美精品一区二| 国产又粗又猛又爽又黄| 亚洲ww精品| 欧美性猛交xxxxxxxx| 国产xxxxx在线观看| 美女高潮在线观看| 午夜久久久影院| a级免费在线观看| 免费a级人成a大片在线观看| 国产区在线观看成人精品 | 亚洲日本一区二区| 亚洲一区免费看| eeuss影院在线观看| 久久久九九九九| 久久综合九色欧美狠狠| 亚洲 欧美 激情 另类| www.一区二区| 精品久久久久久综合日本| 国模人体一区二区| 不卡一二三区首页| 国模精品娜娜一二三区| 无码国产精品一区二区色情男同 | 欧美日韩国产高清| 欧美美女操人视频| 在线观看成人毛片| 亚洲久久在线| 欧美一区二区三区…… | 欧美视频一区二区三区在线观看 | 亚洲丁香久久久| 久久久久麻豆v国产精华液好用吗| 成人影院中文字幕| 日韩成人性视频| 国产又爽又黄无码无遮挡在线观看| 日韩美女国产精品| 国产午夜精品美女视频明星a级| 欧美丰满美乳xxⅹ高潮www| 成人3d动漫在线观看| www.午夜精品| 欧美精品videos极品| 黄色国产精品| 欧美一区二区三区……| 中文字幕在线观看视频免费| 久久精品av麻豆的观看方式| 91嫩草视频在线观看| 日本高清视频免费观看| 久久久不卡影院| 亚洲区成人777777精品| 阿v视频在线| 欧美在线你懂的| 国产成人强伦免费视频网站| 老牛精品亚洲成av人片| 亚洲午夜国产成人av电影男同| 日本二区三区视频| 日韩一级网站| 国产日本欧美在线观看| 99久久久无码国产精品免费| 懂色av中文字幕一区二区三区| 国内视频一区二区| 夜级特黄日本大片_在线| 亚洲精品水蜜桃| 精品视频无码一区二区三区| 国产亚洲观看| 亚洲欧美日韩直播| 69av视频在线| 久色成人在线| aa成人免费视频| 97电影在线观看| 亚洲国产精品一区二区www | 韩日成人影院| 欧美一区二区大片| 国产精久久一区二区三区| 欧美色综合网| 国产精品自产拍在线观看中文| 丰满熟女一区二区三区| 国产精品视频yy9299一区| 精品成在人线av无码免费看| 日韩av黄色| 亚洲人午夜精品| 国产精品自拍视频一区| 韩国一区二区视频| 日本精品国语自产拍在线观看| 色呦呦久久久| 在线不卡免费欧美| 亚洲精品91在线| 亚洲免费高清| 粉嫩av免费一区二区三区| 中国日本在线视频中文字幕| 欧美日韩裸体免费视频| 性高潮久久久久久| 午夜激情久久| 国产精品美乳在线观看| 日本福利片在线| 亚洲18女电影在线观看| 精品无码av一区二区三区不卡| 精品中文一区| 4438全国亚洲精品在线观看视频| 国产黄色片av| 亚洲视频一区在线| 蜜臀一区二区三区精品免费视频 | 亚洲欧美成人一区二区在线电影| 欧美精品一区二区蜜桃| 精品一区二区国语对白| 亚洲黄色一区二区三区| 欧美成人黑人| 亚洲免费电影一区| 免费看一级视频| 久久综合色之久久综合| 国产精品97在线| 欧美日韩看看2015永久免费 | 亚洲国产精品人久久电影| 精品深夜av无码一区二区老年| 国产电影一区在线| 女人被男人躁得好爽免费视频 | 久久视频一区二区三区| 日韩av电影免费观看高清完整版| 欧美一区二区高清在线观看| xxx欧美xxx| 国产亚洲精品91在线| 国产精品第6页| 国产精品久久久久aaaa樱花| 天堂av8在线| 欧美激情四色| 国产91视觉| 鲁鲁在线中文| 国产亚洲欧美aaaa| 在线免费看av的网站| 日韩一区中文字幕| 三大队在线观看| 亚洲网站视频| 免费在线成人av| av高清一区| 久久精品人人爽| 亚洲av无码一区二区三区性色| 亚洲综合免费观看高清完整版| 亚洲av成人精品一区二区三区 | 男女啪啪网站视频| 婷婷亚洲五月色综合| 99久久精品无码一区二区毛片| av资源在线| 亚洲午夜精品视频| 国产精品九九九九| 亚洲 欧美综合在线网络| 成人免费av片| 韩国午夜理伦三级不卡影院| 美女扒开大腿让男人桶| 神马影视一区二区| 成人信息集中地欧美| 大香伊人久久| 国产一区二区三区在线观看视频| 国产精品一级视频| 精品magnet| 亚洲色图日韩精品| www.亚洲国产| 欧美女同在线观看| 日韩午夜av在线| 一本色道久久综合亚洲精品婷婷| 豆花视频一区二区| 国产精品久久久久久久久久ktv | 国产精品视频线看| 一本色道久久hezyo无码| 免费亚洲一区| 麻豆传媒网站在线观看| 岳的好大精品一区二区三区| 亚洲综合在线播放| jvid一区二区三区| 午夜精品理论片| 求av网址在线观看| 亚洲精品资源在线| 丰满人妻一区二区三区免费| 在线观看中文字幕不卡| 国产无遮无挡120秒| 中文字幕在线观看一区二区| 在线观看国产网站| 国产精品主播直播| 我要看一级黄色大片| 激情久久婷婷| 波多野结衣三级在线| 怕怕欧美视频免费大全| 国产精品一区二区三区不卡| 图片一区二区| 国产精品96久久久久久又黄又硬 | 国产精品高潮呻吟久久av黑人| 欧美男男video| 日韩在线免费视频| 国产小视频在线播放| 337p日本欧洲亚洲大胆精品| 国产绿帽一区二区三区| 色美美综合视频| 国内免费精品视频| 亚洲图片一区二区| 日本黄色小说视频| 最新日韩av在线| 呻吟揉丰满对白91乃国产区| 国产欧美日韩三区| 亚洲最大成人网站| 99精品国产99久久久久久白柏| 无码人妻久久一区二区三区蜜桃| 韩国一区二区三区| 欧洲在线免费视频| 美国欧美日韩国产在线播放| 无码内射中文字幕岛国片| 亚洲综合社区| 欧美 国产 综合| 国产精品视频久久一区| 男人插女人视频在线观看| 一区在线播放| 97超碰在线人人| 亚洲激情精品| 男人添女人下部高潮视频在观看| 在线观看视频日韩| av7777777| 国产精品久久久久久久久久妞妞| 亚洲熟妇av日韩熟妇在线| 一区二区三区国产在线| 日日橹狠狠爱欧美超碰| 亚洲一区二区三区高清不卡| 爱福利视频一区二区| 久久亚洲视频| 天天视频天天爽| 精品影视av免费| 能看毛片的网站| 成人高清视频免费观看| 中文字幕 亚洲一区| 久久亚洲精品小早川怜子| 成年人在线观看av| 国产免费久久精品| 五月天色婷婷丁香| 一区二区三区高清不卡| 国产性70yerg老太| 精品久久久久久久久久久久久久 | 欧美日韩国产天堂| 国产精品毛片一区二区在线看舒淇| 欧美乱妇20p| 不卡的日韩av| 亚洲欧美精品suv| 一级毛片视频在线| 欧美激情日韩图片| 校园春色亚洲| 成人免费大片黄在线播放| 视频精品一区二区三区| 欧美二区在线看| 国产精品99一区二区三区| 欧美日韩视频免费| 久久欧美肥婆一二区| 久久精品久久99| www.99精品| 亚洲一级片在线播放| 亚洲精品成人悠悠色影视| 国产精品久久久久久人| 欧美老肥妇做.爰bbww| 全国男人的天堂网| 中文字幕久热精品在线视频| 日本一本在线免费福利| 欧美亚洲在线观看| 高清国产一区二区三区四区五区| 国产精品日韩欧美一区二区| 精品久久久亚洲| 男女裸体影院高潮| 久久综合图片| 中国老熟女重囗味hdxx| 国产亚洲欧美日韩日本| 精国产品一区二区三区a片| 在线国产电影不卡| 色丁香婷婷综合久久| 久久视频在线免费观看| 成人短视频app| 成人在线观看91| 日韩精品二区| 北条麻妃在线视频观看| 国产精品888| 免费一级suv好看的国产网站| 欧美日韩亚洲国产一区| 国产精品特级毛片一区二区三区| 亚洲久久久久久久久久久| 青草视频在线免费直播| 国产精品久久久久久亚洲调教| 欧美日韩夜夜| www.在线观看av| 精品一区二区久久| youjizz亚洲女人| 欧美视频免费在线| 蜜臀av在线观看| 欧美剧在线观看| www 久久久| 亚洲蜜桃在线| 久久一区二区三区超碰国产精品| 不许穿内裤随时挨c调教h苏绵| 国产精品国产自产拍高清av| 神马久久久久久久| 国产视频精品自拍| 日韩欧美精品一区二区三区| 国产精品播放| 国产综合网站| 国产精品嫩草影视| 国产精品久久久久天堂| 欧美另类高清videos的特点| 亚洲免费av网址| 国产精品迅雷| 日韩在线导航| 日韩高清不卡一区二区三区| 国产亚洲无码精品| 欧美午夜激情小视频| 天天操天天干天天爱| 97超碰色婷婷| 精品中文一区| 中文字幕永久视频| 国产精品欧美一区喷水| 中文字幕免费观看视频| 色综久久综合桃花网| yiren22亚洲综合| 亚洲欧美日韩另类精品一区二区三区| 日本午夜一本久久久综合| 国产在线综合视频| 欧美日韩一区二区欧美激情| 91吃瓜网在线观看| 成人在线精品视频| 亚洲综合色网| 中文字幕在线视频播放| 精品久久久久久久久国产字幕| 日产精品久久久久久久性色| 奇米成人av国产一区二区三区| 国产欧美日韩精品高清二区综合区| 日av中文字幕| 国产精品传媒入口麻豆| 国产精品九九九九| 欧美极品第一页| 全国精品免费看| 九九九在线观看视频| 成人免费在线观看入口| 国产高潮在线观看| 91国自产精品中文字幕亚洲| 亚洲人亚洲人色久| 亚洲一区二区在线视频观看| 一区二区三区免费观看| 涩涩视频免费看| 国产精品美腿一区在线看| 欧美69wwwcom| 日本aaa视频| 91精品国产综合久久久久久久| 午夜成年人在线免费视频| 精品九九九九| 久久成人免费网| 男女视频免费看| 中文字幕日韩在线播放| 亚洲精品午夜| 欧美日韩在线中文| 综合亚洲深深色噜噜狠狠网站| 熟妇人妻av无码一区二区三区| 日本久久中文字幕| 中文字幕人成人乱码| 成年人的黄色片| 欧美日韩小视频| 超碰激情在线| 亚洲乱码国产乱码精品天美传媒| www.亚洲精品| 91高潮大合集爽到抽搐| 91精品国产99| 亚洲精品国产成人影院|