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

聊一聊數據庫中的鎖

數據庫 SQL Server
解決這個問題的過程中把數據庫鎖相關的學習了一下,這里把學習成果,分享給大家,希望對大家有所幫助.

背景

數據庫中有一張叫后宮佳麗的表,每天都有幾百萬新的小姐姐插到表中,光陰荏苒,夜以繼日,日久生情,時間長了,表中就有了幾十億的小姐姐數據,看到幾十億的小姐姐,每到晚上,我可愁死了,這么多小姐姐,我翻張牌呢?

辦法當然是精兵簡政,刪除那些age>18的,給年輕的小姐姐們留位置...

于是我在數據庫中添加了一個定時執行的小程序,每到周日,就自動運行如下的腳本 

  1. delete from `后宮佳麗` where age>18 

一開始還自我感覺良好,后面我就發現不對了,每到周日,這個腳本一執行就是一整天,運行的時間有點長是小事,重點是這大好周日,我再想讀這張表的數據,怎么也讀不出來了,怎是一句空虛了得,我好難啊!

[[285414]]

為什么

編不下去了,真實背景是公司中遇到的一張有海量數據表,每次一旦執行歷史數據的清理,我們的程序就因為讀不到這張表的數據,瘋狂地報錯,后面一查了解到,原來是因為定時刪除的語句設計不合理,導致數據庫中數據由行鎖(Row lock)升級為表鎖(Table lock)了😂.

解決這個問題的過程中把數據庫鎖相關的學習了一下,這里把學習成果,分享給大家,希望對大家有所幫助.

我將討論SQL Server鎖機制以及如何使用SQL Server標準動態管理視圖監視SQL Server 中的鎖,相信其他數據的鎖也大同小異,具有一定參考意義.

鋪墊知識

在我開始解釋SQL Server鎖定體系結構之前,讓我們花點時間來描述ACID(原子性,一致性,隔離性和持久性)是什么。ACID是指數據庫管理系統(DBMS)在寫入或更新資料的過程中,為保證事務(transaction)是正確可靠的,所必須具備的四個特性:原子性(atomicity,或稱不可分割性)、一致性(consistency)、隔離性(isolation,又稱獨立性)、持久性(durability)。

ACID#

原子性(Atomicity)#

一個事務(transaction)中的所有操作,或者全部完成,或者全部不完成,不會結束在中間某個環節。事務在執行過程中發生錯誤,會被回滾(Rollback)到事務開始前的狀態,就像這個事務從來沒有執行過一樣。即,事務不可分割、不可約簡。

一致性(Consistency)#

在事務開始之前和事務結束以后,數據庫的完整性沒有被破壞。這表示寫入的資料必須完全符合所有的預設約束、觸發器、級聯回滾等。

隔離性(Isolation)#

數據庫允許多個并發事務同時對其數據進行讀寫和修改的能力,隔離性可以防止多個事務并發執行時由于交叉執行而導致數據的不一致。事務隔離分為不同級別,包括未提交讀(Read uncommitted)、提交讀(read committed)、可重復讀(repeatable read)和串行化(Serializable)。

持久性(Durability)#

事務處理結束后,對數據的修改就是永久的,即便系統故障也不會丟失。

來源:維基百科 https://zh.wikipedia.org/wiki/ACID

事務 (Transaction:)#

事務是進程中最小的堆棧,不能分成更小的部分。此外,某些事務處理組可以按順序執行,但正如我們在原子性原則中所解釋的那樣,即使其中一個事務失敗,所有事務塊也將失敗。

鎖定 (Lock)#

鎖定是一種確保數據一致性的機制。SQL Server在事務啟動時鎖定對象。事務完成后,SQL Server將釋放鎖定的對象。可以根據SQL Server進程類型和隔離級別更改此鎖定模式。這些鎖定模式是:

鎖定層次結構#

SQL Server具有鎖定層次結構,用于獲取此層次結構中的鎖定對象。數據庫位于層次結構的頂部,行位于底部。下圖說明了SQL Server的鎖層次結構。

共享(S)鎖 (Shared (S) Locks)#

當需要讀取對象時,會發生此鎖定類型。這種鎖定類型不會造成太大問題。

獨占(X)鎖定 (Exclusive (X) Locks)# 

發生此鎖定類型時,會發生以防止其他事務修改或訪問鎖定對象。

