久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Akka 指南 之「Actors」

發布時間:2023/12/18 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Akka 指南 之「Actors」 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

溫馨提示:Akka 中文指南的 GitHub 地址為「akka-guide」,歡迎大家Star、Fork,糾錯。

文章目錄

  • Actors
    • 依賴
    • 簡介
    • 創建 Actors
      • 定義 Actor 類
      • Props
      • 危險的變體
      • 推薦實踐
      • 使用 Props 創建 Actors
      • 依賴注入
      • 收件箱
    • Actor API
      • Actor 生命周期
      • 生命周期監控,或稱為 DeathWatch
      • Start 鉤子
      • Restart 鉤子
      • Stop 鉤子
    • 通過 Actor Selection 識別 Actor
    • 信息和不變性
    • 發送消息
      • Tell: Fire-forget
      • Ask: Send-And-Receive-Future
      • 轉發消息
    • 接收消息
    • 回復消息
    • 接收超時
    • 定時器和調度消息
    • 停止 Actor
      • PoisonPill
      • 殺死一個 Actor
      • 優雅的停止
      • 協調關閉
    • Become/Unbecome
      • 升級
      • 對 Scala Actor 嵌套接收進行編碼,而不會意外泄漏內存
    • Stash
    • Actor 和異常
      • 消息發生了什么
      • 郵箱發生了什么
      • Actor 發現了什么
    • 初始化模式
      • 通過構造函數初始化
      • 通過 preStart 初始化
      • 通過消息傳遞初始化

Actors

依賴

為了使用 Actors,你必須在項目中添加如下依賴:

<!-- Maven --> <dependency><groupId>com.typesafe.akka</groupId><artifactId>akka-actor_2.12</artifactId><version>2.5.21</version> </dependency><!-- Gradle --> dependencies {compile group: 'com.typesafe.akka', name: 'akka-actor_2.12', version: '2.5.21' }<!-- sbt --> libraryDependencies += "com.typesafe.akka" %% "akka-actor" % "2.5.21"

簡介

「Actor Model」為編寫并發和分布式系統提供了更高級別的抽象。它減少了開發人員必須處理顯式鎖和線程管理的問題,使編寫正確的并發和并行系統變得更容易。1973 年卡爾·休伊特(Carl Hewitt)在論文中定義了 Actors,然后通過 Erlang 語言所普及,并且在愛立信(Ericsson)成功地建立了高度并發和可靠的電信系統。

Akka 的 Actors API 類似于 Scala Actors,它從 Erlang 中借用了一些語法。

創建 Actors

由于 Akka 實施父級(parental)監督,每個 Actor 都受到其父級的監督并且監督其子級,因此建議你熟悉「Actor Systems」和「Supervision」,它還可能有助于閱讀「Actor References, Paths and Addresses」。

定義 Actor 類

Actor 類是通過繼承AbstractActor類并在createReceive方法中設置“初始行為”來實現的。

createReceive方法沒有參數,并返回AbstractActor.Receive。它定義了 Actor 可以處理哪些消息,以及如何處理消息的實現。可以使用名為ReceiveBuilder的生成器來構建此類行為。在AbstractActor中,有一個名為receiveBuilder的方便的工廠方法。

下面是一個例子:

import akka.actor.AbstractActor; import akka.event.Logging; import akka.event.LoggingAdapter;public class MyActor extends AbstractActor {private final LoggingAdapter log = Logging.getLogger(getContext().getSystem(), this);@Overridepublic Receive createReceive() {return receiveBuilder().match(String.class,s -> {log.info("Received String message: {}", s);}).matchAny(o -> log.info("received unknown message")).build();} }

請注意,Akka Actor 消息循環是徹底的(exhaustive),與 Erlang 和后 Scala Actors 相比,它是不同的。這意味著你需要為它可以接受的所有消息提供一個模式匹配,如果你希望能夠處理未知消息,那么你需要有一個默認情況,如上例所示。否則,akka.actor.UnhandledMessage(message, sender, recipient)將發布到ActorSystem的EventStream。

請進一步注意,上面定義的行為的返回類型是Unit;如果 Actor 應回復收到的消息,則必須按照下面的說明顯式完成。

createReceive方法的結果是AbstractActor.Receive,它是圍繞部分 Scala 函數對象的包裝。它作為其“初始行為”存儲在 Actor 中,有關在 Actor 構造后更改其行為的詳細信息,請參見「Become/Unbecome」。

Props

Props是一個配置類,用于指定創建 Actor 的選項,將其視為不可變的,因此可以自由共享用于創建 Actor 的方法,包括關聯的部署信息(例如,要使用哪個調度程序,請參閱下面的更多內容)。下面是一些如何創建Props實例的示例。

import akka.actor.Props; Props props1 = Props.create(MyActor.class); Props props2 =Props.create(ActorWithArgs.class, () -> new ActorWithArgs("arg")); // careful, see below Props props3 = Props.create(ActorWithArgs.class, "arg");

第二個變量演示了如何將構造函數參數傳遞給正在創建的 Actor,但它只能在 Actor 之外使用,如下所述。

最后一行顯示了傳遞構造函數參數的可能性,而不管它在哪個上下文中使用。在Props對象的構造過程中,會驗證是否存在匹配的構造函數,如果未找到匹配的構造函數或找到多個匹配的構造函數,則會導致IllegalArgumentException。

危險的變體

// NOT RECOMMENDED within another actor: // encourages to close over enclosing class Props props7 = Props.create(ActorWithArgs.class, () -> new ActorWithArgs("arg"));

不建議在另一個 Actor 中使用此方法,因為它鼓勵關閉封閉范圍,從而導致不可序列化的屬性和可能的競態條件(破壞 Actor 封裝)。另一方面,在 Actor 的同伴對象(companion object)中的Props工廠中使用這個變體是完全正確的,如下面的“推薦實踐”中所述。

這些方法有兩個用例:將構造函數參數傳遞給由新引入的Props.create(clazz, args)方法或下面的推薦實踐解決的 Actor,并將 Actor “就地(on the spot)”創建為匿名類。后者應該通過將這些 Actor 命名為類來解決(如果它們沒有在頂級object中聲明,則需要將封閉實例的this引用作為第一個參數傳遞)。

  • 警告:在另一個 Actor 中聲明一個 Actor 是非常危險的,并且會破壞 Actor 的封裝。千萬不要把 Actor 的this引用傳給Props!

推薦實踐

為每個 Actor 提供靜態工廠方法是一個好主意,這有助于使合適的Props創建盡可能接近 Actor 的定義。這也避免了與使用Props.create(...)方法相關聯的陷阱,該方法將參數作為構造函數參數,因為在靜態方法中,給定的代碼塊不會保留對其封閉范圍的引用:

