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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

《MySQL实战45讲》实践篇 9-15讲 学习笔记

發(fā)布時間:2024/4/11 数据库 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 《MySQL实战45讲》实践篇 9-15讲 学习笔记 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

圖片和內(nèi)容來自于極客時間,如有版權(quán)問題,請聯(lián)系我刪除。

09 | 普通索引和唯一索引,應(yīng)該怎么選擇?

查詢

select id from T where k=5
查詢到葉子節(jié)點,唯一索引在找到第一個之后就會不再搜索,而普通索引會繼續(xù)檢索直到遇到第一個不滿足條件的
二者性能差別微乎其微 ,因為InnoDB是按頁加載數(shù)據(jù)的,只是多執(zhí)行一次指針尋找和一次計算,并不耗時

更新

在不影響數(shù)據(jù)一致性的前提下,InnoDB 會將這些更新操作緩存在 change buffer 中。
將 change buffer 中的操作應(yīng)用到原數(shù)據(jù)頁,得到最新結(jié)果的過程稱為 merge。除了訪問這個數(shù)據(jù)頁會觸發(fā) merge 外,系統(tǒng)有后臺線程會定期 merge。在數(shù)據(jù)庫正常關(guān)閉(shutdown)的過程中,也會執(zhí)行 merge 操作

唯一索引的更新就不能使用 change buffer,實際上也只有普通索引可以使用
change buffer適合于寫多讀少的場景,如果讀多寫少,一個業(yè)務(wù)在寫入之后馬上會做查詢,那么就不適合使用change buffer

普通索引和唯一索引:建議使用普通索引–區(qū)別在于更新的效率上

如果所有的更新后面,都馬上伴隨著對這個記錄的查詢,那么你應(yīng)該關(guān)閉 change buffer。而在其他情況下,change buffer 都能提升更新性能

redo log 主要節(jié)省的是隨機寫磁盤的 IO 消耗(轉(zhuǎn)成順序?qū)?#xff09;,而 change buffer 主要節(jié)省的則是隨機讀磁盤的 IO 消耗。

補充:
首先,業(yè)務(wù)正確性優(yōu)先。這里的比較前提是“業(yè)務(wù)代碼已經(jīng)保證不會寫入重復(fù)數(shù)據(jù)”的情況下,討論性能問題。如果業(yè)務(wù)不能保證,或者業(yè)務(wù)就是要求數(shù)據(jù)庫來做約束,那么沒得選,必須創(chuàng)建唯一索引。

然后,在一些“歸檔庫”的場景,你是可以考慮使用普通索引的。比如,線上數(shù)據(jù)只需要保留半年,然后歷史數(shù)據(jù)保存在歸檔庫。這時候,歸檔數(shù)據(jù)已經(jīng)是確保沒有唯一鍵沖突了。要提高歸檔效率,可以考慮把表里面的唯一索引改成普通索引

課后問題: 如果某次寫入使用了 change buffer 機制,之后主機異常重啟,是否會丟失 change buffer 和數(shù)據(jù)。
是不會丟失.
雖然是只更新內(nèi)存,但是在事務(wù)提交的時候,我們把 change buffer 的操作也記錄到 redo log 里了,所以崩潰恢復(fù)的時候,change buffer 也能找回來。