更新(U)鎖 (Update (U) Locks)#

此鎖類型與獨占鎖類似,但它有一些差異。我們可以將更新操作劃分為不同的階段:讀取階段和寫入階段。在讀取階段,SQL Server不希望其他事務有權訪問此對象以進行更改,因此,SQL Server使用更新鎖。

意圖鎖定 (Intent Locks)#

當SQL Server想要在鎖定層次結構中較低的某些資源上獲取共享(S)鎖定或獨占(X)鎖定時,會發生意圖鎖定。實際上,當SQL Server獲取頁面或行上的鎖時,表中需要設置意圖鎖。

SQL Server locking

了解了這些背景知識后,我們嘗試再SQL Server找到這些鎖。SQL Server提供了許多動態管理視圖來訪問指標。要識別SQL Server鎖,我們可以使用sys.dm_tran_locks視圖。在此視圖中,我們可以找到有關當前活動鎖管理的大量信息。

在第一個示例中,我們將創建一個不包含任何索引的演示表,并嘗試更新此演示表。 

  1. CREATE TABLE TestBlock  
  2. (Id INT ,  
  3. Nm VARCHAR(100))  
  4. INSERT INTO TestBlock  
  5. values(1,'CodingSight')  
  6. In this step, we will create an open transaction and analyze the locked resources.  
  7. BEGIN TRAN  
  8. UPDATE TestBlock SET   Nm='NewValue_CodingSight' where Id=1  
  9. select @@SPID 

再獲取到了SPID后,我們來看看sys.dm_tran_lock視圖里有什么。 

  1. select * from sys.dm_tran_locks  WHERE request_session_id=74 

此視圖返回有關活動鎖資源的大量信息,但是是一些我們難以理解的一些數據。因此,我們必須將sys.dm_tran_locks join 一些其他表。 

  1. SELECT dm_tran_locks.request_session_id,  
  2.        dm_tran_locks.resource_database_id,  
  3.        DB_NAME(dm_tran_locks.resource_database_id) AS dbname,  
  4.        CASE  
  5.            WHEN resource_type = 'OBJECT'  
  6.                THEN OBJECT_NAME(dm_tran_locks.resource_associated_entity_id)  
  7.            ELSE OBJECT_NAME(partitions.OBJECT_ID)  
  8.        END AS ObjectName,  
  9.        partitions.index_id,  
  10.        indexes.name AS index_name,  
  11.        dm_tran_locks.resource_type,  
  12.        dm_tran_locks.resource_description,  
  13.        dm_tran_locks.resource_associated_entity_id,  
  14.        dm_tran_locks.request_mode,  
  15.        dm_tran_locks.request_status  
  16. FROM sys.dm_tran_locks  
  17. LEFT JOIN sys.partitions ON partitions.hobt_id = dm_tran_locks.resource_associated_entity_id  
  18. LEFT JOIN sys.indexes ON indexes.OBJECT_ID = partitions.OBJECT_ID AND indexes.index_id = partitions.index_id  
  19. WHERE resource_associated_entity_id > 0  
  20.   AND resource_database_id = DB_ID()  
  21.  and request_session_id=74  
  22. ORDER BY request_session_id, resource_associated_entity_id 

在上圖中,您可以看到鎖定的資源。SQL Server獲取該行中的獨占鎖。(RID:用于鎖定堆中單個行的行標識符)同時,SQL Server獲取頁中的獨占鎖和TestBlock表意向鎖。這意味著在SQL Server釋放鎖之前,任何其他進程都無法讀取此資源,這是SQL Server中的基本鎖定機制。

現在,我們將在測試表上填充一些合成數據。 

  1. TRUNCATE TABLE    TestBlock  
  2. DECLARE @K AS INT=0  
  3. WHILE @K <8000  
  4. BEGIN  
  5. INSERT TestBlock VALUES(@K, CAST(@K AS varchar(10)) + ' Value' )  
  6. SET @K=@K+1  
  7.  END  
  8. --After completing this step, we will run two queries and check the sys.dm_tran_locks view.  
  9. BEGIN TRAN  
  10.  UPDATE TestBlock  set Nm ='New_Value' where Id<5000 

