亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

Sql Server 死鎖的監(jiān)控分析解決思路

2024-08-31 01:04:45
字體:
來源:轉載
供稿:網(wǎng)友

1 背景

1.1 報警情況

最近整理筆記,打算全部遷移到EVERNOTE。整理到鎖這一部分,里邊剛好有個自己記錄下來的案例,重新整理分享下給大家。

某日中午,收到報警短信,DB死鎖異常,單分鐘死鎖120個。

死鎖的xml文件如下:

<deadlock-list><deadlock victim="process810b00cf8"><process-list><process id="process810b00cf8" taskpriority="0" logused="0" waitresource="RID: 13:1:1541136:62" waittime="7682" ownerId="3396587959" transactionname="UPDATE" lasttranstarted="2016-01-08T12:03:51.067" XDES="0xa99746d08" lockMode="U" schedulerid="41" kpid="17308" status="suspended" spid="108" sbid="0" ecid="0" priority="0" trancount="2" lastbatchstarted="2016-01-08T12:03:51.067" lastbatchcompleted="2016-01-08T12:03:51.067" lastattention="1900-01-01T00:00:00.067" clientapp="Microsoft SQL Server Management Studio - 查詢" hostname="test-server" hostpid="1433" loginname="xinysu" isolationlevel="read committed (2)" xactid="3396587959" currentdb="13" lockTimeout="4294967295" clientoption1="671098976" clientoption2="390200"><executionStack><frame procname="adhoc" line="7" stmtstart="214" stmtend="484" sqlhandle="0x020000003acf4f010561e479685209fb09a7fd15239977c60000000000000000000000000000000000000000">UPDATE FinanceReceiptNoRule SET NowSeqValue=@ReturnNum,ISRUNNING='0',LastWriteTime=GETDATE() WHERE IsRunning='1' AND SeqCode=@SeqCode </frame></executionStack><inputbuf>declare @SeqCode varchar(60)declare @ReturnNum bigintset @SeqCode='CGJS20160106'while(1=1)beginUPDATE FinanceReceiptNoRule SET NowSeqValue=@ReturnNum,ISRUNNING='0',LastWriteTime=GETDATE() WHERE IsRunning='1' AND SeqCode=@SeqCodeend </inputbuf></process><process id="process18fd5d8cf8" taskpriority="0" logused="248" waitresource="KEY: 13:72057594040090624 (b3ade7c5980c)" waittime="4" ownerId="3396522828" transactionname="user_transaction" lasttranstarted="2016-01-08T12:03:05.310" XDES="0x18c1db63a8" lockMode="U" schedulerid="57" kpid="16448" status="suspended" spid="161" sbid="0" ecid="0" priority="0" trancount="2" lastbatchstarted="2016-01-08T12:03:58.737" lastbatchcompleted="2016-01-08T12:03:33.847" lastattention="2016-01-08T12:03:33.850" clientapp="Microsoft SQL Server Management Studio - 查詢" hostname="test-server" hostpid="1433" loginname="xinysu" isolationlevel="read committed (2)" xactid="3396522828" currentdb="13" lockTimeout="4294967295" clientoption1="671090784" clientoption2="390200"><executionStack><frame procname="adhoc" line="6" stmtstart="210" stmtend="400" sqlhandle="0x020000001b4f23368af7bba99098c10dec46585804f1b4ce0000000000000000000000000000000000000000">Update dbo.FinanceReceiptNoRule Set [IsRunning]='1' where SeqCode=@SeqCode and IsRunning='0' </frame></executionStack><inputbuf>declare @SeqCode varchar(60)declare @ReturnNum bigintset @SeqCode='CGJS20160106'while(1=1)beginUpdate dbo.FinanceReceiptNoRule Set [IsRunning]='1' where SeqCode=@SeqCode and IsRunning='0' end</inputbuf></process></process-list><resource-list><ridlock fileid="1" pageid="1541136" dbid="13" objectname="fin_test.dbo.FinanceReceiptNoRule" id="lock51e8a3980" mode="X" associatedObjectId="72057594040025088"><owner-list><owner id="process18fd5d8cf8" mode="X" /></owner-list><waiter-list><waiter id="process810b00cf8" mode="U" requestType="wait" /></waiter-list></ridlock><keylock hobtid="72057594040090624" dbid="13" objectname="fin_test.dbo.FinanceReceiptNoRule" indexname="PK_FINANCERECEIPTNORULE" id="lock7b2c6bc80" mode="U" associatedObjectId="72057594040090624"><owner-list><owner id="process810b00cf8" mode="U" /></owner-list><waiter-list><waiter id="process18fd5d8cf8" mode="U" requestType="wait" /></waiter-list></keylock></resource-list></deadlock></deadlock-list>

