午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > Sql Server 死鎖的監(jiān)控分析解決思路

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

熱門標(biāo)簽:400電話辦理泰安 安卡拉地圖標(biāo)注app 零成本地圖標(biāo)注賺錢 電話機器人怎么代理商 千呼電話機器人可以試用嗎 家庭農(nóng)場地圖標(biāo)注名稱怎樣起名 電銷需要外呼系統(tǒng)嗎 互聯(lián)網(wǎng)電話外呼系統(tǒng) 我要地圖標(biāo)注數(shù)量有限制嗎

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 bigint
set @SeqCode='CGJS20160106'
while(1=1)
begin
UPDATE FinanceReceiptNoRule SET NowSeqValue=@ReturnNum,ISRUNNING='0',LastWriteTime=GETDATE() WHERE IsRunning='1' AND SeqCode=@SeqCode
end /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 bigint
set @SeqCode='CGJS20160106'
while(1=1)
begin
Update 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>

表格結(jié)構(gòu)跟模擬數(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')
GO
INSERT [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>,如下圖。

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

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

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

--session 1
CREATE 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 TRANSACTION
UPDATE Test_DL SET Name='a-test' WHERE ID=1

--session3 3 3 3 3 3 3 3 3 3 
BEGIN TRANSACTION
UPDATE 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

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

 

如何使用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 XML
SELECT @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)') hostname
FROM @deadlock_xml.nodes('//event') as tb(col)

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

 

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

2 分析

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

 

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

 

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

會話1:

  • 根據(jù)主鍵SeqCode查找到鍵值所在的 索引頁 Index_Page,找到該頁上面的 keyhashvalue 鍵值行 Index_key,對Index_Page持有IU鎖,對Index_key持有U鎖;
  • 由于該表是堆表,bookmark lookup是通過 RID查找 ,即通過行標(biāo)識符查找,找到RID所對應(yīng)的行數(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鎖,升級結(jié)束后,釋放索引頁跟鍵值行上面的 IU鎖及U鎖。
  • 則此時,會話1 持有 Data_Page 上的IX鎖、RID行上的 X鎖.

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

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

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

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

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

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

 

3 解決

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

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

 

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

  • 根據(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ù)的鎖申請

 

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!

您可能感興趣的文章:
  • sql server中死鎖排查的全過程分享
  • 詳解SQL Server中的事務(wù)與鎖問題
  • sqlserver:查詢鎖住sql以及解鎖方法
  • SQL Server學(xué)習(xí)筆記之事務(wù)、鎖定、阻塞、死鎖用法詳解
  • Sql Server如何查看被鎖的表及解鎖的方法
  • SqlServer查詢和Kill進程死鎖的語句
  • sqlserver進程死鎖關(guān)閉的方法
  • sqlserver鎖表、解鎖、查看銷表的方法
  • 查找sqlserver查詢死鎖源頭的方法 sqlserver死鎖監(jiān)控
  • SQL Server三種鎖定模式的知識講解

標(biāo)簽:池州 新鄉(xiāng) 文山 大同 黃山 東營 來賓 濱州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Sql Server 死鎖的監(jiān)控分析解決思路》,本文關(guān)鍵詞  Sql,Server,死鎖,的,監(jiān)控,分析,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Sql Server 死鎖的監(jiān)控分析解決思路》相關(guān)的同類信息!
  • 本頁收集關(guān)于Sql Server 死鎖的監(jiān)控分析解決思路的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    日韩中文字幕亚洲一区二区va在线| 免费看91的网站| 福利所第一导航| 黄色一级大片在线免费看国产| 一区二区三区四区中文字幕| 精品国产依人香蕉在线精品| 伊人网在线视频观看| 亚洲午夜电影网| 免费在线观看91| 中文字幕人妻丝袜乱一区三区| 综合在线观看色| 亚洲精品一区二区三区婷婷月| 国产在线精品播放| 香蕉视频xxxx| 青草av.久久免费一区| 久久精品夜夜夜夜久久| 亚洲欧洲国产日本综合| 色哟哟在线观看一区二区三区| 7777精品伊人久久久大香线蕉经典版下载| 九九99玖玖| 国模大尺度视频| 日韩激情在线观看| 伊人伊人伊人久久| 久久久无码人妻精品一区| 亚洲成人动漫精品| 丰满少妇被猛烈进入高清播放| 老司机精品视频导航| 青青青国产精品一区二区| 稀缺小u女呦精品呦| 国产一区激情在线| 欧美一区二区三区视频在线| 91在线视频一区| 能直接看的av| 91视频免费看片| 在线视频欧美亚洲| 国产成人精品综合在线观看 | 国产91精品免费| 欧美系列在线观看| 伦伦影院午夜日韩欧美限制| 国产av一区二区三区传媒| 国产精品福利一区| 鲁鲁狠狠狠7777一区二区| 中文字幕在线2019| 欧美一区二区在线视频| 国产欧美日韩综合精品| 一级特黄曰皮片视频| 久久久久国产一区二区三区四区| 欧美视频第一页| 久久伊人91精品综合网站| 黄色免费一级视频| 欧美不卡视频一区| 视频一区国产精品| 国产原创中文av| 亚洲欧美日韩中文视频| 欧美一级淫片videoshd| 999精品在线视频| 亚洲综合色噜噜狠狠| 日韩一级在线播放| 中文字幕一区二区三区波野结| 成人观看免费视频| 久久精品成人av| av影片在线播放| 狠狠干狠狠操视频| 免费裸体美女网站| 国产九九九九九| 九一免费在线观看| 一区二区精品视频| 日韩美女一区| 欧美另类视频在线| 精品伦理一区二区三区| 成人欧美一区二区三区在线观看| 国产欧美韩国高清| 国产精品青草久久久久福利99| 91豆花精品一区| 午夜精品蜜臀一区二区三区免费 | 国产三级精品视频| 99精品国产热久久91蜜凸| 国产福利精品导航| 国产综合久久久久久久久久久久| 日本欧美在线观看| 手机精品视频在线观看| 久久精品成人| 天天色综合av| 久久婷婷亚洲| 日韩av一级片| 日本成人在线不卡视频| 秋霞影院一区二区| 蜜桃精品视频在线观看| 久久精品国产亚洲高清剧情介绍 | 中文字幕无人区二| 成人啪啪18免费游戏链接| 免费不卡av网站| 美女日批在线观看| 亚洲色图欧美日韩| aa片在线观看视频在线播放| av无码av天天av天天爽| 久久精品国产亚洲av久| 精品无人区无码乱码毛片国产| 97人妻精品一区二区免费| 西西444www无码大胆| 国产美女永久免费无遮挡| 亚洲欧美va天堂人熟伦 | 青青草偷拍视频| 国产一级一级片| 亚洲日本视频在线观看| jizz国产在线| 国产黄色一级大片| 久久久久久婷| 韩国精品一区二区| 99国产精品国产精品久久| 国产欧美一区二区精品忘忧草 | 日韩成人av影视| 国产一区二区三区美女| 成人免费看黄yyy456| 久久亚洲精品小早川怜子| 国产精品视频线看| 国产精品久久综合| 午夜视频一区二区| 欧美日韩在线综合| 亚洲国内精品在线| 色婷婷av一区二区三区在线观看 | 日本三级网站在线观看| 日韩黄色片网站| 精品国产亚洲AV| 日韩精品免费视频人成| 国产91丝袜在线播放九色| 久久老女人爱爱| 有坂深雪av一区二区精品| 色屁屁一区二区| 欧美mv日韩mv国产网站| 亚洲午夜色婷婷在线| 久久久久久久久国产| 国产精品欧美日韩| 蜜桃成人免费视频| 男人天堂新网址| 欧美日韩一区二区三区69堂| 久久人妻少妇嫩草av无码专区| 成年人免费视频播放| 毛片视频网站在线观看| 99精品久久久久久中文字幕| 日韩电影免费在线看| 本田岬高潮一区二区三区| 中文字幕一区二区三区视频| 欧美日韩国产中文字幕| 精品对白一区国产伦| 久久九九免费视频| 国产精品免费网站| 热re99久久精品国产99热| 人妻互换免费中文字幕| www.超碰97.com| 18精品爽国产三级网站| 337p粉嫩色噜噜噜大肥臀| 午夜在线观看视频18| a级精品国产片在线观看| 一区二区三区中文免费| 欧美一区二区三区四区视频| 日韩视频在线观看免费| 国产精品午夜视频| 亚洲人成77777| 一区二区三区网址| 中文字幕第69页| 亚洲图片视频小说| 国产一区视频导航| 亚洲激情自拍视频| 日韩欧美一区二区免费| 色综合久久久久久中文网| 亚洲a在线播放| 在线观看成人av电影| 国产喷水theporn| 欧美性生交大片| 国产精品国产三级国产普通话对白| 蓝色福利精品导航| 亚洲天堂av一区| 日韩欧美国产成人一区二区| 欧美日产国产成人免费图片| 国产福利久久| 成人观看免费完整观看| 最近中文字幕在线mv视频在线| 少妇久久久久久久| 久久狠狠亚洲综合| 一区二区三区在线视频观看| 亚洲国产欧美一区| 国产va免费精品高清在线| 午夜精品视频在线观看一区二区| 欧美美女性视频| 久草视频免费在线播放| 四季av日韩精品一区| 国产婷婷一区二区| 91精品国产欧美一区二区成人| 欧美激情va永久在线播放| 国内精品久久国产| 美女喷白浆视频| 欧美偷拍第一页| 久久性天堂网| 亚洲免费在线播放| 亚洲精品一区二区三区不| 国产女人18毛片水18精品| 久久99久久99精品| 国产精品成人无码免费| www.蜜臀av.com| 中文天堂在线一区| 欧美精品一区二区三区在线| 国产成人一区二区三区电影| 麻豆视频传媒入口| 91视频免费观看网站| www.日韩高清| 国产精品久久久久久久久免费丝袜| 777午夜精品免费视频| 97视频在线观看播放| 亚洲欧美一区二区原创| 亚洲欧美日本一区| 99热这里只有精| 国产精品久线观看视频| 亚洲精品美女久久久| 成人黄色片在线| 男人添女人下面高潮视频| 男人的午夜天堂| 日韩精品国产精品| 亚洲成人综合视频| 欧美成年人视频| 日韩免费三级| 99久久国产精| 国产黄色av片| 一区二区三区四区在线| 自拍视频国产精品| 欧美一级日本a级v片| 日本精品一二三| 国产片在线播放| 国产精品国产三级国产aⅴ入口 | 日韩人妻一区二区三区| 午夜久久久久久噜噜噜噜| 亚洲私人影院在线观看| 在线日韩日本国产亚洲| 欧美中文娱乐网| 中文字幕日韩三级片| 亚洲精品福利网站| 亚洲午夜电影在线| 欧美激情视频一区二区三区不卡 | 18岁网站在线观看| 国产精品99无码一区二区| 国产成人日日夜夜| 日韩亚洲欧美一区二区三区| 成人国产精品日本在线| 国产无遮挡猛进猛出免费软件| 中文字幕男人天堂| 亚洲日本在线a| 欧美成人精品激情在线观看| 成人手机视频在线| 国产中文av在线| 国产乱人伦偷精品视频免下载| 在线不卡的av| 亚洲精品女av网站| a级大片免费看| 亚洲免费黄色片| 欧美丝袜一区二区| 日韩av免费在线播放| av在线无限看| 国产美女无遮挡永久免费| 亚洲夂夂婷婷色拍ww47| 国内精品久久久久影院 日本资源| 福利视频一区二区三区四区| 国产精彩视频在线观看| 91视频精品在这里| 亚洲系列中文字幕| 正在播放91九色| 久久久精品一区二区涩爱| 97国产精品videossex| 亚洲男人天堂九九视频| 亚洲资源视频| 久久久久香蕉视频| 久久九九久精品国产免费直播| 在线观看日韩视频| 福利在线小视频| 九九热精品视频在线| 1024国产精品| 国内精品伊人久久| 午夜免费高清视频| 性做久久久久久久| 欧美亚洲高清一区| 国产成人免费电影| 亚洲女同二女同志奶水| 成人免费看视频| 日韩小视频在线| 日本日本19xxxⅹhd乱影响| 中文字幕乱码中文字幕| 亚洲成人免费视频| 国产欧美日韩免费| 岛国精品资源网站| 国产一区日韩二区欧美三区| 亚洲精品少妇网址| wwwwww欧美| 中文字幕一二区| 欧美性猛交xxxx富婆弯腰| 91影视免费在线观看| 粉嫩av蜜桃av蜜臀av| 国产aⅴ综合色| 中文字幕国内精品| 欧美国产激情视频| 精品人妻一区二区三区蜜桃 | 黄色av免费观看| 欧美一区二区免费视频| 日本精品一区二区| 国产一级做a爰片在线看免费| 成人免费一区二区三区视频| 日韩av手机在线看| 精品人妻一区二区三区日产| 国产老妇另类xxxxx| 国产一区二区美女视频| 欧美在线一区视频| 精品国产乱码一区二区三| 欧美高清视频在线高清观看mv色露露十八| 久久精品ww人人做人人爽| 日本妇女毛茸茸| 亚洲欧洲制服丝袜| 成人黄色影片在线| 人妻无码一区二区三区免费| 国产亚洲美州欧州综合国| 91av视频在线免费观看| 波多野吉衣在线视频| 国产一区二区三区四区在线观看| 一区二区欧美在线| 已婚少妇美妙人妻系列| 亚洲人在线观看视频| 日韩成人在线播放| 国产精品自拍片| 午夜视频www| 亚洲欧美在线一区| 无码精品a∨在线观看中文| 色呦呦免费观看| 亚洲精品99久久久久| 久激情内射婷内射蜜桃| 性感美女视频一二三| 国产视频一区在线| 久草青青在线观看| 免费不卡在线观看| 久久久成人的性感天堂| 伊人国产精品视频| 成人sese在线| 欧美中文在线视频| 极品粉嫩小仙女高潮喷水久久| 久久久99精品久久| 成人黄色网免费| 欧美片一区二区| 粉嫩老牛aⅴ一区二区三区| 欧美精品一区二区三区在线四季 | 少妇高潮喷水在线观看| 亚洲av电影一区| 夜夜嗨av色综合久久久综合网| 三级在线免费看| 国产精品888| 55夜色66夜色国产精品视频| 制服丝袜第一页在线观看| 国产日韩欧美电影| 亚洲综合成人婷婷小说| 激情五月色婷婷| 欧美性猛交xxxx乱大交退制版| 国产高清免费在线| 污视频在线免费观看| 最近中文字幕日韩精品| 少妇愉情理伦片bd| 国产欧美一区二区在线| 99中文视频在线| 一级做a爰片久久毛片| 3atv一区二区三区| 国产精品宾馆在线精品酒店| 美女一区二区视频| 国内精品久久久久久久| 自拍偷拍第9页| 精品久久久久久久久久久久| 亚洲精品国产精品国自产观看| 性少妇videosexfreexxx片| 亚洲性夜色噜噜噜7777| 香蕉视频xxx| 欧美激情综合在线| 国产精品美女诱惑| 在线免费看91| 亚洲美女av电影| 日韩高清第一页| 久久久青草青青国产亚洲免观| 91免费观看网站| 亚洲av无码不卡| 亚洲精品国精品久久99热一| 老司机久久精品| 欧美国产日韩a欧美在线观看| 成人网欧美在线视频| 在线观看中文字幕视频| 日韩亚洲欧美高清| 久久国产精品国产精品| 久久精品欧美一区二区三区不卡 | 国产精品亚洲一区二区三区妖精 | 成人久久18免费网站图片| 亚洲精品男人天堂| 亚洲成人性视频| 久久久国产精品久久久| 亚洲色欲色欲www| 色女人综合av| 青草国产精品久久久久久| 国产999在线观看| av大片免费观看| 亚洲精品美女网站| 黄色在线免费播放| 一区二区成人在线观看| 中国老女人av| 国产在线观看一区二区| 91精品久久久久久久久久入口| 波多野结衣大片| 在线观看国产成人av片| 蜜桃久久精品成人无码av| 欧美区视频在线观看| 欧美一级视频在线|