在上面的查詢中,SQL Server獲取每一行的獨占鎖。現在,我們將運行另一個查詢。 

  1. BEGIN TRAN  
  2.  UPDATE TestBlock  set Nm ='New_Value' where Id<7000 

在上面的查詢中,SQL Server在表上創建了獨占鎖,因為SQL Server嘗試為這些將要更新的行獲取大量RID鎖,這種情況會導致數據庫引擎中的大量資源消耗,因此,SQL Server會自動將此獨占鎖定移動到鎖定層次結構中的上級對象(Table)。我們將此機制定義為Lock Escalation, 這就是我開篇所說的鎖升級,它由行鎖升級成了表鎖。

根據官方文檔的描述存在以下任一條件,則會觸發鎖定升級:

  •  單個Transact-SQL語句在單個非分區表或索引上獲取至少5,000個鎖。
  •  單個Transact-SQL語句在分區表的單個分區上獲取至少5,000個鎖,并且ALTER TABLE SET LOCK_ESCALATION選項設置為AUTO。
  •  數據庫引擎實例中的鎖數超過了內存或配置閾值。

https://docs.microsoft.com/en-us/previous-versions/sql/sql-server-2008-r2/ms184286(v=sql.105)

如何避免鎖升級

防止鎖升級的最簡單,最安全的方法是保持事務的簡短,并減少昂貴查詢的鎖占用空間,以便不超過鎖升級閾值,有幾種方法可以實現這一目標.

將大批量操作分解為幾個較小的操作#

例如,在我開篇所說的在幾十億條數據中刪除小姐姐的數據: 

  1. delete from `后宮佳麗` where age>18 

我們可以不要這么心急,一次只刪除500個,可以顯著減少每個事務累積的鎖定數量并防止鎖定升級。例如: 

  1. SET ROWCOUNT 500  
  2. delete_more:  
  3.      delete from `后宮佳麗` where age>18  
  4. IF @@ROWCOUNT > 0 GOTO delete_more 
  5.  SET ROWCOUNT 0 

創建索引使查詢盡可能高效來減少查詢的鎖定占用空間#

如果沒有索引會造成表掃描可能會增加鎖定升級的可能性, 更可怕的是,它增加了死鎖的可能性,并且通常會對并發性和性能產生負面影響。

根據查詢條件創建合適的索引,最大化提升索引查找的效率,此優化的一個目標是使索引查找返回盡可能少的行,以最小化查詢的的成本。

如果其他SPID當前持有不兼容的表鎖,則不會發生鎖升級#

鎖定升級始總是升級成表鎖,而不會升級到頁面鎖定。如果另一個SPID持有與升級的表鎖沖突的IX(intent exclusive)鎖定,則它會獲取更細粒度的級別(行,key或頁面)鎖定,定期進行額外的升級嘗試。表級別的IX(intent exclusive)鎖定不會鎖定任何行或頁面,但它仍然與升級的S(共享)或X(獨占)TAB鎖定不兼容。

如下所示,如果有個操作始終在不到一小時內完成,您可以創建包含以下代碼的sql,并安排在操作的前執行 

  1. BEGIN TRAN  
  2. SELECT * FROM mytable (UPDLOCK, HOLDLOCK) WHERE 1=0  
  3. WAITFOR DELAY '1:00:00'  
  4. COMMIT TRAN 

此查詢在mytable上獲取并保持IX鎖定一小時,這可防止在此期間對表進行鎖定升級。

Happy Ending

好了,不說了,小姐姐們因為不想離我開又打起來了(死鎖). 

 

責任編輯:龐桂玉 來源: 碼農阿宇
相關推薦

2020-02-02 13:59:59

MySQL數據庫線程

2022-02-21 15:01:45

MySQL共享鎖獨占鎖

2020-12-11 11:11:44

原子類JavaCAS

2022-08-30 07:39:57

C++namespace隔離

2019-12-02 16:23:03

Python編程語言“垃圾”回收

2024-10-08 09:10:03

JDK通信并發

2021-01-04 08:09:07

Linux內核Watchdog

2020-07-16 14:40:23

大數據計算框架

2021-06-30 07:19:35

微服務業務MySQL

2022-11-09 08:05:15

JavaScriptsuper()

2022-03-06 20:35:41

并發串行CAP

2024-10-16 15:11:58

消息隊列系統設計

2020-09-08 06:54:29

Java Gradle語言

