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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > asp.net >内容正文

asp.net

详解 ASP.NET异步

發(fā)布時(shí)間:2024/9/20 asp.net 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 详解 ASP.NET异步 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

在前文中,介紹了.NET下的多種異步的形式,在WEB程序中,天生就是多線程的,因此使用異步應(yīng)該更為謹(jǐn)慎。本文將著重展開(kāi)ASP.NET中的異步。

??? 【注意】本文中提到的異步指的是服務(wù)器端異步,而非客戶端異步(Ajax)。

??? 對(duì)于HTTP的請(qǐng)求響應(yīng)模型,服務(wù)器無(wú)法主動(dòng)通知或回調(diào)客戶端,當(dāng)客戶端發(fā)起一個(gè)請(qǐng)求后,必須保持連接等待服務(wù)器的返回結(jié)果,才能繼續(xù)處理,因此,對(duì)于客戶端來(lái)說(shuō),請(qǐng)求與響應(yīng)是無(wú)法異步進(jìn)行,也就是說(shuō)無(wú)論服務(wù)器如何處理請(qǐng)求,對(duì)于客戶端來(lái)說(shuō)沒(méi)有任何差別。

???

??? 那么ASP.NET異步指的又是什么,解決了什么問(wèn)題呢?

??? 在解釋ASP.NET異步前,先來(lái)考察下ASP.NET線程模型。

????ASP.NET線程模型

??? 我們知道,一個(gè)WEB服務(wù)可以同時(shí)服務(wù)器多個(gè)用戶,我們可以想象一下,WEB程序應(yīng)該運(yùn)行于多線程環(huán)境中,對(duì)于運(yùn)行WEB程序的線程,我們可以稱之為WEB線程,那么,先來(lái)看看WEB線程長(zhǎng)什么樣子吧。

??? 我們可以用一個(gè)HttpHandler輸出一些內(nèi)容。

public class Handler : IHttpHandler
{

public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
var thread = Thread.CurrentThread;
context.Response.Write(
string.Format("Name:{0}\r\nManagedThreadId:{1}\r\nIsBackground:{2}\r\nIsThreadPoolThread:{3}",
thread.Name,
thread.ManagedThreadId,
thread.IsBackground,
thread.IsThreadPoolThread)
);
}

public bool IsReusable
{
get {return true;}
}
}

??? 你可以看到類(lèi)似于這樣的結(jié)果:

??? Name:

??? ManagedThreadId:57

??? IsBackground:True

??? IsThreadPoolThread:True

??? 這里可以看到,WEB線程是一個(gè)沒(méi)有名稱的線程池中的線程,如果刷新這個(gè)頁(yè)面,還有機(jī)會(huì)看到 ManagedThreadId 在不斷變化,并且可能重復(fù)出現(xiàn)。說(shuō)明WEB程序有機(jī)會(huì)運(yùn)行于線程池中的不同線程。

??? 為了模擬多用戶并發(fā)訪問(wèn)的情況,我們需要對(duì)這個(gè)處理程序添加人為的延時(shí),并輸出線程相關(guān)信息與開(kāi)始結(jié)束時(shí)間,再通過(guò)客戶端程序同時(shí)發(fā)起多個(gè)請(qǐng)求,查看返回的內(nèi)容,分析請(qǐng)求的處理情況。

public void ProcessRequest(HttpContext context)
{
DateTime begin = DateTime.Now;
int t1, t2, t3;
ThreadPool.GetAvailableThreads(out t1, out t3);
ThreadPool.GetMaxThreads(out t2, out t3);
Thread.Sleep(TimeSpan.FromSeconds(10));
DateTime end = DateTime.Now;
context.Response.ContentType = "text/plain";
var thread = Thread.CurrentThread;
context.Response.Write(
string.Format("TId:{0}\tApp:{1}\tBegin:{2:mm:ss,ffff}\tEnd:{3:mm:ss,ffff}\tTPool:{4}",
thread.ManagedThreadId,
context.ApplicationInstance.GetHashCode(),
begin,
end,
t2 - t1
)
);
}

??? 我們用一個(gè)命令行程序來(lái)發(fā)起請(qǐng)求,并顯示結(jié)果。

static void Main()
{
var url = new Uri("http://localhost:8012/Handler.ashx");
var num = 50;
for (int i = 0; i < num; i++)
{
var request = WebRequest.Create(url);
request.GetResponseAsync().ContinueWith(t =>
{
var stream = t.Result.GetResponseStream();
using (TextReader tr = new StreamReader(stream))
{
Console.WriteLine(tr.ReadToEnd());
}
});
}
Console.ReadLine();
}

??? 這里,我們同時(shí)發(fā)起了50個(gè)請(qǐng)求,然后觀察響應(yīng)的情況。

??? 【注意】后面的結(jié)果會(huì)因?yàn)椴僮飨到y(tǒng)、IIS版本、管道模式、.NET版本、配置項(xiàng) 的不同而不同,以下結(jié)果為在Windows Server 2008 R2 + IIS7.5 + .NET 4.5 beta(.NET 4 runtime) + 默認(rèn)配置 中測(cè)試的結(jié)果,在沒(méi)有特別說(shuō)明的情況下,均為重啟IIS后第一次運(yùn)行的情況。
??? 這個(gè)程序在我的電腦運(yùn)行結(jié)果是這樣的:?

TId:6 App:35898671 Begin:55:30,3176 End:55:40,3182 TPool:2
TId:5 App:22288629 Begin:55:30,3176 End:55:40,3212 TPool:2
TId:7 App:12549444 Begin:55:31,0426 End:55:41,0432 TPool:3
TId:8 App:22008501 Begin:55:31,5747 End:55:41,5752 TPool:4
TId:9 App:37121646 Begin:55:32,1067 End:55:42,1073 TPool:5
TId:10 App:33156464 Begin:55:32,6387 End:55:42,6393 TPool:6
TId:11 App:7995840 Begin:55:33,1707 End:55:43,1713 TPool:7
TId:12 App:36610825 Begin:55:33,7028 End:55:43,7033 TPool:8
TId:13 App:20554616 Begin:55:34,2048 End:55:44,2054 TPool:9
TId:14 App:15510466 Begin:55:35,2069 End:55:45,2074 TPool:10
TId:15 App:23324256 Begin:55:36,2049 End:55:46,2055 TPool:11
TId:16 App:34250480 Begin:55:37,2050 End:55:47,2055 TPool:12
TId:17 App:58408916 Begin:55:38,2050 End:55:48,2056 TPool:13
TId:18 App:2348279 Begin:55:39,2051 End:55:49,2057 TPool:14
TId:19 App:61669314 Begin:55:40,2051 End:55:50,2057 TPool:15
TId:6 App:35898671 Begin:55:40,3212 End:55:50,3217 TPool:15
TId:5 App:22288629 Begin:55:40,3232 End:55:50,3237 TPool:15
TId:7 App:12549444 Begin:55:41,0432 End:55:51,0438 TPool:15
TId:8 App:22008501 Begin:55:41,5752 End:55:51,5758 TPool:15
TId:9 App:37121646 Begin:55:42,1073 End:55:52,1078 TPool:15
TId:10 App:33156464 Begin:55:42,6393 End:55:52,6399 TPool:15
TId:11 App:7995840 Begin:55:43,1713 End:55:53,1719 TPool:15
TId:12 App:36610825 Begin:55:43,7043 End:55:53,7049 TPool:15
TId:13 App:20554616 Begin:55:44,2054 End:55:54,2059 TPool:15
TId:20 App:36865354 Begin:55:45,2074 End:55:55,2080 TPool:16
TId:14 App:15510466 Begin:55:45,2084 End:55:55,2090 TPool:16
TId:21 App:3196068 Begin:55:46,2055 End:55:56,2061 TPool:17
TId:15 App:23324256 Begin:55:46,2065 End:55:56,2071 TPool:17
TId:22 App:4186222 Begin:55:47,2055 End:55:57,2061 TPool:18
TId:16 App:34250480 Begin:55:47,2065 End:55:57,2071 TPool:18
TId:23 App:764807 Begin:55:48,2046 End:55:58,2052 TPool:19
TId:17 App:58408916 Begin:55:48,2056 End:55:58,2062 TPool:19
TId:24 App:10479095 Begin:55:49,2047 End:55:59,2052 TPool:20
TId:18 App:2348279 Begin:55:49,2057 End:55:59,2062 TPool:20
TId:25 App:4684807 Begin:55:50,2047 End:56:00,2053 TPool:21
TId:19 App:61669314 Begin:55:50,2057 End:56:00,2063 TPool:21
TId:6 App:35898671 Begin:55:50,3227 End:56:00,3233 TPool:21
TId:5 App:22288629 Begin:55:50,3237 End:56:00,3243 TPool:21
TId:7 App:12549444 Begin:55:51,0438 End:56:01,0443 TPool:21
TId:8 App:22008501 Begin:55:51,5758 End:56:01,5764 TPool:21
TId:9 App:37121646 Begin:55:52,1078 End:56:02,1084 TPool:21
TId:10 App:33156464 Begin:55:52,6399 End:56:02,6404 TPool:21
TId:11 App:7995840 Begin:55:53,1719 End:56:03,1725 TPool:21
TId:26 App:41662089 Begin:55:53,7049 End:56:03,7055 TPool:22
TId:12 App:36610825 Begin:55:53,7059 End:56:03,7065 TPool:22
TId:13 App:20554616 Begin:55:54,2069 End:56:04,2075 TPool:22
TId:27 App:46338128 Begin:55:55,2070 End:56:05,2076 TPool:23
TId:14 App:15510466 Begin:55:55,2090 End:56:05,2096 TPool:23
TId:20 App:36865354 Begin:55:55,2090 End:56:05,2096 TPool:23
TId:28 App:28975576 Begin:55:56,2051 End:56:06,2056 TPool:24