表格結構跟模擬數(shù)據(jù)如下:

--涉及表格:CREATE TABLE [dbo].[FinanceReceiptNoRule]([SeqCode] [varchar](60) NOT NULL,[NowSeqValue] [bigint] NULL,[SeqDate] [varchar](14) NOT NULL,[IsRunning] [varchar](1) NULL,[LastWriteTime] [datetime] NULL,[Prefix] [varchar](4) NULL) ON [PRIMARY]GO--數(shù)據(jù)模擬INSERT [dbo].[FinanceReceiptNoRule] ([SeqCode], [NowSeqValue], [SeqDate], [IsRunning], [LastWriteTime], [Prefix]) VALUES (N'TEST20150108', 1469, N'20150108', N'0', CAST(N'2015-01-08 05:05:49.163' AS DateTime), N'TEST')GOINSERT [dbo].[FinanceReceiptNoRule] ([SeqCode], [NowSeqValue], [SeqDate], [IsRunning], [LastWriteTime], [Prefix]) VALUES (N'TEST20150109', 1377, N'20150109', N'0', CAST(N'2015-01-09 04:50:26.610' AS DateTime), N'TEST')GO ALTER TABLE [dbo].[FinanceReceiptNoRule] ADD CONSTRAINT [pk_FinanceReceiptNoRule] PRIMARY KEY NONCLUSTERED ([SeqCode] ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]GO

1.2 如何監(jiān)控

捕獲死鎖有多種方式可以捕獲,這里介紹2種:SQL SERVER Profiler工具跟Extended Events。Profiler相對比較耗資源,但是由于只監(jiān)控死鎖這一項,所以性能影響不是很大,其可視化界面較易上手;Extended Events耗費資源較少,實時記錄到倒數(shù)第二個死鎖,同時需要SQL語句來分析查詢記錄文件。

如何使用 Profiler監(jiān)控?

打開 SSMS,點擊<工具>,選擇 <SQL Server Profiler>,如下圖。

sql,server,死鎖,sqlserver

登錄到需要監(jiān)控的DB實例,填寫相應的跟蹤屬性,首先是<常規(guī)>頁面,如下圖。這里注意2個方面,第一,選擇 <TSQL-Locks>模板,這個模板即可以用來監(jiān)控死鎖,也可以拿來觀察 鎖申請與釋放情況,非常詳細,有事沒事可以多拿來看SELECT UPDATE DELETE等語句對鎖的申請及釋放情況;第二,監(jiān)控結果存儲,建議可以存放到某個表格中去,方便定期分析與統(tǒng)計。

sql,server,死鎖,sqlserver

接著填寫<事件選擇>項,只需要選擇 <deadlock graph> Events,其他都不需要打勾,最后點擊運行就可以開始監(jiān)控了。

sql,server,死鎖,sqlserver

可以用一個萬年常用的例子來檢查是否監(jiān)控正常,開3個查詢窗口,按照以下順序執(zhí)行則會發(fā)生資源占用及申請互斥導致死鎖,執(zhí)行完第5步,等待1-3s則發(fā)生死鎖。腳本提供如下:

--session 1CREATE TABLE Test_DL(id int not null primary key ,name varchar(100));INSERT INTO Test_DL(id,name) select 1,'a';INSERT INTO Test_DL(id,name) select 2,'b';--session2 2 2 2 2 2 2 2 2 2 BEGIN TRANSACTIONUPDATE Test_DL SET Name='a-test' WHERE ID=1--session3 3 3 3 3 3 3 3 3 3 BEGIN TRANSACTIONUPDATE Test_DL SET Name='b-test' WHERE ID=2--session2 2 2 2 2 2 2 2 2 2  SELECT * FROM Test_DL WHERE ID=2--session3 3 3 3 3 3 3 3 3 3 SELECT * FROM Test_DL WHERE ID=1模擬死鎖SQL

sql,server,死鎖,sqlserver

監(jiān)控到的死鎖界面如下:

sql,server,死鎖,sqlserver

如何使用Extended Events監(jiān)控?

建立擴展事件監(jiān)控的腳本如下:(擴展事件很贊,2012版支持可視化操作,感興趣的可以上 MSDN了解:https://msdn.microsoft.com/zh-cn/library/bb630282.aspx,本文就不分析語法等知識點了)

CREATE EVENT SESSION [DeadLock] ON SERVER ADD EVENT sqlserver.xml_deadlock_report ADD TARGET package0.event_file(SET filename=N'F:/events/deadlock/deadlock.xel',max_file_size=(20)),ADD TARGET package0.ring_buffer(SET max_events_limit=(100),max_memory=(10240),occurrence_number=(50))WITH (MAX_MEMORY=4096 KB,EVENT_RETENTION_MODE=ALLOW_SINGLE_EVENT_LOSS,MAX_DISPATCH_LATENCY=30 SECONDS,MAX_EVENT_SIZE=0 KB,MEMORY_PARTITION_MODE=NONE,TRACK_CAUSALITY=OFF,STARTUP_STATE=ON)GO

查詢SQL如下,這里需要注意:查詢是基于buffer還是基于filer分析,一般buffer存儲的個數(shù)都是有限的,比如上文我們只分配了4M存儲,file分析則是完整的,但是要看保留的文件個數(shù)。這里我們給出buffer的查詢SQL如下,file的查詢大家感興趣的可以動手寫下。

DECLARE @deadlock_xml XMLSELECT @deadlock_xml=(      SELECT         (         SELECT          CONVERT(XML, target_data)        FROM sys.dm_xe_session_targets st        JOIN sys.dm_xe_sessions s ON s.address = st.event_session_address        WHERE s.name = 'deadlock' AND st.target_name = 'ring_buffer'        ) AS [x]      FOR XML PATH('') , TYPE      )SELECT dateadd(hour,+6,tb.col.value('@timestamp[1]','varchar(max)')) TimePoint,tb.col.value('(data/value/deadlock/process-list/process/executionStack/frame)[1]','VARCHAR(MAX)') statement_parameter_k,tb.col.value('(data/value/deadlock/process-list/process/executionStack/frame)[2]','VARCHAR(MAX)') statement_k,tb.col.value('(data/value/deadlock/process-list/process/executionStack/frame)[3]','VARCHAR(MAX)') statement_parameter,tb.col.value('(data/value/deadlock/process-list/process/executionStack/frame)[4]','VARCHAR(MAX)') [statement],tb.col.value('(data/value/deadlock/process-list/process/@waitresource)[1]','VARCHAR(MAX)') waitresource_k,tb.col.value('(data/value/deadlock/process-list/process/@waitresource)[2]','VARCHAR(MAX)') waitresource,tb.col.value('(data/value/deadlock/process-list/process/@isolationlevel)[1]','VARCHAR(MAX)') isolationlevel_k,tb.col.value('(data/value/deadlock/process-list/process/@isolationlevel)[2]','VARCHAR(MAX)') isolationlevel,tb.col.value('(data/value/deadlock/process-list/process/@waittime)[1]','VARCHAR(MAX)') waittime_k,tb.col.value('(data/value/deadlock/process-list/process/@waittime)[2]','VARCHAR(MAX)') waittime,tb.col.value('(data/value/deadlock/process-list/process/@clientapp)[1]','VARCHAR(MAX)') clientapp_k,tb.col.value('(data/value/deadlock/process-list/process/@clientapp)[2]','VARCHAR(MAX)') clientapp,tb.col.value('(data/value/deadlock/process-list/process/@hostname)[1]','VARCHAR(MAX)') hostname_k,tb.col.value('(data/value/deadlock/process-list/process/@hostname)[2]','VARCHAR(MAX)') hostnameFROM @deadlock_xml.nodes('//event') as tb(col)

這個SQL可以查詢的出非常詳細的資源爭奪情況,如果想要有效的使用擴展事件,建議大家詳細查看下官網(wǎng)的xml語法(SQL SERVER對xml的支持也是棒棒噠,期待2016版中的json支持)

 sql,server,死鎖,sqlserver

是不是很清晰,一目了然,有了這個就可以去分析拉!

2 分析

根據(jù)xml文件內容或者擴展事件的監(jiān)控內容,都可以整理為以下信息(開頭的那個死鎖分析):

 sql,server,死鎖,sqlserver

查看事務1及事務2的執(zhí)行計劃如下:

 sql,server,死鎖,sqlserver

結合表格及執(zhí)行計劃,可以大致推測死鎖過程:

會話1:

  • 根據(jù)主鍵SeqCode查找到鍵值所在的 索引頁 Index_Page,找到該頁上面的 keyhashvalue 鍵值行 Index_key,對Index_Page持有IU鎖,對Index_key持有U鎖;
  • 由于該表是堆表,bookmark lookup是通過 RID查找 ,即通過行標識符查找,找到RID所對應的行數(shù)據(jù)所在的 數(shù)據(jù)頁  Data_Page,然后在該頁面上找到RID指向槽號上的行數(shù)據(jù),對該行數(shù)據(jù)持有U鎖;
  • 這個時候,已經(jīng)查找到了需要更新的行數(shù)據(jù),可以把數(shù)據(jù)頁 Data_Page上的IU鎖 升級為IX鎖,RID指向的行數(shù)據(jù) 從U鎖升級為X鎖,升級結束后,釋放索引頁跟鍵值行上面的 IU鎖及U鎖。
  • 則此時,會話1 持有 Data_Page 上的IX鎖、RID行上的 X鎖.

這個過程中,剛好會話2進行這樣的鎖申請:

  • 找出事務2中持有鎖資源sql,server,死鎖,sqlserver是哪個索引,可以根據(jù)sys.partitions 可以查看到72057594038910976是主鍵pk_FinanceReceiptNoRule,主鍵列是:SeqCode。
  • 根據(jù)主鍵SeqCode查找到鍵值所在的 索引頁 Index_Page,找到該頁上面的 鍵值行 Index_key,對Index_Page持有IU鎖,對Index_key持有U鎖;
  • 由于該表是堆表,bookmark lookup是通過 RID查找 ,即通過行標識符查找,找到RID所對應的行數(shù)據(jù)所在的 數(shù)據(jù)頁  Data_Page,然后在該頁面上找到RID指向槽號上的行數(shù)據(jù),準備該行數(shù)據(jù)持有U鎖,但是發(fā)現(xiàn)RID行上被會話1持有了X鎖,導致其申請 U鎖 Timeout。
  • 則此時 會話2 持有 Index_Page上的IU鎖、Index_key上的U鎖、Data_Page上的IU鎖,請求 RID行的 U鎖。

假設這個時候,會話1 中又執(zhí)行了一次update操作(同一個事務中):

根據(jù)主鍵SeqCode查找到鍵值所在的 索引頁 Index_Page,找到該頁上面的 鍵值行 Index_key,對Index_Page持有IU鎖,準備對Index_key持有U鎖,但是發(fā)現(xiàn) Index_key被會話2持有了U鎖。

那么這個時候死鎖就產生了(詳見下圖):

  • 會話1 持有 Data_Page 上的IX鎖、RID行上的 X鎖,申請 Index_key 的U鎖(等待會話2釋放)
  • 會話2 持有 Index_Page上的IU鎖、Index_key上的U鎖、Data_Page上的IU鎖,請求 RID行的 U鎖(等待會話1釋放)

 sql,server,死鎖,sqlserver

3 解決

想法子除去RID查找,直接index就找到數(shù)據(jù),就不會發(fā)生這個死鎖,也就是,在主鍵上面重新建立聚集索引,丟棄原先的非聚集索引主鍵。因為這樣排除了RID的U鎖申請與持有,直接是保持X鎖 直至事務結束,同時可以直接根據(jù)主鍵來修改鍵值所在的數(shù)據(jù)頁,減少的RID查詢行的時間。

修改后的執(zhí)行計劃如下:

 sql,server,死鎖,sqlserver

其鎖申請釋放的流程如下(詳見截圖):

  • 根據(jù)主鍵SeqCode查找到鍵值所在的 索引頁 Index_Page,找到該頁上面的 keyhashvalue 鍵值行 Index_key,對Index_Page持有IU鎖,對Index_key持有U鎖;
  • 由于該表已經(jīng)是聚集索引表,主鍵所在的頁上包含 行數(shù)據(jù),則可以直接 對Index_Page持有IU鎖升級為IX鎖,對Index_key持有U鎖升級為X鎖,避免了RID逐個找行數(shù)據(jù)的鎖申請

 sql,server,死鎖,sqlserver

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持VeVb武林網(wǎng)!


注:相關教程知識閱讀請移步到MSSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
麻豆成人免费视频| 高清av中文在线字幕观看1| 亚洲国产女人aaa毛片在线| 交videos老少配com| 欧美日韩在线成人| 国产一区二区导航在线播放| 无吗不卡中文字幕| 777米奇影视第四色| 99在线高清视频在线播放| 91看片淫黄大片一级| 琪琪五月天综合婷婷| 亚洲欧美日韩第一区| 国产成人无码aa精品一区| 男人的天堂av高清在线| 一本到12不卡视频在线dvd| 99久久精品无免国产免费| 国产精品沙发午睡系列| 影音先锋久久资源网| 国产精品久久精品国产| 欧美日韩在线精品一区二区三区| 中文字幕av一区二区三区人妻少妇| 天天摸在线视频| 亚洲中文字幕一区二区| 国产高清精品在线观看| 色综合天天综合给合国产| 2021最新国产精品一区| 亚洲精品www久久久久久广东| 国产一区二区三区精品在线| 亚洲欧美日本在线| 久久久久久国产精品久久| 在线观看av大片| 国产精品免费99久久久| 亚洲性线免费观看视频成熟| 免费人成网站在线观看欧美高清| 欧美在线性视频| 亚洲影视在线播放| 亚洲综合在线一区| 欧洲s码亚洲m码精品一区| 精品999在线| 亚洲人成在线观看一区二区| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 最新eeuss影院在线观看| 日本成人在线电影网| 亚洲精品欧美精品| 免费成人av电影| 亚洲精品aⅴ| 精品成人国产在线观看男人呻吟| 成人看片视频| 韩国精品一区二区| 亚洲 精品 综合 精品 自拍| 国产日韩欧美日韩| 亚洲欧美三级伦理| 亚洲欧洲无码一区二区三区| 青青艹在线视频| 中文字幕在线观看第二页| 天海翼一区二区| 国模无码一区二区三区| 日韩精品一区二区三区视频播放| 91电影在线| 日韩欧美不卡在线观看视频| 精品99久久久久成人网站免费| 色国产在线视频| 最新国产精品精品视频| 天堂va蜜桃一区二区三区漫画版| 日韩少妇与小伙激情| 久久悠悠精品综合网| 很污很黄的网站| 一区二区日本视频| 精品嫩草影院久久| 激情福利在线| 欧美一级电影网站| 国产福利一区二区三区视频| 久久久99免费| 久久免费的精品国产v∧| 国产精品白丝jk白祙| 精品国产高清自在线一区二区三区| 麻豆91精品91久久久的内涵| 变态另类ts人妖一区二区| 在线欧美亚洲| 亚洲国产日韩a在线播放性色| 人人人妻人人澡人人爽欧美一区| 天天综合天天添夜夜添狠狠添| 免费黄色片在线观看| av日韩国产| 精品国产午夜肉伦伦影院| 久久亚洲精品小早川怜子| 香蕉成人久久| 黄色免费直接看| 免费看的黄色录像| 国产免费无码一区二区| 性欧美video视频另类| 2025韩国理伦片在线观看| av不卡在线看| 成人女同在线观看| 婷婷色一区二区三区| √新版天堂资源在线资源| 91精品国产麻豆国产自产在线| 橘梨纱av一区二区三区在线观看| 欧美日韩在线资源| 在线观看免费播放网址成人| 美女福利一区二区三区| 久久久久久无码精品人妻一区二区| 九九视频在线观看| 国产激情综合五月久久| avtt综合网| 最新国产在线观看| 日韩最新免费不卡| 欧美黑人激情| 亚洲综合一二区| 国产三级视频在线看| 免费黄网大全| 粉嫩av一区二区三区免费观看| 欧美a在线观看| 亚洲视频视频在线| 最新真实国产在线视频| 欧美大喷水吹潮合集在线观看| 国产农村妇女毛片精品久久麻豆| 国产真实乱人偷精品视频| 国产69久久精品成人| 亚洲精品中文字幕在线播放| 真人做人试看60分钟免费| 国产一区二区三区在线视频| 在线视频你懂得一区二区三区| 亚洲.欧美.日本.国产综合在线| 在线中文字幕一区| 日本少妇精品亚洲第一区| 麻豆91在线播放| 视频在线精品一区| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 日本免费网站在线观看| 欧美日韩亚洲系列| 精品国产一区二区三区| 成人日韩在线| 黄网在线免费看| 色av男人的天堂免费在线| 四虎成人精品永久免费av九九| 无码一区二区三区视频| 激情亚洲一区二区三区四区| 国产91高潮流白浆在线麻豆| 免费成人美女女| 成人网址在线观看| 国产精品综合不卡av| 国产精品久久久久久99| 麻豆短视频在线观看| 中国xxxx视频播放50| 成人免费视频app| 欧美在线免费播放| 日本a级片在线播放| 一日本道久久久精品国产| av网站免费线看精品| www.久久久| ●精品国产综合乱码久久久久| 亚洲在线视频免费观看| 超碰在线免费看| 色噜噜久久综合| 亚洲色图五月天| 很黄很黄激情成人| 亚洲综合一区二区三区| 1024视频在线| 国内毛片毛片毛片毛片毛片| 日韩精品在线免费播放| 国产三级av在线播放| 亚洲第一页中文字幕| 国产一区二区导航在线播放| 最新福利小视频在线播放| 中文字幕一区二区不卡| 欧美精品99久久| 国产精品美女一区二区在线观看| 喜爱夜蒲2在线| 成人国产精品一级毛片视频| 欧美一区二区大胆人体摄影专业网站| 欧美影院午夜播放| 亚洲肉体裸体xxxx137| 好吊视频一区二区三区| 麻豆免费在线观看视频| 日韩毛片免费视频一级特黄| 视频一区中文字幕精品| 色综合久久66| 久久综合影院| caoporm超碰国产精品| 欧美18一12sex性处hd| 国产精品12区| 亚洲aⅴ天堂av在线电影软件| 国产精品久久久久7777按摩| 亚洲激情电影中文字幕| 国产校园另类小说区| 99精品免费观看| 五月激情四射婷婷| 摸摸摸bbb毛毛毛片| 日韩成人黄色av| 日韩电影免费网址| 亚洲精品xxx| 欧美精品高清视频| 中文字幕在线免费| 精品视频—区二区三区免费| 久久久久久国产精品免费无遮挡| 日韩一区二区高清视频| 欧美色图天堂| 亚洲综合激情六月婷婷在线观看| 午夜亚洲福利在线老司机| 亚洲第一狼人区| 成人激情黄色网| 在线男人天堂| 国产亚洲精品美女久久久m| 国产福利一区二区三区| 欧美喷潮久久久xxxxx| 亚洲男人天堂影院| 香蕉视频久久久| 亚洲成人在线电影| 亚洲欧洲午夜一线一品| 国产精品原创| 久久久久久久久久久国产精品| 欧美国产日韩一区二区三区| 亚洲色图欧美制服丝袜另类第一页| 久久91麻豆精品一区| 亚洲福利久久| 成人情趣视频网站| 久热国产精品视频一区二区三区| 朝桐光av在线| 在线免费观看电影网站入口| 一级片在线观看| 国产精品日韩精品欧美精品| 免费av福利| 国产大片精品免费永久看nba| av永久免费观看| 日韩一区二区麻豆国产| 日日噜噜夜夜狠狠视频欧美人| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 欧美xxxx三人交性视频| 久久97人妻无码一区二区三区| 久久精品国产亚洲av久| 日韩av一区在线观看| 制服丝袜中文字幕第一页| 天堂а√在线中文在线新版| 另类尿喷潮videofree| 国产欧美日韩综合精品| 亚洲午夜精品一区 二区 三区| 美女网站视频黄色| 一区二区国产精品精华液| 国产精品99久久久久久久vr| 麻豆一区二区99久久久久| 新婚的少妇hd中文字幕| 在线观看av大片| 国产高清日韩| 欧美一区二区成人| 国产亚洲欧美一区| 99精品国自产在线| 免费男女羞羞的视频网站中文子暮| 一区二区三区免费观看视频| 日本一区二区三区视频在线播放| 久久久久青草大香线综合精品| 欧美又粗又长又爽做受| 日本wwwxxxx| 91精品国产福利在线观看麻豆| 国产精品久久久久国产a级| 国内外成人在线| 91大学生片黄在线观看| 成人午夜免费在线| 草草草视频在线观看| 国产午夜手机精彩视频| 在线中文字幕播放| 在线精品亚洲一区二区不卡| 色婷婷av一区二区三区之一色屋| 韩国欧美国产1区| 欧美丝袜在线观看| 黄页网站在线观看免费| 蜜芽tv福利在线视频| 潘金莲一级淫片aaaaaa播放1| 免费无码一区二区三区| 亚洲第一精品夜夜躁人人躁| 国产亚洲欧美激情| 亚洲视频在线播放免费| 国产精品永久入口久久久| 中文字幕国产欧美| 男人的天堂久久精品| 91成人理论电影| 午夜成人影视| 欧美亚洲另类在线观看| 日本泡妞xxxx免费视频软件| 国产人妻人伦精品| 色多多国产成人永久免费网站| 国产高潮流白浆喷水视频| 国产欧美自拍视频| 久久亚洲精品小早川怜子| 亚洲一区二区免费在线观看| 国产精品99久久久久久宅男| 亚州一区二区三区| 日韩欧美性视频| 日韩 欧美 视频| 久久综合成人精品亚洲另类欧美| 在线观看成人免费视频| 国精一区二区三区| 免费男女羞羞的视频网站中文字幕| 99在线高清视频在线播放| 一级片在线观看| 亚洲一区二区三区毛片| 91精品国产91久久久久久| 国产精品调教| 97视频在线观看视频免费视频| 大肉大捧一进一出好爽视频| 精品国产污污免费网站入口| www.性欧美| 精品久久久久久综合日本| 青青草综合在线| 老司机av在线免费看| 成年人深夜福利| 狠狠噜噜久久| 亚洲激情在线视频| 久久精品国产免费观看99| 黄色小视频在线免费观看| 亚洲性色视频| 伊人精品在线视频| 色一情一伦一子一伦一区| 99在线观看免费视频精品观看| 91社区国产高清| 久久免费高清视频| 欧美人妇做爰xxxⅹ性高电影| 亚洲精品无码久久久| 色a资源在线| 日韩欧美精品在线| 99精品老司机免费视频| 青椒成人免费视频| 亚洲精品毛片一区二区三区| 1024av视频| 精品欧美aⅴ在线网站| 免费观看羞羞视频网站| 日韩欧美一区二区三区视频| 国产精品日日做人人爱|