merge 的過程是否會把數(shù)據(jù)直接寫回磁盤?
merge 的執(zhí)行流程是這樣的:

  • 從磁盤讀入數(shù)據(jù)頁到內(nèi)存(老版本的數(shù)據(jù)頁);
  • 從 change buffer 里找出這個數(shù)據(jù)頁的 change buffer 記錄 (可能有多個),依次應(yīng)用,得到新版數(shù)據(jù)頁;
  • 寫 redo log。這個 redo log 包含了數(shù)據(jù)的變更和 change buffer 的變更。
  • 到這里 merge 過程就結(jié)束了。這時候,數(shù)據(jù)頁和內(nèi)存中 change buffer 對應(yīng)的磁盤位置都還沒有修改,屬于臟頁,之后各自刷回自己的物理數(shù)據(jù),就是另外一個過程了。

    10 | MySQL為什么有時候會選錯索引?

    delimiter ;; create procedure idata() begin declare i int; set i=1; while(i<=100000)do insert into t values(i, i, i); set i=i+1; end while; end;; delimiter ; call idata();

    往表t中插入10萬行記錄,取值按整數(shù)遞增,即:(1,1,1),(2,2,2),(3,3,3) 直到(100000,100000,100000)

    選擇索引是優(yōu)化器的工作

    優(yōu)化器的邏輯

    MySQL 在真正開始執(zhí)行語句之前,并不能精確地知道滿足這個條件的記錄有多少條,而只能根據(jù)統(tǒng)計信息來估算記錄數(shù)。
    這個統(tǒng)計信息就是索引的“區(qū)分度”,而一個索引上不同的值的個數(shù),我們稱之為“基數(shù)”。

    我們可以使用 show index 方法,看到一個索引的基數(shù)。雖然這個表的每一行的三個字段值都是一樣的,但是在統(tǒng)計信息中,這三個索引的基數(shù)值并不同,而且其實都不準確。

    MySQL 是通過采樣統(tǒng)計得到索引的基數(shù)
    采樣統(tǒng)計的時候,InnoDB 默認會選擇 N 個數(shù)據(jù)頁,統(tǒng)計這些頁面上的不同值,得到一個平均值,然后乘以這個索引的頁面數(shù),就得到了這個索引的基數(shù)

    數(shù)據(jù)表是會持續(xù)更新的,索引統(tǒng)計信息也不會固定不變。所以,當變更的數(shù)據(jù)行數(shù)超過 1/M 的時候,會自動觸發(fā)重新做一次索引統(tǒng)計

    在 MySQL 中,有兩種存儲索引統(tǒng)計的方式,可以通過設(shè)置參數(shù) innodb_stats_persistent 的值來選擇:
    設(shè)置為 on 的時候,表示統(tǒng)計信息會持久化存儲。這時,默認的 N 是 20,M 是 10。
    設(shè)置為 off 的時候,表示統(tǒng)計信息只存儲在內(nèi)存中。這時,默認的 N 是 8,M 是 16

    如果show index的統(tǒng)計信息不對,那就修正。analyze table t 命令,可以用來重新統(tǒng)計索引信息

    除了考慮掃描行數(shù),MySQL還會考慮回表造成的額外開銷

    索引選擇異常和處理

    一種方法是,像我們第一個例子一樣,采用 force index 強行選擇一個索引。
    缺點:使用 force index 最主要的問題還是變更的及時性。
    因為選錯索引的情況還是比較少出現(xiàn)的,所以開發(fā)的時候通常不會先寫上 force index。

    第二種方法就是,我們可以考慮修改語句,引導(dǎo) MySQL 使用我們期望的索引。

    mysql> explain select * from t where (a between 1 and 1000) and (b between 50000 and 100000) order by b limit 1;

    這樣的一個SQL,分析應(yīng)該是使用a作為索引掃描行數(shù)更小,但是優(yōu)化器選擇了b(可能是由于這里使用了b進行排序)
    改成 order by b,a limit 1;就可以引導(dǎo)MySQL去使用索引a

    第三種方法是,在有些場景下,我們可以新建一個更合適的索引,來提供給優(yōu)化器做選擇,或刪掉誤用的索引。

    課后問題:為什么經(jīng)過這個操作序列,explain的結(jié)果就不對了?
    delete 語句刪掉了所有的數(shù)據(jù),然后再通過 call idata() 插入了 10 萬行數(shù)據(jù),看上去是覆蓋了原來的 10 萬行。
    但是,session A 開啟了事務(wù)并沒有提交,所以之前插入的 10 萬行數(shù)據(jù)是不能刪除的。這樣,之前的數(shù)據(jù)每一行數(shù)據(jù)都有兩個版本,舊版本是 delete 之前的數(shù)據(jù),新版本是標記為 deleted 的數(shù)據(jù)。

    這樣,索引 a 上的數(shù)據(jù)其實就有兩份。然后你會說,不對啊,主鍵上的數(shù)據(jù)也不能刪,那沒有使用 force index 的語句,使用 explain 命令看到的掃描行數(shù)為什么還是 100000 左右?(潛臺詞,如果這個也翻倍,也許優(yōu)化器還會認為選字段 a 作為索引更合適)

    是的,不過這個是主鍵,主鍵是直接按照表的行數(shù)來估計的。而表的行數(shù),優(yōu)化器直接用的是 show table status 的值。

    11 | 怎么給字符串字段加索引?

    可以針對整個字符串創(chuàng)建索引,也可以使用前綴索引
    使用前綴索引,定義好長度,就可以做到既節(jié)省空間,又不用額外增加太多的查詢成本。
    可以通過區(qū)分度找到一個比較合適的長度

    前綴索引對覆蓋索引的影響
    使用前綴索引就用不上覆蓋索引對查詢性能的優(yōu)化了,這也是你在選擇是否使用前綴索引時需要考慮的一個因素

    如果前綴索引的區(qū)分度不高,怎么辦?比方說身份證,一個縣的前6位基本都是一致的
    一種方式是使用倒序存儲

    mysql> select field_list from t where id_card = reverse('input_id_card_string');

    二種方式是使用 hash 字段
    在表上再創(chuàng)建一個整數(shù)字段,來保存身份證的校驗碼(就是對身份證做hash),同時在這個字段上創(chuàng)建索引

    mysql> select field_list from t where id_card_crc=crc32('input_id_card_string') and id_card='input_id_card_string'

    缺點:兩種都不支持范圍查詢
    區(qū)別:
    1.從占用的額外空間來看,倒序存儲方式在主鍵索引上,不會消耗額外的存儲空間,
    而 hash 字段方法需要增加一個字段。當然,倒序存儲方式使用 4 個字節(jié)的前綴長度應(yīng)該是不夠的,如果再長一點,這個消耗跟額外這個 hash 字段也差不多抵消了。(倒序存儲后還需要創(chuàng)建前綴索引,需要額外的存儲空間)
    2.在 CPU 消耗方面,倒序方式每次寫和讀的時候,都需要額外調(diào)用一次 reverse 函數(shù),而 hash 字段的方式需要額外調(diào)用一次 crc32() 函數(shù)。如果只從這兩個函數(shù)的計算復(fù)雜度來看的話,reverse 函數(shù)額外消耗的 CPU 資源會更小些。
    3.從查詢效率上看,使用 hash 字段方式的查詢性能相對更穩(wěn)定一些。因為 crc32 算出來的值雖然有沖突的概率,但是概率非常小,可以認為每次查詢的平均掃描行數(shù)接近 1。而倒序存儲方式畢竟還是用的前綴索引的方式,也就是說還是會增加掃描行數(shù)

    課后問題: 如何給一個學生學號創(chuàng)建索引
    前三位是所在城市編號、第四到第六位是學校編號,接下來是入學年份+排序號+郵箱后綴(@gamil.com)
    因為維護的只是一個學校的,因此前面 6 位,可以只存入學年份加順序編號,它們的長度是 9 位。

    在此基礎(chǔ)上,可以用數(shù)字類型來存這 9 位數(shù)字。比如 201100001,這樣只需要占 4 個字節(jié)。其實這個就是一種 hash,只是它用了最簡單的轉(zhuǎn)換規(guī)則:字符串轉(zhuǎn)數(shù)字的規(guī)則,而剛好我們設(shè)定的這個背景,可以保證這個轉(zhuǎn)換后結(jié)果的唯一性。

    12 | 為什么我的MySQL會“抖”一下?— 突發(fā)性SQL執(zhí)行變慢

    當內(nèi)存數(shù)據(jù)頁跟磁盤數(shù)據(jù)頁內(nèi)容不一致的時候,我們稱這個內(nèi)存頁為“臟頁”。內(nèi)存數(shù)據(jù)寫入到磁盤后,內(nèi)存和磁盤上的數(shù)據(jù)頁的內(nèi)容就一致了,稱為“干凈頁”

    平時執(zhí)行很快的更新操作,其實就是在寫內(nèi)存和日志,而 MySQL 偶爾“抖”一下的那個瞬間,可能就是在刷臟頁(flush)

    flush時間:
    1.redo log滿了 check point向前移動
    2.系統(tǒng)內(nèi)存不足,需要淘汰一些數(shù)據(jù)頁以加載新的數(shù)據(jù)頁,如果淘汰的是“臟頁”,就要先將臟頁寫到磁盤。
    3.MySQL 認為系統(tǒng)“空閑”的時候
    4.MySQL 正常關(guān)閉的情況

    分析下前兩種對性能的影響:
    1.redo log滿了flush 這種情形需要盡可能避免。因為出現(xiàn)這種情況的時候,整個系統(tǒng)就不能再接受更新了,所有的更新都必須堵住。如果你從監(jiān)控上看,這時候更新數(shù)會跌為 0
    2.“內(nèi)存不夠用了,要先將臟頁寫到磁盤”,這種情況其實是常態(tài)。InnoDB 用緩沖池(buffer pool)管理內(nèi)存,緩沖池中的內(nèi)存頁有三種狀態(tài):
    第一種是,還沒有使用的;
    第二種是,使用了并且是干凈頁;
    第三種是,使用了并且是臟頁

    總結(jié)下:這兩種情況,都是會明顯影響性能的
    1.一個查詢要淘汰的臟頁個數(shù)太多,會導(dǎo)致查詢的響應(yīng)時間明顯變長;
    2.日志寫滿,更新全部堵住,寫性能跌為 0,這種情況對敏感業(yè)務(wù)來說,是不能接受的

    InnoDB 需要有控制臟頁比例的機制,來盡量避免上面的這兩種情況

    InnoDB 刷臟頁的控制策略

    首先需要正確地告訴 InnoDB 所在主機的 IO 能力,這樣 InnoDB 才能知道需要全力刷臟頁的時候,可以刷多快。(innodb_io_capacity)

    InnoDB 的刷盤速度就是要參考這兩個因素:一個是臟頁比例,一個是 redo log 寫盤速度。
    innodb_max_dirty_pages_pct 是臟頁比例上限,默認值是 75%

    InnoDB會根據(jù)當前的臟頁比例(假設(shè)為M),算出一個范圍在0到100之間的數(shù)字

    F1(M) { if M>=innodb_max_dirty_pages_pct then return 100; return 100*M/innodb_max_dirty_pages_pct; }

    InnoDB每次寫入的日志都有一個序號,當前寫入的序號-checkpoint假設(shè)為N。根據(jù)這個N算出一個范圍在0到100之間的數(shù)字,這個計算公式可以記為F2(N),N越大,算出來的值越大。

    引擎就可以按照innodb_io_capacity定義的能力乘以R%來控制刷臟頁的速度。

    要盡量避免這種情況,你就要合理地設(shè)置 innodb_io_capacity 的值,并且平時要多關(guān)注臟頁比例,不要讓它經(jīng)常接近 75%

    一旦一個查詢請求需要在執(zhí)行過程中先 flush 掉一個臟頁時,這個查詢就可能要比平時慢了。
    而 MySQL 會在刷臟時去判斷相鄰的數(shù)據(jù)頁是否是臟頁,是的話就一起flush,并且會不斷蔓延
    在 InnoDB 中,innodb_flush_neighbors 參數(shù)就是用來控制這個行為的,值為 1 的時候會有上述的“連坐”機制,值為 0 時表示不找鄰居,自己刷自己的。
    找“鄰居”這個優(yōu)化在機械硬盤時代是很有意義的,可以減少很多隨機 IO。機械硬盤的隨機 IOPS 一般只有幾百,相同的邏輯操作減少隨機 IO 就意味著系統(tǒng)性能的大幅度提升。
    而如果使用的是 SSD 這類 IOPS 比較高的設(shè)備的話,建議把 innodb_flush_neighbors 的值設(shè)置成 0。

    在 MySQL 8.0 中,innodb_flush_neighbors 參數(shù)的默認值已經(jīng)是 0 了。

    課后問題: 如果一個高配的機器,redo log設(shè)置太小,會發(fā)生什么情況。

    每次事務(wù)提交都要寫redo log,如果設(shè)置太小,很快就會被寫滿,也就是下面這個圖的狀態(tài),這個“環(huán)”將很快被寫滿,write pos一直追著checkpoint。

    這時候系統(tǒng)不得不停止所有更新,去推進checkpoint。

    這時,你看到的現(xiàn)象就是磁盤壓力很小,但是數(shù)據(jù)庫出現(xiàn)間歇性的性能下跌。

    13 | 為什么表數(shù)據(jù)刪掉一半,表文件大小不變?

    一個 InnoDB 表包含兩部分,即:表結(jié)構(gòu)定義和數(shù)據(jù)。在 MySQL 8.0 版本以前,表結(jié)構(gòu)是存在以.frm 為后綴的文件里。而 MySQL 8.0 版本,則已經(jīng)允許把表結(jié)構(gòu)定義放在系統(tǒng)數(shù)據(jù)表中了。

    表數(shù)據(jù)既可以存在共享表空間里,也可以是單獨的文件。這個行為是由參數(shù) innodb_file_per_table 控制的

    ON : 每個 InnoDB 表數(shù)據(jù)存儲在一個以 .ibd 為后綴的文件中。 推薦

    OFF : 表的數(shù)據(jù)放在系統(tǒng)共享表空間,也就是跟數(shù)據(jù)字典放在一起

    一個表單獨存儲為一個文件更容易管理,而且在你不需要這個表的時候,通過 drop table 命令,系統(tǒng)就會直接刪除這個文件。而如果是放在共享表空間中,即使表刪掉了,空間也是不會回收的。

    數(shù)據(jù)刪除流程

    假設(shè),我們要刪掉 R4 這個記錄,InnoDB 引擎只會把 R4 這個記錄標記為刪除。如果之后要再插入一個 ID 在 300 和 600 之間的記錄時,可能會復(fù)用這個位置。但是,磁盤文件的大小并不會縮小

    數(shù)據(jù)頁的復(fù)用跟記錄的復(fù)用是不同的。
    記錄的復(fù)用,只限于符合范圍條件的數(shù)據(jù)。比如上面的這個例子,R4 這條記錄被刪除后,如果插入一個 ID 是 400 的行,可以直接復(fù)用這個空間。但如果插入的是一個 ID 是 800 的行,就不能復(fù)用這個位置了

    如果我們用 delete 命令把整個表的數(shù)據(jù)刪除,那么,所有的數(shù)據(jù)頁都會被標記為可復(fù)用。但是磁盤上,文件不會變小。

    delete 命令其實只是把記錄的位置,或者數(shù)據(jù)頁標記為了“可復(fù)用”

    這些可以復(fù)用,而沒有被使用的空間,看起來就像是“空洞”。實際上,插入數(shù)據(jù)也會造成空洞(發(fā)生頁分裂的時候)。

    經(jīng)過大量增刪改的表,都是可能是存在空洞的。(因為頁分裂導(dǎo)致的索引不緊湊)
    重建表可以幫助我們減少不必要的空間浪費

    新建與表 A 結(jié)構(gòu)相同的表 B,按照主鍵 ID 遞增的順序,把數(shù)據(jù)一行一行地從表 A 里讀出來再插入到表 B 中

    可以使用 alter table A engine=InnoDB 完成重建表
    MySQL 5.5之前要求這個DDL期間 表A不能有數(shù)據(jù)更新 通過創(chuàng)建臨時表來完成

    MySQL 5.6 版本引入的 Online DDL,對這個操作流程做了優(yōu)化

  • 建立一個臨時文件,掃描表 A 主鍵的所有數(shù)據(jù)頁;
  • 用數(shù)據(jù)頁中表 A 的記錄生成 B+ 樹,存儲到臨時文件中;
  • 生成臨時文件的過程中,將所有對 A 的操作記錄在一個日志文件(row log)中,對應(yīng)的是圖中 state2 的狀態(tài);
  • 臨時文件生成后,將日志文件中的操作應(yīng)用到臨時文件,得到一個邏輯數(shù)據(jù)上與表 A 相同的數(shù)據(jù)文件,對應(yīng)的就是圖中 state3 的狀態(tài);
  • 用臨時文件替換表 A 的數(shù)據(jù)文件

    上圖的流程中,alter語句在啟動的時候需要獲取MDL寫鎖,但是這個寫鎖在真正拷貝數(shù)據(jù)之前就退化成讀鎖了。(為了實現(xiàn)Online,MDL讀鎖不會阻塞增刪改操作)
  • 那為什么不干脆直接解鎖呢?為了保護自己,禁止其他線程對這個表同時做DDL。

    而對于一個大表來說,Online DDL最耗時的過程就是拷貝數(shù)據(jù)到臨時表的過程,這個步驟的執(zhí)行期間可以接受增刪改操作。所以,相對于整個DDL過程來說,鎖的時間非常短。對業(yè)務(wù)來說,就可以認為是Online的。

    需要補充說明的是,上述的這些重建方法都會掃描原表數(shù)據(jù)和構(gòu)建臨時文件。對于很大的表來說,這個操作是很消耗IO和CPU資源的。因此,如果是線上服務(wù),你要很小心地控制操作時間。如果想要比較安全的操作的話,我推薦你使用GitHub開源的gh-ost來做。

    Online 和 inplace

    在圖4中,根據(jù)表A重建出來的數(shù)據(jù)是放在“tmp_file”里的,這個臨時文件是InnoDB在內(nèi)部創(chuàng)建出來的。整個DDL過程都在InnoDB內(nèi)部完成。對于server層來說,沒有把數(shù)據(jù)挪動到臨時表,是一個“原地”操作,這就是“inplace”名稱的來源。

    所以,我現(xiàn)在問你,如果你有一個1TB的表,現(xiàn)在磁盤間是1.2TB,能不能做一個inplace的DDL呢?

    答案是不能。因為,tmp_file也是要占用臨時空間的。

    我們重建表的這個語句alter table t engine=InnoDB,其實隱含的意思是:
    alter table t engine=innodb,ALGORITHM=inplace;
    跟inplace對應(yīng)的就是拷貝表的方式了,用法是:

    alter table t engine=innodb,ALGORITHM=copy;
    當你使用ALGORITHM=copy的時候,表示的是強制拷貝表,對應(yīng)的流程就是圖3的操作過程。

    聯(lián)系:
    DDL過程如果是Online的,就一定是inplace的;
    反過來未必,也就是說inplace的DDL,有可能不是Online的。截止到MySQL 8.0,添加全文索引(FULLTEXT index)和空間索引(SPATIAL index)就屬于這種情況。

    optimize table、analyze table 和 alter table 三種方式區(qū)別

    從 MySQL 5.6 版本開始,
    1.alter table t engine = InnoDB(也就是 recreate)默認的就是上面的流程了;
    2.analyze table t 其實不是重建表,只是對表的索引信息做重新統(tǒng)計,沒有修改數(shù)據(jù),這個過程中加了 MDL 讀鎖;
    3.optimize table t 等于 recreate+analyze。

    課后問題: 什么時候使用 alter table t engine=InnoDB 會讓一個表占用的空間反而變大。
    如果這個表,本身就已經(jīng)沒有空洞的了,比如說剛剛做過一次重建表操作。
    在 DDL 期間,如果剛好有外部的 DML 在執(zhí)行,這期間可能會引入一些新的空洞。
    在重建表的時候,InnoDB 不會把整張表占滿,每個頁留了 1/16 給后續(xù)的更新用。也就是說,其實重建表之后不是“最”緊湊的。
    假如是這么一個過程:
    將表 t 重建一次;
    插入一部分數(shù)據(jù),但是插入的這些數(shù)據(jù),用掉了一部分的預(yù)留空間;(此時的預(yù)留空間不足1/16))
    這種情況下,再重建一次表 t,就可能會出現(xiàn)問題中的現(xiàn)象(因為需要預(yù)留空間1/16,導(dǎo)致所需的空間更大))。

    14 | count(*)這么慢,我該怎么辦?

    count的實現(xiàn)方式

    MyISAM 引擎把一個表的總行數(shù)存在了磁盤上,因此執(zhí)行 count 的時候會直接返回這個數(shù),效率很高;
    而 InnoDB 引擎就麻煩了,它執(zhí)行 count 的時候,需要把數(shù)據(jù)一行一行地從引擎里面讀出來,然后累積計數(shù)

    即使是在同一個時刻的多個查詢,由于多版本并發(fā)控制(MVCC)的原因,InnoDB 表“應(yīng)該返回多少行”也是不確定的。 所以InnoDB表沒辦法向MyISAM一樣在磁盤上保存對應(yīng)的表的行數(shù)

    對于 count 這樣的操作,遍歷哪個索引樹得到的結(jié)果邏輯上都是一樣的。因此,*MySQL 優(yōu)化器會找到最小的那棵樹來遍歷。在保證邏輯正確的前提下,盡量減少掃描的數(shù)據(jù)量,是數(shù)據(jù)庫系統(tǒng)設(shè)計的通用法則之一。
    *
    MyISAM 表雖然 count很快,但是不支持事務(wù);

    show table status 命令的輸出結(jié)果里面也有一個TABLE_ROWS用于顯示這個表當前有多少行,但是TABLE_ROWS是從索引的統(tǒng)計值估算來的(而索引的統(tǒng)計值是通過采樣來估算的),因此它也很不準, 官方文檔說誤差可能達到40%到50%。

    InnoDB 表直接 count會遍歷全表,雖然結(jié)果準確,但會導(dǎo)致性能問題。

    所以當遇到count的性能問題時,我們只能自己去實現(xiàn)計數(shù)的方式

    實現(xiàn)計數(shù)的方式

    用緩存系統(tǒng)保存計數(shù)
    問題:
    1.緩存系統(tǒng)可能會丟失更新。redis的持久化可能會有數(shù)據(jù)丟失(取決于你持久化的配置) 可以在重啟后執(zhí)行一次count拿到最新的行數(shù)
    2.有可能會和數(shù)據(jù)庫的結(jié)果不完全一致 (緩存一致性問題)

    在數(shù)據(jù)庫保存計數(shù)
    通過事務(wù)可以解決上述的計數(shù)不一致問題

    不同count()的用法

    count() 是一個聚合函數(shù),對于返回的結(jié)果集,一行行地判斷,如果 count 函數(shù)的參數(shù)不是 NULL,累計值就加 1,否則不加。最后返回累計值。

    count(星號)、count(主鍵 id) 和 count(1) 都表示返回滿足條件的結(jié)果集的總行數(shù);而 count(字段),則表示返回滿足條件的數(shù)據(jù)行里面,參數(shù)“字段”不為 NULL 的總個數(shù)

    原則:

  • server 層要什么就給什么;
  • InnoDB 只給必要的值;
  • 現(xiàn)在的優(yōu)化器只優(yōu)化了 count(星號) 的語義為“取行數(shù)”,其他“顯而易見”的優(yōu)化并沒有做。
  • 對于 count(主鍵 id) 來說 InnoDB 引擎會遍歷整張表,把每一行的 id 值都取出來,返回給 server 層。server 層拿到 id 后,判斷是不可能為空的,就按行累加

    對于 count(1) 來說,InnoDB 引擎遍歷整張表,但不取值。server 層對于返回的每一行,放一個數(shù)字“1”進去,判斷是不可能為空的,按行累加

    count(1) 執(zhí)行得要比 count(主鍵 id) 快。因為從引擎返回 id 會涉及到解析數(shù)據(jù)行,以及拷貝字段值的操作

    對于 count(字段) 來說:
    如果這個“字段”是定義為 not null 的話,一行行地從記錄里面讀出這個字段,判斷不能為 null,按行累加;
    如果這個“字段”定義允許為 null,那么執(zhí)行的時候,判斷到有可能是 null,還要把值取出來再判斷一下,不是 null 才累加。

    但是 count(星號) 是例外,并不會把全部字段取出來,而是專門做了優(yōu)化,不取值。count(星號) 肯定不是 null,按行累加。

    按照效率排序的話,count(字段)<count(主鍵 id)<count(1)≈count(星號),所以建議,盡量使用 count(星號)

    課后問題: 計數(shù)放在Redis里面,不能夠保證計數(shù)和MySQL表里的數(shù)據(jù)精確一致的原因,是這兩個不同的存儲構(gòu)成的系統(tǒng),不支持分布式事務(wù),無法拿到精確一致的視圖。而把計數(shù)值也放在MySQL中,就解決了一致性視圖的問題。

    我們用了事務(wù)來確保計數(shù)準確。由于事務(wù)可以保證中間結(jié)果不被別的事務(wù)讀到,因此修改計數(shù)值和插入新記錄的順序是不影響邏輯結(jié)果的。但是,從并發(fā)系統(tǒng)性能的角度考慮,你覺得在這個事務(wù)序列里,應(yīng)該先插入操作記錄,還是應(yīng)該先更新計數(shù)表呢?

    并發(fā)系統(tǒng)性能的角度考慮,應(yīng)該先插入操作記錄,再更新計數(shù)表。
    知識點在《行鎖功過:怎么減少行鎖對性能的影響?》
    因為更新計數(shù)表涉及到行鎖的競爭,先插入再更新能最大程度地減少事務(wù)之間的鎖等待,提升并發(fā)度。

    15 | 答疑文章(一):日志和索引相關(guān)問題

    問題1: 兩階段期間發(fā)生crash

    A時刻發(fā)生crash會回滾。在B時刻發(fā)生異常:
    如果 redo log 里面的事務(wù)是完整的,也就是已經(jīng)有了 commit 標識,則直接提交;
    如果 redo log 里面的事務(wù)只有完整的 prepare,則判斷對應(yīng)的事務(wù) binlog 是否存在并完整:
    a. 如果是,則提交事務(wù);
    b. 否則,回滾事務(wù)

    問題2:MySQL 怎么知道 binlog 是完整的?

    MySQL一個事務(wù)的bin log是有完整格式的:
    statement 格式的 binlog,最后會有 COMMIT;
    row 格式的 binlog,最后會有一個 XID event

    另外,在MySQL 5.6.2版本以后,還引入了binlog-checksum參數(shù),用來驗證binlog內(nèi)容的正確性。對于binlog日志由于磁盤原因,可能會在日志中間出錯的情況,MySQL可以通過校驗checksum的結(jié)果來發(fā)現(xiàn)。所以,MySQL還是有辦法驗證事務(wù)binlog的完整性的。

    問題3: redo log 和 binlog 是怎么關(guān)聯(lián)起來的?

    它們有一個共同的數(shù)據(jù)字段,叫 XID。
    崩潰恢復(fù)的時候,會按順序掃描 redo log:
    如果碰到既有 prepare、又有 commit 的 redo log,就直接提交;
    如果碰到只有 parepare、而沒有 commit 的 redo log,就拿著 XID 去 binlog 找對應(yīng)的事務(wù)。

    問題4 : 為什么還要兩階段提交呢?干脆先 redo log 寫完,再寫 binlog。崩潰恢復(fù)的時候,必須得兩個日志都完整才可以。是不是一樣的邏輯?

    對于 InnoDB 引擎來說,如果 redo log 提交完成了,事務(wù)就不能回滾(如果這還允許回滾,就可能覆蓋掉別的事務(wù)的更新)。而如果 redo log 直接提交,然后 binlog 寫入的時候失敗,InnoDB 又回滾不了,數(shù)據(jù)和 binlog 日志又不一致了。
    兩階段提交就是為了給所有人一個機會,當每個人都說“我 ok”的時候,再一起提交。

    問題5: 不引入兩個日志,也就沒有兩階段提交的必要了。只用 binlog 來支持崩潰恢復(fù),又能支持歸檔,不就可以了?

    歷史原因:
    InnoDB并不是MySQL的原生存儲引擎。MySQL的原生引擎是MyISAM,設(shè)計之初就有沒有支持崩潰恢復(fù)。
    InnoDB在作為MySQL的插件加入MySQL引擎家族之前,就已經(jīng)是一個提供了崩潰恢復(fù)和事務(wù)支持的引擎了。InnoDB接入了MySQL后,發(fā)現(xiàn)既然binlog沒有崩潰恢復(fù)的能力,那就用InnoDB原有的redo log好了。

    問題在于binlog 沒有能力恢復(fù)“數(shù)據(jù)頁”。
    如果在圖中標的位置,也就是 binlog2 寫完了,但是整個事務(wù)還沒有 commit 的時候,MySQL 發(fā)生了 crash。
    重啟后,引擎內(nèi)部事務(wù) 2 會回滾,然后應(yīng)用 binlog2 可以補回來;
    但是對于事務(wù) 1 來說,系統(tǒng)已經(jīng)認為提交完成了,不會再應(yīng)用一次 binlog1。

    但是,InnoDB 引擎使用的是 WAL 技術(shù),執(zhí)行事務(wù)的時候,寫完內(nèi)存和日志,事務(wù)就算完成了。
    如果之后崩潰,要依賴于日志來恢復(fù)數(shù)據(jù)頁。也就是說在圖中這個位置發(fā)生崩潰的話,事務(wù) 1 也是可能丟失了的,而且是數(shù)據(jù)頁級的丟失。此時,binlog 里面并沒有記錄數(shù)據(jù)頁的更新細節(jié),是補不回來的。

    如果要說,那我優(yōu)化一下binlog的內(nèi)容,讓它來記錄數(shù)據(jù)頁的更改可以嗎?可以但是這其實就是又做了一個redo log出來。

    所以,至少現(xiàn)在的binlog能力,還不能支持崩潰恢復(fù)。

    我的理解:這跟InnoDB的設(shè)計有關(guān),它使用了WAL技術(shù),而redo log里記錄的是已經(jīng)更新到緩存但是還沒有更新到磁盤的數(shù)據(jù)修改。但是bin log文件是記錄了所有的操作,如果只使用bin log,那么就沒辦法知道哪些日志是需要用來恢復(fù)數(shù)據(jù)的,如果把之前已經(jīng)提交的事務(wù)的bin log又拿過來執(zhí)行,就又跟bin log設(shè)計的初衷違背了

    問題6:那能不能反過來,只用redo log,不要binlog?

    只從崩潰恢復(fù)的角度來講是可以的,沒有binlog關(guān)掉,系統(tǒng)依然是crash-safe的。

    但是bin log尤其重要作用
    一個是歸檔。redo log是循環(huán)寫,起不到歸檔的作用。
    一個就是MySQL系統(tǒng)依賴于binlog。MySQL系統(tǒng)高可用的基礎(chǔ),就是binlog復(fù)制。
    還有很多公司有異構(gòu)系統(tǒng)(比如一些數(shù)據(jù)分析系統(tǒng)),這些系統(tǒng)就靠消費MySQL的binlog來更新自己的數(shù)據(jù)。關(guān)掉binlog的話,這些下游系統(tǒng)就沒法輸入了。

    問題7: redo log一般設(shè)置多大?

    redo log太小的話,會導(dǎo)致很快就被寫滿,然后不得不強行刷redo log。如果是現(xiàn)在常見的幾個TB的磁盤的話,可以直接將redo log設(shè)置為4個文件、每個文件1GB吧。

    問題8: 正常運行中的實例,數(shù)據(jù)寫入后的最終落盤,是從 redo log 更新過來的還是從 buffer pool 更新過來的呢?

    實際上,redo log 并沒有記錄數(shù)據(jù)頁的完整數(shù)據(jù),所以它并沒有能力自己去更新磁盤數(shù)據(jù)頁,也就不存在“數(shù)據(jù)最終落盤,是由 redo log 更新過去”的情況。

    如果是正常運行的實例的話,數(shù)據(jù)頁被修改以后,跟磁盤的數(shù)據(jù)頁不一致,稱為臟頁。最終數(shù)據(jù)落盤,就是把內(nèi)存中的數(shù)據(jù)頁寫盤。這個過程,甚至與 redo log 毫無關(guān)系。
    在崩潰恢復(fù)場景中,InnoDB 如果判斷到一個數(shù)據(jù)頁可能在崩潰恢復(fù)的時候丟失了更新,就會將它讀到內(nèi)存,然后讓 redo log 更新內(nèi)存內(nèi)容。更新完成后,內(nèi)存頁變成臟頁,就回到了第一種情況的狀態(tài)。

    問題9: redo log buffer 是什么?是先修改內(nèi)存,還是先寫 redo log 文件?


    redo log buffer 就是一塊內(nèi)存,用來先存 redo 日志的。
    真正把日志寫到 redo log 文件(文件名是 ib_logfile+ 數(shù)字),是在執(zhí)行 commit 語句的時候做的
    在事務(wù)執(zhí)行過程中執(zhí)行的生成的日志是需要先保存到redo log buffer的

    業(yè)務(wù)設(shè)計問題

    業(yè)務(wù)上有這樣的需求,A、B 兩個用戶,如果互相關(guān)注,則成為好友。
    設(shè)計上是有兩張表,一個是 like 表,一個是 friend 表,like 表有 user_id、liker_id 兩個字段,我設(shè)置為復(fù)合唯一索引即 uk_user_id_liker_id。
    語句執(zhí)行邏輯是這樣的:
    以 A 關(guān)注 B 為例:
    第一步,先查詢對方有沒有關(guān)注自己(B 有沒有關(guān)注 A)
    select * from like where user_id = B and liker_id = A;
    如果有,則成為好友insert into friend;沒有,則只是單向關(guān)注關(guān)系insert into like;

    但是如果 A、B 同時關(guān)注對方,會出現(xiàn)不會成為好友的情況。因為上面第 1 步,雙方都沒關(guān)注對方。第 1 步即使使用了排他鎖也不行,因為記錄不存在,行鎖無法生效。

    請問這種情況,在 MySQL 鎖層面有沒有辦法處理?

    CREATE TABLE `like` ( `id` int(11) NOT NULL AUTO_INCREMENT, `user_id` int(11) NOT NULL, `liker_id` int(11) NOT NULL, PRIMARY KEY (`id`), UNIQUE KEY `uk_user_id_liker_id` (`user_id`,`liker_id`) ) ENGINE=InnoDB;CREATE TABLE `friend` ( id` int(11) NOT NULL AUTO_INCREMENT, `friend_1_id` int(11) NOT NULL, `firned_2_id` int(11) NOT NULL, UNIQUE KEY `uk_friend` (`friend_1_id`,`firned_2_id`) PRIMARY KEY (`id`) ) ENGINE=InnoDB;

    上述問題就是如下場景:

    首先,要給“l(fā)ike”表增加一個字段,比如叫作 relation_ship,并設(shè)為整型,取值 1、2、3

    值是 1 的時候,表示 user_id 關(guān)注 liker_id;
    值是 2 的時候,表示 liker_id 關(guān)注 user_id;
    值是 3 的時候,表示互相關(guān)注。

    當 A 關(guān)注 B 的時候,邏輯改成如下所示的樣子:
    應(yīng)用代碼里面,比較 A 和 B 的大小,如果 A<B,就執(zhí)行下面的邏輯
    (這里的on duplicate key update就是如果插入失敗就更新的意思)

    mysql> begin; /*啟動事務(wù)*/ insert into `like`(user_id, liker_id, relation_ship) values(A, B, 1) on duplicate key update relation_ship=relation_ship | 1; select relation_ship from `like` where user_id=A and liker_id=B; /*代碼中判斷返回的 relation_ship,如果是1,事務(wù)結(jié)束,執(zhí)行 commit如果是3,則執(zhí)行下面這兩個語句:*/ insert ignore into friend(friend_1_id, friend_2_id) values(A,B); commit;

    如果A>B,則執(zhí)行如下:

    mysql> begin; /*啟動事務(wù)*/ insert into `like`(user_id, liker_id, relation_ship) values(B, A, 2) on duplicate key update relation_ship=relation_ship | 2; select relation_ship from `like` where user_id=B and liker_id=A; /*代碼中判斷返回的 relation_ship,如果是2,事務(wù)結(jié)束,執(zhí)行 commit如果是3,則執(zhí)行下面這兩個語句: */ insert ignore into friend(friend_1_id, friend_2_id) values(B,A); commit;

    讓“l(fā)ike”表里的數(shù)據(jù)保證 user_id < liker_id,這樣不論是 A 關(guān)注 B,還是 B 關(guān)注 A,在操作“l(fā)ike”表的時候,如果反向的關(guān)系已經(jīng)存在,就會出現(xiàn)行鎖沖突

    然后,insert … on duplicate 語句,確保了在事務(wù)內(nèi)部,執(zhí)行了這個 SQL 語句后,就強行占住了這個行鎖,之后的 select 判斷 relation_ship 這個邏輯時就確保了是在行鎖保護下的讀操作。

    操作符 “|” 是按位或,連同最后一句 insert 語句里的 ignore,是為了保證重復(fù)調(diào)用時的冪等性。

    這樣,即使在雙方“同時”執(zhí)行關(guān)注操作,最終數(shù)據(jù)庫里的結(jié)果,也是 like 表里面有一條關(guān)于 A 和 B 的記錄,而且 relation_ship 的值是 3, 并且 friend 表里面也有了 A 和 B 的這條記錄。

    我的理解:
    通過添加relation_ship字段,將A,B之間相互關(guān)注的操作都集中在同一記錄里(前面因為是在操作不同的記錄導(dǎo)致可以并發(fā)操作),這樣就可以利用InnoDB的行鎖來解決同時關(guān)注的問題。
    使用了"|" 按位或來簡化代碼操作,如果插入時的relation_ship和自己想要插入的不一致,那么就說明是相互關(guān)注,"|"運算后就得到3(相互關(guān)注的關(guān)系)

    之所以要根據(jù)A,B的大小判斷也是為了讓A,B之間的關(guān)注操作的都是同一記錄

    課后問題:

    mysql> CREATE TABLE `t` ( `id` int(11) NOT NULL primary key auto_increment, `a` int(11) DEFAULT NULL ) ENGINE=InnoDB; insert into t values(1,2);

    表t里有唯一的一行數(shù)據(jù)(1,2)。假設(shè),我現(xiàn)在要執(zhí)行:

    mysql> update t set a=2 where id=1;

    你會看到這樣的結(jié)果:

    僅從現(xiàn)象上看,MySQL內(nèi)部在處理這個命令的時候,可以有以下三種選擇:

  • 更新都是先讀后寫的,MySQL讀出數(shù)據(jù),發(fā)現(xiàn)a的值本來就是2,不更新,直接返回,執(zhí)行結(jié)束;
  • MySQL調(diào)用了InnoDB引擎提供的“修改為(1,2)”這個接口,但是引擎發(fā)現(xiàn)值與原來相同,不更新,直接返回;
  • InnoDB認真執(zhí)行了“把這個值修改成(1,2)"這個操作,該加鎖的加鎖,該更新的更新。
  • 你覺得實際情況會是以上哪種呢?你可否用構(gòu)造實驗的方式,來證明你的結(jié)論?進一步地,可以思考一下,MySQL為什么要選擇這種策略呢?

    第一個選項是,MySQL 讀出數(shù)據(jù),發(fā)現(xiàn)值與原來相同,不更新,直接返回,執(zhí)行結(jié)束。這里我們可以用一個鎖實驗來確認。假設(shè),當前表 t 里的值是 (1,2)。

    session B 的 update 語句被 blocked 了,加鎖這個動作是 InnoDB 才能做的,而讀取操作不會鎖記錄,所以排除選項 1。

    第二個選項是,MySQL 調(diào)用了 InnoDB 引擎提供的接口,但是引擎發(fā)現(xiàn)值與原來相同,不更新,直接返回。這里用一個可見性實驗來確認

    session A 的第二個 select 語句是一致性讀(快照讀),讀取的數(shù)據(jù)是session A快照生成時的數(shù)據(jù),session A的快照讀按理是不能看見 session B 的更新的。現(xiàn)在它返回的是 (1,3),表示它看見了某個新的版本,那么這個版本只能是 session A 自己的 update 語句做更新的時候生成。

    答案應(yīng)該是選項 3,即:InnoDB 認真執(zhí)行了“把這個值修改成 (1,2)"這個操作,該加鎖的加鎖,該更新的更新。
    然后你會說,MySQL 怎么這么笨,就不會更新前判斷一下值是不是相同嗎?如果判斷一下,不就不用浪費 InnoDB 操作,多去更新一次了?
    其實 MySQL 是確認了的。只是在這個語句里面,MySQL 認為讀出來的值,只有一個確定的 (id=1), 而要寫的是 (a=3),只從這兩個信息是看不出來“不需要修改”的。

    我覺得還可以反向思維 : 如果在執(zhí)行的時候不進行加鎖和更新操作,那么此時其他會話就是有可能去操作這個數(shù)據(jù)的,這樣一來數(shù)據(jù)就可能會產(chǎn)生不一致的問題

    session Asession B
    begin;
    update t set a=2 where id=1;
    update t set a=5 where id=1; //blocked
    update t set a=a+1 where id=1;
    commit;

    實際操作后的數(shù)據(jù)是(1,3)

    說明在session A執(zhí)行update t set a=2 where id=1;的時候就已經(jīng)鎖住了對應(yīng)的記錄,否則就會被session B的操作修改該記錄

    總結(jié)

    以上是生活随笔為你收集整理的《MySQL实战45讲》实践篇 9-15讲 学习笔记的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    久草国产在线观看 | 九九视频免费在线观看 | 久久草草热国产精品直播 | 欧美成人高清 | 亚洲国产一区在线观看 | 九九久久久久久久久激情 | 久操97 | 成人黄色小说视频 | 国产中文字幕网 | 91国内在线 | 天天操天天干天天爱 | 国际av在线 | 一级淫片在线观看 | 中文字幕久久精品 | a级黄色片视频 | 激情综合色综合久久 | 五月综合色 | 免费观看av | 人人看人人草 | 草久久精品 | 精品一区二区在线播放 | 免费av一级电影 | 免费观看一级 | a久久免费视频 | 国产香蕉在线 | 亚洲精品一区二区三区在线观看 | 免费av网站在线看 | 久久久久久久久久久久久影院 | 一区二区视频在线免费观看 | 97香蕉久久超级碰碰高清版 | 人人爽人人av | 久久午夜免费观看 | 2023天天干| 中文字幕欲求不满 | 91免费在线视频 | 在线观看完整版 | 久久久久免费看 | 久青草视频在线观看 | 久久久天堂 | 免费黄色在线网址 | 973理论片235影院9 | www.五月婷 | 成人xxxx | 99欧美| 黄色国产精品 | 久草在线免 | 国产午夜精品一区二区三区 | 天天摸夜夜操 | 天天爽夜夜爽精品视频婷婷 | 亚洲精品乱码久久久久久高潮 | 日韩精品1区2区 | 亚洲国产精品视频在线观看 | 激情小说久久 | 亚洲精品五月天 | 欧美精品久久久久久久久老牛影院 | 天天综合操 | 黄色一级动作片 | 91在线视频精品 | 国产福利a | 久久久国产一区二区 | 色综合a| 国产视频一二区 | 国产亚洲一区 | 日韩中文在线电影 | 亚洲天堂免费视频 | 久久久精品成人 | 99久高清在线观看视频99精品热在线观看视频 | 日韩av手机在线观看 | 国产色一区| 国产91成人在在线播放 | 在线国产福利 | 欧美最新大片在线看 | 91麻豆精品国产91 | 久久一二区| 久草精品免费 | 久久超碰免费 | 国产精品一区二区美女视频免费看 | 啪啪小视频网站 | 午夜久久久久久久久 | 一区二区视频欧美 | 久久国产精品久久精品 | 国产高清区| 天天摸日日操 | 欧美日韩国产一二 | 亚洲天天摸日日摸天天欢 | 免费观看福利视频 | 中文乱码视频在线观看 | 欧美一二三区在线观看 | 国产色一区| 波多野结衣在线观看视频 | av直接看| 在线成人免费电影 | 激情综合五月 | 成人av在线影院 | 一级全黄毛片 | 九九交易行官网 | 国产在线观看高清视频 | 中文字幕免费一区 | 天天综合入口 | 五月天国产 | 91在线精品一区二区 | 免费观看黄色12片一级视频 | 国产在线a免费观看 | 国产乱对白刺激视频在线观看女王 | 日韩伦理片一区二区三区 | a国产精品 | 久久久久久久国产精品视频 | 在线亚洲小视频 | 亚洲国产精品va在线看 | 欧美久久99 | 国产高清在线a视频大全 | 美女黄频 | 九色精品免费永久在线 | 91精品国自产在线 | 国产麻豆视频网站 | 久久久免费 | 97影视| av短片在线 | 激情五月综合网 | 日韩欧美99 | 久久黄色网址 | 狠狠操.com | 国内久久精品视频 | 91在线免费播放 | 日韩精品一区二区在线 | 中文字幕中文字幕在线中文字幕三区 | 久久精品一区二区三区视频 | 亚洲涩涩涩涩涩涩 | 国产剧在线观看片 | 黄色小说视频在线 | 日韩色视频在线观看 | 天天操夜夜操天天射 | 射综合网 | 日韩理论视频 | 国产91精品一区二区麻豆网站 | 99精品免费久久久久久久久 | 国产精品九九久久久久久久 | 天天操天天操天天爽 | a特级毛片 | www黄com| 色综合久久久久综合体 | 毛片网在线 | 麻豆视传媒官网免费观看 | 狠狠色狠狠色合久久伊人 | 男女啪啪网站 | 久久av福利 | 亚洲男男gaygayxxxgv | 成人av影院在线观看 | 欧美精品第一 | 91桃色在线观看视频 | 久久精品日本啪啪涩涩 | 色多多视频在线观看 | 午夜少妇一区二区三区 | 五月视频| 国产精品久久久久aaaa九色 | 欧美性生活免费 | 午夜成人影视 | 婷婷中文字幕在线观看 | 在线观看日韩国产 | 国产免费作爱视频 | 亚一亚二国产专区 | 亚洲天天在线日亚洲洲精 | 91精品久久久久久久久久入口 | 99热精品在线观看 | 91丨九色丨国产在线 | 不卡中文字幕av | 波多野结衣久久资源 | 97人人人人 | 丁香六月婷婷开心 | 国产一级免费视频 | av免费在线观看网站 | 久久久久成人免费 | 亚洲免费不卡 | 日韩欧美在线第一页 | 中文字幕美女免费在线 | 美女网站久久 | 欧美特一级 | 精品免费视频. | 久久视频6| 99热精品国产 | 国产精品毛片久久 | 夜夜操夜夜干 | 日韩一级片网址 | 视色网站 | 国产91av视频在线观看 | 久久久亚洲网站 | 在线观看午夜 | 四虎影视国产精品免费久久 | 中文字幕在线看视频国产 | 久久久免费精品 | 91福利视频久久久久 | 日韩在线免费看 | 在线免费观看黄网站 | 国产中文字幕一区 | 久青草视频在线观看 | 99精品一区 | 日韩免费成人av | 国产一级视频免费看 | 国产精品二区在线观看 | 国产日韩精品欧美 | 国产精品久久网 | 欧美一二三专区 | 亚洲激精日韩激精欧美精品 | 在线97| 国产一区二区在线免费播放 | 999久久久久久久久 69av视频在线观看 | 国产日韩欧美在线观看 | 日日夜夜狠狠干 | 国产精品99精品 | 91丨九色丨国产丨porny精品 | 亚洲精品视频二区 | 日韩精品久久久久久久电影99爱 | 精品久久久久久亚洲 | 日韩一级成人av | 黄色的视频网站 | 精品视频久久久 | 日本中文在线观看 | 免费精品视频在线观看 | 91色九色| 中文字幕一区二区三区久久 | 狠狠操狠狠干2017 | 亚洲国产精品传媒在线观看 | 91麻豆精品 | 国内丰满少妇猛烈精品播 | 精品毛片一区二区免费看 | 成年人国产精品 | 91精品网站| 久久久久久久久久久国产精品 | 国产亚洲精品久 | 天天操天天爱天天干 | 激情五月婷婷丁香 | 91麻豆精品国产91久久久久久久久 | 伊人亚洲精品 | 成年人在线电影 | 国产亚洲人成网站在线观看 | 91精品久久久久久久久久久久久 | 久久亚洲综合色 | 欧美日韩aa | 国产精品午夜在线 | 久草免费在线 | 国产无套一区二区三区久久 | 91在线91拍拍在线91 | 中文字幕日韩精品有码视频 | 天堂中文在线视频 | 久久久精品国产一区二区电影四季 | 国产91aaa| 香蕉久久久久久av成人 | 亚洲激情视频在线观看 | 亚洲一级理论片 | 欧洲视频一区 | 黄色在线观看网站 | 最近中文字幕视频网 | 精品一区二区电影 | 天天·日日日干 | 伊人亚洲综合 | 在线观看一区 | 日本三级人妇 | 久久老司机精品视频 | 国产97视频在线 | 久久久久久不卡 | 精品视频免费观看 | 国产精品久久久久久久久久久免费看 | 91九色综合| 亚洲资源网 | 亚洲精品国产日韩 | 亚洲人成免费 | 国产成人一区二区三区免费看 | 99产精品成人啪免费网站 | 成年人免费在线观看网站 | 久久免费看片 | 色多多视频在线观看 | 国产精品一区二区免费看 | 波多野结衣网址 | 成人av在线播放网站 | 黄色免费在线视频 | 日韩视频在线观看视频 | 亚洲日韩欧美视频 | 国产在线精品一区二区不卡了 | 激情影院在线观看 | 国产色秀视频 | 一级淫片在线观看 | 久久久久久久久久久久亚洲 | 色五月激情五月 | 国产精品久久伊人 | 国产91对白在线播 | 成人91免费视频 | 久久久久麻豆v国产 | 视频二区在线 | 久久激情视频免费观看 | 国产亚洲免费观看 | 97香蕉超级碰碰久久免费软件 | 成人久久久精品国产乱码一区二区 | 日日爱999 | 高清一区二区三区av | 日本精品一区二区在线观看 | 午夜在线免费观看 | 91免费高清 | 日本在线观看一区 | 91在线观看欧美日韩 | 黄色影院在线播放 | 欧美人人 | 日韩视频区 | 91精品国产高清自在线观看 | 91久久国产露脸精品国产闺蜜 | 日韩网站在线播放 | 伊人狠狠色 | 美女网站久久 | 有没有在线观看av | 丰满少妇在线 | 91毛片在线 | 国产成人精品网站 | 91自拍成人 | 免费在线黄 | 久草精品视频在线看网站免费 | av资源免费看 | 天天色综合天天 | 黄网站污| 91精品爽啪蜜夜国产在线播放 | 久久免费试看 | 狠狠色丁香九九婷婷综合五月 | 久久99视频精品 | av在线在线 | 人人干人人爽 | 久久经典国产视频 | 五月婷婷欧美视频 | 亚洲在线视频观看 | 97电影在线看视频 | 91av免费观看 | 国产色婷婷精品综合在线手机播放 | 久久免费电影网 | 亚洲免费永久精品国产 | 欧美日韩综合在线 | 国产男女免费完整视频 | 国产精品一区二区久久久久 | 国产免费人成xvideos视频 | 国产裸体视频网站 | 揉bbb玩bbb少妇bbb| 国产99久久久国产精品 | 制服丝袜天堂 | 国产啊v在线观看 | 久草在线视频在线观看 | 欧美与欧洲交xxxx免费观看 | 国产在线一区二区 | www好男人| 久久超级碰视频 | 中文字幕色站 | 日批网站在线观看 | 超碰97在线看 | av成人免费在线观看 | 日韩在线第一区 | 久久精品一二三区白丝高潮 | 精品国产乱码久久久久久浪潮 | 超碰在线1| 国产精品综合久久久 | 国产免费黄视频在线观看 | 激情电影影院 | 高清不卡一区二区三区 | 色综合久久综合中文综合网 | 久久精品官网 | 二区三区中文字幕 | 天天干天天操天天爱 | 久久99精品国产99久久6尤 | 日韩精品无 | 中文字幕国内精品 | 天天躁日日躁狠狠躁 | 国产精品av在线免费观看 | 丝袜美腿在线 | 免费网站观看www在线观看 | 国产精品久久久久四虎 | 国产日本在线播放 | 亚洲日本三级 | 一本一本久久a久久 | 国产免费观看视频 | 久久精品99国产国产 | 日韩成人在线免费观看 | 六月丁香伊人 | 欧美在线视频a | 欧美国产精品一区二区 | 夜添久久精品亚洲国产精品 | 欧美人交a欧美精品 | 久久99免费| 在线a人v观看视频 | 国产精品久久久久9999 | 久久精品女人毛片国产 | 人人看人人爱 | 久久中文字幕视频 | 激情婷婷六月 | 国产精品久久网 | 久久久精品电影 | 人人干人人爽 | 亚洲激情在线 | 国产一区精品在线 | 午夜视频免费在线观看 | 成人永久免费 | 国产精品日韩在线播放 | 欧美日韩在线观看一区二区三区 | 色综合五月 | 久久久精品国产一区二区三区 | 久草视频在线免费看 | 99久久视频| 久久视频在线免费观看 | 中文字幕一区二区三区久久蜜桃 | 国产精品久久久久久久毛片 | 亚洲欧美日韩一级 | 亚洲黄色在线免费观看 | 日日干网 | 精品在线不卡 | 久久国产精品小视频 | 国产综合精品久久 | av品善网| 激情中文在线 | 中文字幕免费高 | 2020天天干夜夜爽 | 国产尤物一区二区三区 | 国产传媒一区在线 | 久久色在线播放 | 中文字幕 国产精品 | 九九免费在线观看视频 | 91成人在线观看喷潮 | 日韩精品一区二区三区在线播放 | 中文字幕区 | 99精品国产一区二区三区麻豆 | 午夜性生活| 国产精品视频99 | 亚洲一区免费在线 | 日韩videos | 欧美日韩精品影院 | 国产品久精国精产拍 | 久久国产网站 | 免费看wwwwwwwwwww的视频 久久久久久99精品 91中文字幕视频 | 91精品国产高清自在线观看 | 97超碰站| 午夜体验区 | 精品国产伦一区二区三区观看说明 | 国产精品久久久777 成人手机在线视频 | 国产成人综 | 天天综合在线观看 | 久久久久久久久久久久久久免费看 | 亚洲午夜不卡 | av在线com| 久久高清视频免费 | 四虎小视频 | 国产精品人成电影在线观看 | 久久全国免费视频 | 日韩手机在线 | 一级免费片 | 成年性视频 | 久久99精品国产麻豆婷婷 | 天天射成人 | 五月婷婷毛片 | 亚洲精品视| 五月婷婷在线观看 | 日韩乱理 | 国产很黄很色的视频 | 色婷婷色 | 亚洲区另类春色综合小说 | 日本深夜福利视频 | 欧美激精品 | 我要色综合天天 | 日韩大片免费在线观看 | 国产在线一线 | 日韩在线观看第一页 | 91精品在线免费观看视频 | 日本精品小视频 | 美女久久视频 | 国产流白浆高潮在线观看 | 亚洲a资源 | 日韩中文字幕电影 | 国产无遮挡又黄又爽在线观看 | 亚洲砖区区免费 | 性日韩欧美在线视频 | 国产精品久久久久久久久久久不卡 | 久久久网页 | 又黄又爽又刺激的视频 | 青青草国产在线 | 夜夜视频欧洲 | 91精品导航 | 亚洲精品影视在线观看 | 久久tv视频 | 97精品国产| 免费精品在线视频 | 午夜精品电影 | 波多野结衣在线播放一区 | 亚洲成人网在线 | 国产麻豆成人传媒免费观看 | 久久国产手机看片 | 中文字幕.av.在线 | h文在线观看免费 | 99久久精品免费看国产免费软件 | 久久久久免费看 | 久久的色 | 欧美一级电影免费观看 | 日韩视频中文 | 国产一区免费在线观看 | 久久五月情影视 | 亚洲高清视频在线播放 | 亚洲香蕉视频 | 天天操天天舔天天干 | 美女视频黄是免费的 | 免费男女羞羞的视频网站中文字幕 | 91成人在线免费观看 | 久久久久亚洲精品中文字幕 | 黄色免费高清视频 | 91亚洲综合| 国产经典 欧美精品 | 成人在线视频论坛 | 999成人 | 香蕉视频在线免费看 | 久草视频在线资源站 | 亚洲国产经典视频 | 日本在线观看中文字幕无线观看 | 成人av在线一区二区 | 久久三级毛片 | 中文字幕国产精品 | 手机在线中文字幕 | 久热国产视频 | 国产1区2区3区精品美女 | 欧美日韩国产伦理 | 婷婷去俺也去六月色 | 国产99一区视频免费 | 国产精品一区二区三区在线播放 | 欧美成人在线网站 | 黄色免费观看网址 | 中文字幕在线播放一区 | 日韩中文字幕国产精品 | 在线观看中文字幕视频 | 精品国产一区二区三区久久久蜜月 | 国产精品系列在线 | 日韩免费高清在线观看 | 99re8这里有精品热视频免费 | 91人人在线 | 91精品电影 | 欧美一区二区在线 | 丝袜制服天堂 | 精品国产乱码久久久久久1区2匹 | 成人精品一区二区三区中文字幕 | 97人人爽| 日韩激情第一页 | 五月婷婷国产 | 国产伦精品一区二区三区高清 | 国产xxxx | 蜜桃av久久久亚洲精品 | 国产精品久久久一区二区 | 日韩大片在线看 | 午夜婷婷在线播放 | 欧美一级网站 | 国产精品久久久久久电影 | 国产精品高清一区二区三区 | 国产 日韩 中文字幕 | 九九热av | 国产精品久久久久一区二区三区共 | 色视频在线看 | 日日添夜夜添 | 黄色一级在线视频 | 人人澡人人爽欧一区 | 日本久久高清视频 | av资源免费在线观看 | 国产一二区视频 | 久av在线 | 日产乱码一二三区别在线 | 超碰在线cao | 国产美女网| 国产一区二区在线观看免费 | 亚洲黄色一级大片 | 国产在线欧美在线 | 高清不卡免费视频 | 91在线你懂的 | 国偷自产中文字幕亚洲手机在线 | 久久久久久久久久久久av | 天天干 天天摸 天天操 | 日日爱夜夜爱 | 在线观看国产成人av片 | 成年人国产视频 | 久久曰视频 | 99在线观看免费视频精品观看 | 久久久免费 | 亚洲黄网站| 一级做a爱片性色毛片www | 天天爱天天干天天爽 | 成人午夜电影在线观看 | 欧美日韩一区二区免费在线观看 | 网站在线观看你们懂的 | 国内视频1区 | 国产xxxx| 亚洲精品资源在线观看 | 精品1区2区3区 | 2018好看的中文在线观看 | 国产一区二区高清视频 | 欧美国产日韩久久 | 99久久久久| 911久久| 丁香5月婷婷久久 | 亚洲精品中文在线 | 国产精品免费观看在线 | 久久色在线播放 | 国产伦精品一区二区三区在线 | 97视频免费播放 | 99色在线视频 | 色九九在线 | 国产手机视频在线播放 | 91福利视频免费观看 | 91专区在线观看 | 久草电影在线 | 又黄又刺激的网站 | 日韩一级黄色大片 | 国产精品18p | 天天激情天天干 | 亚洲综合欧美激情 | 91天堂影院 | 国产精品系列在线播放 | 伊人热| 国产裸体视频网站 | 最近中文字幕大全 | 在线观看aaa | 久久色在线观看 | 98超碰在线 | 天天色棕合合合合合合 | 欧美性护士 | 久久av中文字幕片 | 丁香综合网 | 国产一级电影 | 草久在线视频 | 日韩成年视频 | 国产免费专区 | 色综合天天爱 | 国际精品久久久 | .国产精品成人自产拍在线观看6 | 毛片网免费 | 激情五月六月婷婷 | 粉嫩av一区二区三区四区在线观看 | 在线观看的av | 超碰在线97观看 | 一区二区视频在线免费观看 | 日韩欧美在线视频一区二区 | 欧美日韩网站 | 美女视频a美女大全免费下载蜜臀 | 国产小视频网站 | 久操视频在线播放 | 亚洲一区二区视频在线播放 | 波多野结衣在线播放视频 | 日本三级吹潮在线 | 人人爽人人爽av | 国产精品久久久久免费a∨ 欧美一级性生活片 | 亚洲精品国产区 | 国产精彩视频一区 | 最近免费在线观看 | 91av九色 | 日日夜夜婷婷 | 一级黄色片网站 | 三级av小说 | 日韩av电影免费在线观看 | 国产成人av电影 | 精品免费久久 | 色婷婷免费视频 | 黄色中文字幕在线 | 中文字幕免费观看视频 | av在线免费在线 | www.狠狠色 | 四虎影视精品 | 亚洲开心激情 | 国产视频 亚洲精品 | 五月婷婷伊人网 | 日本视频久久久 | 日韩精品短视频 | 欧美另类一二三四区 | 在线精品亚洲一区二区 | 6080yy精品一区二区三区 | 亚洲精品大片www | 成全免费观看视频 | 国产精品成人久久久久久久 | 香蕉视频在线免费 | 日韩免费视频一区二区 | 午夜男人影院 | 亚洲黄色在线 | 国产成人精品av久久 | 亚洲不卡123 | 国产99在线| 黄色三级网站在线观看 | 亚洲精品乱码久久久久久蜜桃动漫 | 91网址在线看 | 天天射天天操天天色 | 成人免费观看视频网站 | 激情五月看片 | 狠狠干狠狠艹 | 狠狠亚洲| 国产中文字幕视频在线观看 | 国产精品福利在线观看 | 精品少妇一区二区三区在线 | 精品一区三区 | 国产一区二区在线免费播放 | 国产不卡视频 | av丝袜在线| 国产一区二区在线看 | 999视频在线观看 | 日韩欧美视频 | 国产精品久久久久aaaa九色 | 天天操天天干天天 | 国产精品免费一区二区三区在线观看 | 麻豆va一区二区三区久久浪 | 国产中文字幕91 | 久久视频在线观看免费 | 久久激情视频 久久 | 91中文字幕永久在线 | 91亚洲精 | 91色国产在线 | 伊人久久在线观看 | 97手机电影网 | 永久免费观看视频 | 91在线成人 | 免费观看的黄色 | 在线观看91精品国产网站 | 特级片免费看 | 色婷婷综合五月 | 日韩一级电影在线观看 | 精品国产理论 | 国产a国产a国产a | 国产精品va在线播放 | 99精品视频精品精品视频 | 亚洲国产三级在线观看 | 国产亚洲精品久久久久久久久久久久 | 国产精品一区二区在线看 | www免费黄色 | 亚洲人成影院在线 | 久久久久久久久艹 | 最新色站| 天天综合色网 | 久久视频在线视频 | 精品免费视频 | 中文av不卡 | 日韩三区在线观看 | 激情大尺度视频 | 色综久久 | 五月婷婷亚洲 | 999久久久免费精品国产 | 4p变态网欧美系列 | 国产一区久久久 | 日本公妇色中文字幕 | 亚洲成人av在线电影 | 亚洲欧美婷婷六月色综合 | 99免费视频| 超碰免费成人 | 国产麻豆剧果冻传媒视频播放量 | 91精品国产综合久久福利 | 国产高清无线码2021 | 久久99国产综合精品免费 | 国产精品一区久久久久 | 亚洲一二三久久 | 91九色国产视频 | 欧美午夜精品久久久久久孕妇 | 国产在线观看一 | 高清久久久 | 国产精品久久久久久吹潮天美传媒 | 在线观看午夜 | 国产精品麻豆视频 | 国产精品亚洲片夜色在线 | 久久99国产精品免费 | 久久视频一区二区 | 亚洲影视资源 | 国产精品二区在线观看 | 中文字幕在线看视频国产中文版 | 国产精品欧美一区二区 | 免费成人在线视频网站 | 最近中文字幕免费av | 亚洲黄色成人网 | 亚洲欧洲视频 | 精品视频免费播放 | 欧美一区二区三区在线 | 亚洲伊人成综合网 | 黄色软件在线观看免费 | 狠狠色丁香婷婷 | 五月天激情视频在线观看 | 国产这里只有精品 | 国产在线观看中文字幕 | 国产精品久久久久久久久蜜臀 | 天天射成人 | 日本巨乳在线 | 亚洲成年人在线播放 | 日韩精品大片 | 激情综合狠狠 | 丝袜网站在线观看 | 一级黄色免费 | 亚洲乱码在线 | 精品999 | 国产高清在线看 | 免费三级在线 | 日韩黄色av网站 | 久久激情精品 | 久久久久久国产一区二区三区 | 日韩av一区二区三区 | 久久久麻豆精品一区二区 | 欧美日韩国产一区二 | 81国产精品久久久久久久久久 | 五月天视频网 | 黄色精品一区 | 美女视频黄是免费的 | 国产成人亚洲在线观看 | 91午夜精品 | 久久这里 | 国产九色视频在线观看 | 黄色a在线观看 | 国产一二区视频 | 亚洲激情一区二区三区 | 91桃色在线免费观看 | 少妇性bbb搡bbb爽爽爽欧美 | 91成年人视频 | 亚洲欧美日本一区二区三区 | 亚洲国产欧洲综合997久久, | 久久伊人综合 | 中文字幕资源在线 | 亚洲精色| 日韩一区正在播放 | 美女黄频视频大全 | 日韩视频中文字幕 | 成人影片在线免费观看 | 91视频88av| 最近中文字幕视频网 | av女优中文字幕在线观看 | 欧美另类交在线观看 | 久久久18 | 一级一级一片免费 | 亚洲在线视频免费 | 国产高清成人av | 一区二区三区在线观看中文字幕 | 国产亚洲va综合人人澡精品 | 国产福利91精品张津瑜 | 最近中文字幕在线中文高清版 | 91亚洲狠狠婷婷综合久久久 | 麻花豆传媒mv在线观看 | 国产高清精品在线 | 91av在线精品 | 国内精品久久久久久久影视麻豆 | 日本黄色免费在线 | 久久视频免费在线观看 | 亚洲成av人片在线观看无 | 久久久久久久久久久免费 | 日韩com | av看片在线观看 | 亚洲国产精品激情在线观看 | 在线三级播放 | 精品av在线播放 | 久久精品99视频 | 日韩r级在线 | 天天激情综合 | 欧美日韩免费网站 | 成人资源在线播放 | 九九免费精品视频在线观看 | 最新av中文字幕 | 国产人免费人成免费视频 | 日韩欧美中文 | 色就色,综合激情 | www免费| 久久久久久久久久免费 | 天天操天天舔天天干 | 日本精品久久久久久 | 国内三级在线观看 | 人人爽人人澡人人添人人人人 | 日韩精品久久久久久久电影99爱 | 爱色婷婷 | 四虎国产精品成人免费影视 | 91成人观看 | 欧美在线视频不卡 | 亚洲精品国产品国语在线 | 在线观看不卡的av | 国产中文字幕视频在线观看 | 久久一级电影 | 91亚洲网 | 免费观看黄 | 99久久激情视频 | 久久激情小说 | 国产高清在线永久 | 国产视频1| 亚洲精品久久久久中文字幕m男 | 99久久99久久精品国产片 | 成人av久久| 97免费中文视频在线观看 | 韩日电影在线 | 成人91免费视频 | 天天插综合| 99精品偷拍视频一区二区三区 | 色视频在线免费观看 | 国产亚洲在线观看 | 热久久免费视频精品 | 午夜婷婷综合 | 成年人天堂com | 国产成人精品av在线 | 激情网婷婷 | 日韩视| 国外调教视频网站 | 精品久久久久一区二区国产 | a午夜电影 | 伊人电影在线观看 | 99国产在线| 成人在线观看av | 精品资源在线 | 91视频在线免费 | 久久夜色精品国产欧美一区麻豆 | av在线进入 | 久久国产精品久久精品国产演员表 | 精品在线观看一区二区 | 国产精品久久久久久麻豆一区 | 日韩欧美极品 | 久草视频在线看 | 91麻豆精品国产91 | 欧美成人黄 | 久久久久免费电影 | 久草在| 99在线精品视频在线观看 | 日韩国产精品毛片 | 操久 | 在线免费成人 | 久久久久国产一区二区三区四区 | 欧美乱码精品一区二区 | 亚洲男男gaygay无套 | 亚洲精品一区二区三区新线路 | 91成人免费在线 | 国产精品第十页 | 欧亚日韩精品一区二区在线 | av中文字幕在线看 | 久久婷婷色 | 丁香国产视频 | 久久天天躁夜夜躁狠狠85麻豆 | www黄| 国产做aⅴ在线视频播放 | 91在线一区 | 午夜精品久久久久久久久久久久久久 | 亚洲激情网站免费观看 | 久久精品播放 | 中文字幕一区在线观看视频 | 国产成人在线播放 | 亚洲黄色片一级 | 婷婷丁香色 | 在线看的av网站 | 91漂亮少妇露脸在线播放 | 久久精品国产一区 | 久久免费在线视频 | 久久99热这里只有精品国产 | 91在线产啪 | 日韩高清不卡在线 | 国产精品美女久久久久久 | 色av男人的天堂免费在线 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | av短片在线 | 色wwwww| 日韩黄色软件 | 手机版av在线 | 日韩精品不卡在线观看 | 日日操操操 | 中文在线a∨在线 | 日韩久久精品一区二区三区下载 | 亚洲国产成人在线 | 99久久婷婷国产 | 又污又黄的网站 | 日韩一区二区三区观看 | 黄色一级网 | 亚洲国产成人精品电影在线观看 | 国产成人一区三区 | 久久综合中文字幕 | 久久久久久久久久久免费 | 在线亚洲高清视频 | 免费开视频 | 一级黄色在线免费观看 | 一级a性色生活片久久毛片波多野 | 探花视频在线版播放免费观看 | 在线日韩精品视频 | 免费国产在线观看 | 深爱五月激情五月 | 欧美国产日韩一区二区三区 | 在线看一区 | 精品女同一区二区三区在线观看 | 天天艹| 在线 日韩 av| 中文字幕激情 | 特级西西www44高清大胆图片 | 中文av字幕在线观看 | av在线观| 国产精品成人一区二区 | 黄色成人小视频 | 99热精品国产 | 色婷婷成人网 | 99精品热视频只有精品10 | 国产一级视频免费看 | 久久久精品国产免费观看一区二区 | 日本中文字幕网 | 探花视频免费观看 | 亚洲精品视频在线看 | 91色国产在线| 91免费看黄| 欧美日韩免费一区二区三区 | 黄色三级久久 | 天天天天射 | 狠狠干夜夜操天天爽 | 成x99人av在线www | 日韩欧美专区 | 精品视频不卡 | 久操中文字幕在线观看 | 九九三级毛片 | 国产日韩精品在线 | 69国产盗摄一区二区三区五区 |