??? 從這個(gè)結(jié)果大概可以看出,開(kāi)始兩個(gè)請(qǐng)求幾乎同時(shí)開(kāi)始處理,因?yàn)榫€程池最小線程數(shù)為2(可配置),緊接著后面的請(qǐng)求會(huì)每隔半秒鐘開(kāi)始一個(gè),因?yàn)槿绻刂械木€程都忙,會(huì)等待半秒(.NET版本不同而不同),如果還是沒(méi)有線程釋放則開(kāi)啟新的線程,直到達(dá)到最大線程數(shù)(可配置)。未能在線程池中處理的請(qǐng)求將被放入請(qǐng)求隊(duì)列,當(dāng)一個(gè)線程釋放后,下一個(gè)請(qǐng)求緊接著開(kāi)始在該線程處理。

??? 最終50個(gè)請(qǐng)求共產(chǎn)生24個(gè)線程,總用時(shí)約35.9秒。

??? 光看數(shù)據(jù)不夠形象,用簡(jiǎn)單的代碼把數(shù)據(jù)轉(zhuǎn)換成圖形吧,下面是100個(gè)請(qǐng)求的處理過(guò)程。

???

??? 我們可以看到,當(dāng)WEB線程長(zhǎng)時(shí)間被占用時(shí),請(qǐng)求會(huì)由于線程池而阻塞,同時(shí)產(chǎn)生大量的線程,最終響應(yīng)時(shí)間變長(zhǎng)。

??? 作為對(duì)比,我們列出處理時(shí)間10毫秒的數(shù)據(jù)。

TId:6 App:44665200 Begin:41:07,9932 End:41:08,0032 TPool:2
TId:5 App:37489757 Begin:41:07,9932 End:41:08,0032 TPool:2
TId:5 App:44665200 Begin:41:08,0042 End:41:08,0142 TPool:2
TId:6 App:37489757 Begin:41:08,0052 End:41:08,0152 TPool:2
TId:5 App:44665200 Begin:41:08,0142 End:41:08,0242 TPool:2
TId:6 App:37489757 Begin:41:08,0152 End:41:08,0252 TPool:2
TId:5 App:44665200 Begin:41:08,0242 End:41:08,0342 TPool:2
TId:6 App:37489757 Begin:41:08,0252 End:41:08,0352 TPool:2
TId:5 App:44665200 Begin:41:08,0342 End:41:08,0442 TPool:2
TId:6 App:37489757 Begin:41:08,0352 End:41:08,0452 TPool:2
TId:5 App:44665200 Begin:41:08,0442 End:41:08,0542 TPool:2
TId:6 App:37489757 Begin:41:08,0452 End:41:08,0552 TPool:2
TId:5 App:44665200 Begin:41:08,0542 End:41:08,0642 TPool:2
TId:6 App:37489757 Begin:41:08,0552 End:41:08,0652 TPool:2
TId:5 App:44665200 Begin:41:08,0642 End:41:08,0742 TPool:2
TId:6 App:37489757 Begin:41:08,0652 End:41:08,0752 TPool:2
TId:5 App:44665200 Begin:41:08,0742 End:41:08,0842 TPool:2
TId:6 App:37489757 Begin:41:08,0752 End:41:08,0852 TPool:2
TId:5 App:44665200 Begin:41:08,0842 End:41:08,0942 TPool:2
TId:6 App:37489757 Begin:41:08,0852 End:41:08,0952 TPool:2
TId:5 App:44665200 Begin:41:08,0942 End:41:08,1042 TPool:2
TId:6 App:37489757 Begin:41:08,0952 End:41:08,1052 TPool:2
TId:5 App:44665200 Begin:41:08,1042 End:41:08,1142 TPool:2
TId:6 App:37489757 Begin:41:08,1052 End:41:08,1152 TPool:2
TId:5 App:44665200 Begin:41:08,1142 End:41:08,1242 TPool:2
TId:6 App:37489757 Begin:41:08,1152 End:41:08,1252 TPool:2
TId:5 App:44665200 Begin:41:08,1242 End:41:08,1342 TPool:2
TId:6 App:37489757 Begin:41:08,1252 End:41:08,1352 TPool:2
TId:5 App:44665200 Begin:41:08,1342 End:41:08,1442 TPool:2
TId:6 App:37489757 Begin:41:08,1352 End:41:08,1452 TPool:2
TId:5 App:44665200 Begin:41:08,1442 End:41:08,1542 TPool:2
TId:6 App:37489757 Begin:41:08,1452 End:41:08,1552 TPool:2
TId:5 App:44665200 Begin:41:08,1542 End:41:08,1642 TPool:2
TId:6 App:37489757 Begin:41:08,1552 End:41:08,1652 TPool:2
TId:5 App:44665200 Begin:41:08,1642 End:41:08,1742 TPool:2
TId:6 App:37489757 Begin:41:08,1652 End:41:08,1752 TPool:2
TId:5 App:44665200 Begin:41:08,1742 End:41:08,1842 TPool:3
TId:7 App:12547953 Begin:41:08,1752 End:41:08,1852 TPool:3
TId:6 App:37489757 Begin:41:08,1762 End:41:08,1862 TPool:3
TId:5 App:44665200 Begin:41:08,1842 End:41:08,1942 TPool:3
TId:7 App:12547953 Begin:41:08,1852 End:41:08,1952 TPool:3
TId:6 App:37489757 Begin:41:08,1862 End:41:08,1962 TPool:3
TId:5 App:44665200 Begin:41:08,1942 End:41:08,2042 TPool:3
TId:7 App:12547953 Begin:41:08,1952 End:41:08,2092 TPool:3
TId:6 App:37489757 Begin:41:08,1962 End:41:08,2102 TPool:3
TId:5 App:44665200 Begin:41:08,2052 End:41:08,2152 TPool:3
TId:7 App:12547953 Begin:41:08,2092 End:41:08,2192 TPool:3
TId:6 App:37489757 Begin:41:08,2102 End:41:08,2202 TPool:3
TId:5 App:44665200 Begin:41:08,2152 End:41:08,2252 TPool:3
TId:7 App:12547953 Begin:41:08,2192 End:41:08,2292 TPool:3

??? 共產(chǎn)生線程3個(gè),總用時(shí)0.236秒。

??? 根據(jù)以上的數(shù)據(jù),我們可以得出結(jié)論,要提高系統(tǒng)響應(yīng)時(shí)間與并發(fā)處理數(shù),應(yīng)盡可能減少WEB線程的等待。

??? 【略】請(qǐng)各位自行查驗(yàn)當(dāng)一次并發(fā)全部處理完畢后再次測(cè)試的處理情況。

??? 【略】請(qǐng)各位自行查驗(yàn)當(dāng)處理程序中使用線程池處理等待任務(wù)的處理情況。

??? 如何減少WEB線程的等待呢,那就應(yīng)該盡早的結(jié)果ProcessRequest方法,前一篇中講到,對(duì)于一些需要等待完成的任務(wù),可以使用異步方法來(lái)做,于是我們可以在ProcessRequest中調(diào)用異步方法,但問(wèn)題是當(dāng)ProcessRequest結(jié)束后,請(qǐng)求處理也即將結(jié)束,一但請(qǐng)求結(jié)束,將沒(méi)有辦法在這一次請(qǐng)求中返回結(jié)果給客戶端,但是此時(shí),異步任務(wù)還沒(méi)有完成,當(dāng)異步任務(wù)完成時(shí),也許再也沒(méi)有辦法將結(jié)果傳給客戶端了。(難道用輪詢?囧)

???? 我們需要的方案是,處理請(qǐng)求時(shí)可以暫停處理(不是暫停線程),并保持客戶端連接,在需要時(shí),向客戶端輸出結(jié)果,并結(jié)束請(qǐng)求。

???

??? 在這個(gè)模型中,可以看到,對(duì)于WebServerRuntime來(lái)說(shuō),我們的請(qǐng)求處理程序就是一個(gè)異步方法,而對(duì)于客戶端來(lái)說(shuō),卻并不知道后面的處理情況。無(wú)論在WebServerRuntime或是我們的處理程序,都沒(méi)有直接占用線程,一切由何時(shí)SetComplete決定。同時(shí)可以看到,這種模式需要WebServerRuntime的緊密配合,提供調(diào)用異步方法的接口。在ASP.NET中,這個(gè)接口就是IHttpAsyncHandler。