static class DemoActor extends AbstractActor {/*** Create Props for an actor of this type.** @param magicNumber The magic number to be passed to this actor’s constructor.* @return a Props for creating this actor, which can then be further configured (e.g. calling* `.withDispatcher()` on it)*/static Props props(Integer magicNumber) {// You need to specify the actual type of the returned actor// since Java 8 lambdas have some runtime type information erasedreturn Props.create(DemoActor.class, () -> new DemoActor(magicNumber));}private final Integer magicNumber;public DemoActor(Integer magicNumber) {this.magicNumber = magicNumber;}@Overridepublic Receive createReceive() {return receiveBuilder().match(Integer.class,i -> {getSender().tell(i + magicNumber, getSelf());}).build();} }static class SomeOtherActor extends AbstractActor {// Props(new DemoActor(42)) would not be safeActorRef demoActor = getContext().actorOf(DemoActor.props(42), "demo");// ... }

另一個好的做法是聲明 Actor 可以接收的消息盡可能接近 Actor 的定義(例如,作為 Actor 內部的靜態類或使用其他合適的類),這使得更容易知道它可以接收到什么:

static class DemoMessagesActor extends AbstractLoggingActor {public static class Greeting {private final String from;public Greeting(String from) {this.from = from;}public String getGreeter() {return from;}}@Overridepublic Receive createReceive() {return receiveBuilder().match(Greeting.class,g -> {log().info("I was greeted by {}", g.getGreeter());}).build();} }

使用 Props 創建 Actors

Actors 是通過將Props實例傳遞到actorOf工廠方法來創建的,該方法在ActorSystem和ActorContext上可用。

import akka.actor.ActorRef; import akka.actor.ActorSystem;

使用ActorSystem將創建頂級 Actor,由ActorSystem提供的守護者 Actor 進行監督,而使用ActorContext將創建子 Actor。

static class FirstActor extends AbstractActor {final ActorRef child = getContext().actorOf(Props.create(MyActor.class), "myChild");@Overridepublic Receive createReceive() {return receiveBuilder().matchAny(x -> getSender().tell(x, getSelf())).build();} }

建議創建一個子級、孫子(grand-children)級這樣的層次結構,以便它適合應用程序的邏輯故障處理結構,詳見「Actor Systems」。

對actorOf的調用返回ActorRef的實例。這是 Actor 實例的句柄,也是與之交互的唯一方法。ActorRef是不可變的,并且與它所表示的 Actor 有一對一的關系。ActorRef也是可序列化的,并且具有網絡意識(network-aware)。這意味著你可以序列化它,通過網絡發送它,并在遠程主機上使用它,并且它仍然在網絡上表示原始節點上的同一個 Actor。

name參數是可選的,但你最好為 Actor 命名,因為它用于日志消息和標識 Actor。名稱不能為空或以$開頭,但可以包含 URL 編碼字符(例如,空格為%20)。如果給定的名稱已被同一父級的另一個子級使用,則會引發InvalidActorNameException。

Actor 在創建時自動異步啟動。

依賴注入

如果你的 Actor 有一個接受參數的構造函數,那么這些參數也需要成為Props的一部分,如上所述。但在某些情況下,必須使用工廠方法,例如,當依賴項注入(dependency injection)框架確定實際的構造函數參數時。

import akka.actor.Actor; import akka.actor.IndirectActorProducer; class DependencyInjector implements IndirectActorProducer {final Object applicationContext;final String beanName;public DependencyInjector(Object applicationContext, String beanName) {this.applicationContext = applicationContext;this.beanName = beanName;}@Overridepublic Class<? extends Actor> actorClass() {return TheActor.class;}@Overridepublic TheActor produce() {TheActor result;result = new TheActor((String) applicationContext);return result;} }final ActorRef myActor =getContext().actorOf(Props.create(DependencyInjector.class, applicationContext, "TheActor"), "TheActor");
  • 警告:有時,你可能會試圖提供始終返回同一實例的IndirectActorProducer,例如使用靜態字段。這是不支持的,因為它違背了 Actor 重新啟動的含義,這里描述了:「重新啟動意味著什么」。

當使用依賴注入框架時,Actor bean不能有singleton作用域。

在「Using Akka with Dependency Injection」指南和「Akka Java Spring」教程中,有關于依賴注入的更深層次的描述。

收件箱

當在與 Actor 通信的 Actor 外部編寫代碼時,ask模式可以是一個解決方案(見下文),但它不能做兩件事:接收多個回復(例如,通過向通知服務訂閱ActorRef)和觀察其他 Actor 的生命周期。出于這些目的,有一個Inbox類:

final Inbox inbox = Inbox.create(system); inbox.send(target, "hello"); try {assert inbox.receive(Duration.ofSeconds(1)).equals("world"); } catch (java.util.concurrent.TimeoutException e) {// timeout }

send方法包裝了一個普通的tell,并將內部 Actor 的引用作為發送者提供。這允許在最后一行接收回復。監視(Watching)Actor 也很簡單:

final Inbox inbox = Inbox.create(system); inbox.watch(target); target.tell(PoisonPill.getInstance(), ActorRef.noSender()); try {assert inbox.receive(Duration.ofSeconds(1)) instanceof Terminated; } catch (java.util.concurrent.TimeoutException e) {// timeout }

Actor API

AbstractActor類定義了一個名為createReceive的方法,該方法用于設置 Actor 的“初始行為”。

如果當前的 Actor 行為與接收到的消息不匹配,則調用unhandled,默認情況下,它在Actor 系統的事件流上發布akka.actor.UnhandledMessage(message, sender, recipient)(將配置項akka.actor.debug.unhandled設置為on,以便將其轉換為實際的Debug消息)。

此外,它還提供:

  • getSelf(),對 Actor 的ActorRef的引用
  • getSender(),前一次接收到的消息的發送方 Actor 的引用
  • supervisorStrategy(),用戶可重寫定義用于監視子 Actor 的策略

該策略通常在 Actor 內部聲明,以便訪問決策函數中 Actor 的內部狀態:由于故障作為消息發送給其監督者并像其他消息一樣進行處理(盡管不屬于正常行為),因此 Actor 內的所有值和變量都可用,就像sender引用一樣(報告失敗的是直接子級;如果原始失敗發生在一個遙遠的后代中,則每次仍向上一級報告)。

  • getContext()公開 Actor 和當前消息的上下文信息,例如:
    • 創建子 Actor 的工廠方法(actorOf)
    • Actor 所屬的系統
    • 父級監督者
    • 受監督的子級
    • 生命周期監控
    • 如Become/Unbecome中所述的熱交換行為棧(hotswap behavior stack)

其余可見的方法是用戶可重寫的生命周期鉤子方法,如下所述:

public void preStart() {}public void preRestart(Throwable reason, Optional<Object> message) {for (ActorRef each : getContext().getChildren()) {getContext().unwatch(each);getContext().stop(each);}postStop(); }public void postRestart(Throwable reason) {preStart(); }public void postStop() {}

上面顯示的實現是AbstractActor類提供的默認值。

Actor 生命周期


Actor 系統中的一條路徑表示一個“地方”,可能被一個活著的 Actor 占據。最初(除了系統初始化的 Actor 之外)路徑是空的,當調用actorOf()時,它將通過傳遞的Props描述的 Actor 的化身(incarnation)分配給給定的路徑,Actor 的化身由路徑(path)和UID標識。

值得注意的是:

  • restart
  • stop,然后重新創建 Actor

如下所述。

重新啟動(restart)只交換由Props定義的Actor實例,因此UID保持不變。只要化身是相同的,你可以繼續使用相同的ActorRef。重啟是通過 Actor 的父 Actor 的「Supervision Strategy」來處理的,關于重啟的含義還有「更多的討論」。

當 Actor 停止時,化身的生命周期就結束了。此時將調用適當的生命周期事件,并將終止通知觀察 Actor。當化身停止后,可以通過使用actorOf()創建 Actor 來再次使用路徑。在這種情況下,新化身的名稱將與前一個相同,但UID將不同。Actor 可以由 Actor 本身、另一個 Actor 或 Actor 系統停止,詳見「停止 Actor」。

  • 注釋:重要的是要注意,Actor 不再被引用時不會自動停止,創建的每個 Actor 也必須顯式銷毀。唯一的簡化是,停止父 Actor 也將遞歸地停止此父 Actor 創建的所有子 Actor。

ActorRef總是代表一個化身(路徑和UID),而不僅僅是一個給定的路徑。因此,如果一個 Actor 被停止,一個同名的新 Actor 被創造出來,舊化身的 Actor 引用就不會指向新的 Actor。

另一方面,ActorSelection指向路徑(或者如果使用通配符,則指向多個路徑),并且完全忽略了具體化當前正在占用的路徑。由于這個原因,ActorSelection不能被觀看??梢酝ㄟ^向ActorSelection發送Identify消息來獲取(resolve)當前化身的ActorRef,該消息將以包含正確引用的ActorIdentity回復,詳見ActorSelection」。這也可以通過ActorSelection的resolveOne方法來實現,該方法返回匹配ActorRef的Future。

生命周期監控,或稱為 DeathWatch

為了在另一個 Actor 終止時得到通知(即永久停止,而不是臨時失敗和重新啟動),Actor 可以注冊(register)自己,以便在終止時接收另一個 Actor 發送的Terminated消息,詳見「停止 Actor」。此服務由 Actor 系統的DeathWatch組件提供。

注冊監視器(monitor)很容易:

import akka.actor.Terminated; static class WatchActor extends AbstractActor {private final ActorRef child = getContext().actorOf(Props.empty(), "target");private ActorRef lastSender = system.deadLetters();public WatchActor() {getContext().watch(child); // <-- this is the only call needed for registration}@Overridepublic Receive createReceive() {return receiveBuilder().matchEquals("kill",s -> {getContext().stop(child);lastSender = getSender();}).match(Terminated.class,t -> t.actor().equals(child),t -> {lastSender.tell("finished", getSelf());}).build();} }

在這里,有一點需要我們注意:Terminated消息的生成與注冊和終止發生的順序無關。特別是,即使被監視的 Actor 在注冊時已經被終止,監視的 Actor 也將收到一條Terminated消息。

多次注冊并不一定會導致生成多條消息,但不能保證只接收到一條這樣的消息:如果被監視的 Actor 的終止消息已經生成并將消息排隊,并且在處理此消息之前完成了另一個注冊,則第二條消息也將進入消息隊列。因為注冊監視已經終止的 Actor 會導致立即生成Terminated消息。

也可以通過context.unwatch(target)取消監視另一個 Actor 的存活情況。即使Terminated消息已經在郵箱中排隊,也可以這樣做;在調用unwatch之后,將不再處理該 Actor 的Terminated消息。

Start 鉤子

啟動 Actor 之后,立即調用其preStart方法。

@Override public void preStart() {target = getContext().actorOf(Props.create(MyActor.class, "target")); }

首次創建 Actor 時調用此方法。在重新啟動期間,它由postRestart的默認實現調用,這意味著通過重寫該方法,你可以選擇是否只為此 Actor 或每次重新啟動時調用一次此方法中的初始化代碼。當創建 Actor 類的實例時,總是會調用作為 Actor 構造函數一部分的初始化代碼,該實例在每次重新啟動時都會發生。

Restart 鉤子

所有 Actor 都受到監督,即通過故障處理策略鏈接到另一個 Actor。如果在處理消息時引發異常,則可以重新啟動 Actor(詳見「supervision」)。重新啟動涉及上述掛鉤:

  • 通過調用導致preRestart的異常和觸發該異常的消息來通知舊 Actor ;如果重新啟動不是由處理消息引起的,則后者可能為None,例如,當監督者不捕獲異常并由其監督者依次重新啟動時,或者某個 Actor 由于其同級 Actor 的失敗而導致重新啟動時。如果消息可用,那么該消息的發送者也可以通過常規方式訪問,即調用sender。此方法是清理、準備移交給新的 Actor 實例等的最佳位置。默認情況下,它會停止所有子級并調用postStop。
  • 來自actorOf調用的初始工廠用于生成新實例。
  • 調用新 Actor 的postRestart方法時出現導致重新啟動的異常。默認情況下,會調用preStart,就像在正常啟動情況下一樣。
  • Actor 重新啟動僅替換實際的 Actor 對象;郵箱的內容不受重新啟動的影響,因此在postRestart鉤子返回后,將繼續處理消息,而且將不再接收觸發異常的消息。重新啟動時發送給 Actor 的任何消息都將像往常一樣排隊進入其郵箱。

    • 警告:請注意,與用戶消息相關的失敗通知的順序是不確定的。特別是,父級可以在處理子級在失敗之前發送的最后一條消息之前重新啟動其子級。有關詳細信息,請參閱「討論:消息排序」。

    Stop 鉤子

    停止某個 Actor 后,將調用其postStop鉤子,該鉤子可用于將該 Actor 從其他服務中注銷。此鉤子保證在禁用此 Actor 的消息隊列后運行,即發送到已停止 Actor 的消息將被重定向到ActorSystem的deadLetters。

    通過 Actor Selection 識別 Actor

    如「Actor References, Paths and Addresses」中所述,每個 Actor 都有唯一的邏輯路徑,該路徑通過從子級到父級的 Actor 鏈獲得,直到到達 Actor 系統的根,并且它有一個物理路徑,如果監督鏈(supervision chain)包含任何遠程監管者,則該路徑可能有所不同。系統使用這些路徑來查找 Actor,例如,當接收到遠程消息并搜索收件人時,它們很有用:Actor 可以通過指定邏輯或物理的絕對或相對路徑來查找其他 Actor,并接收帶有結果的ActorSelection:

    // will look up this absolute path getContext().actorSelection("/user/serviceA/actor"); // will look up sibling beneath same supervisor getContext().actorSelection("../joe");
    • 注釋:與其他 Actor 交流時,最好使用他們的ActorRef,而不是依靠ActorSelection。但也有例外,如
      • 使用「至少一次傳遞」能力發送消息
      • 啟動與遠程系統的第一次連接

    在所有其他情況下,可以在 Actor 創建或初始化期間提供ActorRef,將其從父級傳遞到子級,或者通過將其ActorRef發送到其他 Actor 來引出 Actor。

    提供的路徑被解析為java.net.URI,這意味著它在路徑元素上被/拆分。如果路徑以/開頭,則為絕對路徑,查找從根守護者(它是/user的父級)開始;否則,查找從當前 Actor 開始。如果路徑元素等于..,則查找將向當前遍歷的 Actor 的監督者“向上”一步,否則將向命名的子級“向下”一步。應該注意的是..在 Actor 路徑中,總是指邏輯結構,即監督者。

    Actor 選擇(selection)的路徑元素可以包含允許向該部分廣播(broadcasting)消息的通配符模式:

    // will look all children to serviceB with names starting with worker getContext().actorSelection("/user/serviceB/worker*"); // will look up all siblings beneath same supervisor getContext().actorSelection("../*");

    消息可以通過ActorSelection發送,并且在傳遞每個消息時查找ActorSelection的路徑。如果選擇(selection)與任何 Actor 都不匹配,則消息將被刪除。

    要獲取ActorRef以進行ActorSelection,你需要向選擇發送消息,并使用來自 Actor 的答復的getSender()引用。有一個內置的Identify消息,所有 Actor 都將理解該消息,并使用包含ActorRef的ActorIdentity消息自動回復。此消息由 Actor 專門處理,如果具體的名稱查找失敗(即非通配符路徑元素與存活的 Actor 不對應),則會生成負(negative)結果。請注意,這并不意味著保證回復的傳遞(delivery of that reply is guaranteed),它仍然是正常的消息。

    import akka.actor.ActorIdentity; import akka.actor.ActorSelection; import akka.actor.Identify; static class Follower extends AbstractActor {final Integer identifyId = 1;public Follower() {ActorSelection selection = getContext().actorSelection("/user/another");selection.tell(new Identify(identifyId), getSelf());}@Overridepublic Receive createReceive() {return receiveBuilder().match(ActorIdentity.class,id -> id.getActorRef().isPresent(),id -> {ActorRef ref = id.getActorRef().get();getContext().watch(ref);getContext().become(active(ref));}).match(ActorIdentity.class,id -> !id.getActorRef().isPresent(),id -> {getContext().stop(getSelf());}).build();}final AbstractActor.Receive active(final ActorRef another) {return receiveBuilder().match(Terminated.class, t -> t.actor().equals(another), t -> getContext().stop(getSelf())).build();} }

    你還可以使用ActorSelection的resolveOne方法獲取ActorRef以進行actorselection。如果存在這樣的 Actor,它將返回匹配的ActorRef的Future,可參閱「 Java 8 Compatibility for Java compatibility」。如果不存在這樣的 Actor 或標識在提供的timeout內未完成,則完成此操作并拋出akka.actor.ActorNotFound異常。

    如果啟用「remoting」,也可以查找遠程 Actor 的地址:

    getContext().actorSelection("akka.tcp://app@otherhost:1234/user/serviceB");

    「Remoting Sample」中給出了一個在啟用遠程處理(remoting)的情況下演示 Actor 查找的例子。

    信息和不變性

    • 重要的:消息可以是任何類型的對象,但必須是不可變的。Akka 還不能強制執行不可變性,所以必須按慣例執行。

    以下是不可變消息的示例:

    public class ImmutableMessage {private final int sequenceNumber;private final List<String> values;public ImmutableMessage(int sequenceNumber, List<String> values) {this.sequenceNumber = sequenceNumber;this.values = Collections.unmodifiableList(new ArrayList<String>(values));}public int getSequenceNumber() {return sequenceNumber;}public List<String> getValues() {return values;} }

    發送消息

    消息通過以下方法之一發送給 Actor。

    • tell的意思是“發送并忘記(fire-and-forget)”,例如異步發送消息并立即返回。
    • ask異步發送消息,并返回一個表示可能的答復。

    每一個發送者都有消息順序的保證。

    • 注釋:使用ask會帶來性能方面的影響,因為有些東西需要跟蹤它何時超時,需要有一些東西將一個Promise連接到ActorRef中,并且還需要通過遠程處理實現它。所以,我們更傾向于使用tell,只有當你有足夠的理由時才應該使用ask。

    在所有這些方法中,你可以選擇傳遞自己的ActorRef。將其作為一種實踐,因為這樣做將允許接收者 Actor 能夠響應你的消息,因為發送者引用與消息一起發送。

    Tell: Fire-forget

    這是發送消息的首選方式,它不用等待消息返回,因此不是阻塞的。這提供了最佳的并發性和可伸縮性的特性。

    // don’t forget to think about who is the sender (2nd argument) target.tell(message, getSelf());

    發送方引用與消息一起傳遞,并在處理此消息時通過getSender()方法在接收 Actor 中使用。在一個 Actor 內部,通常是getSelf()作為發送者,但在某些情況下,回復(replies)應該路由到另一個 Actor,例如,父對象,其中tell的第二個參數將是另一個 Actor。在 Actor 外部,如果不需要回復,則第二個參數可以為null;如果在 Actor 外部需要回復,則可以使用下面描述的ask模式。

    Ask: Send-And-Receive-Future

    ask模式涉及 Actor 和Future,因此它是作為一種使用模式而不是ActorRef上的一種方法提供的:

    import static akka.pattern.Patterns.ask; import static akka.pattern.Patterns.pipe;import java.util.concurrent.CompletableFuture; final Duration t = Duration.ofSeconds(5);// using 1000ms timeout CompletableFuture<Object> future1 =ask(actorA, "request", Duration.ofMillis(1000)).toCompletableFuture();// using timeout from above CompletableFuture<Object> future2 = ask(actorB, "another request", t).toCompletableFuture();CompletableFuture<Result> transformed =CompletableFuture.allOf(future1, future2).thenApply(v -> {String x = (String) future1.join();String s = (String) future2.join();return new Result(x, s);});pipe(transformed, system.dispatcher()).to(actorC);

    這個例子演示了ask和pipeTo模式在Future上的結合,因為這可能是一個常見的組合。請注意,以上所有內容都是完全非阻塞和異步的:ask生成一個,其中兩個使用CompletableFuture.allOf和thenApply方法組合成新的Future,然后pipe在CompletionStage上安裝一個處理程序,以將聚合Result提交給另一個 Actor。

    使用ask會像使用tell一樣向接收 Actor 發送消息,并且接收 Actor 必須使用getSender().tell(reply, getSelf())才能完成返回的值。ask操作涉及創建一個用于處理此回復的內部 Actor,該 Actor 需要有一個超時,在該超時之后才能將其銷毀,以便不泄漏資源;具體請參閱下面更多的內容。

    • 警告:要完成帶異常的,你需要向發件人發送akka.actor.Status.Failure消息。當 Actor 在處理消息時拋出異常,不會自動執行此操作。
    try {String result = operation();getSender().tell(result, getSelf()); } catch (Exception e) {getSender().tell(new akka.actor.Status.Failure(e), getSelf());throw e; }

    如果 Actor 未完成,則它將在超時期限(指定為ask方法的參數)之后過期;這將使用AskTimeoutException完成CompletionStage。

    這可以用于注冊回調以便在完成時獲取通知,從而提供避免阻塞的方法。

    • 警告:當使用Future的回調時,內部 Actor 需要小心避免關閉包含 Actor 的引用,即不要從回調中調用方法或訪問封閉 Actor 的可變狀態。這將破壞 Actor 的封裝,并可能引入同步錯誤和競態條件,因為回調將被同時調度到封閉 Actor。不幸的是,目前還沒有一種方法可以在編譯時檢測到這些非法訪問。另見「Actors 和共享可變狀態」。

    轉發消息

    你可以將消息從一個 Actor 轉發到另一個 Actor。這意味著即使消息通過“中介器(mediator)”,原始發送方地址/引用也會得到維護。這在編寫充當路由器(routers)、負載平衡器(load-balancers)、復制器(replicators)等的 Actor 時很有用。

    target.forward(result, getContext());

    接收消息

    Actor 必須通過在AbstractActor中實現createReceive方法來定義其初始接收行為:

    @Override public Receive createReceive() {return receiveBuilder().match(String.class, s -> System.out.println(s.toLowerCase())).build(); }

    返回類型是AbstractActor.Receive,它定義了 Actor 可以處理哪些消息,以及如何處理這些消息的實現。可以使用名為ReceiveBuilder的生成器來構建此類行為。下面是一個例子:

    import akka.actor.AbstractActor; import akka.event.Logging; import akka.event.LoggingAdapter;public class MyActor extends AbstractActor {private final LoggingAdapter log = Logging.getLogger(getContext().getSystem(), this);@Overridepublic Receive createReceive() {return receiveBuilder().match(String.class,s -> {log.info("Received String message: {}", s);}).matchAny(o -> log.info("received unknown message")).build();} }

    如果你希望提供許多match案例,但希望避免創建長調用跟蹤(a long call trail),可以將生成器的創建拆分為多個語句,如示例中所示:

    import akka.actor.AbstractActor; import akka.event.Logging; import akka.event.LoggingAdapter; import akka.japi.pf.ReceiveBuilder;public class GraduallyBuiltActor extends AbstractActor {private final LoggingAdapter log = Logging.getLogger(getContext().getSystem(), this);@Overridepublic Receive createReceive() {ReceiveBuilder builder = ReceiveBuilder.create();builder.match(String.class,s -> {log.info("Received String message: {}", s);});// do some other stuff in betweenbuilder.matchAny(o -> log.info("received unknown message"));return builder.build();} }

    在 Actor 中,使用小方法也是一種很好的做法。建議將消息處理的實際工作委托給方法,而不是在每個lambda中定義具有大量代碼的大型ReceiveBuilder。一個結構良好的 Actor 可以是這樣的:

    static class WellStructuredActor extends AbstractActor {public static class Msg1 {}public static class Msg2 {}public static class Msg3 {}@Overridepublic Receive createReceive() {return receiveBuilder().match(Msg1.class, this::receiveMsg1).match(Msg2.class, this::receiveMsg2).match(Msg3.class, this::receiveMsg3).build();}private void receiveMsg1(Msg1 msg) {// actual work}private void receiveMsg2(Msg2 msg) {// actual work}private void receiveMsg3(Msg3 msg) {// actual work} }

    這樣做有以下好處:

    • 更容易看到 Actor 能處理什么樣的信息
    • 異常情況下的可讀堆棧跟蹤
    • 更好地使用性能分析工具
    • Java HotSpot 有更好的機會進行優化

    Receive可以通過其他方式實現,而不是使用ReceiveBuilder,因為它最終只是一個 Scala PartialFunction的包裝器。在 Java 中,可以通過擴展AbstractPartialFunction實現PartialFunction。例如,可以實現「與 DSL 匹配的 Vavr 模式適配器」,有關更多詳細信息,請參閱「Akka Vavr 示例項目」。

    如果對某些 Actor 來說,驗證ReceiveBuilder匹配邏輯是一個瓶頸,那么你可以考慮通過擴展UntypedAbstractActor而不是AbstractActor來在較低的級別實現它。ReceiveBuilder創建的分部函數由每個match語句的多個lambda表達式組成,其中每個lambda都引用要運行的代碼。這是 JVM 在優化時可能會遇到的問題,并且產生的代碼的性能可能不如非類型化版本。當擴展UntypedAbstractActor時,每個消息都作為非類型化Object接收,你必須以其他方式檢查并轉換為實際的消息類型,如下所示:

    static class OptimizedActor extends UntypedAbstractActor {public static class Msg1 {}public static class Msg2 {}public static class Msg3 {}@Overridepublic void onReceive(Object msg) throws Exception {if (msg instanceof Msg1) receiveMsg1((Msg1) msg);else if (msg instanceof Msg2) receiveMsg2((Msg2) msg);else if (msg instanceof Msg3) receiveMsg3((Msg3) msg);else unhandled(msg);}private void receiveMsg1(Msg1 msg) {// actual work}private void receiveMsg2(Msg2 msg) {// actual work}private void receiveMsg3(Msg3 msg) {// actual work} }

    回復消息

    如果你想有一個回復消息的句柄,可以使用getSender(),它會給你一個ActorRef。你可以通過使用getSender().tell(replyMsg, getSelf())發送ActorRef來進行回復。你還可以存儲ActorRef以供稍后回復或傳遞給其他 Actor。如果沒有發送者(發送的消息沒有 Actor 或Future上下文),那么發送者默認為死信(dead-letter)Actor 引用。

    getSender().tell(s, getSelf());

    接收超時

    ActorContext setReceiveTimeout定義了非活動超時,在該超時之后,將觸發發送ReceiveTimeout消息。指定超時時間后,接收函數應該能夠處理akka.actor.ReceiveTimeout消息。1毫秒是支持的最小超時時間。

    請注意,接收超時(receive timeout)可能會在另一條消息排隊后立即觸發并排隊ReceiveTimeout消息;因此,不保證在接收超時,如通過此方法配置的那樣,事先必須有空閑時間。

    設置后,接收超時將保持有效(即在非活動期后繼續重復觸發),可以通過傳入Duration.Undefined消息來關閉此功能。

    static class ReceiveTimeoutActor extends AbstractActor {public ReceiveTimeoutActor() {// To set an initial delaygetContext().setReceiveTimeout(Duration.ofSeconds(10));}@Overridepublic Receive createReceive() {return receiveBuilder().matchEquals("Hello",s -> {// To set in a response to a messagegetContext().setReceiveTimeout(Duration.ofSeconds(1));}).match(ReceiveTimeout.class,r -> {// To turn it offgetContext().cancelReceiveTimeout();}).build();} }

    標記為NotInfluenceReceiveTimeout的消息將不會重置計時器。當ReceiveTimeout受外部不活動而不受內部活動(如定時勾選消息)影響時,這可能會很有用(This can be useful when ReceiveTimeout should be fired by external inactivity but not influenced by internal activity, e.g. scheduled tick messages.)。

    定時器和調度消息

    通過直接使用「Scheduler」,可以將消息安排在以后的時間點發送,但是在將 Actor 中的定期或單個消息安排到自身時,使用對命名定時器(named timers)的支持更為方便和安全。當 Actor 重新啟動并由定時器處理時,調度(scheduled)消息的生命周期可能難以管理。

    import java.time.Duration; import akka.actor.AbstractActorWithTimers;static class MyActor extends AbstractActorWithTimers {private static Object TICK_KEY = "TickKey";private static final class FirstTick {}private static final class Tick {}public MyActor() {getTimers().startSingleTimer(TICK_KEY, new FirstTick(), Duration.ofMillis(500));}@Overridepublic Receive createReceive() {return receiveBuilder().match(FirstTick.class,message -> {// do something useful heregetTimers().startPeriodicTimer(TICK_KEY, new Tick(), Duration.ofSeconds(1));}).match(Tick.class,message -> {// do something useful here}).build();} }

    每個定時器都有一個鍵,可以更換或取消。它保證不會收到來自具有相同密鑰的定時器的前一個實例的消息,即使當它被取消或新定時器啟動時,它可能已經在郵箱中排隊。

    定時器綁定到擁有它的 Actor 的生命周期,因此當它重新啟動或停止時自動取消。請注意,TimerScheduler不是線程安全的,即它只能在擁有它的 Actor 中使用。

    停止 Actor

    通過調用ActorRefFactory的stop方法(即ActorContext或ActorSystem)來停止 Actor。通常,上下文用于停止 Actor 本身或子 Actor,以及停止頂級 Actor 的系統。Actor 的實際終止是異步執行的,也就是說,stop可能會在 Actor 停止之前返回。

    import akka.actor.ActorRef; import akka.actor.AbstractActor;public class MyStoppingActor extends AbstractActor {ActorRef child = null;// ... creation of child ...@Overridepublic Receive createReceive() {return receiveBuilder().matchEquals("interrupt-child", m -> getContext().stop(child)).matchEquals("done", m -> getContext().stop(getSelf())).build();} }

    當前郵件(如果有)的處理將在 Actor 停止之前繼續,但不會處理郵箱中的其他郵件。默認情況下,這些消息將發送到ActorSystem的deadLetters,但這取決于郵箱的實現。

    一個 Actor 的終止分兩步進行:首先,Actor 暫停其郵箱處理并向其所有子級發送停止命令,然后繼續處理其子級的內部終止通知,直到最后一個終止,最后終止其自身(調用postStop、轉儲郵箱、在DeathWatch上發布Terminated、通知其監督者)。此過程確保 Actor 系統子樹以有序的方式終止,將stop命令傳播到葉,并將其確認信息收集回已停止的監督者。如果其中一個 Actor 沒有響應(即長時間處理消息,因此不接收stop命令),那么整個過程將被阻塞。

    在ActorSystem.terminate()之后,系統守護者 Actor 將被停止,上述過程將確保整個系統的正確終止。

    postStop()鉤子在 Actor 完全停止后調用。這樣可以清理資源:

    @Override public void postStop() {final String message = "stopped";// don’t forget to think about who is the sender (2nd argument)target.tell(message, getSelf());final Object result = "";target.forward(result, getContext());target = null; }
    • 注釋:由于停止 Actor 是異步的,因此不能立即重用剛剛停止的子級的名稱;這將導致InvalidActorNameException。相反,watch()終止的 Actor,并創建其替換(replacement),以響應最終到達的Terminated消息。

    PoisonPill

    你還可以向 Actor 發送akka.actor.PoisonPill消息,該消息將在處理消息時停止 Actor。PoisonPill作為普通消息排隊,并將在郵箱中已排隊的消息之后處理。

    victim.tell(akka.actor.PoisonPill.getInstance(), ActorRef.noSender());

    殺死一個 Actor

    你也可以通過發送一條Kill消息來“殺死”一個 Actor。與PoisonPill不同的是,這可能會使 Actor 拋出ActorKilledException,并觸發失敗。Actor 將暫停操作,并詢問其監督者如何處理故障,這可能意味著恢復 Actor、重新啟動或完全終止 Actor。更多信息,請參閱「What Supervision Means」。

    像這樣使用Kill:

    victim.tell(akka.actor.Kill.getInstance(), ActorRef.noSender());// expecting the actor to indeed terminate: expectTerminated(Duration.ofSeconds(3), victim);

    一般來說,雖然在設計 Actor 交互時不建議過分依賴于PoisonPill或Kill,但通常情況下,鼓勵使用諸如PleaseCleanupAndStop之類的協議級(protocol-level)消息,因為 Actor 知道如何處理這些消息。像PoisonPill和Kill這樣的信息是為了能夠停止那些你無法控制的 Actor 的。

    優雅的停止

    如果你需要等待終止或組合多個 Actor 的有序終止,則gracefulStop非常有用:

    import static akka.pattern.Patterns.gracefulStop; import akka.pattern.AskTimeoutException; import java.util.concurrent.CompletionStage;try {CompletionStage<Boolean> stopped =gracefulStop(actorRef, Duration.ofSeconds(5), Manager.SHUTDOWN);stopped.toCompletableFuture().get(6, TimeUnit.SECONDS);// the actor has been stopped } catch (AskTimeoutException e) {// the actor wasn't stopped within 5 seconds }

    當gracefulStop()成功返回時,Actor 的postStop()鉤子將被執行:在postStop()結尾和gracefulStop()返回之間存在一個“發生在邊緣之前(happens-before edge)”的關系。

    在上面的例子中,一個定制的Manager.Shutdown消息被發送到目標 Actor,以啟動停止 Actor 的過程。你可以為此使用PoisonPill,但在停止目標 Actor 之前,你與其他 Actor 進行交互的可能性很有限??梢栽趐ostStop中處理簡單的清理任務。

    • 警告:請記住,停止的 Actor 和取消注冊的 Actor 是彼此異步發生的獨立事件。因此,在gracefulStop()返回后,你可能會發現該名稱仍在使用中。為了保證正確的注銷,只能重用你控制的監督者中的名稱,并且只響應Terminated消息,即不用于頂級 Actor。

    協調關閉

    有一個名為CoordinatedShutdown的擴展,它將按特定順序停止某些 Actor 和服務,并在關閉過程中執行注冊的任務。

    停機階段(shutdown phases)的順序在配置akka.coordinated-shutdown.phases中定義。默認階段定義為:

    # CoordinatedShutdown is enabled by default and will run the tasks that # are added to these phases by individual Akka modules and user logic. # # The phases are ordered as a DAG by defining the dependencies between the phases # to make sure shutdown tasks are run in the right order. # # In general user tasks belong in the first few phases, but there may be use # cases where you would want to hook in new phases or register tasks later in # the DAG. # # Each phase is defined as a named config section with the # following optional properties: # - timeout=15s: Override the default-phase-timeout for this phase. # - recover=off: If the phase fails the shutdown is aborted # and depending phases will not be executed. # - enabled=off: Skip all tasks registered in this phase. DO NOT use # this to disable phases unless you are absolutely sure what the # consequences are. Many of the built in tasks depend on other tasks # having been executed in earlier phases and may break if those are disabled. # depends-on=[]: Run the phase after the given phases phases {# The first pre-defined phase that applications can add tasks to.# Note that more phases can be added in the application's# configuration by overriding this phase with an additional# depends-on.before-service-unbind {}# Stop accepting new incoming connections.# This is where you can register tasks that makes a server stop accepting new connections. Already# established connections should be allowed to continue and complete if possible.service-unbind {depends-on = [before-service-unbind]}# Wait for requests that are in progress to be completed.# This is where you register tasks that will wait for already established connections to complete, potentially# also first telling them that it is time to close down.service-requests-done {depends-on = [service-unbind]}# Final shutdown of service endpoints.# This is where you would add tasks that forcefully kill connections that are still around.service-stop {depends-on = [service-requests-done]}# Phase for custom application tasks that are to be run# after service shutdown and before cluster shutdown.before-cluster-shutdown {depends-on = [service-stop]}# Graceful shutdown of the Cluster Sharding regions.# This phase is not meant for users to add tasks to.cluster-sharding-shutdown-region {timeout = 10 sdepends-on = [before-cluster-shutdown]}# Emit the leave command for the node that is shutting down.# This phase is not meant for users to add tasks to.cluster-leave {depends-on = [cluster-sharding-shutdown-region]}# Shutdown cluster singletons# This is done as late as possible to allow the shard region shutdown triggered in# the "cluster-sharding-shutdown-region" phase to complete before the shard coordinator is shut down.# This phase is not meant for users to add tasks to.cluster-exiting {timeout = 10 sdepends-on = [cluster-leave]}# Wait until exiting has been completed# This phase is not meant for users to add tasks to.cluster-exiting-done {depends-on = [cluster-exiting]}# Shutdown the cluster extension# This phase is not meant for users to add tasks to.cluster-shutdown {depends-on = [cluster-exiting-done]}# Phase for custom application tasks that are to be run# after cluster shutdown and before ActorSystem termination.before-actor-system-terminate {depends-on = [cluster-shutdown]}# Last phase. See terminate-actor-system and exit-jvm above.# Don't add phases that depends on this phase because the# dispatcher and scheduler of the ActorSystem have been shutdown.# This phase is not meant for users to add tasks to.actor-system-terminate {timeout = 10 sdepends-on = [before-actor-system-terminate]} }

    如果需要,可以在應用程序的配置中添加更多的階段(phases),方法是使用附加的depends-on覆蓋階段。尤其是在before-service-unbind、before-cluster-shutdown和before-actor-system-terminate的階段,是針對特定于應用程序的階段或任務的。

    默認階段是以單個線性順序定義的,但是通過定義階段之間的依賴關系,可以將階段排序為有向非循環圖(DAG)。階段是按 DAG 的拓撲排序的。

    可以將任務添加到具有以下內容的階段:

    CoordinatedShutdown.get(system).addTask(CoordinatedShutdown.PhaseBeforeServiceUnbind(),"someTaskName",() -> {return akka.pattern.Patterns.ask(someActor, "stop", Duration.ofSeconds(5)).thenApply(reply -> Done.getInstance());});

    在任務完成后,應返回CompletionStage<Done>。任務名稱參數僅用于調試或日志記錄。

    添加到同一階段的任務是并行執行的,沒有任何排序假設。在完成前一階段的所有任務之前,下一階段將不會啟動。

    如果任務沒有在配置的超時內完成(請參見「reference.conf」),則下一個階段無論如何都會啟動。如果任務失敗或未在超時內完成,則可以為一個階段配置recover=off以中止關閉過程的其余部分。

    任務通常應在系統啟動后盡早注冊。運行時,將執行已注冊的協調關閉任務,但不會運行添加得太晚的任務。

    要啟動協調關閉進程,可以對CoordinatedShutdown擴展調用runAll:

    CompletionStage<Done> done =CoordinatedShutdown.get(system).runAll(CoordinatedShutdown.unknownReason());

    多次調用runAll方法是安全的,它只能運行一次。

    這也意味著ActorSystem將在最后一個階段終止。默認情況下,不會強制停止 JVM(如果終止了所有非守護進程線程,則會停止 JVM)。要啟用硬System.exit作為最終操作,可以配置:

    akka.coordinated-shutdown.exit-jvm = on

    當使用「Akka 集群」時,當集群節點將自己視為Exiting時,CoordinatedShutdown將自動運行,即從另一個節點離開將觸發離開節點上的關閉過程。當使用 Akka 集群時,會自動添加集群的優雅離開任務,包括集群單例的優雅關閉和集群分片,即運行關閉過程也會觸發尚未進行的優雅離開。

    默認情況下,當 JVM 進程退出時,例如通過kill SIGTERM信號(SIGINT時Ctrl-C不起作用),將運行CoordinatedShutdown。此行為可以通過以下方式禁用:

    akka.coordinated-shutdown.run-by-jvm-shutdown-hook=off

    如果你有特定于應用程序的 JVM 關閉鉤子,建議你通過CoordinatedShutdown對它們進行注冊,以便它們在 Akka 內部關閉鉤子之前運行,例如關閉 Akka 遠程處理。

    CoordinatedShutdown.get(system).addJvmShutdownHook(() -> System.out.println("custom JVM shutdown hook..."));

    對于某些測試,可能不希望通過CoordinatedShutdown來終止ActorSystem。你可以通過將以下內容添加到測試時使用的ActorSystem的配置中來禁用此功能:

    # Don't terminate ActorSystem via CoordinatedShutdown in tests akka.coordinated-shutdown.terminate-actor-system = off akka.coordinated-shutdown.run-by-jvm-shutdown-hook = off akka.cluster.run-coordinated-shutdown-when-down = off

    Become/Unbecome

    升級

    Akka 支持在運行時對 Actor 的消息循環(例如其實現)進行熱交換:從 Actor 內部調用context.become方法。become采用實現新消息處理程序的PartialFunction<Object, BoxedUnit>。熱交換代碼(hotswapped code)保存在一個Stack中,可以推送和彈出。

    • 警告:請注意,Actor 在被其監督者重新啟動時將恢復其原始行為。

    要使用become熱交換 Actor 的行為,可以參考以下操作:

    static class HotSwapActor extends AbstractActor {private AbstractActor.Receive angry;private AbstractActor.Receive happy;public HotSwapActor() {angry =receiveBuilder().matchEquals("foo",s -> {getSender().tell("I am already angry?", getSelf());}).matchEquals("bar",s -> {getContext().become(happy);}).build();happy =receiveBuilder().matchEquals("bar",s -> {getSender().tell("I am already happy :-)", getSelf());}).matchEquals("foo",s -> {getContext().become(angry);}).build();}@Overridepublic Receive createReceive() {return receiveBuilder().matchEquals("foo", s -> getContext().become(angry)).matchEquals("bar", s -> getContext().become(happy)).build();} }

    become方法的這種變體對于許多不同的事情都很有用,例如實現有限狀態機(FSM,例如「Dining Hakkers」)。它將替換當前行為(即行為堆棧的頂部),這意味著你不使用unbecome,而是始終顯式安裝(installed)下一個行為。

    另一種使用become的方法不是替換而是添加到行為堆棧的頂部。在這種情況下,必須注意確保pop操作的數量(即unbecome)與push操作的數量在長期內匹配,否則這將導致內存泄漏,這就是為什么此行為不是默認行為。

    static class Swapper extends AbstractLoggingActor {@Overridepublic Receive createReceive() {return receiveBuilder().matchEquals(Swap,s -> {log().info("Hi");getContext().become(receiveBuilder().matchEquals(Swap,x -> {log().info("Ho");getContext().unbecome(); // resets the latest 'become' (just for fun)}).build(),false); // push on top instead of replace}).build();} }static class SwapperApp {public static void main(String[] args) {ActorSystem system = ActorSystem.create("SwapperSystem");ActorRef swapper = system.actorOf(Props.create(Swapper.class), "swapper");swapper.tell(Swap, ActorRef.noSender()); // logs Hiswapper.tell(Swap, ActorRef.noSender()); // logs Hoswapper.tell(Swap, ActorRef.noSender()); // logs Hiswapper.tell(Swap, ActorRef.noSender()); // logs Hoswapper.tell(Swap, ActorRef.noSender()); // logs Hiswapper.tell(Swap, ActorRef.noSender()); // logs Hosystem.terminate();} }

    對 Scala Actor 嵌套接收進行編碼,而不會意外泄漏內存

    請參閱「Unnested receive example」。

    Stash

    AbstractActorWithStash類使 Actor 能夠臨時存儲"不能"或"不應該"使用 Actor 當前行為處理的消息。更改 Actor 的消息處理程序后,即在調用getContext().become()或getContext().unbecome()之前,所有隱藏的消息都可以“unstashed”,從而將它們預存到 Actor 的郵箱中。這樣,可以按照與最初接收到的消息相同的順序處理隱藏的消息。擴展AbstractActorWithStash的 Actor 將自動獲得基于deque的郵箱。

    • 注釋:抽象類AbstractActorWithStash實現了標記接口RequiresMessageQueue<DequeBasedMessageQueueSemantics>,如果希望對郵箱進行更多控制,請參閱有關郵箱的文檔:「Mailboxes」。

    下面是AbstractActorWithStash類的一個示例:

    static class ActorWithProtocol extends AbstractActorWithStash {@Overridepublic Receive createReceive() {return receiveBuilder().matchEquals("open",s -> {getContext().become(receiveBuilder().matchEquals("write",ws -> {/* do writing */}).matchEquals("close",cs -> {unstashAll();getContext().unbecome();}).matchAny(msg -> stash()).build(),false);}).matchAny(msg -> stash()).build();} }

    調用stash()會將當前消息(Actor 最后收到的消息)添加到 Actor 的stash中。它通常在處理 Actor 消息處理程序中的默認情況時調用,以存儲其他情況未處理的消息。將同一條消息存儲兩次是非法的;這樣做會導致IllegalStateException。stash也可以是有界的,在這種情況下,調用stash()可能導致容量沖突(capacity violation),從而導致StashOverflowException。可以使用郵箱配置的stash-capacity設置(一個int值)存儲容量。

    調用unstashAll()將消息從stash排隊到 Actor 的郵箱,直到達到郵箱的容量(如果有),請注意,stash中的消息是預先發送到郵箱的。如果有界郵箱溢出,將引發MessageQueueAppendFailedException。調用unstashAll()后,stash保證為空。

    stash由scala.collection.immutable.Vector支持。因此,即使是非常大量的消息也可能被存儲起來,而不會對性能產生重大影響。

    請注意,與郵箱不同,stash是短暫的 Actor 狀態的一部分。因此,它應該像 Actor 狀態中具有相同屬性的其他部分一樣進行管理。preRestart的AbstractActorWithStash實現將調用unstashAll(),這通常是需要的行為。

    • 注釋:如果你想強制你的 Actor 只能使用無界的stash,那么你應該使用AbstractActorWithUnboundedStash類。

    Actor 和異常

    當 Actor 處理消息時,可能會引發某種異常,例如數據庫異常。

    消息發生了什么

    如果在處理郵件時引發異常(即從郵箱中取出并移交給當前行為),則此郵件將丟失。重要的是要知道它不會放回郵箱。因此,如果你想重試處理消息,你需要自己處理它,捕獲異常并重試處理流程(retry your flow)。確保對重試次數進行了限制,因為你不希望系統進行livelock,否則的話,這會在程序沒有進展的情況下消耗大量 CPU 周期。

    郵箱發生了什么

    如果在處理郵件時引發異常,則郵箱不會發生任何異常。如果 Actor 重新啟動,則會出現相同的郵箱。因此,該郵箱上的所有郵件也將在那里。

    Actor 發現了什么

    如果 Actor 內的代碼拋出異常,則該 Actor 將被掛起,并且監控過程將啟動。根據監督者的決定,Actor 被恢復(好像什么都沒有發生)、重新啟動(清除其內部狀態并從頭開始)或終止。

    初始化模式

    Actor 的豐富生命周期鉤子提供了一個有用的工具箱來實現各種初始化模式(initialization patterns)。在ActorRef的生命周期中,Actor 可能會經歷多次重新啟動,舊實例被新實例替換,外部觀察者看不見內部的變化,外部觀察者只看到ActorRef引用。

    每次實例化一個 Actor 時,可能都需要初始化,但有時只需要在創建ActorRef時對第一個實例進行初始化。以下部分提供了不同初始化需求的模式。

    通過構造函數初始化

    使用構造函數進行初始化有很多好處。首先,它讓使用val字段存儲在 Actor 實例的生命周期中不發生更改的任何狀態成為可能,從而使 Actor 的實現更加健壯。當創建一個調用actorOf的 Actor 實例時,也會在重新啟動時調用構造函數,因此 Actor 的內部始終可以假定發生了正確的初始化。這也是這種方法的缺點,因為在某些情況下,人們希望避免在重新啟動時重新初始化內部信息。例如,在重新啟動時保護子 Actor 通常很有用。下面的部分提供了這個案例的模式。

    通過 preStart 初始化

    在第一個實例的初始化過程中,即在創建ActorRef時,只直接調用一次 Actor 的preStart()方法。在重新啟動的情況下,postRestart()調用preStart(),因此如果不重寫,則在每次重新啟動時都會調用preStart()。但是,通過重寫postRestart(),可以禁用此行為,并確保只有一個對preStart()的調用。

    此模式的一個有用用法是在重新啟動期間禁用為子級創建新的ActorRef。這可以通過重寫preRestart()來實現。以下是這些生命周期掛鉤的默認實現:

    @Override public void preStart() {// Initialize children here }// Overriding postRestart to disable the call to preStart() // after restarts @Override public void postRestart(Throwable reason) {}// The default implementation of preRestart() stops all the children // of the actor. To opt-out from stopping the children, we // have to override preRestart() @Override public void preRestart(Throwable reason, Optional<Object> message) throws Exception {// Keep the call to postStop(), but no stopping of childrenpostStop(); }

    請注意,子 Actor 仍然重新啟動,但沒有創建新的ActorRef??梢赃f歸地為子級應用相同的原則,確保只在創建引用時調用它們的preStart()方法。

    有關更多信息,請參閱「What Restarting Means」。

    通過消息傳遞初始化

    有些情況下,在構造函數中無法傳遞 Actor 初始化所需的所有信息,例如在存在循環依賴項的情況下。在這種情況下,Actor 應該監聽初始化消息,并使用become()或有限狀態機(finite state-machine)狀態轉換來編碼 Actor 的初始化和未初始化狀態。

    @Override public Receive createReceive() {return receiveBuilder().matchEquals("init",m1 -> {initializeMe = "Up and running";getContext().become(receiveBuilder().matchEquals("U OK?",m2 -> {getSender().tell(initializeMe, getSelf());}).build());}).build(); }

    如果 Actor 可能在初始化消息之前收到消息,那么一個有用的工具可以是Stash存儲消息,直到初始化完成,然后在 Actor 初始化之后重放消息。

    • 警告:此模式應小心使用,并且僅當上述模式均不適用時才應用。其中一個潛在的問題是,消息在發送到遠程 Actor 時可能會丟失。此外,在未初始化狀態下發布ActorRef可能會導致在初始化完成之前接收到用戶消息的情況。

    英文原文鏈接:Actors.


    ———— ☆☆☆ —— 返回 -> Akka 中文指南 <- 目錄 —— ☆☆☆ ————

    總結

    以上是生活随笔為你收集整理的Akka 指南 之「Actors」的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    学生妹亚洲一区二区 | 人人爽人人爽人人片av亚洲 | 国产无套粉嫩白浆在线 | 日欧一片内射va在线影院 | 亚洲精品中文字幕乱码 | 久久综合给合久久狠狠狠97色 | 国产成人精品三级麻豆 | 对白脏话肉麻粗话av | 一本色道久久综合亚洲精品不卡 | 国产疯狂伦交大片 | 清纯唯美经典一区二区 | 久久久精品欧美一区二区免费 | 国产成人精品久久亚洲高清不卡 | 国产av无码专区亚洲awww | 无码乱肉视频免费大全合集 | 中文字幕精品av一区二区五区 | 国产精品对白交换视频 | 麻花豆传媒剧国产免费mv在线 | 粗大的内捧猛烈进出视频 | 国内少妇偷人精品视频免费 | 男女性色大片免费网站 | 亚洲国产日韩a在线播放 | 国产精品久久福利网站 | 久久综合网欧美色妞网 | 人妻无码αv中文字幕久久琪琪布 | 丝袜 中出 制服 人妻 美腿 | 亚无码乱人伦一区二区 | 亚洲男女内射在线播放 | 老司机亚洲精品影院 | 内射欧美老妇wbb | 国产精品福利视频导航 | 人妻体内射精一区二区三四 | 久久综合给久久狠狠97色 | 国产亚洲精品久久久闺蜜 | 亚洲va中文字幕无码久久不卡 | 性色欲情网站iwww九文堂 | 午夜福利试看120秒体验区 | 久久天天躁狠狠躁夜夜免费观看 | 性生交大片免费看l | 久久综合网欧美色妞网 | 国产欧美亚洲精品a | 久热国产vs视频在线观看 | 香蕉久久久久久av成人 | 国产精品怡红院永久免费 | 野外少妇愉情中文字幕 | 国产成人一区二区三区别 | 国产无套内射久久久国产 | 国产在线精品一区二区高清不卡 | 真人与拘做受免费视频一 | 国产成人精品优优av | 亚洲精品一区国产 | 欧美老妇交乱视频在线观看 | 中文毛片无遮挡高清免费 | 九月婷婷人人澡人人添人人爽 | 亚洲成a人一区二区三区 | 国产亚洲精品久久久久久久久动漫 | 熟女少妇在线视频播放 | 国产av无码专区亚洲a∨毛片 | 国产亚洲精品久久久ai换 | 牲欲强的熟妇农村老妇女 | 亚洲精品中文字幕久久久久 | 自拍偷自拍亚洲精品10p | 国产情侣作爱视频免费观看 | 久9re热视频这里只有精品 | 伊人久久大香线蕉av一区二区 | 国产肉丝袜在线观看 | 国产在线精品一区二区三区直播 | 在线播放亚洲第一字幕 | 亚洲精品久久久久久一区二区 | 国产sm调教视频在线观看 | 天天摸天天透天天添 | 中文字幕av日韩精品一区二区 | 亚洲一区二区三区偷拍女厕 | 久久久久久久人妻无码中文字幕爆 | 荡女精品导航 | 精品久久久久久亚洲精品 | 又粗又大又硬又长又爽 | 一二三四在线观看免费视频 | 精品国精品国产自在久国产87 | 亚洲国精产品一二二线 | 天堂久久天堂av色综合 | 亚洲成av人片在线观看无码不卡 | 波多野结衣乳巨码无在线观看 | 大胆欧美熟妇xx | 水蜜桃亚洲一二三四在线 | 国产精品亚洲五月天高清 | 国产在线精品一区二区三区直播 | 一本一道久久综合久久 | 无套内谢的新婚少妇国语播放 | 国产精品久久国产三级国 | 精品无码一区二区三区爱欲 | 国产成人精品一区二区在线小狼 | 兔费看少妇性l交大片免费 | 亚洲一区二区三区无码久久 | 欧洲精品码一区二区三区免费看 | 欧美野外疯狂做受xxxx高潮 | 亚洲欧洲中文日韩av乱码 | 国产真实乱对白精彩久久 | 国产麻豆精品一区二区三区v视界 | 日本高清一区免费中文视频 | 国产农村妇女高潮大叫 | 欧美性生交xxxxx久久久 | 国产人妖乱国产精品人妖 | 九九综合va免费看 | 中文字幕乱码人妻二区三区 | 国产午夜视频在线观看 | a国产一区二区免费入口 | 性生交大片免费看l | 天干天干啦夜天干天2017 | 成年美女黄网站色大免费全看 | 野外少妇愉情中文字幕 | 小鲜肉自慰网站xnxx | 欧美黑人乱大交 | 国产亚洲精品久久久久久 | 极品嫩模高潮叫床 | 任你躁国产自任一区二区三区 | 欧美亚洲日韩国产人成在线播放 | 午夜肉伦伦影院 | 无码午夜成人1000部免费视频 | 欧美阿v高清资源不卡在线播放 | 熟女体下毛毛黑森林 | 三上悠亚人妻中文字幕在线 | 欧美成人午夜精品久久久 | 永久免费观看美女裸体的网站 | 国产精品怡红院永久免费 | 国产精品久久久久久无码 | 亚洲精品午夜无码电影网 | 牲欲强的熟妇农村老妇女视频 | 曰韩少妇内射免费播放 | 伊人久久大香线焦av综合影院 | 欧美日韩人成综合在线播放 | 日本精品少妇一区二区三区 | 日韩亚洲欧美中文高清在线 | 久久99精品国产.久久久久 | 天堂а√在线地址中文在线 | 牲欲强的熟妇农村老妇女 | 97se亚洲精品一区 | 亚洲 a v无 码免 费 成 人 a v | 精品欧洲av无码一区二区三区 | 任你躁国产自任一区二区三区 | 99精品无人区乱码1区2区3区 | 亚洲成a人片在线观看日本 | 亚洲天堂2017无码 | 香蕉久久久久久av成人 | 国内少妇偷人精品视频 | 久久www免费人成人片 | 4hu四虎永久在线观看 | 午夜熟女插插xx免费视频 | 人人爽人人澡人人人妻 | 国产成人亚洲综合无码 | 狂野欧美性猛xxxx乱大交 | 久久综合激激的五月天 | 国产亚av手机在线观看 | 男女性色大片免费网站 | 一二三四社区在线中文视频 | 久久久久99精品国产片 | 亚洲中文字幕av在天堂 | 国产热a欧美热a在线视频 | 欧美熟妇另类久久久久久多毛 | 中文无码伦av中文字幕 | 夜先锋av资源网站 | 在线精品国产一区二区三区 | 精品厕所偷拍各类美女tp嘘嘘 | 国产精品人人妻人人爽 | 久久午夜夜伦鲁鲁片无码免费 | 88国产精品欧美一区二区三区 | 午夜福利不卡在线视频 | 一二三四社区在线中文视频 | 精品亚洲成av人在线观看 | 天天摸天天碰天天添 | 国产真实乱对白精彩久久 | 夜精品a片一区二区三区无码白浆 | 无码精品人妻一区二区三区av | 国产精品久久久久久亚洲毛片 | 国产特级毛片aaaaaa高潮流水 | 国产情侣作爱视频免费观看 | 午夜嘿嘿嘿影院 | 蜜桃臀无码内射一区二区三区 | 欧美日韩色另类综合 | 啦啦啦www在线观看免费视频 | 国内综合精品午夜久久资源 | 日日摸日日碰夜夜爽av | 国产特级毛片aaaaaaa高清 | 国产成人精品一区二区在线小狼 | 窝窝午夜理论片影院 | 国产成人无码av一区二区 | 在线观看免费人成视频 | 无码人妻出轨黑人中文字幕 | 精品国产乱码久久久久乱码 | 国产亚洲精品久久久久久久 | 人人妻人人藻人人爽欧美一区 | 国产乱子伦视频在线播放 | 一本久道久久综合狠狠爱 | av人摸人人人澡人人超碰下载 | 一个人免费观看的www视频 | 国产成人午夜福利在线播放 | 国产精品久久福利网站 | 成人无码视频在线观看网站 | 欧美日韩亚洲国产精品 | 一个人看的视频www在线 | 内射后入在线观看一区 | 国产做国产爱免费视频 | 一区二区传媒有限公司 | 在教室伦流澡到高潮hnp视频 | 中文精品久久久久人妻不卡 | 国产97色在线 | 免 | 国产成人无码专区 | 国产乱人伦av在线无码 | 无码人妻丰满熟妇区五十路百度 | 亚洲中文字幕无码中字 | 又大又硬又黄的免费视频 | www国产亚洲精品久久久日本 | 男女超爽视频免费播放 | 国产激情精品一区二区三区 | 人妻体内射精一区二区三四 | 中文字幕无码人妻少妇免费 | 欧美午夜特黄aaaaaa片 | 67194成是人免费无码 | 国产精品亚洲专区无码不卡 | 无码人妻精品一区二区三区下载 | 日本大乳高潮视频在线观看 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产人妻大战黑人第1集 | 亚洲精品综合一区二区三区在线 | 国产香蕉97碰碰久久人人 | 亚洲一区二区三区偷拍女厕 | 亚洲成av人影院在线观看 | 日本免费一区二区三区最新 | 久久久久亚洲精品男人的天堂 | 少妇无码吹潮 | 99久久精品国产一区二区蜜芽 | 国产亚洲视频中文字幕97精品 | 国产成人无码a区在线观看视频app | 日日摸天天摸爽爽狠狠97 | 国产猛烈高潮尖叫视频免费 | 性欧美大战久久久久久久 | 大肉大捧一进一出好爽视频 | 亚洲色偷偷偷综合网 | 欧美亚洲国产一区二区三区 | 人人澡人人妻人人爽人人蜜桃 | 樱花草在线社区www | 午夜精品一区二区三区的区别 | 日本一区二区更新不卡 | 熟妇人妻中文av无码 | 久久精品人妻少妇一区二区三区 | 久9re热视频这里只有精品 | 亚洲国产av精品一区二区蜜芽 | 国产精品内射视频免费 | 性史性农村dvd毛片 | 欧美日韩亚洲国产精品 | 国产av无码专区亚洲awww | 国产成人精品优优av | 亚洲综合久久一区二区 | 无码国产色欲xxxxx视频 | 亚洲精品国产精品乱码视色 | 午夜时刻免费入口 | 人妻有码中文字幕在线 | 亚洲综合精品香蕉久久网 | 东京无码熟妇人妻av在线网址 | 精品人人妻人人澡人人爽人人 | 亚洲最大成人网站 | 精品国产国产综合精品 | 中文字幕日产无线码一区 | 久久 国产 尿 小便 嘘嘘 | 亚洲成熟女人毛毛耸耸多 | 疯狂三人交性欧美 | 在线观看免费人成视频 | 天堂无码人妻精品一区二区三区 | 内射白嫩少妇超碰 | 无码精品人妻一区二区三区av | 熟女少妇人妻中文字幕 | 亚洲一区二区三区在线观看网站 | 免费视频欧美无人区码 | 欧美日韩精品 | 国产福利视频一区二区 | 亚洲热妇无码av在线播放 | 无码人中文字幕 | 精品国产精品久久一区免费式 | 国产农村妇女高潮大叫 | 亚洲一区二区三区四区 | 免费视频欧美无人区码 | 国产精品久久久av久久久 | 桃花色综合影院 | 男女超爽视频免费播放 | 婷婷五月综合缴情在线视频 | 色婷婷综合中文久久一本 | 精品国精品国产自在久国产87 | 欧美freesex黑人又粗又大 | 国产亚洲精品久久久久久大师 | 日产精品高潮呻吟av久久 | 国产成人人人97超碰超爽8 | 天天摸天天透天天添 | 强辱丰满人妻hd中文字幕 | 久久国产精品二国产精品 | 少妇性l交大片欧洲热妇乱xxx | 性做久久久久久久免费看 | 久久国内精品自在自线 | 精品无码国产一区二区三区av | 亚洲高清偷拍一区二区三区 | 久久精品成人欧美大片 | 婷婷色婷婷开心五月四房播播 | 99久久人妻精品免费二区 | 搡女人真爽免费视频大全 | 国产人成高清在线视频99最全资源 | 丝袜足控一区二区三区 | 人人妻人人澡人人爽欧美一区九九 | 亚洲精品一区国产 | 秋霞特色aa大片 | 日韩精品久久久肉伦网站 | 夜精品a片一区二区三区无码白浆 | 国产农村乱对白刺激视频 | 在线观看国产午夜福利片 | 精品无码国产一区二区三区av | 国精产品一品二品国精品69xx | 亚洲 另类 在线 欧美 制服 | 乱人伦人妻中文字幕无码久久网 | 欧美自拍另类欧美综合图片区 | 亚洲乱码中文字幕在线 | 国产免费无码一区二区视频 | 又大又黄又粗又爽的免费视频 | 国内精品久久毛片一区二区 | 99久久婷婷国产综合精品青草免费 | 国产av一区二区三区最新精品 | 色综合久久久无码中文字幕 | 国产色在线 | 国产 | 99久久人妻精品免费一区 | 蜜臀av在线播放 久久综合激激的五月天 | 成人免费无码大片a毛片 | 国产午夜福利100集发布 | 一本久道久久综合狠狠爱 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 亚洲区小说区激情区图片区 | 偷窥日本少妇撒尿chinese | 99久久精品日本一区二区免费 | 精品日本一区二区三区在线观看 | 牛和人交xxxx欧美 | 无码播放一区二区三区 | 97夜夜澡人人双人人人喊 | 亚洲国精产品一二二线 | 无码av岛国片在线播放 | 在线精品亚洲一区二区 | 四虎影视成人永久免费观看视频 | 国产精品美女久久久网av | 无码精品国产va在线观看dvd | 少妇高潮喷潮久久久影院 | 又色又爽又黄的美女裸体网站 | 国产无套粉嫩白浆在线 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 国产亲子乱弄免费视频 | 无码人妻出轨黑人中文字幕 | 西西人体www44rt大胆高清 | 精品无码国产一区二区三区av | 亚洲成熟女人毛毛耸耸多 | 国产精品高潮呻吟av久久4虎 | 亚洲乱码日产精品bd | 好爽又高潮了毛片免费下载 | 久久综合九色综合欧美狠狠 | 麻豆国产丝袜白领秘书在线观看 | 久久精品国产精品国产精品污 | 成人亚洲精品久久久久 | 福利一区二区三区视频在线观看 | 国产福利视频一区二区 | 国产精品怡红院永久免费 | 国产xxx69麻豆国语对白 | 欧美 亚洲 国产 另类 | 亚洲精品中文字幕 | 日韩成人一区二区三区在线观看 | 国产办公室秘书无码精品99 | 久久99精品国产麻豆蜜芽 | 国产成人无码一二三区视频 | 任你躁在线精品免费 | 一本久久a久久精品亚洲 | 四虎国产精品免费久久 | 亚洲精品成人av在线 | a国产一区二区免费入口 | 2020久久香蕉国产线看观看 | 亚洲精品久久久久久一区二区 | a片在线免费观看 | √天堂资源地址中文在线 | 少妇被粗大的猛进出69影院 | 国产av一区二区精品久久凹凸 | 日本熟妇乱子伦xxxx | 国产激情艳情在线看视频 | 国产精品嫩草久久久久 | 青草青草久热国产精品 | 午夜精品久久久久久久久 | 内射白嫩少妇超碰 | www国产亚洲精品久久久日本 | 欧美zoozzooz性欧美 | 国产精品沙发午睡系列 | 成 人 网 站国产免费观看 | 无码乱肉视频免费大全合集 | 综合激情五月综合激情五月激情1 | 国内精品久久久久久中文字幕 | 久久人人爽人人人人片 | 天堂无码人妻精品一区二区三区 | 99久久人妻精品免费一区 | 久久99精品国产.久久久久 | 亚洲狠狠色丁香婷婷综合 | 无码纯肉视频在线观看 | 免费无码一区二区三区蜜桃大 | 丰满少妇女裸体bbw | 亚洲の无码国产の无码步美 | 国产偷国产偷精品高清尤物 | 成 人影片 免费观看 | 一个人免费观看的www视频 | 精品夜夜澡人妻无码av蜜桃 | 亚洲人亚洲人成电影网站色 | 成年女人永久免费看片 | 少妇一晚三次一区二区三区 | 久久精品国产大片免费观看 | 天天综合网天天综合色 | 无码人妻黑人中文字幕 | 国产在线无码精品电影网 | 日韩精品无码一本二本三本色 | 中国大陆精品视频xxxx | 窝窝午夜理论片影院 | 少妇性荡欲午夜性开放视频剧场 | 国产香蕉尹人综合在线观看 | 亚洲中文字幕av在天堂 | 丰满人妻翻云覆雨呻吟视频 | 无遮挡啪啪摇乳动态图 | 国产午夜亚洲精品不卡 | 国内老熟妇对白xxxxhd | 九月婷婷人人澡人人添人人爽 | 亚洲国产日韩a在线播放 | 国产农村乱对白刺激视频 | 男人和女人高潮免费网站 | 内射后入在线观看一区 | 日韩av无码一区二区三区不卡 | 亚洲国产一区二区三区在线观看 | 丰满妇女强制高潮18xxxx | 亚洲 日韩 欧美 成人 在线观看 | 一本色道婷婷久久欧美 | 国精品人妻无码一区二区三区蜜柚 | 国产精品国产三级国产专播 | 日日摸天天摸爽爽狠狠97 | 国产片av国语在线观看 | 久久午夜无码鲁丝片秋霞 | 日日碰狠狠躁久久躁蜜桃 | 久久99热只有频精品8 | 四十如虎的丰满熟妇啪啪 | 国产免费观看黄av片 | 亚洲人亚洲人成电影网站色 | 日本高清一区免费中文视频 | 久久国产精品二国产精品 | 美女黄网站人色视频免费国产 | 在教室伦流澡到高潮hnp视频 | 欧美熟妇另类久久久久久多毛 | 欧美激情内射喷水高潮 | 日本一区二区三区免费高清 | 无码av最新清无码专区吞精 | 乱码午夜-极国产极内射 | 初尝人妻少妇中文字幕 | 99久久精品无码一区二区毛片 | 十八禁视频网站在线观看 | 综合激情五月综合激情五月激情1 | 黄网在线观看免费网站 | а天堂中文在线官网 | 亚洲热妇无码av在线播放 | 99视频精品全部免费免费观看 | 日韩少妇内射免费播放 | 欧美一区二区三区视频在线观看 | 麻豆蜜桃av蜜臀av色欲av | 久久久久久av无码免费看大片 | 狠狠色丁香久久婷婷综合五月 | 丰满少妇弄高潮了www | 中文无码伦av中文字幕 | 中文字幕无码日韩欧毛 | 99久久久国产精品无码免费 | 偷窥村妇洗澡毛毛多 | 人人妻人人澡人人爽欧美精品 | 亚洲va中文字幕无码久久不卡 | 日韩人妻无码一区二区三区久久99 | 欧美喷潮久久久xxxxx | 国产亚洲精品精品国产亚洲综合 | 精品少妇爆乳无码av无码专区 | 大乳丰满人妻中文字幕日本 | 久久99久久99精品中文字幕 | 西西人体www44rt大胆高清 | 国产在线aaa片一区二区99 | 狂野欧美激情性xxxx | 精品无码一区二区三区爱欲 | 5858s亚洲色大成网站www | 中文字幕人成乱码熟女app | 国产午夜亚洲精品不卡下载 | 99久久精品无码一区二区毛片 | 国产人妻精品一区二区三区 | 免费看男女做好爽好硬视频 | 成人无码精品一区二区三区 | 欧美三级不卡在线观看 | 中文字幕精品av一区二区五区 | 曰韩少妇内射免费播放 | 国产超碰人人爽人人做人人添 | 日本熟妇人妻xxxxx人hd | 日本一卡2卡3卡四卡精品网站 | 国产熟女一区二区三区四区五区 | 少妇高潮喷潮久久久影院 | 人妻少妇被猛烈进入中文字幕 | 色综合久久网 | 亚洲国精产品一二二线 | 欧美第一黄网免费网站 | 双乳奶水饱满少妇呻吟 | 男女爱爱好爽视频免费看 | 久久综合网欧美色妞网 | 免费视频欧美无人区码 | 欧美性猛交内射兽交老熟妇 | 在线a亚洲视频播放在线观看 | 久久精品女人的天堂av | 一区二区传媒有限公司 | 久久综合九色综合欧美狠狠 | 一个人看的www免费视频在线观看 | 日韩人妻系列无码专区 | 樱花草在线播放免费中文 | 亚洲人交乣女bbw | 九九热爱视频精品 | 99久久99久久免费精品蜜桃 | 国产精品久久久久影院嫩草 | 亚无码乱人伦一区二区 | 日日摸天天摸爽爽狠狠97 | 亚洲欧美国产精品专区久久 | 久久综合九色综合欧美狠狠 | 日韩人妻少妇一区二区三区 | 久久久国产一区二区三区 | 国产激情无码一区二区 | 丰满少妇弄高潮了www | 人人妻人人澡人人爽人人精品浪潮 | 久久精品国产一区二区三区 | 欧美一区二区三区视频在线观看 | 久久国产自偷自偷免费一区调 | 丁香花在线影院观看在线播放 | 欧洲vodafone精品性 | 午夜精品一区二区三区的区别 | 亚洲精品欧美二区三区中文字幕 | 国产在线aaa片一区二区99 | 国内精品九九久久久精品 | 中文字幕+乱码+中文字幕一区 | 特大黑人娇小亚洲女 | 国产成人精品视频ⅴa片软件竹菊 | 青青青手机频在线观看 | 中文字幕人成乱码熟女app | 日韩av无码一区二区三区 | 久久天天躁夜夜躁狠狠 | 学生妹亚洲一区二区 | 最近中文2019字幕第二页 | 欧美人与动性行为视频 | 国产无套粉嫩白浆在线 | 清纯唯美经典一区二区 | 国产三级精品三级男人的天堂 | 成 人影片 免费观看 | 亚洲天堂2017无码 | 亚洲自偷精品视频自拍 | 国产精品鲁鲁鲁 | 国产两女互慰高潮视频在线观看 | 爆乳一区二区三区无码 | 国产特级毛片aaaaaaa高清 | 永久免费观看国产裸体美女 | 欧美激情一区二区三区成人 | 国产免费久久精品国产传媒 | 亚洲午夜福利在线观看 | 秋霞成人午夜鲁丝一区二区三区 | 欧美日韩在线亚洲综合国产人 | 一本色道久久综合亚洲精品不卡 | 综合人妻久久一区二区精品 | 一个人看的www免费视频在线观看 | 久久这里只有精品视频9 | 国产香蕉尹人综合在线观看 | 巨爆乳无码视频在线观看 | 久久久久国色av免费观看性色 | 精品少妇爆乳无码av无码专区 | 国产精品va在线播放 | 少女韩国电视剧在线观看完整 | 强辱丰满人妻hd中文字幕 | 午夜免费福利小电影 | 久久久久久国产精品无码下载 | 亚洲人亚洲人成电影网站色 | 无遮挡啪啪摇乳动态图 | 亚洲日韩中文字幕在线播放 | 亚洲码国产精品高潮在线 | 国产av一区二区三区最新精品 | 清纯唯美经典一区二区 | 久久久久亚洲精品中文字幕 | 伊人久久大香线焦av综合影院 | 国产免费久久久久久无码 | 300部国产真实乱 | 亚洲精品成a人在线观看 | 精品久久久久久人妻无码中文字幕 | 亚洲人成影院在线无码按摩店 | 国产激情综合五月久久 | 一本色道久久综合狠狠躁 | 日本一区二区三区免费播放 | 人妻体内射精一区二区三四 | 黄网在线观看免费网站 | 亚洲国产午夜精品理论片 | 毛片内射-百度 | 欧美高清在线精品一区 | 色一情一乱一伦一区二区三欧美 | 久久久成人毛片无码 | 亚洲精品国产第一综合99久久 | 午夜嘿嘿嘿影院 | 97久久国产亚洲精品超碰热 | 国产精品亚洲综合色区韩国 | 国产偷国产偷精品高清尤物 | 国内揄拍国内精品人妻 | 天堂а√在线地址中文在线 | 在线视频网站www色 | 国产精品a成v人在线播放 | 国产疯狂伦交大片 | 亚洲日本在线电影 | 亚洲精品一区三区三区在线观看 | √天堂资源地址中文在线 | 玩弄人妻少妇500系列视频 | 熟女体下毛毛黑森林 | 久久精品一区二区三区四区 | 台湾无码一区二区 | 国产精品久免费的黄网站 | 国产莉萝无码av在线播放 | 日韩人妻少妇一区二区三区 | 国产麻豆精品精东影业av网站 | 给我免费的视频在线观看 | 樱花草在线社区www | 色欲久久久天天天综合网精品 | 国产农村乱对白刺激视频 | 久久视频在线观看精品 | 欧美日本日韩 | 无码av最新清无码专区吞精 | 国产午夜无码精品免费看 | 国产精品久久久久久无码 | 搡女人真爽免费视频大全 | 中国女人内谢69xxxxxa片 | 亚洲aⅴ无码成人网站国产app | 国产精品福利视频导航 | 国产超级va在线观看视频 | 久久综合狠狠综合久久综合88 | 性色av无码免费一区二区三区 | 国产精品人人妻人人爽 | 亚洲成av人综合在线观看 | 成人aaa片一区国产精品 | 国产综合色产在线精品 | 天堂久久天堂av色综合 | 国产人妻精品一区二区三区 | 无套内谢的新婚少妇国语播放 | 老子影院午夜伦不卡 | 亚洲日韩一区二区三区 | 青草视频在线播放 | 国产成人精品久久亚洲高清不卡 | 动漫av一区二区在线观看 | 国产精品无码一区二区桃花视频 | 久久久av男人的天堂 | 日本乱偷人妻中文字幕 | 欧美猛少妇色xxxxx | 日本精品高清一区二区 | 国产真实夫妇视频 | 久久精品人人做人人综合试看 | 未满成年国产在线观看 | 男女爱爱好爽视频免费看 | 黑森林福利视频导航 | 在线播放无码字幕亚洲 | 日韩欧美中文字幕在线三区 | 98国产精品综合一区二区三区 | 欧美黑人乱大交 | 亚洲欧美精品aaaaaa片 | 麻豆国产人妻欲求不满 | 国产热a欧美热a在线视频 | 国产在线一区二区三区四区五区 | 精品国产一区二区三区av 性色 | 色综合久久久久综合一本到桃花网 | 色婷婷av一区二区三区之红樱桃 | 欧美老妇与禽交 | 天天躁夜夜躁狠狠是什么心态 | 性啪啪chinese东北女人 | 国内揄拍国内精品少妇国语 | 亚洲精品一区二区三区在线 | 国产综合色产在线精品 | 人人妻人人澡人人爽精品欧美 | 国产一区二区三区影院 | 欧美日韩精品 | 小鲜肉自慰网站xnxx | 人妻aⅴ无码一区二区三区 | 伊人色综合久久天天小片 | 蜜桃臀无码内射一区二区三区 | 亚洲成a人片在线观看无码 | 欧美国产亚洲日韩在线二区 | 漂亮人妻洗澡被公强 日日躁 | 97久久超碰中文字幕 | 婷婷丁香六月激情综合啪 | 99久久精品日本一区二区免费 | 色欲久久久天天天综合网精品 | 免费人成在线视频无码 | 老太婆性杂交欧美肥老太 | 色婷婷av一区二区三区之红樱桃 | 亚洲色无码一区二区三区 | 少妇邻居内射在线 | 日本精品高清一区二区 | 亚洲午夜久久久影院 | 久久午夜夜伦鲁鲁片无码免费 | 中文字幕人成乱码熟女app | 内射爽无广熟女亚洲 | 精品国偷自产在线 | 午夜熟女插插xx免费视频 | 亚洲成a人片在线观看无码3d | 自拍偷自拍亚洲精品10p | 一个人免费观看的www视频 | 国产舌乚八伦偷品w中 | 日本熟妇人妻xxxxx人hd | 4hu四虎永久在线观看 | 国产成人一区二区三区别 | 国产精品亚洲五月天高清 | 国产亚洲精品久久久闺蜜 | 免费无码肉片在线观看 | 内射爽无广熟女亚洲 | 小sao货水好多真紧h无码视频 | 国产精品无码一区二区桃花视频 | 性欧美牲交在线视频 | 精品人妻av区 | 精品无码成人片一区二区98 | 久久久久se色偷偷亚洲精品av | 国产成人无码一二三区视频 | 亚洲人成网站免费播放 | av无码不卡在线观看免费 | 久久精品人人做人人综合 | av无码不卡在线观看免费 | 精品久久久久久亚洲精品 | 国产又粗又硬又大爽黄老大爷视 | 伊在人天堂亚洲香蕉精品区 | 偷窥日本少妇撒尿chinese | 在线看片无码永久免费视频 | 久久国产自偷自偷免费一区调 | 亚洲大尺度无码无码专区 | 久久亚洲中文字幕精品一区 | 两性色午夜视频免费播放 | 88国产精品欧美一区二区三区 | 无码帝国www无码专区色综合 | 国产精品无码永久免费888 | 久久天天躁狠狠躁夜夜免费观看 | 久久精品无码一区二区三区 | 日韩人妻无码一区二区三区久久99 | 国产美女极度色诱视频www | 特级做a爰片毛片免费69 | 国产疯狂伦交大片 | 亚洲日韩av片在线观看 | 国产偷自视频区视频 | 男人扒开女人内裤强吻桶进去 | 精品日本一区二区三区在线观看 | 成在人线av无码免观看麻豆 | 国产乱码精品一品二品 | 国产成人无码一二三区视频 | 国产 精品 自在自线 | 国产av一区二区三区最新精品 | 中文毛片无遮挡高清免费 | 国产午夜手机精彩视频 | 国产无遮挡又黄又爽免费视频 | av无码电影一区二区三区 | 国产一区二区三区影院 | 伊人久久婷婷五月综合97色 | 欧美日韩亚洲国产精品 | 国产乱人无码伦av在线a | 夜夜影院未满十八勿进 | av小次郎收藏 | 在线播放无码字幕亚洲 | 国产精品毛多多水多 | 久久午夜无码鲁丝片秋霞 | 77777熟女视频在线观看 а天堂中文在线官网 | 国内精品一区二区三区不卡 | 红桃av一区二区三区在线无码av | 伊在人天堂亚洲香蕉精品区 | 国产av人人夜夜澡人人爽麻豆 | 国内揄拍国内精品少妇国语 | 国产在热线精品视频 | 久久 国产 尿 小便 嘘嘘 | 精品无码国产自产拍在线观看蜜 | 大乳丰满人妻中文字幕日本 | 欧美成人家庭影院 | 精品亚洲成av人在线观看 | 99精品久久毛片a片 | 少妇无套内谢久久久久 | 欧美日韩一区二区免费视频 | 麻豆果冻传媒2021精品传媒一区下载 | 蜜桃视频插满18在线观看 | 国产精品-区区久久久狼 | 最近的中文字幕在线看视频 | 永久免费观看美女裸体的网站 | 精品一区二区三区无码免费视频 | 丰满护士巨好爽好大乳 | 无码人妻久久一区二区三区不卡 | 性啪啪chinese东北女人 | 国产凸凹视频一区二区 | 久久综合给合久久狠狠狠97色 | 久青草影院在线观看国产 | 久久亚洲国产成人精品性色 | 午夜丰满少妇性开放视频 | 国产97人人超碰caoprom | 亚洲人成无码网www | 激情内射日本一区二区三区 | 久在线观看福利视频 | 领导边摸边吃奶边做爽在线观看 | 午夜性刺激在线视频免费 | 日本大乳高潮视频在线观看 | 熟女少妇在线视频播放 | 乱人伦中文视频在线观看 | 超碰97人人做人人爱少妇 | aⅴ亚洲 日韩 色 图网站 播放 | √天堂资源地址中文在线 | 国产小呦泬泬99精品 | 男人扒开女人内裤强吻桶进去 | 欧美freesex黑人又粗又大 | 撕开奶罩揉吮奶头视频 | 亚洲七七久久桃花影院 | 未满成年国产在线观看 | 老子影院午夜伦不卡 | 天堂一区人妻无码 | 久久久久人妻一区精品色欧美 | 国产人妻人伦精品1国产丝袜 | 俺去俺来也www色官网 | 一个人看的www免费视频在线观看 | 麻豆md0077饥渴少妇 | 亚欧洲精品在线视频免费观看 | 欧美精品无码一区二区三区 | 丰满妇女强制高潮18xxxx | 国产亚洲精品久久久久久久 | 76少妇精品导航 | 性色欲网站人妻丰满中文久久不卡 | 大屁股大乳丰满人妻 | 性欧美牲交xxxxx视频 | 奇米影视7777久久精品人人爽 | 国产乱人伦av在线无码 | 亚洲国产精品无码久久久久高潮 | 国产又爽又猛又粗的视频a片 | 欧美一区二区三区视频在线观看 | 国产精品久久久久久久影院 | 久精品国产欧美亚洲色aⅴ大片 | 久久精品丝袜高跟鞋 | 日本乱人伦片中文三区 | 国産精品久久久久久久 | 任你躁在线精品免费 | 动漫av一区二区在线观看 | 人人妻人人澡人人爽欧美一区 | 人妻少妇精品无码专区动漫 | 久久精品一区二区三区四区 | 香蕉久久久久久av成人 | 久久久久成人片免费观看蜜芽 | 蜜桃臀无码内射一区二区三区 | 亚洲 a v无 码免 费 成 人 a v | 人妻熟女一区 | 任你躁国产自任一区二区三区 | 国产亚洲视频中文字幕97精品 | 国产精品高潮呻吟av久久 | 少妇的肉体aa片免费 | 性欧美牲交xxxxx视频 | 在线精品国产一区二区三区 | 中文字幕人妻丝袜二区 | av人摸人人人澡人人超碰下载 | 亚洲阿v天堂在线 | 久久久久成人片免费观看蜜芽 | 亚洲熟妇色xxxxx亚洲 | 国产人妻人伦精品1国产丝袜 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 久久国产精品偷任你爽任你 | 久久精品国产一区二区三区 | 国产精品内射视频免费 | 成人试看120秒体验区 | 精品aⅴ一区二区三区 | 国产偷国产偷精品高清尤物 | 草草网站影院白丝内射 | 成人精品一区二区三区中文字幕 | 日韩少妇内射免费播放 | 久久综合狠狠综合久久综合88 | 乱码av麻豆丝袜熟女系列 | 久久国产精品精品国产色婷婷 | 波多野42部无码喷潮在线 | 又湿又紧又大又爽a视频国产 | 精品亚洲韩国一区二区三区 | 国产又爽又黄又刺激的视频 | 亚洲精品久久久久avwww潮水 | 午夜福利试看120秒体验区 | 精品国产一区二区三区四区 | 精品夜夜澡人妻无码av蜜桃 | 午夜无码人妻av大片色欲 | 精品 日韩 国产 欧美 视频 | 最近中文2019字幕第二页 | 大色综合色综合网站 | 乱中年女人伦av三区 | 人人妻人人澡人人爽欧美一区九九 | 永久免费观看美女裸体的网站 | 在线成人www免费观看视频 | 人人妻人人澡人人爽精品欧美 | 爆乳一区二区三区无码 | 97久久精品无码一区二区 | 999久久久国产精品消防器材 | 一本久久a久久精品亚洲 | 人妻aⅴ无码一区二区三区 | 欧美 日韩 亚洲 在线 | 最近的中文字幕在线看视频 | 亚洲精品一区三区三区在线观看 | 日本爽爽爽爽爽爽在线观看免 | 少妇被粗大的猛进出69影院 | 国产精品人人爽人人做我的可爱 | 亚洲综合无码一区二区三区 | 综合激情五月综合激情五月激情1 | 国内精品人妻无码久久久影院 | 日韩人妻无码中文字幕视频 | 黑人粗大猛烈进出高潮视频 | 久久99精品国产.久久久久 | 亚洲国产高清在线观看视频 | 亚洲成熟女人毛毛耸耸多 | 欧美真人作爱免费视频 | 亚洲欧美日韩成人高清在线一区 | 中文字幕日韩精品一区二区三区 | 国产婷婷色一区二区三区在线 | 中文字幕无码乱人伦 | 久久久久久a亚洲欧洲av冫 | 色婷婷久久一区二区三区麻豆 | 亚洲大尺度无码无码专区 | 99久久久无码国产aaa精品 | 久久人人爽人人爽人人片av高清 | 人妻尝试又大又粗久久 | 精品久久久久久亚洲精品 | 国产精品第一国产精品 | 国产欧美精品一区二区三区 | 亚洲中文字幕乱码av波多ji | 永久免费观看美女裸体的网站 | 精品无码成人片一区二区98 | 久久国产精品_国产精品 | 国产免费久久久久久无码 | 亚洲男女内射在线播放 | 97se亚洲精品一区 | 国产内射爽爽大片视频社区在线 | av无码电影一区二区三区 | 粉嫩少妇内射浓精videos | 欧美国产日韩久久mv | 永久免费精品精品永久-夜色 | 亚洲一区二区三区四区 | 久久精品中文字幕一区 | 日韩欧美成人免费观看 | 久久人人97超碰a片精品 | 男女下面进入的视频免费午夜 | 亚洲欧洲中文日韩av乱码 | 在线а√天堂中文官网 | 国产成人精品一区二区在线小狼 | 国产亚洲人成a在线v网站 | 欧美国产亚洲日韩在线二区 | 美女黄网站人色视频免费国产 | 久久精品国产日本波多野结衣 | 色综合视频一区二区三区 | 在线亚洲高清揄拍自拍一品区 | 久久久久久亚洲精品a片成人 | 狠狠噜狠狠狠狠丁香五月 | 日产精品99久久久久久 | 亚洲欧美日韩综合久久久 | 77777熟女视频在线观看 а天堂中文在线官网 | 国内精品人妻无码久久久影院蜜桃 | 亚洲呦女专区 | 久久久久久久人妻无码中文字幕爆 | 久久精品人人做人人综合试看 | 无码人妻丰满熟妇区五十路百度 | 扒开双腿疯狂进出爽爽爽视频 | 亚洲欧美日韩综合久久久 | 亚洲欧美国产精品专区久久 | 国产九九九九九九九a片 | 亚洲人成影院在线观看 | 国产精品99爱免费视频 | 图片区 小说区 区 亚洲五月 | 任你躁在线精品免费 | 亚洲精品鲁一鲁一区二区三区 | 3d动漫精品啪啪一区二区中 | 日本高清一区免费中文视频 | 精品偷自拍另类在线观看 | 日日摸日日碰夜夜爽av | 天天躁日日躁狠狠躁免费麻豆 | 夜夜躁日日躁狠狠久久av | 无码国产激情在线观看 | 麻豆人妻少妇精品无码专区 | v一区无码内射国产 | 欧美丰满少妇xxxx性 | 人妻体内射精一区二区三四 | 国内精品人妻无码久久久影院蜜桃 | 国产三级精品三级男人的天堂 | 日本护士毛茸茸高潮 | 国内揄拍国内精品人妻 | 国产乱人无码伦av在线a | 亚洲熟妇自偷自拍另类 | 欧美成人免费全部网站 | 亚洲伊人久久精品影院 | 久久综合狠狠综合久久综合88 | 国产婷婷色一区二区三区在线 | 精品国产国产综合精品 | 国产无遮挡又黄又爽又色 | 99精品无人区乱码1区2区3区 | 亚洲熟悉妇女xxx妇女av | 日日天日日夜日日摸 | 欧美xxxx黑人又粗又长 | 丝袜美腿亚洲一区二区 | 亚洲国产成人a精品不卡在线 | 狠狠躁日日躁夜夜躁2020 | 无码av岛国片在线播放 | 青青青手机频在线观看 | 国产偷抇久久精品a片69 | 无码精品国产va在线观看dvd | 亚洲精品无码人妻无码 | 久久综合九色综合欧美狠狠 | 青青青爽视频在线观看 | 粗大的内捧猛烈进出视频 | 无码人妻少妇伦在线电影 | 国产偷国产偷精品高清尤物 | 欧美成人家庭影院 | 人妻少妇精品视频专区 | 老司机亚洲精品影院无码 | 蜜臀av无码人妻精品 | 亚洲成av人片天堂网无码】 | 精品一区二区三区无码免费视频 | 午夜无码人妻av大片色欲 | 欧洲熟妇色 欧美 | 欧美人妻一区二区三区 | 2019午夜福利不卡片在线 | 国产人妻精品午夜福利免费 | 爱做久久久久久 | 国产成人一区二区三区别 | 国产香蕉97碰碰久久人人 | 国产小呦泬泬99精品 | 自拍偷自拍亚洲精品被多人伦好爽 | 高清国产亚洲精品自在久久 | 久久国产精品二国产精品 | 天天躁夜夜躁狠狠是什么心态 | 清纯唯美经典一区二区 | 真人与拘做受免费视频 | 国产 浪潮av性色四虎 | 国产成人一区二区三区在线观看 | 亚洲一区二区三区播放 | 初尝人妻少妇中文字幕 | 亚洲国产午夜精品理论片 | 午夜福利试看120秒体验区 | 日韩人妻少妇一区二区三区 | 日韩亚洲欧美中文高清在线 | 51国偷自产一区二区三区 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 久久午夜无码鲁丝片 | 亚洲熟女一区二区三区 | 黑人玩弄人妻中文在线 | 国产精华av午夜在线观看 | 在线精品国产一区二区三区 | 精品偷自拍另类在线观看 | 成人亚洲精品久久久久软件 | 少妇人妻av毛片在线看 | 一本久久a久久精品亚洲 | 亚洲日韩乱码中文无码蜜桃臀网站 | 欧美真人作爱免费视频 | 天天摸天天透天天添 | 中文字幕无码视频专区 | 无人区乱码一区二区三区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 精品国精品国产自在久国产87 | 国内精品一区二区三区不卡 | 欧美xxxx黑人又粗又长 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 亚洲欧美日韩综合久久久 | 男人和女人高潮免费网站 | 亚洲精品无码国产 | 奇米影视888欧美在线观看 | 亚洲日本va中文字幕 | 欧美国产日韩亚洲中文 | 亚洲欧洲日本综合aⅴ在线 | 久久久久久av无码免费看大片 | 亚洲综合无码久久精品综合 | 亚洲精品一区二区三区在线观看 | 在线播放免费人成毛片乱码 | 强伦人妻一区二区三区视频18 | 天堂在线观看www | 人人澡人人透人人爽 | 97夜夜澡人人爽人人喊中国片 | 在线天堂新版最新版在线8 | 精品国产av色一区二区深夜久久 | 国产午夜手机精彩视频 | 欧美黑人性暴力猛交喷水 | 国产亲子乱弄免费视频 | 久久精品女人天堂av免费观看 | 国产一精品一av一免费 | 日韩av激情在线观看 | 四虎国产精品一区二区 | 丝袜足控一区二区三区 | aⅴ在线视频男人的天堂 | 亚洲精品美女久久久久久久 | 久久久久免费精品国产 | 久激情内射婷内射蜜桃人妖 | 日本丰满护士爆乳xxxx | 97久久超碰中文字幕 | 国产精品久久精品三级 | 国产人妖乱国产精品人妖 | 亚洲精品一区二区三区四区五区 | 三上悠亚人妻中文字幕在线 | 国产亚洲精品久久久久久 | 亚洲一区二区观看播放 | 久久综合色之久久综合 | 久久精品人人做人人综合 | 亚洲国精产品一二二线 | 疯狂三人交性欧美 | 久久天天躁狠狠躁夜夜免费观看 | 欧美精品国产综合久久 | 欧美猛少妇色xxxxx | 在线观看免费人成视频 | 99精品国产综合久久久久五月天 | а√资源新版在线天堂 | 一本精品99久久精品77 | 欧美熟妇另类久久久久久不卡 | 高清无码午夜福利视频 | 九一九色国产 | 国产成人无码av片在线观看不卡 | 极品嫩模高潮叫床 | 亚洲欧美综合区丁香五月小说 | 亚洲人亚洲人成电影网站色 | 红桃av一区二区三区在线无码av | 九九热爱视频精品 | 中文字幕色婷婷在线视频 | 午夜时刻免费入口 | 激情爆乳一区二区三区 | 在线 国产 欧美 亚洲 天堂 | 荫蒂被男人添的好舒服爽免费视频 | 亚洲精品中文字幕 | 国产在线精品一区二区高清不卡 | 免费观看激色视频网站 | 无码人妻丰满熟妇区五十路百度 | 人妻aⅴ无码一区二区三区 | 欧美丰满熟妇xxxx | 欧洲美熟女乱又伦 | 六月丁香婷婷色狠狠久久 | 亚洲小说图区综合在线 | 久久久婷婷五月亚洲97号色 | 狂野欧美性猛交免费视频 | 最新国产乱人伦偷精品免费网站 | 少妇被黑人到高潮喷出白浆 | 天堂久久天堂av色综合 | 亚洲一区二区三区在线观看网站 | 欧美激情内射喷水高潮 | 欧美激情一区二区三区成人 | 熟妇女人妻丰满少妇中文字幕 | 久久伊人色av天堂九九小黄鸭 | 中文字幕人妻无码一夲道 | 久久国语露脸国产精品电影 | 无码吃奶揉捏奶头高潮视频 | 激情内射亚州一区二区三区爱妻 | 精品久久久无码中文字幕 | 国产成人综合色在线观看网站 | 老头边吃奶边弄进去呻吟 | 国产成人无码午夜视频在线观看 | 中文久久乱码一区二区 | 免费中文字幕日韩欧美 | 国产午夜福利亚洲第一 | 日日摸日日碰夜夜爽av | 久久久www成人免费毛片 | 亚洲娇小与黑人巨大交 | 女人和拘做爰正片视频 | 欧美日本精品一区二区三区 | 久久国产劲爆∧v内射 | 国产极品美女高潮无套在线观看 | 国内揄拍国内精品少妇国语 | 一本久道久久综合婷婷五月 | 少妇无套内谢久久久久 | 日本饥渴人妻欲求不满 | 中文字幕乱码人妻无码久久 | 国产福利视频一区二区 | 欧美日本精品一区二区三区 | 亚洲а∨天堂久久精品2021 | 人妻与老人中文字幕 | 久久综合激激的五月天 | 国产特级毛片aaaaaaa高清 | 亚洲国产精品无码一区二区三区 | 日本精品人妻无码77777 天堂一区人妻无码 | 久久久中文字幕日本无吗 | 久久久久av无码免费网 | 日本成熟视频免费视频 | 东京无码熟妇人妻av在线网址 | 久久久成人毛片无码 | 国产熟妇另类久久久久 | 夜夜高潮次次欢爽av女 | 精品久久久久久人妻无码中文字幕 | 色妞www精品免费视频 | 亚洲精品综合一区二区三区在线 | 亚洲日韩一区二区三区 | 亚洲欧洲无卡二区视頻 | 欧美精品国产综合久久 | 精品久久久无码人妻字幂 | 性生交片免费无码看人 | 真人与拘做受免费视频一 | 日韩成人一区二区三区在线观看 | 国产色视频一区二区三区 | a国产一区二区免费入口 | 国内精品久久毛片一区二区 | 最新国产麻豆aⅴ精品无码 | 国产精品久久久久久无码 | 亚洲国产精品无码一区二区三区 | 亚洲啪av永久无码精品放毛片 | 国产精品无码永久免费888 | 欧美丰满少妇xxxx性 | 亚洲色无码一区二区三区 | 欧美国产亚洲日韩在线二区 | 欧美真人作爱免费视频 | 无码av最新清无码专区吞精 | 精品久久久无码中文字幕 | 国产无遮挡又黄又爽又色 | 东京一本一道一二三区 | 日本饥渴人妻欲求不满 | 丰满护士巨好爽好大乳 | 乱码午夜-极国产极内射 | 欧美黑人性暴力猛交喷水 | 国产成人精品视频ⅴa片软件竹菊 | 婷婷色婷婷开心五月四房播播 | 成人性做爰aaa片免费看 | 欧洲极品少妇 | 亚欧洲精品在线视频免费观看 | 亚洲中文字幕久久无码 | 亚洲の无码国产の无码步美 | 少妇久久久久久人妻无码 | 亚洲日韩av一区二区三区中文 | 熟女少妇在线视频播放 | 亚洲国产成人a精品不卡在线 | 亚洲一区二区三区国产精华液 | 麻豆成人精品国产免费 | 装睡被陌生人摸出水好爽 | 欧美一区二区三区视频在线观看 | 97色伦图片97综合影院 | 亚洲人成网站在线播放942 | 亚洲爆乳精品无码一区二区三区 | 精品国产一区av天美传媒 | 亚洲欧洲日本综合aⅴ在线 | 久久精品人妻少妇一区二区三区 | 亚洲综合色区中文字幕 | 亚洲综合久久一区二区 | 300部国产真实乱 | 亚洲另类伦春色综合小说 | www国产亚洲精品久久网站 | 日本精品人妻无码免费大全 | 东京热一精品无码av | 无码人妻丰满熟妇区五十路百度 | 帮老师解开蕾丝奶罩吸乳网站 | 白嫩日本少妇做爰 | 亚洲国产精品久久久天堂 | 亚洲日本va午夜在线电影 | 精品欧美一区二区三区久久久 | 荫蒂添的好舒服视频囗交 | 亚洲精品国产精品乱码不卡 | 国产成人精品三级麻豆 | 久久精品女人的天堂av | 99麻豆久久久国产精品免费 | 激情综合激情五月俺也去 | 永久免费观看美女裸体的网站 | 亚洲国产精品成人久久蜜臀 | √天堂资源地址中文在线 | 又大又紧又粉嫩18p少妇 | 国产午夜精品一区二区三区嫩草 | 丰满少妇女裸体bbw | 免费人成在线观看网站 | 国产麻豆精品一区二区三区v视界 | 亚洲无人区午夜福利码高清完整版 | 国产精品第一国产精品 | 曰韩无码二三区中文字幕 | 青青久在线视频免费观看 | 久激情内射婷内射蜜桃人妖 | 暴力强奷在线播放无码 | 男女下面进入的视频免费午夜 | 纯爱无遮挡h肉动漫在线播放 | 欧美日韩在线亚洲综合国产人 | 精品人妻中文字幕有码在线 | 青青青爽视频在线观看 | 久久精品人人做人人综合 | 亚洲成a人片在线观看无码3d | 国产av人人夜夜澡人人爽麻豆 | 日本护士毛茸茸高潮 | 日本爽爽爽爽爽爽在线观看免 | 色婷婷综合激情综在线播放 | 99久久99久久免费精品蜜桃 | 亲嘴扒胸摸屁股激烈网站 | 亚洲小说春色综合另类 | 九九热爱视频精品 | 99国产精品白浆在线观看免费 | 久久99精品久久久久久动态图 | 国产在线精品一区二区高清不卡 | a国产一区二区免费入口 | 亚洲伊人久久精品影院 | 99久久久国产精品无码免费 | 亚洲 日韩 欧美 成人 在线观看 | 成 人影片 免费观看 | 亚洲中文字幕无码中文字在线 | 久久视频在线观看精品 | 色婷婷欧美在线播放内射 | 国产乱人偷精品人妻a片 | 亚洲va中文字幕无码久久不卡 | 小鲜肉自慰网站xnxx | 亚洲一区二区三区偷拍女厕 | 亚洲 高清 成人 动漫 | 亚洲中文字幕无码一久久区 | 欧美一区二区三区视频在线观看 | √8天堂资源地址中文在线 | 国产午夜福利100集发布 | 久久天天躁狠狠躁夜夜免费观看 | 日韩精品无码一本二本三本色 | 欧美兽交xxxx×视频 | 亚洲日韩乱码中文无码蜜桃臀网站 | 一区二区三区乱码在线 | 欧洲 | 一本久道久久综合婷婷五月 | 国产无套内射久久久国产 | 99er热精品视频 | 日本饥渴人妻欲求不满 | 国产人妻大战黑人第1集 | 伊在人天堂亚洲香蕉精品区 | 大色综合色综合网站 | 领导边摸边吃奶边做爽在线观看 | 国产精品鲁鲁鲁 | 女人色极品影院 | 欧美老熟妇乱xxxxx | 久热国产vs视频在线观看 | 露脸叫床粗话东北少妇 | 亚洲第一无码av无码专区 | 男女超爽视频免费播放 | 狠狠亚洲超碰狼人久久 | 成人精品视频一区二区三区尤物 | 精品无人国产偷自产在线 | 99麻豆久久久国产精品免费 | 人人澡人人透人人爽 | 国产精品欧美成人 | 中文字幕av日韩精品一区二区 | 日韩精品a片一区二区三区妖精 | 亚洲の无码国产の无码影院 | 九九热爱视频精品 | 精品国产乱码久久久久乱码 | 亚洲成a人片在线观看无码3d | 亚洲成av人影院在线观看 | 欧美大屁股xxxxhd黑色 | 美女毛片一区二区三区四区 | 青青久在线视频免费观看 | 丰满少妇熟乱xxxxx视频 | 人妻有码中文字幕在线 | 亚洲熟妇色xxxxx亚洲 | 大屁股大乳丰满人妻 | 午夜嘿嘿嘿影院 | 日本一卡二卡不卡视频查询 | 日本丰满熟妇videos | 日韩欧美成人免费观看 | 国产亚洲视频中文字幕97精品 | 人妻少妇精品视频专区 | 久久综合色之久久综合 | 国产精品爱久久久久久久 | 99久久人妻精品免费二区 | 色欲人妻aaaaaaa无码 | 男人的天堂av网站 | 乱人伦人妻中文字幕无码久久网 | 精品久久久久久亚洲精品 | 国产av一区二区三区最新精品 | 无码人中文字幕 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 在教室伦流澡到高潮hnp视频 | 伊人久久大香线蕉亚洲 | 久久99热只有频精品8 | 中文字幕无码日韩欧毛 | 亚洲精品欧美二区三区中文字幕 | 亚洲无人区一区二区三区 | 欧美第一黄网免费网站 | v一区无码内射国产 | 丝袜美腿亚洲一区二区 | 亚洲乱码日产精品bd | 天堂无码人妻精品一区二区三区 | 97资源共享在线视频 | 99精品国产综合久久久久五月天 | 一本无码人妻在中文字幕免费 | 亚洲中文字幕无码中字 | 精品人妻中文字幕有码在线 | 一本一道久久综合久久 | 国产综合久久久久鬼色 | 少妇高潮喷潮久久久影院 | 亚洲国产精品毛片av不卡在线 | 国产精品手机免费 | 久激情内射婷内射蜜桃人妖 | 国产亚洲日韩欧美另类第八页 | √8天堂资源地址中文在线 | 国产精品久久国产三级国 | 理论片87福利理论电影 | 久久午夜无码鲁丝片午夜精品 | 国产色精品久久人妻 | 国产亚洲视频中文字幕97精品 | 亚洲国产日韩a在线播放 | 三级4级全黄60分钟 | 人人澡人人妻人人爽人人蜜桃 | 东北女人啪啪对白 | 国产成人无码a区在线观看视频app | 97色伦图片97综合影院 | 亚洲爆乳精品无码一区二区三区 | 欧美日韩一区二区免费视频 | 国产9 9在线 | 中文 | 在线观看欧美一区二区三区 | 国产色在线 | 国产 | 两性色午夜视频免费播放 | 亚洲成av人综合在线观看 | √天堂资源地址中文在线 | 欧美一区二区三区视频在线观看 | 中文字幕日韩精品一区二区三区 | 久久伊人色av天堂九九小黄鸭 | 亚洲成色在线综合网站 | 亚洲成在人网站无码天堂 | 国产激情艳情在线看视频 | 成人无码视频免费播放 | 激情亚洲一区国产精品 | 天堂无码人妻精品一区二区三区 | 在线а√天堂中文官网 | 亚洲成熟女人毛毛耸耸多 | 国产精品va在线播放 | 日韩人妻无码一区二区三区久久99 | 玩弄人妻少妇500系列视频 | 欧美日韩一区二区免费视频 | 免费无码av一区二区 | 亚洲综合在线一区二区三区 | 国产凸凹视频一区二区 | 久久精品国产精品国产精品污 | 欧美人与善在线com | 少妇性荡欲午夜性开放视频剧场 | 精品成在人线av无码免费看 | 无人区乱码一区二区三区 | 丰满人妻翻云覆雨呻吟视频 | 色婷婷综合中文久久一本 | 波多野结衣aⅴ在线 | 好屌草这里只有精品 | 强辱丰满人妻hd中文字幕 | 国产综合久久久久鬼色 | 欧美熟妇另类久久久久久多毛 | 成人影院yy111111在线观看 | 欧美日韩视频无码一区二区三 | 老子影院午夜精品无码 | 亚洲精品久久久久久一区二区 | 97精品人妻一区二区三区香蕉 | 水蜜桃色314在线观看 | 国产成人精品视频ⅴa片软件竹菊 | 亚洲国产精品久久久久久 | 内射后入在线观看一区 | 人人澡人摸人人添 | 最近免费中文字幕中文高清百度 | 中文字幕无线码免费人妻 | 国产在线精品一区二区三区直播 | 人人超人人超碰超国产 | 国产乱子伦视频在线播放 | 日韩少妇内射免费播放 | 午夜成人1000部免费视频 | 曰本女人与公拘交酡免费视频 | 伊人久久大香线蕉午夜 | 色一情一乱一伦一区二区三欧美 | 国产精品久久久av久久久 | 亚洲欧美日韩国产精品一区二区 | 久久99精品久久久久久 | 天天躁日日躁狠狠躁免费麻豆 | 久久久久成人片免费观看蜜芽 | 亚洲中文字幕av在天堂 | 国产亚洲精品精品国产亚洲综合 | 激情内射亚州一区二区三区爱妻 | 国产网红无码精品视频 | 精品无码成人片一区二区98 | 少妇邻居内射在线 | 午夜熟女插插xx免费视频 | 无码人妻黑人中文字幕 | 丁香啪啪综合成人亚洲 | 亚洲乱码日产精品bd | 国内少妇偷人精品视频免费 | 亚洲国产成人a精品不卡在线 | 国产区女主播在线观看 | 国产极品美女高潮无套在线观看 | 色妞www精品免费视频 | 午夜福利电影 | √8天堂资源地址中文在线 | 免费国产成人高清在线观看网站 | 国产精品第一国产精品 | 成人动漫在线观看 | 日本又色又爽又黄的a片18禁 | 国产精品久久久久9999小说 | 精品久久久久久人妻无码中文字幕 | 一个人看的www免费视频在线观看 | 午夜精品一区二区三区的区别 | 午夜精品久久久久久久久 | 国产精品福利视频导航 | 久久人人97超碰a片精品 | 国产精品亚洲综合色区韩国 | 精品久久久中文字幕人妻 | 精品国产青草久久久久福利 | 久久www免费人成人片 | 久久99精品国产.久久久久 | 欧美怡红院免费全部视频 | 激情综合激情五月俺也去 | 亚洲爆乳大丰满无码专区 | 亚洲精品一区二区三区大桥未久 | 国精产品一区二区三区 | 色一情一乱一伦一区二区三欧美 | 久久久久国色av免费观看性色 | 国产无遮挡吃胸膜奶免费看 | 狠狠亚洲超碰狼人久久 | 国产午夜无码精品免费看 | 人妻无码久久精品人妻 | 免费观看又污又黄的网站 | 亚洲国产午夜精品理论片 | 亚洲啪av永久无码精品放毛片 | av无码久久久久不卡免费网站 | 久久精品国产99精品亚洲 | 欧美日韩一区二区三区自拍 | 亚洲国产av精品一区二区蜜芽 | 久久精品国产一区二区三区肥胖 | 欧美 日韩 人妻 高清 中文 | 国产特级毛片aaaaaaa高清 | 男女猛烈xx00免费视频试看 | 激情五月综合色婷婷一区二区 | 国产美女极度色诱视频www | 高潮毛片无遮挡高清免费视频 | 中文字幕乱码中文乱码51精品 | 少妇厨房愉情理9仑片视频 | av人摸人人人澡人人超碰下载 | 波多野结衣一区二区三区av免费 | 久久亚洲国产成人精品性色 | 婷婷丁香六月激情综合啪 | 成人性做爰aaa片免费看 | 老太婆性杂交欧美肥老太 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 久久国产36精品色熟妇 | 日本熟妇乱子伦xxxx | 午夜性刺激在线视频免费 | 精品亚洲韩国一区二区三区 | 任你躁在线精品免费 | 精品国偷自产在线视频 | 亚洲综合无码久久精品综合 | 女人被男人爽到呻吟的视频 | 国产成人午夜福利在线播放 | 国产精品无码成人午夜电影 | 国产乱人无码伦av在线a | 日韩精品乱码av一区二区 | 97精品国产97久久久久久免费 | 亚洲男女内射在线播放 | 麻豆md0077饥渴少妇 | 免费无码一区二区三区蜜桃大 | √8天堂资源地址中文在线 | 国产人妻大战黑人第1集 | 精品夜夜澡人妻无码av蜜桃 | 无码国产乱人伦偷精品视频 | 精品一二三区久久aaa片 | 久久综合久久自在自线精品自 | 亚洲乱亚洲乱妇50p | 久久久久亚洲精品男人的天堂 | 欧美日韩久久久精品a片 | 暴力强奷在线播放无码 | 俄罗斯老熟妇色xxxx | 天天av天天av天天透 | 亚洲精品美女久久久久久久 | 亚洲国产精品毛片av不卡在线 | 久久久久99精品国产片 | 国产av久久久久精东av | 国产成人精品必看 | 99国产欧美久久久精品 | 国产又粗又硬又大爽黄老大爷视 | 久久久久久av无码免费看大片 | 午夜福利不卡在线视频 | 色一情一乱一伦一视频免费看 | 欧美黑人乱大交 | 精品乱码久久久久久久 | www国产亚洲精品久久网站 | 欧美 丝袜 自拍 制服 另类 | 日韩精品无码一本二本三本色 | 日韩成人一区二区三区在线观看 | 国产成人av免费观看 | 暴力强奷在线播放无码 | 波多野结衣 黑人 | 日本一本二本三区免费 | 国产成人无码av在线影院 | 少妇性荡欲午夜性开放视频剧场 | 免费无码av一区二区 | 国产美女极度色诱视频www | 色一情一乱一伦一视频免费看 | 鲁鲁鲁爽爽爽在线视频观看 | 奇米影视888欧美在线观看 | 精品偷自拍另类在线观看 | 国产手机在线αⅴ片无码观看 | 久久精品中文字幕大胸 | 亚洲精品一区二区三区在线观看 | 亚洲精品一区二区三区四区五区 | 999久久久国产精品消防器材 | 成年美女黄网站色大免费全看 | 伊人久久大香线蕉午夜 | 人妻尝试又大又粗久久 | 宝宝好涨水快流出来免费视频 | 国产亚av手机在线观看 | 欧洲精品码一区二区三区免费看 | 日本一卡二卡不卡视频查询 | 日韩无码专区 | 日韩欧美中文字幕在线三区 | 国产精品va在线播放 | 欧美日韩色另类综合 | 无码人妻av免费一区二区三区 | 99久久精品午夜一区二区 | 免费无码av一区二区 | 性色av无码免费一区二区三区 | 激情内射日本一区二区三区 | 国产猛烈高潮尖叫视频免费 | 噜噜噜亚洲色成人网站 | 精品国产精品久久一区免费式 | 久久国产精品萌白酱免费 | 国产一区二区三区四区五区加勒比 | 无码av免费一区二区三区试看 | 狠狠cao日日穞夜夜穞av | 成人av无码一区二区三区 | 亚无码乱人伦一区二区 | 国产精品无码一区二区三区不卡 | 欧美日韩色另类综合 | 国产精品人人妻人人爽 | 久久国产自偷自偷免费一区调 | 中文字幕乱码亚洲无线三区 | 国产内射爽爽大片视频社区在线 | 亚洲精品国产品国语在线观看 | 国产真实乱对白精彩久久 | 亚洲成av人片在线观看无码不卡 | 高潮毛片无遮挡高清免费 | 国产精品成人av在线观看 | 欧美人与牲动交xxxx | 国产精品永久免费视频 | 99久久精品无码一区二区毛片 | 一本久久伊人热热精品中文字幕 | 在线亚洲高清揄拍自拍一品区 | 国产尤物精品视频 | 亚洲欧美中文字幕5发布 | 亚洲色欲色欲欲www在线 | 中文字幕亚洲情99在线 | 午夜精品一区二区三区在线观看 | 久久熟妇人妻午夜寂寞影院 | 日日天干夜夜狠狠爱 | 久久亚洲中文字幕精品一区 | 亚洲gv猛男gv无码男同 | 波多野结衣 黑人 | 性欧美牲交xxxxx视频 | 国产真实夫妇视频 | 免费乱码人妻系列无码专区 | 麻豆md0077饥渴少妇 | 久久久久久av无码免费看大片 | 99久久人妻精品免费二区 | 亚洲色偷偷偷综合网 | 国产一区二区三区四区五区加勒比 | 欧美日韩人成综合在线播放 | 久精品国产欧美亚洲色aⅴ大片 | 日本又色又爽又黄的a片18禁 | 少妇性荡欲午夜性开放视频剧场 | 国产黑色丝袜在线播放 | 无套内射视频囯产 | 久久99精品国产麻豆蜜芽 | а√天堂www在线天堂小说 | 欧美丰满熟妇xxxx | 日本一区二区更新不卡 | 成人影院yy111111在线观看 | 免费视频欧美无人区码 | 四虎4hu永久免费 | 无套内谢的新婚少妇国语播放 | 极品尤物被啪到呻吟喷水 | 成人精品天堂一区二区三区 | 欧美国产亚洲日韩在线二区 | 蜜臀av在线播放 久久综合激激的五月天 | 亚洲中文字幕在线无码一区二区 | 亚洲中文字幕成人无码 | 久久精品国产99精品亚洲 | 无码av免费一区二区三区试看 | 日本精品人妻无码免费大全 | 高清国产亚洲精品自在久久 | 国产成人精品优优av | 国产在线精品一区二区高清不卡 | 免费无码av一区二区 | 国产两女互慰高潮视频在线观看 | 中文字幕乱码中文乱码51精品 | 波多野结衣一区二区三区av免费 | 午夜福利不卡在线视频 | 欧美xxxxx精品 | 亚洲色www成人永久网址 | 亚洲男人av香蕉爽爽爽爽 | 国产尤物精品视频 | 精品一区二区三区波多野结衣 | 人人澡人摸人人添 | 99riav国产精品视频 | 99久久亚洲精品无码毛片 | 精品无码一区二区三区的天堂 | 日韩人妻无码一区二区三区久久99 | 无码乱肉视频免费大全合集 | 玩弄人妻少妇500系列视频 |