2023-07-06 13:56:14

微軟Skype

2017-12-26 10:19:14

大數據問題缺陷

2023-10-07 08:17:40

公平鎖非公平鎖

2018-06-07 13:17:12

契約測試單元測試API測試

2021-01-28 22:31:33

分組密碼算法

2020-05-22 08:16:07

PONGPONXG-PON

2023-09-22 17:36:37

點贊
收藏

51CTO技術棧公眾號

国产精品xxxav免费视频| 国产高清视频在线播放| 亚洲日本免费| 国产一区二区免费| 日韩av影视大全| ****av在线网毛片| 国产精品免费人成网站| caoporn国产精品免费公开| 偷偷操不一样的久久| 久久在线免费| 日韩精品一区二区视频| 亚洲精品免费一区亚洲精品免费精品一区| 少女频道在线观看高清| www国产成人| 成人黄色激情网| 影音先锋亚洲天堂| 亚洲精品二区三区| 亚洲天堂av在线免费| 伦伦影院午夜理论片| 高清不卡亚洲| 亚洲一区在线观看免费观看电影高清 | 黄色小网站在线观看| av动漫一区二区| 成人免费激情视频| 岛国av中文字幕| 欧美喷水视频| 色妞欧美日韩在线| www.久久国产| 盗摄牛牛av影视一区二区| 欧美日韩久久一区二区| 美女福利视频在线| 国产区美女在线| 日韩毛片一二三区| 亚洲国产日韩综合一区| 青青青手机在线视频观看| 福利一区二区在线| 91色精品视频在线| 亚洲视频在线免费播放| 日本成人在线电影网| 9.1国产丝袜在线观看 | 色偷偷久久一区二区三区| 国产精品videossex国产高清| 毛片免费不卡| 亚洲国产电影在线观看| 欧美日本韩国在线| 黄色软件在线观看| 久久久午夜精品理论片中文字幕| 国产乱子伦精品| 欧洲精品久久一区二区| 成人免费高清视频| 国产亚洲欧美一区二区| 天天操天天干天天操| 99久久精品国产导航| 国产手机精品在线| 三级在线视频| 久久久精品影视| 色吧亚洲视频| 黄网站免费在线播放| 亚洲老司机在线| 成人一区二区av| 不卡一本毛片| 精品久久久久久中文字幕| 亚洲不卡中文字幕无码| 午夜影院在线观看国产主播| 色综合中文字幕国产| 国产精品69页| 精品久久福利| 日韩欧美卡一卡二| 国产一级黄色录像| 九九综合在线| 日韩在线欧美在线| 久久精品黄色片| 日韩午夜一区| 国产精品欧美一区二区| 国产av无码专区亚洲a∨毛片| 国产成人av电影在线| 精品无人区一区二区三区| 日本电影一区二区在线观看| 国产情人综合久久777777| 正在播放精油久久| 国模雨婷捆绑高清在线| 色综合色狠狠天天综合色| av五月天在线| 日本一区二区三区视频在线看| 日韩三级在线免费观看| 日韩综合第一页| 欧美裸体在线版观看完整版| 久久夜色精品国产亚洲aⅴ| 久久久久无码国产精品 | 奇米影视四色在线| 日韩不卡在线视频| 亚洲精品日韩在线| 777777国产7777777| 99精品国产在热久久婷婷| 国产精品99久久久久久久久| 99热精品在线播放| 2024国产精品| 在线观看三级网站| 中文字幕影音在线| 欧美一区二区高清| 亚洲自拍偷拍图| 国产精品v一区二区三区 | 精品一区二区三区亚洲| 精品一区精品二区| 亚洲色婷婷一区二区三区| 久久激情一区| www.成人三级视频| 日本电影全部在线观看网站视频| 亚洲成人综合在线| 国产三级精品三级在线| 国产不卡一区| 国内精品久久久久久久久| 91国内精品视频| 久久亚洲欧美国产精品乐播| 日韩精品福利片午夜免费观看| 小草在线视频免费播放| 日韩精品中文字幕在线一区| 1024在线看片| 亚洲欧美日本视频在线观看| caoporen国产精品| 黄在线免费看| 欧美美女黄视频| 国产精品高清无码在线观看| 亚洲精品1区2区| 91免费视频国产| 成av人电影在线观看| 黑人巨大精品欧美一区二区| 日本女人性视频| 91精品国产调教在线观看| 国产精品福利网| 青青草视频免费在线观看| 亚洲午夜影视影院在线观看| 亚洲av无日韩毛片久久| 色呦哟—国产精品| 国产精品久久久久久久久久 | 免费黄色片视频| 91日韩一区二区三区| 男的插女的下面视频| 国产精一区二区| 久久精品免费电影| 91国在线视频| 亚洲欧美一区二区三区久本道91 | 色爱av美腿丝袜综合粉嫩av| 国产天堂第一区| 国产人成一区二区三区影院| www.色就是色| 99久久婷婷| 亚洲一区制服诱惑| 午夜影院免费在线| 精品国产麻豆免费人成网站| 国产一级免费av| 国产成人av电影| 欧美乱大交xxxxx潮喷l头像| 成人看片黄a免费看视频| 欧美激情网友自拍| 日本激情视频网站| 精品久久久中文| 成人乱码一区二区三区av| 久久久久99| 亚洲精品一区二| 国产高清亚洲| 欧美高清视频在线播放| 少妇荡乳情欲办公室456视频| 亚洲福利视频一区| 性久久久久久久久久| 日韩成人午夜精品| 国产成人三级视频| 中文字幕视频精品一区二区三区| 欧美激情一区二区三区久久久| 免费a视频在线观看| 欧美性高跟鞋xxxxhd| 精品成人无码一区二区三区| 另类小说欧美激情| a级黄色片免费| 欧美电影完整版在线观看| 国产成人精品电影| 国产在线更新| 日韩av在线网址| 免费一级a毛片| 亚洲男人的天堂av| 免费在线观看你懂的| 久久精品国产精品亚洲综合| 久久久久久久久久伊人| 亚洲人成网77777色在线播放| 国产精品美女网站| 羞羞的网站在线观看| 亚洲老头同性xxxxx| 91av久久久| 午夜视频在线观看一区二区| 影音先锋男人在线| 国产电影一区二区三区| 啊啊啊一区二区| 国产精品久久久久久| 激情小说网站亚洲综合网| 精品国产欧美日韩一区二区三区| 欧美精品少妇videofree| 深夜福利在线观看直播| 欧美猛男超大videosgay| 久久一区二区三区视频| 亚洲天堂av一区| 婷婷色一区二区三区| 懂色av中文字幕一区二区三区| 欧美伦理片在线看| 亚洲精品系列| 国产在线无码精品| 精品国产91| 狠狠色伊人亚洲综合网站色| 亚洲福利影视| 日本欧美黄网站| 欧美videossex另类| 最近2019年中文视频免费在线观看| 俄罗斯嫩小性bbwbbw| 91精品午夜视频| 亚洲精品国产欧美在线观看| 亚洲成人自拍网| 全网免费在线播放视频入口 | 日本黄网免费一区二区精品| 日韩精品中文字幕吗一区二区| 国产精品第3页| 日本乱码一区二区三区不卡| 欧美丰满少妇xxxx| 国产福利视频在线观看| 色诱女教师一区二区三区| 撸视在线观看免费视频| 精品久久久久久无| 国产av无码专区亚洲a∨毛片| 欧美日韩国产一二三| 日韩精品在线一区二区三区| 欧美体内谢she精2性欧美| 国产第100页| 亚洲国产综合色| 久久久久成人精品无码| 亚洲色图清纯唯美| 永久免费看片直接| 亚洲天天做日日做天天谢日日欢| 婷婷综合在线视频| 欧美韩日一区二区三区四区| 精品人伦一区二区三电影| 久久无码av三级| brazzers精品成人一区| 2014亚洲片线观看视频免费| 国产乱了高清露脸对白| 99久久精品国产毛片| 欧美 变态 另类 人妖| 91天堂素人约啪| 成年人在线观看av| 国产亚洲一二三区| 欧美自拍偷拍网| 成人欧美一区二区三区小说| 欧美 日韩 国产 一区二区三区| 亚洲视频一区在线| 免费麻豆国产一区二区三区四区| 亚洲综合激情另类小说区| 日韩欧美亚洲一区二区三区| 欧美日韩亚洲91| 天天干天天色综合| 欧美色网站导航| 国产乱人乱偷精品视频| 日韩一区二区电影在线| 高清乱码毛片入口| 日韩电影免费观看在线观看| 你懂的视频在线| 自拍视频国产精品| 国产cdts系列另类在线观看| 欧美国产极速在线| 九九色在线视频| 91av在线播放| 久久久免费人体| 91日韩久久| 亚洲精品国产动漫| 一区二区三区四区在线视频| 综合在线视频| 国产超级av在线| 美女看a上一区| 久久久无码人妻精品无码| av一区二区三区四区| 在线免费观看视频| 亚洲人精品一区| 国产精品黄色大片| 欧美日韩色综合| 日本免费一区视频| 丝袜美腿精品国产二区| 操喷在线视频| 国产精品一区二区3区| 77成人影视| 视频在线精品一区| 午夜久久福利| 天堂社区在线视频| 国产a区久久久| 国产美女免费无遮挡| 亚洲欧美日韩久久| 香蕉污视频在线观看| 日韩一级完整毛片| 国产在线自天天| 欧美激情xxxx| 久久久久久一区二区三区四区别墅| 国产精品久久久久久久久婷婷| 不卡一区综合视频| 欧美一级视频免费看| 激情都市一区二区| 天天躁日日躁aaaxxⅹ| 亚洲一区二区三区视频在线| 中文天堂在线播放| 国产视频久久久久| 污污在线观看| 国产在线日韩在线| 国产成人调教视频在线观看| 国产精品久久久久久久久电影网| 麻豆久久一区二区| 久久精品—区二区三区舞蹈| 亚洲成人免费在线| 国产三级小视频| 欲色天天网综合久久| 英国三级经典在线观看| 福利精品视频| 亚洲欧美综合久久久| 午夜久久久精品| 国产亚洲精品久| 日本视频免费观看| 亚洲成年人在线播放| 在线āv视频| 成人国产精品一区二区| 成人影院天天5g天天爽无毒影院| 国产九九九九九| 成人午夜电影久久影院| 精品国产欧美日韩不卡在线观看 | 国内精久久久久久久久久人| 91成人小视频| 中文字幕中文字幕一区三区| 日韩成人av影视| 亚洲av无码国产精品麻豆天美| 欧美三级欧美成人高清www| 黄色av网址在线| 久99九色视频在线观看| 精品一区二区三区中文字幕| 一级一片免费播放| 狠狠狠色丁香婷婷综合久久五月| 国产精品理论在线| 欧美综合在线视频| 春暖花开成人亚洲区| 国产成人欧美在线观看| 国产成人精品免费视| 国产女女做受ⅹxx高潮| 久久综合色综合88| 久久精品视频2| 一区二区欧美久久| 丁香婷婷久久| 看全色黄大色大片| 国产超碰在线一区| 国产一级二级毛片| 亚洲精品久久在线| 中文字幕在线免费观看视频| 欧美久久久久久久| 美女视频网站黄色亚洲| 韩国一级黄色录像| 日韩视频永久免费| 不卡av免费观看| 欧美激情专区| 美女视频第一区二区三区免费观看网站| 林心如三级全黄裸体| 8v天堂国产在线一区二区| 在线三级电影| 久久国产精品高清| 青青草97国产精品免费观看无弹窗版| 成人做爰69片免网站| 正在播放一区二区| av在线私库| 色涩成人影视在线播放| 国产精品自拍一区| 黄网在线观看视频| 伊人久久男人天堂| 久久99成人| 丰满人妻中伦妇伦精品app| 中文字幕不卡在线| 亚洲精品久久久蜜桃动漫| 欧美综合在线观看| 日韩大片在线播放| 国产一精品一aⅴ一免费| 一本在线高清不卡dvd| 在线国产情侣| 国产精品亚洲综合| 日本欧美韩国一区三区| 欧美三级小视频| 亚洲女人天堂成人av在线| www.成人| 日韩av综合在线观看| 国产精品剧情在线亚洲| 十八禁一区二区三区| 国产精选久久久久久| 亚洲二区视频| 手机免费观看av| 亚洲高清在线观看| 亚洲成人毛片| 亚洲 中文字幕 日韩 无码| 亚洲精品久久久蜜桃| 国产中文在线| 国产日韩三区| 国产激情一区二区三区桃花岛亚洲| 天堂中文字幕在线观看| 久久91精品国产91久久跳|