????異步ASP.NET處理程序

??? 首先,我們來(lái)實(shí)現(xiàn)第一個(gè)異步處理程序,在適當(dāng)?shù)臅r(shí)候觸發(fā)結(jié)束,在開(kāi)始和結(jié)束時(shí)輸出一些信息。?

public class Handler : IHttpHandler, IHttpAsyncHandler
{
public void ProcessRequest(HttpContext context)
{
//異步處理器不執(zhí)行該方法
}

public bool IsReusable
{
//設(shè)置允許重用對(duì)象
get { return false; }
}

//請(qǐng)求開(kāi)始時(shí)由ASP.NET調(diào)用此方法
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, object extraData)
{
context.Response.ContentType = "text/xml";
context.Response.Write("App:");
context.Response.Write(context.ApplicationInstance.GetHashCode());
context.Response.Write("\tBegin:");
context.Response.Write(DateTime.Now.ToString("mm:ss,ffff"));
//輸出當(dāng)前線程
context.Response.Write("\tThreadId:");
context.Response.Write(Thread.CurrentThread.ManagedThreadId);
//構(gòu)建異步結(jié)果并返回
var result = new WebAsyncResult(cb, context);
//用一個(gè)定時(shí)器來(lái)模擬異步觸發(fā)完成
Timer timer = null;
timer = new Timer(o =>
{
result.SetComplete();
timer.Dispose();
}, null, TimeSpan.FromSeconds(5), TimeSpan.FromSeconds(5));
return result;
}

//異步結(jié)束時(shí),由ASP.NET調(diào)用此方法
public void EndProcessRequest(IAsyncResult result)
{
WebAsyncResult webresult = (WebAsyncResult)result;
webresult.Context.Response.Write("\tEnd:");
webresult.Context.Response.Write(DateTime.Now.ToString("mm:ss,ffff"));
//輸出當(dāng)前線程
webresult.Context.Response.Write("\tThreadId:");
webresult.Context.Response.Write(Thread.CurrentThread.ManagedThreadId);
}

//WEB異步方法結(jié)果
class WebAsyncResult : IAsyncResult
{
private AsyncCallback _callback;

public WebAsyncResult(AsyncCallback cb, HttpContext context)
{
Context = context;
_callback = cb;
}

//當(dāng)異步完成時(shí)調(diào)用該方法
public void SetComplete()
{
IsCompleted = true;
if (_callback != null)
{
_callback(this);
}
}

public HttpContext Context
{
get;
private set;
}

public object AsyncState
{
get { return null; }
}

//由于ASP.NET不會(huì)等待WEB異步方法,所以不使用此對(duì)象
public WaitHandle AsyncWaitHandle
{
get { throw new NotImplementedException(); }
}

public bool CompletedSynchronously
{
get { return false; }
}

public bool IsCompleted
{
get;
private set;
}
}
}

??? 在這里,我們實(shí)現(xiàn)了一個(gè)簡(jiǎn)單的AsyncResult,由于ASP.NET通過(guò)回調(diào)方法獲取異步完成,不會(huì)等待異步,所以不需要WaitHandle。在開(kāi)始請(qǐng)求時(shí),建立一個(gè)AsyncResult后直接返回,當(dāng)異步完成時(shí),調(diào)用AsyncResult的SetComplete方法,調(diào)用回調(diào)方法,再由ASP.NET調(diào)用異步結(jié)束。此時(shí)整個(gè)請(qǐng)求即完成。

??? 當(dāng)我們?cè)L問(wèn)這個(gè)地址,可以得到類(lèi)似于下面的結(jié)果:

??? App:11240144 Begin:37:24,2676 ThreadId:6 End:37:29,2619 ThreadId:6

??? 可以看到開(kāi)始和結(jié)束在同一個(gè)線程中運(yùn)行。?

???

??? 當(dāng)有多個(gè)并發(fā)請(qǐng)求時(shí),線程池將忙碌起來(lái),開(kāi)始與結(jié)束處理也獎(jiǎng)有機(jī)會(huì)運(yùn)行于不同的線程上。50個(gè)請(qǐng)求并發(fā)時(shí)的處理數(shù)據(jù):

App:52307948 Begin:39:47,8128 ThreadId:6 End:39:52,8231 ThreadId:5
App:58766839 Begin:39:47,8358 ThreadId:5 End:39:52,8321 ThreadId:7
App:23825510 Begin:39:47,8348 ThreadId:5 End:39:52,8321 ThreadId:7
App:30480920 Begin:39:47,8348 ThreadId:5 End:39:52,8321 ThreadId:7
App:62301924 Begin:39:47,8348 ThreadId:6 End:39:52,8321 ThreadId:6
App:28062782 Begin:39:47,8338 ThreadId:5 End:39:52,8321 ThreadId:6
App:41488021 Begin:39:47,8338 ThreadId:6 End:39:52,8321 ThreadId:7
App:15315213 Begin:39:47,8338 ThreadId:6 End:39:52,8321 ThreadId:6
App:17228638 Begin:39:47,8328 ThreadId:5 End:39:52,8321 ThreadId:7
App:51438283 Begin:39:47,8328 ThreadId:6 End:39:52,8321 ThreadId:6
App:32901400 Begin:39:47,8328 ThreadId:5 End:39:52,8321 ThreadId:7
App:61925337 Begin:39:47,8358 ThreadId:6 End:39:52,8321 ThreadId:6
App:24914721 Begin:39:47,8318 ThreadId:6 End:39:52,8321 ThreadId:6
App:26314214 Begin:39:47,8318 ThreadId:6 End:39:52,8321 ThreadId:6
App:51004322 Begin:39:47,8358 ThreadId:6 End:39:52,8321 ThreadId:6
App:51484875 Begin:39:47,8308 ThreadId:5 End:39:52,8321 ThreadId:7
App:19420176 Begin:39:47,8308 ThreadId:6 End:39:52,8321 ThreadId:6
App:16868352 Begin:39:47,8298 ThreadId:6 End:39:52,8321 ThreadId:7
App:61115195 Begin:39:47,8298 ThreadId:5 End:39:52,8321 ThreadId:6
App:63062333 Begin:39:47,8288 ThreadId:6 End:39:52,8321 ThreadId:6
App:53447344 Begin:39:47,8298 ThreadId:5 End:39:52,8321 ThreadId:7
App:31665793 Begin:39:47,8288 ThreadId:5 End:39:52,8321 ThreadId:7
App:2174563 Begin:39:47,8288 ThreadId:6 End:39:52,8321 ThreadId:6
App:12053474 Begin:39:47,8318 ThreadId:5 End:39:52,8321 ThreadId:7
App:41728762 Begin:39:47,8278 ThreadId:6 End:39:52,8321 ThreadId:6
App:6385742 Begin:39:47,8278 ThreadId:5 End:39:52,8321 ThreadId:7
App:13009416 Begin:39:47,8268 ThreadId:6 End:39:52,8321 ThreadId:6
App:43205102 Begin:39:47,8268 ThreadId:5 End:39:52,8321 ThreadId:7
App:14333193 Begin:39:47,8268 ThreadId:6 End:39:52,8321 ThreadId:6
App:2808346 Begin:39:47,8258 ThreadId:6 End:39:52,8321 ThreadId:6
App:37489757 Begin:39:47,8128 ThreadId:5 End:39:52,8231 ThreadId:6
App:34106743 Begin:39:47,8258 ThreadId:5 End:39:52,8321 ThreadId:7
App:30180123 Begin:39:47,8248 ThreadId:6 End:39:52,8321 ThreadId:6
App:44313942 Begin:39:47,8248 ThreadId:5 End:39:52,8321 ThreadId:7
App:12611187 Begin:39:47,8248 ThreadId:6 End:39:52,8321 ThreadId:6
App:7141266 Begin:39:47,8238 ThreadId:5 End:39:52,8321 ThreadId:7
App:25425822 Begin:39:47,8278 ThreadId:5 End:39:52,8321 ThreadId:7
App:51288387 Begin:39:47,8238 ThreadId:5 End:39:52,8321 ThreadId:7
App:66166301 Begin:39:47,8228 ThreadId:6 End:39:52,8321 ThreadId:6
App:34678979 Begin:39:47,8228 ThreadId:6 End:39:52,8321 ThreadId:7
App:10104599 Begin:39:47,8218 ThreadId:5 End:39:52,8321 ThreadId:6
App:47362231 Begin:39:47,8258 ThreadId:5 End:39:52,8321 ThreadId:7
App:40535505 Begin:39:47,8218 ThreadId:6 End:39:52,8321 ThreadId:7
App:20726372 Begin:39:47,8368 ThreadId:5 End:39:52,8321 ThreadId:5
App:2730334 Begin:39:47,8368 ThreadId:6 End:39:52,8321 ThreadId:6
App:59884855 Begin:39:47,8368 ThreadId:5 End:39:52,8321 ThreadId:7
App:39774547 Begin:39:47,8238 ThreadId:6 End:39:52,8321 ThreadId:6
App:12070837 Begin:39:47,8378 ThreadId:6 End:39:52,8491 ThreadId:7
App:64828693 Begin:39:47,8218 ThreadId:5 End:39:52,8331 ThreadId:6
App:14509978 Begin:39:47,9308 ThreadId:6 End:39:52,9281 ThreadId:5

??? 可以看到,從始至終只由3個(gè)線程處理所有的請(qǐng)求,總共時(shí)間約5.12秒。

??? 為簡(jiǎn)化分析,我們用下面的圖來(lái)示意異步處理程序的并發(fā)處理過(guò)程。

????

??? 這樣,我們就可以通過(guò)異步的方式,將WEB線程撤底釋放出來(lái)。由WEB線程進(jìn)行請(qǐng)求的接收與結(jié)束處理,耗時(shí)的操作與等待都進(jìn)行異步處理。這樣少量的WEB線程就可以承受大量的并發(fā)請(qǐng)求,WEB線程將不再成為系統(tǒng)的瓶頸。

??? 在大并發(fā)的異步模式下,和前面的數(shù)據(jù)相比較,可以看到HttpApplication的對(duì)象數(shù)量隨并發(fā)處理數(shù)提高而提高,隨之帶來(lái)的一系列數(shù)據(jù)結(jié)構(gòu),如HttpHandler緩存,是需要考慮的內(nèi)存開(kāi)銷(xiāo)。同時(shí),在異步模式下,請(qǐng)求的完成需要編程的方式來(lái)控制,在觸發(fā)完成前,客戶端連接、HttpContext對(duì)象都保持活動(dòng)狀態(tài),客戶端也一直保持等待,直到超時(shí)。因此,異步模式下需要更細(xì)致的資源操作。

??? 我們來(lái)看ASP.NET異步?的典型應(yīng)用場(chǎng)景。

??? 場(chǎng)景一:處理過(guò)程中有需要等待的任務(wù),并且可以使用異步完成的。

//同步方法
public void ProcessRequest(HttpContext context)
{
FileStream fs = new FileStream("", FileMode.Open, FileAccess.Read, FileShare.ReadWrite, 4096, FileOptions.Asynchronous);
fs.CopyTo(context.Response.OutputStream);
}

//異步方法開(kāi)始
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, object extraData)
{
FileStream fs = new FileStream("D:\\a.txt", FileMode.Open, FileAccess.Read, FileShare.ReadWrite, 4096, FileOptions.Asynchronous);
var task = fs.CopyToAsync(context.Response.OutputStream);
task.GetAwaiter().OnCompleted(() => cb(task));
return task;
}

//異步方法結(jié)束
public void EndProcessRequest(IAsyncResult result)
{
}

??? 這個(gè)處理程序讀取服務(wù)器的文件并輸出到客戶端。

//同步方法
public void ProcessRequest(HttpContext context)
{
var url = context.Request.QueryString["url"];
var request = (HttpWebRequest)WebRequest.Create(url);
var response = request.GetResponse();
var stream = response.GetResponseStream();
stream.CopyTo(context.Response.OutputStream);
}

//異步方法開(kāi)始
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, object extraData)
{
//構(gòu)建異步結(jié)果并返回
var result = new WebAsyncResult(cb, context);

var url = context.Request.QueryString["url"];
var request = (HttpWebRequest)WebRequest.Create(url);
var responseTask = request.GetResponseAsync();
responseTask.GetAwaiter().OnCompleted(() =>
{
var stream = responseTask.Result.GetResponseStream();
stream.CopyToAsync(context.Response.OutputStream).GetAwaiter().OnCompleted(() =>
{
result.SetComplete();
});
});

return result;
}

//異步方法結(jié)束
public void EndProcessRequest(IAsyncResult result)
{
}

??? 這是一個(gè)簡(jiǎn)單的代理,服務(wù)器獲取WEB資源后寫(xiě)回。

??? 在這類(lèi)程序中,我們提供的異步處理程序調(diào)用了IOCP異步方法,使得大量節(jié)省了WEB線程的占用,相比同步處理程序來(lái)說(shuō),并發(fā)量會(huì)得到相當(dāng)大的提升。

??? 【注意】前面提到,由于WEB線程屬于線程池線程,因此,如果在線程池中加入任務(wù),將同樣會(huì)影響并發(fā)處理數(shù)。而在異步處理程序中,由線程池來(lái)完成異步將得不到任何本質(zhì)上的提升,因此在異步處理程序中禁止操作線程池(ThreadPool.QueueUserWorkItem、delegate.BeginInvoke,Task.Run等)。如果確定需要使用多線程來(lái)處理大量的計(jì)算,需要自己開(kāi)啟線程或?qū)崿F(xiàn)自己的線程池。

public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, object extraData)
{
return new Action(() =>
{
Thread.Sleep(1000);
context.Response.Write("OK");
}).BeginInvoke(cb, extraData);
}

??? 上面的代碼將無(wú)法達(dá)到異步的效果。

????

??? 雖然等待工作交由另一線程去操作,但是該線程與WEB線程性質(zhì)相同,同樣會(huì)導(dǎo)致其他請(qǐng)求阻塞。

??? 【思考】如果我們的程序中的確需要有大量的計(jì)算,那么可以考慮將這些計(jì)算提取到獨(dú)立的應(yīng)用服務(wù)器中,然后通過(guò)網(wǎng)絡(luò)IOCP異步調(diào)用,達(dá)到WEB服務(wù)器的高吞吐量與系統(tǒng)的平行擴(kuò)展性。

??? 典型應(yīng)用場(chǎng)景二:長(zhǎng)連接消息推送。

??? 一般來(lái)說(shuō),在WEB中獲取服務(wù)器消息,采用輪詢的方式,這種方式不可避免會(huì)有延時(shí),當(dāng)我們需要即時(shí)消息的推送時(shí)(如WEBIM),需要用到長(zhǎng)連接。

??? 長(zhǎng)連接方式,由客戶端發(fā)起請(qǐng)求,服務(wù)器端接收后暫停處理并保持連接,當(dāng)需要發(fā)送消息給客戶端時(shí),輸出內(nèi)容并結(jié)束處理,客戶端得到消息或者超時(shí)后,再次發(fā)起連接。如此達(dá)到在HTTP協(xié)議上服務(wù)器消息即時(shí)推送到客戶端的目的。

??

??? 在這種情況下,我們希望服務(wù)器盡可能長(zhǎng)時(shí)間保持連接,如果采用同步處理程序,則連接數(shù)受到服務(wù)器線程數(shù)的限制,而異步處理程序則可以很好的解決這個(gè)問(wèn)題。異步處理程序開(kāi)始時(shí),收集相關(guān)信息,并放入集合后返回異步結(jié)果。當(dāng)需要向這個(gè)客戶端發(fā)送消息時(shí),從客戶端集合中找到需要發(fā)送的目標(biāo),發(fā)送完成即可。

??? 首先,我們需要對(duì)客戶端進(jìn)行標(biāo)識(shí),這個(gè)標(biāo)識(shí)往往采用sessionid來(lái)做,本例中簡(jiǎn)單起見(jiàn),通過(guò)客戶端傳遞參數(shù)獲取。

public class WebAsyncResult : IAsyncResult
{
private AsyncCallback _callback;

public WebAsyncResult(AsyncCallback cb, HttpContext context, string clientID)
{
Context = context;
ClientID = clientID;
_callback = cb;
}

//當(dāng)異步完成時(shí)調(diào)用該方法
public void SetComplete()
{
IsCompleted = true;
if (_callback != null)
{
_callback(this);
}
}
//存儲(chǔ)客戶端標(biāo)識(shí)
public string ClientID
{
get;
private set;
}

public HttpContext Context
{
get;
private set;
}

public object AsyncState
{
get { return null; }
}

//由于ASP.NET不會(huì)等待WEB異步方法,所以不使用此對(duì)象
public WaitHandle AsyncWaitHandle
{
get { throw new NotImplementedException(); }
}

public bool CompletedSynchronously
{
get { return false; }
}

public bool IsCompleted
{
get;
private set;
}
}

??? 我們需要一個(gè)集合來(lái)保存連接中的客戶端,提供一個(gè)向這些客戶端發(fā)送消息的方法。

public class WebAsyncResultCollection : List<WebAsyncResult>, ICollection<WebAsyncResult>
{
private static WebAsyncResultCollection _instance = new WebAsyncResultCollection();

public static WebAsyncResultCollection Instance
{
get { return WebAsyncResultCollection._instance; }
}

public bool SendMessage(string clientID, string message)
{
var result = this.FirstOrDefault(r => r.ClientID == clientID);
if (result != null)
{
Remove(result);
bool sendsuccess = false;
if (result.Context.Response.IsClientConnected)
{
sendsuccess = true;
result.Context.Response.Write(message);
}
result.SetComplete();
return sendsuccess;
}
return false;
}
}

??? 對(duì)于異步處理程序的開(kāi)始方法,我們收集信息并放入集合。

public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, object extraData)
{
var clientID = context.Request.QueryString["id"];
WebAsyncResultCollection.Instance.SendMessage(clientID, "ClearClientID");
WebAsyncResult result = new WebAsyncResult(cb, context, clientID);
WebAsyncResultCollection.Instance.Add(result);
return result;
}

??? 【不完善】由于客戶端收到一次消息后結(jié)束請(qǐng)求,由客戶端再次發(fā)起請(qǐng)求,中間會(huì)有部分時(shí)間間隙,在這間隙中向該客戶端發(fā)送的消息將丟失,解決方案是維護(hù)另一個(gè)用戶是否在線的表,如果用戶不在線,則處理離線消息,如果在線,并且正在連接中,則按上述處理,如果不在連接中,則緩存在服務(wù)器,當(dāng)客戶端再次連接時(shí),首先檢查緩存的消息,如果有未接消息,則獲取消息并立即返回。

??? 發(fā)送消息的處理程序。

public class SendMessage : IHttpHandler
{

public void ProcessRequest(HttpContext context)
{
var clientID = context.Request.QueryString["clientID"];
var message = context.Request.QueryString["message"];
WebAsyncResultCollection.Instance.SendMessage(clientID, message);
}

public bool IsReusable
{
get
{
return true;
}
}
}

??? 可以在任何需要的位置向客戶端發(fā)送消息。

??? 【不完善】我們需要定時(shí)刷新客戶端集合,對(duì)于長(zhǎng)時(shí)間未處理的客戶端進(jìn)行超時(shí)結(jié)束處理。

??? 通過(guò)異步處理程序構(gòu)建的長(zhǎng)連接消息推送機(jī)制,單臺(tái)服務(wù)器可以輕松支持上萬(wàn)個(gè)并發(fā)連接。

????異步Action

??? 在ASP.NET MVC 4中,添加了對(duì)異步Action的支持。?? ??

????

??? 在ASP.NET MVC4中,整個(gè)處理過(guò)程都是異步的。

??? 在圖中可以看到,最右邊的ActionDescriptor將決定如何調(diào)用我們的Action方法,而如何調(diào)用是由具體的Action方法形式?jīng)Q定,ASP.NET MVC會(huì)根據(jù)不同的方法形式創(chuàng)建不同的ActionDescriptor實(shí)例,從而調(diào)用不同的處理過(guò)程。對(duì)于傳統(tǒng)的方法,則使用ReflectedActionDescriptor,他實(shí)現(xiàn)Execute方法,調(diào)用我們的Action,并在AsyncControllerActionInvoker包裝成同步調(diào)用。而異步調(diào)用在ASP.NET MVC 4? 中有兩種模式。

??? 異步Action模式一:AsyncController/XXXAsync/XXXCompleted

??? 我們可以使一個(gè)Controller繼承自AsyncController,按照約定同時(shí)提供兩個(gè)方法,分別命名為XXXAsync/XXXCompleted,ASP.NET MVC則會(huì)將他們包裝成ReflectedAsyncActionDescriptor。???

public class DefaultController : AsyncController
{
public void DoAsync()
{
//注冊(cè)一次異步
AsyncManager.OutstandingOperations.Increment();
Timer timer = null;
timer = new Timer(o =>
{
//一次異步完成
AsyncManager.OutstandingOperations.Decrement();
timer.Dispose();
},null, 5000, 5000);
}

public ActionResult DoCompleted()
{
return Content("OK");
}
}

???? 由于沒(méi)有IAsyncResult,我們需要通過(guò)AsyncManager來(lái)告訴ASP.NET MVC何時(shí)完成異步,我們可以在方法內(nèi)部在啟用異步時(shí)調(diào)用AsyncManager.OutstandingOperations.Increment()告訴ASP.NET MVC開(kāi)始了一次異步,完成異步時(shí)調(diào)用AsyncManager.OutstandingOperations.Decrement()告訴ASP.NET MVC完成了一次異步,當(dāng)所有異步完成,AsyncManager會(huì)自動(dòng)觸發(fā)異步完成事件,調(diào)用回調(diào)方法,最終調(diào)用我們的XXXComplete方法。我們也可以用AsyncManager.Finish()也觸發(fā)所有異步完成。當(dāng)不使用任何AsyncManager時(shí),則不啟用異步。

??

??? 可以看到整個(gè)異步過(guò)程由ASP.NET完成,在適當(dāng)?shù)臅r(shí)候會(huì)調(diào)用我們的方法。異步的開(kāi)始、結(jié)束動(dòng)作與及如何觸發(fā)完成都在我們的代碼中體現(xiàn)。

??? 異步Action模式二:Task Action

??? 對(duì)于Action,如果返回的類(lèi)型是 Task,ASP.NET MVC則會(huì)將他們包裝成TaskAsyncActionDescriptor。?

public class DefaultController : Controller
{
public async Task<FileResult> Download()
{
using (FileStream fs = new FileStream("D:\\a.txt", FileMode.Open, FileAccess.Read, FileShare.ReadWrite, 4096, FileOptions.Asynchronous))
{
byte[] data = new byte[fs.Length];
await fs.ReadAsync(data, 0, data.Length);
return new FileContentResult(data, "application/octet-stream");
}
}
}

???? 我只需要需提供一個(gè)返回類(lèi)型為T(mén)ask的方法即可,我里我們采用async/await語(yǔ)法構(gòu)建一個(gè)異步方法,在方法內(nèi)部調(diào)用其他的異步方法。

???

??? 相比之前的模式,簡(jiǎn)單了一些,特別是我們的Controller中,只有一個(gè)方法,異步的操作都交由Task完成。對(duì)于可以返回Task的方法來(lái)說(shuō)(如通過(guò)async/await包裝多個(gè)異步方法),就顯得十分方便。

與50位技術(shù)專(zhuān)家面對(duì)面20年技術(shù)見(jiàn)證,附贈(zèng)技術(shù)全景圖

總結(jié)

以上是生活随笔為你收集整理的详解 ASP.NET异步的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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

国产精品久久久久9999吃药 | 日韩r级电影在线观看 | 日韩一区二区免费在线观看 | 亚洲精品视频在线 | 国产成人一区二区精品非洲 | 在线观看亚洲国产 | 激情网在线观看 | 亚洲va欧美va | 午夜性生活 | 最新国产精品亚洲 | 亚洲va欧洲va国产va不卡 | 黄色网址a | 亚洲欧美观看 | 97av视频| av永久网址| 美女啪啪图片 | 国产精品女人久久久久久 | 激情网站免费观看 | 欧美日韩精品影院 | 日韩精品中文字幕有码 | 日日草视频 | 91精品网站 | 日韩高清免费在线 | 欧美人操人 | www黄免费 | 69av在线播放 | 欧美日韩高清一区二区三区 | 免费在线电影网址大全 | 精品96久久久久久中文字幕无 | 99精品一级欧美片免费播放 | 国产成人香蕉 | 国产成人精品一二三区 | 天天综合网入口 | 久久天天躁狠狠躁亚洲综合公司 | 国产精品久久久久久五月尺 | 亚洲综合在线五月天 | 成人午夜电影免费在线观看 | 中文视频在线播放 | 亚洲一区二区三区在线看 | 精品国产一区在线观看 | 国产在线精品视频 | 久久草草影视免费网 | 六月丁香激情网 | 三级性生活视频 | 91亚洲欧美激情 | 天天操狠狠干 | 手机在线看片日韩 | 国产免费久久精品 | av大片免费在线观看 | 808电影 | 中文字幕日韩在线播放 | 久久久精品亚洲 | 成人教育av | 激情婷婷av | 免费看久久久 | 欧美色图30p | 99久久影视| 亚洲精品99久久久久中文字幕 | 一区二区三区精品在线视频 | 黄色亚洲精品 | 久久精品精品 | 手机成人av在线 | 波多野结衣电影一区二区 | av中文字幕在线电影 | 欧美日韩国产精品爽爽 | 91探花在线视频 | 欧美午夜a | 久久久亚洲网站 | 亚洲精品456在线播放第一页 | 日韩成人免费观看 | 欧美日韩a视频 | 91精品区 | 国产资源在线视频 | 国产亚洲在线视频 | 狠狠干天天色 | 一区二区中文字幕在线 | 欧美另类一二三四区 | 欧美欧美| 亚洲视频电影在线 | 亚洲欧美综合精品久久成人 | 深爱开心激情 | 99久久精品无码一区二区毛片 | 最新av网址在线观看 | 精品成人国产 | 色国产在线 | av7777777| 最近中文字幕在线 | 亚洲精品玖玖玖av在线看 | 91字幕| 手机看片中文字幕 | 国产精品美女在线观看 | 五月婷婷激情六月 | 成人福利在线观看 | 深夜国产福利 | 五月婷婷婷婷婷 | 麻豆久久久久久久 | 免费在线播放黄色 | 91精品成人久久 | 天天射网站 | 国产一区二区在线观看视频 | 一区二区三区高清在线观看 | 国产尤物在线 | 日韩三级久久 | 国产黄在线观看 | 91精品在线免费观看视频 | 97av影院 | 视频福利在线观看 | 这里只有精品视频在线观看 | 伊人五月在线 | 精品福利在线 | 国产亚洲精品v | 成人一区二区三区在线观看 | 精品国产一区二 | 色综合狠狠干 | 视频在线在亚洲 | 国产色女人 | 五月天婷婷在线观看视频 | 精精国产xxxx视频在线播放 | 91chinesexxx | 综合网色 | 草久久av| 97视频在线观看视频免费视频 | 色综合天天做天天爱 | 免费观看www7722午夜电影 | 一性一交视频 | 天天色天天综合网 | 日韩一区二区免费视频 | 手机看片99 | 97天天综合网 | 奇米四色影狠狠爱7777 | 天堂在线免费视频 | 亚洲另类视频 | 黄免费网站 | 1000部国产精品成人观看 | 国产一级片播放 | 久久久精品在线观看 | 国产精品麻豆一区二区三区 | 国产精品一区在线播放 | 麻豆成人网 | 亚洲精品久久久久中文字幕二区 | 五月天综合婷婷 | 成全在线视频免费观看 | 国产精品久久久久久久久久久久久 | 88av视频| 亚洲视频99 | 91在线视频导航 | 亚洲精品在线观看中文字幕 | 玖玖在线资源 | 国产精品1区2区在线观看 | 精品国内自产拍在线观看视频 | 日韩精品久久久久久中文字幕8 | 日韩精品一区二区三区三炮视频 | 亚洲精品久久久蜜臀下载官网 | 在线探花 | 欧美日韩一二三四区 | 午夜精品婷婷 | 美女视频a美女大全免费下载蜜臀 | 一二三精品视频 | 亚洲激情视频 | 大胆欧美gogo免费视频一二区 | 一级国产视频 | 天天艹日日干 | av中文在线观看 | 日韩电影久久 | 中文字幕国产亚洲 | 97免费公开视频 | a v在线观看| 91亚洲精| 99热这里精品 | 黄色一及电影 | 一区二区三区在线不卡 | 久久99精品国产91久久来源 | 久久精品国产免费看久久精品 | 国产一级淫片免费看 | 91麻豆精品国产自产在线游戏 | 91在线国产观看 | 欧美三级高清 | 久久人人插 | 国产精品av一区二区 | 日韩av电影中文字幕在线观看 | 国产精品videoxxxx | 亚洲精品视频 | 天天综合网在线 | 丁香激情综合久久伊人久久 | 日日干夜夜骑 | av字幕在线 | 国产精品视屏 | 精品久久久一区二区 | 青草视频在线看 | www.久久91 | 激情综合五月天 | 久草视频网 | 亚洲视频免费在线观看 | 综合中文字幕 | 欧美一级日韩免费不卡 | av电影一区二区三区 | 五月综合在线观看 | 人人人爽 | 欧美一区二区伦理片 | 四虎国产精品成人免费影视 | 精品国产一区二区三区久久久蜜月 | 亚洲一区二区三区毛片 | 亚洲免费色 | 91成人免费看 | 欧美日韩国产页 | 91人人在线 | 日韩免费观看一区二区 | 天天操导航 | 国产成人99久久亚洲综合精品 | 久久九九影视 | 久草观看视频 | 亚洲精品777 | 丁香久久五月 | www免费网站在线观看 | 四虎永久视频 | 国产精品va在线观看入 | 亚洲国产资源 | 亚洲免费精品视频 | 欧美日韩精品在线一区二区 | 99亚洲精品| 久久国产精品久久w女人spa | .精品久久久麻豆国产精品 亚洲va欧美 | 九九九九热精品免费视频点播观看 | 国产精品一区二区久久 | 成人免费看片98欧美 | 波多野结衣在线视频一区 | 免费日韩| 国产69精品久久99不卡的观看体验 | 久草免费新视频 | av在线网站大全 | 国产精品你懂的在线观看 | 99视频网址 | 国产手机免费视频 | 欧美最新大片在线看 | 天天操夜 | 精品国模一区二区三区 | 久久久999免费视频 日韩网站在线 | 亚洲 欧洲 国产 精品 | 一区二区不卡视频在线观看 | 免费黄色在线播放 | 国产精品99爱 | 天天操操操操操 | 国产精品视频在线观看 | 人人干干人人 | 国产精品久久精品 | 51久久夜色精品国产麻豆 | 日本护士撒尿xxxx18 | 久热免费在线观看 | 精品影院一区二区久久久 | 91在线日本| 中文字幕视频一区 | 91大神在线观看视频 | 国产亚洲午夜高清国产拍精品 | 亚洲美女精品区人人人人 | 国偷自产视频一区二区久 | 成人av视屏 | 免费一级片观看 | 一区二区三区观看 | 97在线视频免费观看 | 青青河边草免费视频 | 黄色avwww| 午夜精品久久久久久久久久久久久久 | 中文av网站 | 九九视频免费在线观看 | 九月婷婷人人澡人人添人人爽 | 午夜精品中文字幕 | 中文字幕在线播放日韩 | 看片网站黄色 | 久久久久在线 | a黄色 | 超碰av在线播放 | 午夜123 | 顶级bbw搡bbbb搡bbbb | 天天操天天添 | 中文字幕精品一区二区三区电影 | 一区二区电影网 | 国产高清av | 国产精品12 | 在线成人一区二区 | 四虎最新入口 | 日韩黄色在线 | 色综合天天综合在线视频 | 国产一级91 | 又黄又爽的免费高潮视频 | 免费观看一级成人毛片 | www.eeuss影院av撸| 成人在线网站观看 | 一区二区在线电影 | 久久久不卡影院 | 国内外成人在线 | 国产中文字幕在线 | 免费视频一区二区 | 久久99精品久久久久婷婷 | 欧美精品久久久久久久久久 | 麻豆国产露脸在线观看 | 国产在线精品一区二区不卡了 | 日韩av线观看 | 黄网站免费大全入口 | 日韩欧美精品一区二区 | 色网址99 | 成人精品福利 | 国产精品 亚洲精品 | 欧美一级特黄高清视频 | 亚洲天天摸日日摸天天欢 | 欧美一级片免费观看 | 97色在线视频| 夜夜澡人模人人添人人看 | 国产精品一区二区你懂的 | 尤物一区二区三区 | 五月情婷婷 | 五月婷婷激情五月 | 国产美女免费观看 | 91成人看片 | 久久香蕉影视 | 欧美天天射 | 成人国产网址 | 国产精品video爽爽爽爽 | 天天爱天天操天天爽 | 波多野结衣在线播放一区 | 久久免费视频这里只有精品 | 天天操偷偷干 | 亚洲欧美日韩精品久久久 | 亚洲精品乱码久久久久久按摩 | 九九精品视频在线观看 | 中文字幕一区二区三区四区久久 | 黄在线免费看 | 九九免费在线视频 | 99精彩视频在线观看免费 | 亚洲激情p| 日韩精品免费在线播放 | 欧美日韩中文字幕综合视频 | 在线播放亚洲激情 | 久久综合亚洲鲁鲁五月久久 | 你操综合 | 国产精品综合av一区二区国产馆 | 深爱婷婷激情 | 午夜精品久久久久久久99婷婷 | 一级c片 | 久久精品第一页 | 久草线 | 日韩激情久久 | 久久九精品 | 日韩欧美在线观看一区二区三区 | 日韩二区在线 | 免费欧美| 一区二区三区免费在线播放 | 日日成人网| 92国产精品久久久久首页 | 五月花丁香婷婷 | 国产91在| 欧美一级欧美一级 | 国产精品永久久久久久久www | 亚洲精品乱码久久久久久蜜桃动漫 | 九九免费在线观看视频 | 丁香 久久 综合 | 欧美久久久久久久 | 国产精品一区二区吃奶在线观看 | 五月天久久久久久 | 丁香一区二区 | 免费精品久久久 | 国产精品96久久久久久吹潮 | 亚洲精品视频免费观看 | 午夜精品麻豆 | 国色综合 | 又爽又黄又无遮挡网站动态图 | 国产高清免费在线观看 | 日本mv大片欧洲mv大片 | 欧美日韩国产在线 | 色综合久久88色综合天天人守婷 | 中日韩欧美精彩视频 | 亚洲成a人片综合在线 | 99久久精品免费视频 | 国产麻豆精品在线观看 | 国产超碰97 | 丁香六月婷婷综合 | 久久中文网 | 国精产品一二三线999 | 天天久久综合 | 在线观看免费成人av | 91精品久久久久久综合乱菊 | 国产三级视频 | 99视频网址 | 国产精品久久艹 | 一区二区三区在线视频观看58 | 97国产在线视频 | 黄色的网站免费看 | 麻豆视频大全 | 国产手机视频在线播放 | 久久免费观看少妇a级毛片 久久久久成人免费 | 天天操天天操天天操天天操 | 中文字幕av免费在线观看 | 啪啪动态视频 | 国产亚洲精品v | 日本精品在线视频 | 国产黄色片免费看 | 成人资源网 | 午夜精品久久久久久久99热影院 | 国产亚洲精品免费 | 日批视频在线播放 | 日本性xxx | 亚洲在线网址 | 69亚洲精品 | 国产日产精品一区二区三区四区的观看方式 | 亚洲精品视频大全 | 久久免视频 | 毛片99| 黄色一级影院 | 丝袜美腿一区 | 亚洲三级网 | 四虎国产永久在线精品 | 精品国产诱惑 | 成 人 免费 黄 色 视频 | 久久久免费精品国产一区二区 | 日韩免费成人 | 亚洲色视频 | 久久久香蕉视频 | 欧美日韩在线免费观看视频 | 天天射天天射天天 | 伊人狠狠操 | 超碰人人草| 探花视频网站 | 亚洲丝袜一区二区 | 91av视屏 | 天天色天天射天天操 | 婷婷色狠狠 | 亚洲日b视频 | 国产麻豆果冻传媒在线观看 | 国产 字幕 制服 中文 在线 | 欧美精品视 | 91精品人成在线观看 | 亚洲成a人片在线观看网站口工 | 免费观看一级 | 娇妻呻吟一区二区三区 | 国产色女人 | 亚洲一区二区三区毛片 | 在线日韩精品视频 | 亚洲永久精品视频 | 亚洲精品乱码久久久久久高潮 | 久久综合久久综合这里只有精品 | 国产成人精品电影久久久 | 国产99久久久欧美黑人 | 麻豆91视频| 亚洲日本欧美在线 | 久久久久久高潮国产精品视 | 免费看黄色毛片 | 欧美一级淫片videoshd | 丁香婷婷激情啪啪 | 国产在线视频在线观看 | 国产精品久久久久久久久免费 | 久久综合九色综合97婷婷女人 | 成人一区在线观看 | 91福利免费| 久久人人看 | 国产中文字幕视频在线观看 | 五月婷婷久 | av高清在线观看 | 久久精品国产第一区二区三区 | 久久视频网 | 欧美精品久久久久久久久久久 | 天天干,天天操,天天射 | 人人射人人澡 | 久久久国产一区二区三区 | www日韩视频 | 天天操天天射天天插 | 国产精品日韩在线观看 | 国产精品毛片久久久久久 | 亚洲国产精品视频 | 伊人婷婷综合 | 91免费在线播放 | 欧美一区二区在线免费看 | 天天鲁一鲁摸一摸爽一爽 | 激情网五月| 日韩理论在线 | 久久国产午夜精品理论片最新版本 | 91精品人成在线观看 | 国产视频一区二区在线 | 日韩高清免费观看 | 久久美女电影 | av免费在线观看网站 | 精品国产欧美一区二区三区不卡 | 日韩欧美一区二区三区免费观看 | 黄色特级一级片 | 日韩欧美综合在线视频 | 麻豆一区二区三区视频 | 成年人电影免费在线观看 | 99久高清在线观看视频99精品热在线观看视频 | 美女黄色网在线播放 | 久久久久久国产精品久久 | 天天操人| 国产一区二区三区高清播放 | 色福利网站 | 国产福利不卡视频 | 中文字幕免费观看全部电影 | 亚洲精品在线免费 | 成人免费91 | 香蕉网址| 超碰成人网 | 91精品小视频 | 在线视频a | 在线观看免费 | 欧美日韩一级在线 | av成人亚洲 | 国产资源在线免费观看 | 日日摸日日 | 久久在线一区 | 亚洲精品观看 | 国产va精品免费观看 | www日日| 一区二区三区 中文字幕 | 国产精品久久久久久久久大全 | 一本一本久久a久久精品综合妖精 | 国产视频精选在线 | 99精品电影 | 欧美美女视频在线观看 | 91专区在线观看 | 亚洲天堂精品视频在线观看 | 99久久夜色精品国产亚洲 | av一级免费 | 偷拍福利视频一区二区三区 | 夜添久久精品亚洲国产精品 | 久久涩涩网站 | 91免费网站在线观看 | 综合网久久 | 国产天天爽 | 中文字幕在线播出 | 精品国产一区二区三区不卡 | 91免费高清视频 | 五月婷婷毛片 | 操操碰 | www.香蕉| 天天操天天舔天天干 | 九九在线视频 | 毛片网在线 | 免费在线色 | 精品久久久久久亚洲 | 97视频成人 | 日韩视频免费观看高清完整版在线 | 玖玖精品在线 | 亚洲精品久久在线 | 91色网址 | 91av电影网 | 婷婷色资源 | 国产精品99久久久久久大便 | 午夜国产福利在线观看 | 日韩精品视频在线观看网址 | 国产成本人视频在线观看 | 久久tv| 久久精品爱爱视频 | 91九色蝌蚪国产 | 天天操网址 | 久久电影中文字幕视频 | 91av官网| 91av蜜桃| 超碰在线官网 | 99精品国产一区二区三区麻豆 | 九九在线播放 | 久久精品成人 | 激情久久综合 | 亚洲国产中文字幕在线 | 国产国产人免费人成免费视频 | 国产福利午夜 | 中文字幕2021| 国产精品成人品 | 免费在线中文字幕 | 免费观看丰满少妇做爰 | 四虎在线永久免费观看 | 日韩黄色免费 | 成人av播放 | 国产精品字幕 | 成年人免费电影在线观看 | 成人黄色av免费在线观看 | 日韩精品一区二区三区丰满 | 久久国产精品99久久久久久老狼 | 国产精品网红直播 | 欧美精品久久久久久久免费 | 久久久久在线 | www.xxxx变态.com | 国产中文字幕大全 | 日韩专区一区二区 | 夜夜躁日日躁狠狠久久av | 日韩中文在线播放 | 九九有精品 | 国产精品网站一区二区三区 | av永久网址| 亚洲国产中文字幕在线观看 | 日本中文字幕网站 | 国产午夜精品av一区二区 | 国产91电影在线观看 | 国产精品黄色影片导航在线观看 | 欧美日韩中文国产一区发布 | 五月天激情综合网 | 九九久久免费 | 久久超碰在线 | 国内免费久久久久久久久久久 | 精品久久久久久亚洲综合网 | 国产伦理久久精品久久久久_ | 亚洲精品久久在线 | 波多野结衣综合网 | 又爽又黄又刺激的视频 | 亚洲成成品网站 | 国产成人精品一区一区一区 | 免费a v在线| 又黄又爽又湿又无遮挡的在线视频 | 日韩视频在线观看免费 | 亚洲国产精品免费 | 日韩在线播放视频 | 免费福利在线观看 | 久射网| a资源在线 | 久久久久久久久亚洲精品 | www.69xx | 国产黄色精品视频 | 精品亚洲免a | 在线91色 | 婷婷免费视频 | 99精品视频在线观看免费 | 激情五月网站 | 日韩午夜电影网 | 一级片在线 | 久久资源总站 | 日韩一区二区三区在线看 | 97日日 | av在线免费在线观看 | 国产精品美女久久久久久 | 午夜在线日韩 | 欧美精品乱码久久久久 | 日韩黄色av网站 | 日韩二级毛片 | 天天狠狠操 | 97视频在线观看成人 | 成人久久18免费网站麻豆 | 国产在线欧美日韩 | 99视频在线免费播放 | 日日碰狠狠添天天爽超碰97久久 | 西西444www大胆高清视频 | 久久久久久免费视频 | 天天玩天天操天天射 | 久久久久久久久免费视频 | a色视频| 日韩高清免费无专码区 | 国产视频一区在线播放 | 久艹视频在线观看 | 五月婷婷国产 | 成人久久18免费网站图片 | 国产精品对白一区二区三区 | 精品久久久久久久久久久久久 | 天天插日日射 | 久操久 | 97在线观看视频 | 一区二区视频播放 | 国产97在线播放 | 精品福利网站 | 五月开心色 | 亚洲乱码久久久 | 超级碰碰碰视频 | 97人人视频| 97人人澡人人添人人爽超碰 | 精品国产欧美 | 国产亚洲精品中文字幕 | 久久免费视频8 | 99这里都是精品 | 国产精品99久久久久 | 日韩激情在线 | 欧美a级片网站 | 在线黄色国产 | 天天色天天骑天天射 | 99视频精品视频高清免费 | japanesexxxhd奶水| 91中文字幕在线 | 中文字幕中文字幕在线中文字幕三区 | 特级西西www44高清大胆图片 | 免费特级黄色片 | 97成人资源 | 蜜臀av免费一区二区三区 | 久久久69| a电影免费看 | 亚洲第一av在线 | 国产夫妻自拍av | 亚洲免费观看在线视频 | 国产手机在线观看 | 欧美一二区视频 | 欧美日韩性视频在线 | 久久99久久精品国产 | 91免费观看网站 | 四虎影视成人精品 | 久久99视频免费观看 | 91在线国内视频 | 中文字幕一区二 | 香蕉在线播放 | av不卡免费在线观看 | 欧美日韩首页 | 国产精品高清在线观看 | 亚洲精品国产精品国 | а天堂中文最新一区二区三区 | 亚洲视频h| 久久久www免费电影网 | 日一日操一操 | 欧美福利在线播放 | 激情久久久久久久久久久久久久久久 | 国产品久精国精产拍 | 久久亚洲婷婷 | 久久视频热| 中文字幕a∨在线乱码免费看 | 国产精品国产亚洲精品看不卡 | 黄网站免费大全入口 | 国产色影院 | 久久久久国产a免费观看rela | 午夜影视一区 | 天天操狠狠操网站 | www狠狠 | 久久久精品久久日韩一区综合 | 99国产精品久久久久久久久久 | 97国产精品一区二区 | 日韩免费在线观看网站 | 色狠狠综合 | 色在线亚洲 | 4hu视频 | 91在线操| 国产精品免费看久久久8精臀av | 97香蕉视频 | 亚洲高清视频在线观看免费 | 91毛片在线 | 97在线观看免费观看 | 国产在线不卡视频 | 91中文字幕在线播放 | 亚洲日本在线视频观看 | 在线不卡中文字幕播放 | 欧美日韩亚洲国产一区 | 亚洲一区二区三区miaa149 | 久久久久久欧美二区电影网 | 亚洲综合激情小说 | 久久久久久福利 | 黄色一级大片在线观看 | 日韩成人免费观看 | 日韩理论视频 | 成x99人av在线www | 免费日韩一区 | av在线免费网 | 天天插伊人 | 一区 二区电影免费在线观看 | 啪啪激情网 | www久久精品| 成人av免费电影 | 国产专区视频 | 伊甸园av在线 | 久草在线欧美 | 国产精品va在线 | 丁香花在线观看免费完整版视频 | 在线精品亚洲一区二区 | 国产伦精品一区二区三区免费 | 天天综合天天做 | 免费色视频在线 | 国产一区欧美在线 | 中文在线字幕观看电影 | 久久精品网站视频 | 91精彩视频 | 在线视频 一区二区 | 日韩理论片在线 | 午夜精品剧场 | 四虎在线观看 | 国产精品美女久久久久久久久 | 在线电影中文字幕 | a级国产乱理论片在线观看 特级毛片在线观看 | 美女搞黄国产视频网站 | 亚洲精品小视频 | 亚洲成av人片在线观看 | 久久精品视频中文字幕 | 看片黄网站 | www.五月婷婷.com | 精品在线播放视频 | 欧洲精品久久久久毛片完整版 | 日批在线看 | 一区二区三区四区免费视频 | 天天射天天射 | 日日夜夜精品免费观看 | 91三级视频 | 亚洲成人网在线 | 日韩欧美一区二区在线播放 | 欧亚久久 | 欧美成人在线网站 | 久久夜靖品 | 日日操天天操狠狠操 | 国产99久久久国产 | 亚洲va韩国va欧美va精四季 | 最近2019中文免费高清视频观看www99 | 日韩精品免费在线观看视频 | 亚洲资源在线观看 | 9草在线| 91av在线免费 | 午夜影院一级片 | 美女网站在线看 | 久久视频这里只有精品 | 欧美日韩综合在线观看 | 日韩免费电影一区二区 | 一区二区三区精品久久久 | 在线91播放| 亚洲精品国产精品乱码在线观看 | 五月天激情在线 | 久久人人爽人人爽人人片 | 欧美性色综合网站 | 午夜精品中文字幕 | 日韩有码欧美 | 成年人视频在线 | 91视频久久| 丁香久久综合 | 97视频久久久 | 99久久99久久精品 | 亚洲a资源 | 日韩av在线免费看 | 97视频在线播放 | av在线免费观看不卡 | 国产一二区在线观看 | 日本不卡123区 | 国产成人一区二区三区免费看 | 国产精品一区二区免费 | 久久久久国产精品厨房 | 四虎成人精品永久免费av | 91亚色视频 | 婷婷免费在线视频 | 99精品在线播放 | 少妇搡bbbb搡bbb搡忠贞 | 日本中出在线观看 | 亚洲专区欧美专区 | 亚洲资源片 | ,久久福利影视 | 成人久久免费视频 | 日本资源中文字幕在线 | 久草久草久草久草 | 国产高清在线视频 | 午夜视频在线观看欧美 | 欧美一区二区在线免费观看 | 911香蕉| 毛片在线网 | 女人18精品一区二区三区 | 国产精品福利午夜在线观看 | 久久国产电影院 | 久久久久久久久久久久久久电影 | 日日夜夜爱 | 六月激情网 | 久久麻豆视频 | h动漫中文字幕 | 亚洲成a人片在线www | 久久电影网站中文字幕 | 久久久久久久99 | 日本精品在线视频 | 欧美一二三区在线观看 | 欧美一二区在线 | 福利视频区| 中国一级片免费看 | 亚洲激情视频 | 国产手机视频在线 | 久草电影免费在线观看 | 韩国精品视频在线观看 | 成人免费亚洲 | 一区二区三区视频在线 | 亚洲欧美激情精品一区二区 | 啪啪资源| 精品国产一区二区三区免费 | 久久婷五月 | 精品国产一二三四区 | 国内小视频 | 高清av在线 | 久久香蕉国产精品麻豆粉嫩av | 久久大香线蕉app | 午夜久久久久久久久久久 | 国产一级片免费播放 | 亚洲精品一区二区久 | 色偷偷网站视频 | 日日草天天干 | www.久久视频 | 亚洲精品色 | 国产99爱| 午夜a区| 欧美日韩久久不卡 | 欧洲不卡av | 久草com | 久久综合亚洲鲁鲁五月久久 | 亚洲伊人婷婷 | 精品国产视频在线观看 | 国产一级片久久 | 高清有码中文字幕 | 国产在线a | 国产午夜一区二区 | 狠狠色丁香久久婷婷综合五月 | 国产中文字幕亚洲 | 999久久久免费视频 午夜国产在线观看 | 97国产精品一区二区 | 免费看一及片 | 天天狠狠干 | 亚洲日本va在线观看 | 中文字幕精品一区 | 国产日韩欧美精品在线观看 | 日韩电影在线观看一区二区三区 | wwxxx日本| 操操操人人人 | 色综合久久综合中文综合网 | 免费日韩三级 | 欧美色婷 | 国产区 在线 | 日日天天干 | 一区二区精品在线 | 亚洲午夜精品一区 | 国产又粗又猛又爽又黄的视频免费 | 国产精品永久免费观看 | 99亚洲国产精品 | 日本久久久久久久久久 | 色综合五月天 | 一区二区三区免费在线观看视频 | 激情欧美一区二区三区免费看 | 99精品国产兔费观看久久99 | 免费福利视频网站 | 91在线你懂的 | 91爱爱网址 | 久久艹艹 | 91少妇精拍在线播放 | 久草香蕉在线 | 国产 日韩 中文字幕 | 日韩在线免费观看视频 | 亚洲欧美视屏 | 91av短视频 | 亚洲午夜久久久综合37日本 | 亚洲天天摸日日摸天天欢 | 九色视频自拍 | 免费在线观看一区二区三区 | 97超碰人| www.黄色片.com | 精品国产乱码久久久久久1区2匹 | 91视频高清完整版 | 欧美久久久久久久久中文字幕 | 黄污视频大全 | 又黄又爽又刺激的视频 | 日韩中文在线视频 | 精品9999| 成人av午夜| 免费成人在线视频网站 | 在线视频精品播放 | 亚洲精品国产精品久久99 | 天天舔天天射天天操 | 99久热在线精品视频成人一区 | 成人网大片 | 久草网站 | 99视频在线观看免费 | 91亚洲精品乱码久久久久久蜜桃 | 丁香五婷 | 亚洲欧洲av | 国产成人a亚洲精品 | 亚洲午夜av | 中文日韩在线视频 | 黄色avwww | 国产三级在线播放 | 免费看搞黄视频网站 | 国产一线二线三线性视频 | 99在线看| 成人精品视频 | 欧美一区二区在线 | 亚洲一级片免费观看 | 韩日精品在线 | 四虎影视成人精品国库在线观看 | 国产精品一区二区三区在线看 | 精品中文字幕视频 | 日韩免费在线视频 | 日韩视频三区 | 99精品视频免费看 | 精品网站999www | 国产一区视频免费在线观看 | 国产99爱 | 亚洲一级二级 | 亚洲小视频在线观看 | 91精品免费在线观看 | 久久国产女人 | 在线观看国产亚洲 | 国产麻豆果冻传媒在线观看 | 永久免费的啪啪网站免费观看浪潮 | 91av免费观看| 91精品视频网站 | 精品国产欧美一区二区 | 在线亚洲免费视频 | av在线播放中文字幕 | 2023av| 国内视频在线 | 丁香视频 | 亚洲黄色免费电影 | 高清在线一区 | 日本中文乱码卡一卡二新区 | 久久久人 | 香蕉视频在线视频 | 91大神精品视频在线观看 | 夜夜操综合网 | 免费看亚洲毛片 | 国产色区 | 9ⅰ精品久久久久久久久中文字幕 | av久久在线 | 亚洲精品自拍视频在线观看 | 一区二区三区免费在线观看视频 | 国产中文字幕在线 | 在线直播av| 色婷婷综合久久久中文字幕 | 热久久免费国产视频 |