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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Spark详解(六):Spark集群资源调度算法原理

發(fā)布時間:2025/4/16 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spark详解(六):Spark集群资源调度算法原理 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1. 應(yīng)用程序之間

在Standalone模式下,Master提供里資源管理調(diào)度功能。在調(diào)度過程中,Master先啟動等待列表中應(yīng)用程序的Driver,這個Driver盡可能分散在集群的Worker節(jié)點上,然后根據(jù)集群的內(nèi)存和CPU使用情況,對等待運行的應(yīng)用程序進行資源分配。默認分配規(guī)則是有條件的FIFO,先分配的應(yīng)用程序會盡可能多的獲取滿足條件的資源,后分配的應(yīng)用程序只能在剩余資源中再次篩選。如果沒有合適資源的應(yīng)用程序只能等待。Master.scheduler方法如下:

private def schedule(): Unit = {if (state != RecoveryState.ALIVE) {return}// 隨機打亂Worker節(jié)點val shuffledAliveWorkers = Random.shuffle(workers.toSeq.filter(_.state == WorkerState.ALIVE))val numWorkersAlive = shuffledAliveWorkers.sizevar curPos = 0// 這是只對Standalone下的Cluster模式才生效,client模式Driver是在客戶端for (driver <- waitingDrivers.toList) { var launched = falsevar numWorkersVisited = 0while (numWorkersVisited < numWorkersAlive && !launched) {val worker = shuffledAliveWorkers(curPos)numWorkersVisited += 1if (worker.memoryFree >= driver.desc.mem && worker.coresFree >= driver.desc.cores) {launchDriver(worker, driver)waitingDrivers -= driverlaunched = true}curPos = (curPos + 1) % numWorkersAlive}}// 對等待應(yīng)用程序按照順序分配運行資源startExecutorsOnWorkers()}

默認情況下,在Standalone模式下,每個應(yīng)用程序可以分配到的CPU核數(shù)可以由spark.deploy.defaultCores進行設(shè)置,但是該配置默認為Int.max,也就是不限制,從而應(yīng)用程序會盡可能獲取CPU資源。為了限制每個應(yīng)用程序使用CPU資源,用戶一方面可以設(shè)置spark.core.max配置項,約束每個應(yīng)用程序所能申請的最大CPU核數(shù);另一方面可以設(shè)置spark.executor.cores配置項,用于設(shè)置在每個Executor上啟動的CPU核數(shù)。

/*** Schedule and launch executors on workers*/private def startExecutorsOnWorkers(): Unit = {// Right now this is a very simple FIFO scheduler. We keep trying to fit in the first app// in the queue, then the second app, etc.// 使用FIFO算法運行應(yīng)用,即先注冊的應(yīng)用先運行for (app <- waitingApps if app.coresLeft > 0) {val coresPerExecutor: Option[Int] = app.desc.coresPerExecutor// Filter out workers that don't have enough resources to launch an executorval usableWorkers = workers.toArray.filter(_.state == WorkerState.ALIVE).filter(worker => worker.memoryFree >= app.desc.memoryPerExecutorMB &&worker.coresFree >= coresPerExecutor.getOrElse(1)).sortBy(_.coresFree).reverse// 一種是spreadOutApps,就是把應(yīng)用運行在盡量多的Worker上,另一種是非spreadOutAppsval assignedCores = scheduleExecutorsOnWorkers(app, usableWorkers, spreadOutApps)// Now that we've decided how many cores to allocate on each worker, let's allocate them// 給每個worker分配完application要求的cpu core之后,遍歷worker啟動executorfor (pos <- 0 until usableWorkers.length if assignedCores(pos) > 0) {allocateWorkerResourceToExecutors(app, assignedCores(pos), coresPerExecutor, usableWorkers(pos))}}}

對于Worker的分配策略有兩種:一種是盡量把應(yīng)用程序運行可能多的Worker上,這種分配算法不僅能充分利用集群資源,還有利于數(shù)據(jù)本地性;另一種就是應(yīng)用程序運行在盡量少的Worker上,這種適用于CPU密集型而內(nèi)存使用較少的場景。配置項為spark.deploy.spreadOut。主要代碼為:Master.scheduleExecutorsOnWorkers方法實現(xiàn)。

private def scheduleExecutorsOnWorkers(app: ApplicationInfo,usableWorkers: Array[WorkerInfo],spreadOutApps: Boolean): Array[Int] = {// 應(yīng)用程序中每個Executor所需要的CPU核數(shù)val coresPerExecutor = app.desc.coresPerExecutor// 每個Executor所需的最少核數(shù),如果設(shè)置了coresPerExecutor則為該值,否則為1val minCoresPerExecutor = coresPerExecutor.getOrElse(1)// 如果沒有設(shè)置coresPerExecutor,那么每個Worker上只有一個Executor,并盡可能分配資源val oneExecutorPerWorker = coresPerExecutor.isEmpty// 每個Executor需要分配多少內(nèi)存val memoryPerExecutor = app.desc.memoryPerExecutorMB// 集群中可用的Worker節(jié)點的數(shù)量val numUsable = usableWorkers.length// Worker節(jié)點所能提供的CPU核數(shù)數(shù)組val assignedCores = new Array[Int](numUsable) // Number of cores to give to each worker// Worker分配Executor個數(shù)數(shù)組val assignedExecutors = new Array[Int](numUsable) // Number of new executors on each worker// 需要分配的CPU核數(shù),為應(yīng)用程序所需CPU核數(shù)和可用CPU核數(shù)最小值var coresToAssign = math.min(app.coresLeft, usableWorkers.map(_.coresFree).sum)/** Return whether the specified worker can launch an executor for this app. *//*** 返回指定的Worker節(jié)點是否能夠啟動Executor,滿足條件:* 1. 應(yīng)用程序需要分配CPU核數(shù)>=每個Executor所需的最少CPU核數(shù)* 2. 是否有足夠的CPU核數(shù),判斷條件為該Worker節(jié)點可用CPU核數(shù)-該Worker節(jié)點已分配的CPU核數(shù)>=每個Executor所需最少CPU核數(shù)* 如果在該Worker節(jié)點上允許啟動新的Executor,需要追加以下兩個條件:* 1. 判斷內(nèi)存是否足夠啟動Executor,其方法是:當(dāng)前Worker節(jié)點可用內(nèi)存-該Worker已分配的內(nèi)存>=每個Executor分配的內(nèi)存大小* 2. 已經(jīng)分配給該應(yīng)用程序的Executor數(shù)量+已經(jīng)運行該應(yīng)用程序的Executor數(shù)量<該應(yīng)用程序Executor設(shè)置的最大值*/def canLaunchExecutor(pos: Int): Boolean = {val keepScheduling = coresToAssign >= minCoresPerExecutorval enoughCores = usableWorkers(pos).coresFree - assignedCores(pos) >= minCoresPerExecutor// If we allow multiple executors per worker, then we can always launch new executors.// Otherwise, if there is already an executor on this worker, just give it more cores.// 啟動新Executor條件是:該Worker節(jié)點允許啟動多個Executor或者在該Worker節(jié)點上沒有為該應(yīng)用程序分配Executorval launchingNewExecutor = !oneExecutorPerWorker || assignedExecutors(pos) == 0// 如果在該Worker節(jié)點上允許啟動多個Executor,那么該Executor節(jié)點滿足啟動條件就可以啟動新Executor,// 否則只能啟動一個Executor并盡可能的多分配CPU核數(shù)if (launchingNewExecutor) {val assignedMemory = assignedExecutors(pos) * memoryPerExecutorval enoughMemory = usableWorkers(pos).memoryFree - assignedMemory >= memoryPerExecutorval underLimit = assignedExecutors.sum + app.executors.size < app.executorLimitkeepScheduling && enoughCores && enoughMemory && underLimit} else {// We're adding cores to an existing executor, so no need// to check memory and executor limitskeepScheduling && enoughCores}}// Keep launching executors until no more workers can accommodate any// more executors, or if we have reached this application's limitsvar freeWorkers = (0 until numUsable).filter(canLaunchExecutor)// 在可用的Worker節(jié)點中啟動Executor,在Worker節(jié)點每次分配資源時,分配給Executor所需的最少CPU核數(shù),該過程是通過多次輪詢進行,// 直到?jīng)]有Worker節(jié)點滿足啟動Executor條件活著已經(jīng)達到應(yīng)用程序限制。在分配過程中Worker節(jié)點可能多次分配,// 如果該Worker節(jié)點可以啟動多個Executor,則每次分配的時候啟動新的Executor并賦予資源;// 如果該Worker節(jié)點只能啟動一個Executor,則每次分配的時候把資源追加到該Executorwhile (freeWorkers.nonEmpty) {freeWorkers.foreach { pos =>var keepScheduling = true// 滿足 keepScheduling標(biāo)志為真(第一次分配或者集中運行)和該Worker節(jié)點滿足// 啟動Executor條件時,進行資源分配while (keepScheduling && canLaunchExecutor(pos)) {// 每次分配CPU核數(shù)為Executor所需的最少CPU核數(shù)coresToAssign -= minCoresPerExecutorassignedCores(pos) += minCoresPerExecutor// If we are launching one executor per worker, then every iteration assigns 1 core// to the executor. Otherwise, every iteration assigns cores to a new executor.// 如果設(shè)置每個Executor啟動CPU核數(shù),則該Worker只能為該應(yīng)用程序啟動1個Executor,// 否則在每次分配中啟動1個新的Executorif (oneExecutorPerWorker) {assignedExecutors(pos) = 1} else {assignedExecutors(pos) += 1}// Spreading out an application means spreading out its executors across as// many workers as possible. If we are not spreading out, then we should keep// scheduling executors on this worker until we use all of its resources.// Otherwise, just move on to the next worker.// 如果是分散運行,則在某一Worker節(jié)點上做完資源分配立即移到下一個Worker節(jié)點,// 如果是集中運行,則持續(xù)在某一Worker節(jié)點上做資源分配,知道使用完該Worker節(jié)點所有資源。// 傳入的Worker節(jié)點列表是按照CPU核數(shù)倒序排列,在集中運行時,會盡可能少的使用Worker節(jié)點if (spreadOutApps) {keepScheduling = false}}}// 繼續(xù)從上一次分配完的可用Worker節(jié)點列表獲取滿足啟動Executor的Worker節(jié)點列表freeWorkers = freeWorkers.filter(canLaunchExecutor)}// 返回每個Worker節(jié)點分配的CPU核數(shù)assignedCores}

tips:
關(guān)于branch-2.0,這個算法是在Spark 1.4.2的版本中優(yōu)化的。在以前,Worker節(jié)點中,只能為某應(yīng)用程序啟動一個Executor。輪詢分配資源時,Worker節(jié)點每次分配1個CPU核數(shù),這樣有可能會造成某個Worker節(jié)點最終分配CPU核數(shù)小于每個Executor所需CPU核數(shù),那么該節(jié)點將不啟動該Executor。例如:
在集群中有4個Worker節(jié)點,每個節(jié)點擁有16個CPU核數(shù),其中設(shè)置了spark.cores.max=48和spark.executor.cores=16,由于每個Worker只啟動一個Executor,按照每次分配一個CPU核數(shù),則每個Worker節(jié)點的Executor將分配到12個CPU核數(shù),每個由于12<16, 所以沒有Executor能啟動?,F(xiàn)在改進的算法是,如果設(shè)置了spark.executor.cores,那么每次分配的時候就分配這個指定的CPU核數(shù)

2. 作業(yè)以及調(diào)度階段之間

Spark應(yīng)用程序提交執(zhí)行時,會根據(jù)RDD依賴關(guān)系形成有向無環(huán)圖(DAG),然后交給DAGScheduler進行劃分作業(yè)和調(diào)度階段。這些作業(yè)之間沒有任何依賴關(guān)系,對于多個作業(yè)之間的調(diào)度,Spark目前提供了兩種不同的調(diào)度策略,一種是FIFO模式,這也是目前默認的模式;還有一種是FAIR模式,該模式的調(diào)度可以通過兩個參數(shù)來決定Job執(zhí)行的優(yōu)先模式,兩個參數(shù)分別是minShare(最小任務(wù)數(shù))和weight(任務(wù)的權(quán)重)。

2.1 創(chuàng)建調(diào)度池

在TaskSchedulerImpl.initialize方法中先創(chuàng)建根調(diào)度池rootPool對象,然后根據(jù)系統(tǒng)配置的調(diào)度模式創(chuàng)建調(diào)度創(chuàng)建器,針對兩種調(diào)度策略進行具體實例化FIFOSchedulableBuilder或者FairSchedulableBuilder,最終使用調(diào)度器創(chuàng)建buildPools方法根調(diào)度池rootPool下創(chuàng)建調(diào)度池。

def initialize(backend: SchedulerBackend) {this.backend = backend// temporarily set rootPool name to emptyrootPool = new Pool("", schedulingMode, 0, 0)schedulableBuilder = {schedulingMode match {case SchedulingMode.FIFO =>new FIFOSchedulableBuilder(rootPool)case SchedulingMode.FAIR =>new FairSchedulableBuilder(rootPool, conf)case _ =>throw new IllegalArgumentException(s"Unsupported spark.scheduler.mode: $schedulingMode")}}schedulableBuilder.buildPools()}

2. 調(diào)度池中加入調(diào)度內(nèi)容

在TaskSchedulerImpl.submitTask方法中,先把調(diào)度階段拆分為任務(wù)集,然后把這些任務(wù)集交給管理器TaskSetManager進行管理,最后把該任務(wù)集的管理器加入到調(diào)度池中,等待分配執(zhí)行。在FIFO中,由于創(chuàng)建的buildPools方法為空,所以在根調(diào)度器rootPool中并沒有下級調(diào)度池,而是直接包含了一組TaskSetManager;而在Fair調(diào)度器中,根調(diào)度池rootPool中包含了下級調(diào)度池Pool,在這些下級調(diào)度池Pool包含一組TaskSetManager。

override def submitTasks(taskSet: TaskSet) {val tasks = taskSet.taskslogInfo("Adding task set " + taskSet.id + " with " + tasks.length + " tasks")this.synchronized {// 為每一個taskSet創(chuàng)建一個taskSetManager// taskSetManager在后面負責(zé),TaskSet的任務(wù)執(zhí)行狀況的監(jiān)視和管理val manager = createTaskSetManager(taskSet, maxTaskFailures)val stage = taskSet.stageIdval stageTaskSets =taskSetsByStageIdAndAttempt.getOrElseUpdate(stage, new HashMap[Int, TaskSetManager])// 把manager加入內(nèi)存緩存中stageTaskSets(taskSet.stageAttemptId) = managerval conflictingTaskSet = stageTaskSets.exists { case (_, ts) =>ts.taskSet != taskSet && !ts.isZombie}if (conflictingTaskSet) {throw new IllegalStateException(s"more than one active taskSet for stage $stage:" +s" ${stageTaskSets.toSeq.map{_._2.taskSet.id}.mkString(",")}")}// 將該任務(wù)集的管理器加入到系統(tǒng)調(diào)度池中,由系統(tǒng)統(tǒng)一調(diào)配,該調(diào)度器屬于應(yīng)用級別// 支持FIFO和FAIR兩種,默認FIFOschedulableBuilder.addTaskSetManager(manager, manager.taskSet.properties)

3. 提供已排序的任務(wù)集管理器

在TaskSchedulerImpl.resourceOffers方法中進行資源分配時,會從根調(diào)度池rootPool獲取以及排序的任務(wù)管理器,排序算法由兩種調(diào)度策略提供。

// 獲取按照調(diào)度策略排序好的TaskSetManager// 從rootPool中取出排序了的TaskSetManager// 在創(chuàng)建完TaskScheduler StandaloneSchedulerBackend之后,會執(zhí)行initialize()方法,其實會創(chuàng)建一個調(diào)度池// 這里就是所有提交的TaskSetManager,首先會放入這個調(diào)度池中,然后再執(zhí)行task分配算法的時候,會從這個調(diào)度池中,取出排好隊的TaskSetManagerval sortedTaskSets = rootPool.getSortedTaskSetQueue

在FIFO調(diào)度策略中,由于根調(diào)度池rootPool直接包含了多個作業(yè)的任務(wù)管理器,在比較時,首先需要比較作業(yè)的優(yōu)先級(根據(jù)作業(yè)編號判斷,作業(yè)編號越小優(yōu)先級越高),如果是同一個作業(yè),則會比較調(diào)度階段優(yōu)先級(根據(jù)調(diào)度階段編號判斷,調(diào)度階段編號越小優(yōu)先級越高)

private[spark] class FIFOSchedulingAlgorithm extends SchedulingAlgorithm {override def comparator(s1: Schedulable, s2: Schedulable): Boolean = {//獲取作業(yè)優(yōu)先級,實際上是作業(yè)編號val priority1 = s1.priorityval priority2 = s2.priorityvar res = math.signum(priority1 - priority2)//如果是同一個作業(yè),再比較調(diào)度階段優(yōu)先級if (res == 0) {val stageId1 = s1.stageIdval stageId2 = s2.stageIdres = math.signum(stageId1 - stageId2)}res < 0} }

在FAIR調(diào)度策略中包含了兩層調(diào)度,第一層調(diào)度池rootPool中包含了下級調(diào)度池Pool,第二層為下級調(diào)度池Pool包含多個TaskSetManager。具體配置參見$SPARK_HOME/conf/fairscheduler.xml文件,在該文件中包含多個下級調(diào)度池Pool配置項,其中minShare(最小任務(wù)數(shù))和weight(任務(wù)的權(quán)重)用來設(shè)置第一級調(diào)度算法,而SchedulingMode參數(shù)是用來設(shè)置第二層調(diào)度算法。

在FAIR算法中,先獲取兩個調(diào)度器的饑餓程度,饑餓程度為正在運行的任務(wù)是否小于最小任務(wù),如果是,則表示該調(diào)度處于饑餓程度。獲取饑餓程度后進行如下比較:

  • 如果某個調(diào)度處于解狀態(tài),另一個處于非饑餓狀態(tài),則先滿足處于饑餓狀態(tài)的調(diào)度
  • 如果兩個調(diào)度都處于饑餓狀態(tài),則比較資源比,先們在這資源比較少的調(diào)度。
  • 如果兩個調(diào)度處于非饑餓狀態(tài),則比較權(quán)重比,先滿足權(quán)重比少的調(diào)度。
  • 以上情況均相同的情況,根據(jù)調(diào)度的名稱進行排序。
private[spark] class FairSchedulingAlgorithm extends SchedulingAlgorithm {override def comparator(s1: Schedulable, s2: Schedulable): Boolean = {//最小任務(wù)數(shù)val minShare1 = s1.minShareval minShare2 = s2.minShare//正在運行的任務(wù)數(shù)val runningTasks1 = s1.runningTasksval runningTasks2 = s2.runningTasks//饑餓程序,判斷標(biāo)準(zhǔn)為正在運行的任務(wù)數(shù)量是否小于最小任務(wù)數(shù)量val s1Needy = runningTasks1 < minShare1val s2Needy = runningTasks2 < minShare2//資源比,正在運行的任務(wù)數(shù)量/最小任務(wù)數(shù)量val minShareRatio1 = runningTasks1.toDouble / math.max(minShare1, 1.0)val minShareRatio2 = runningTasks2.toDouble / math.max(minShare2, 1.0)//權(quán)重比,正在運行的任務(wù)數(shù)/任務(wù)的權(quán)重val taskToWeightRatio1 = runningTasks1.toDouble / s1.weight.toDoubleval taskToWeightRatio2 = runningTasks2.toDouble / s2.weight.toDouble//判斷執(zhí)行var compare = 0if (s1Needy && !s2Needy) {return true} else if (!s1Needy && s2Needy) {return false} else if (s1Needy && s2Needy) {compare = minShareRatio1.compareTo(minShareRatio2)} else {compare = taskToWeightRatio1.compareTo(taskToWeightRatio2)}if (compare < 0) {true} else if (compare > 0) {false} else {s1.name < s2.name}} }

3. 任務(wù)之間

我們先了解數(shù)據(jù)本地型和延遲兩個概念。

3.1 數(shù)據(jù)本地型

數(shù)據(jù)的計算盡可能在數(shù)據(jù)所在的節(jié)點上進行,這樣可以減少數(shù)據(jù)在網(wǎng)絡(luò)上的傳輸,畢竟移動計算比移動數(shù)據(jù)代價來得小些。進一步看,數(shù)據(jù)如果在運行的節(jié)點的內(nèi)存中,就能夠進一步減少磁盤I/O的傳輸。在Spark中數(shù)據(jù)本地型優(yōu)先級從高到低為PROCESS_LOCAL>NODE_LOCAL>NO_PREF>PACK_LOCAL>ANY,即最好是任務(wù)運行的節(jié)點內(nèi)存中存在數(shù)據(jù),次好是同一個Node(同一個機器)上,再次是同機架,最后是同一個為。其中任務(wù)數(shù)據(jù)本地型通過以下情況來確定:

  • 如果任務(wù)處于作業(yè)的開始的調(diào)度階段,這些任務(wù)對于的RDD分區(qū)都有首選運行位置,該位置也是任務(wù)運行的首選位置,數(shù)據(jù)本地性為NODE_LOCAL.
  • 如果任務(wù)處于非作業(yè)開頭的調(diào)度階段,可以根據(jù)父調(diào)度階段運行的位置得到任務(wù)的首選位置,這種情況下,如果Executor處于活躍狀態(tài),則數(shù)據(jù)本地性為PROCESS_LOCAL;如果Executor不處于活動狀態(tài),但存在父調(diào)度階段運行結(jié)果,則數(shù)據(jù)本地性為NODE_LOCAL
  • 如果沒有首選位置,則數(shù)據(jù)本地型為NO_PREF

3.2 延遲執(zhí)行

在任務(wù)分配運行節(jié)點時先判斷最佳運行節(jié)點是否空閑,如果該節(jié)點沒有足夠的資源運行該任務(wù),在這種情況下任務(wù)會等待一定的時間;如果在等待時間內(nèi)該節(jié)點釋放足夠的資源,則任務(wù)在該節(jié)點運行,如果還不足會找出次佳的節(jié)點運行。通過這樣的方式進行能夠讓任務(wù)運行在更高級別的數(shù)據(jù)本地性節(jié)點,從而減少磁盤I/O和網(wǎng)絡(luò)傳輸。一般來說PROCESS_LOCAL和NODE_LOCAL兩個數(shù)據(jù)本地性級別進行等待,系統(tǒng)默認延遲時間為3s。

Spakr任務(wù)分配的原則就是讓任務(wù)運行在數(shù)據(jù)本地性優(yōu)先級別更高的節(jié)點上,甚至可以為此等待一定的時間。該任務(wù)分配有TaskSchedulerImpl.resourceOffers方法實現(xiàn),在該方法中先對應(yīng)于程序獲取的資源(Worker節(jié)點)進行混洗,以使任務(wù)能夠更加均衡的分散在集群中運行。然后對任務(wù)集對應(yīng)的TaskManager根據(jù)設(shè)置地調(diào)度算法進行排序,最后對TaskSetManager中的任務(wù)按照數(shù)據(jù)本地性分配任務(wù)運行節(jié)點,在分配時先根據(jù)任務(wù)集的本地性從優(yōu)先級高到低進行分配任務(wù),在分配的過程中動態(tài)地判斷集群中節(jié)點運行的請,通過延遲執(zhí)行等待數(shù)據(jù)本地性更高的節(jié)點運行。

《新程序員》:云原生和全面數(shù)字化實踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

總結(jié)

以上是生活随笔為你收集整理的Spark详解(六):Spark集群资源调度算法原理的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

亚洲最大在线视频 | 在线免费观看黄色 | 九九电影在线 | 精品国产伦一区二区三区免费 | 一级黄色片在线 | 亚洲成免费 | 五月婷婷黄色 | www久久精品| 国产特黄色片 | 国产一区二区三精品久久久无广告 | 精品在线观 | 丁香九月婷婷综合 | 日本韩国中文字幕 | 国产成人一区二区三区免费看 | 十八岁免进欧美 | 欧美日韩高清在线一区 | 国产99在线 | 久久最新网址 | 国产在线黄色 | 亚洲婷婷综合色高清在线 | 国产精品嫩草69影院 | 超碰97国产精品人人cao | 欧美日韩一区二区三区在线观看视频 | 在线免费中文字幕 | 九九热免费精品视频 | 黄色精品国产 | 天天色天 | 久久久免费看片 | se婷婷 | 精品国产自| 怡红院av久久久久久久 | 国产一级性生活 | 91在线视频观看免费 | 国产成人精品一区二区三区福利 | 99精品国产免费久久久久久下载 | 日韩av免费一区二区 | 久久综合久久久 | 日韩黄色软件 | 国产精品国产三级国产不产一地 | 天天草天天 | 亚洲精品乱码久久久久久蜜桃91 | 久久久久久久久久福利 | 亚洲精品自在在线观看 | 91资源在线视频 | 激情五月五月婷婷 | 国产精品一区二区三区免费看 | 欧美精品国产综合久久 | 美女视频黄色免费 | 婷婷精品国产一区二区三区日韩 | 在线观看视频精品 | 久久九九影视网 | 黄色成人小视频 | 中文字幕亚洲在线观看 | 中文字幕在线观看网站 | 欧美韩日在线 | 国产精品免费久久久久久 | 亚洲国产综合在线 | 黄色成人免费电影 | 国产在线精品一区二区不卡了 | 国产日韩精品一区二区三区 | 五月婷婷激情网 | 中文字幕在线观看资源 | 亚洲午夜精品一区二区三区电影院 | 国内精品久久天天躁人人爽 | 亚洲欧美久久 | 精品美女在线视频 | 国产精品国产亚洲精品看不卡 | 国产精品一区二区三区久久久 | 天天摸夜夜操 | 精品欧美一区二区在线观看 | 久久久国产毛片 | 久久免费播放视频 | 国产亚洲字幕 | 国产一区二区三区免费观看视频 | 中文字幕在线观看网站 | 91在线超碰| 成人av.com| 国产精品资源在线 | 国产高清免费在线观看 | 在线黄色免费 | 国产精品久久久久一区二区三区 | 亚洲免费精品一区二区 | 亚洲另类在线视频 | 91探花视频| a视频在线播放 | 在线蜜桃视频 | 久草视频免费在线观看 | 国产成人精品午夜在线播放 | 91超在线| 波多野结衣一区三区 | 日韩精品一区电影 | 99视频这里只有 | 69av在线视频 | www夜夜操com | 国产99精品在线观看 | 欧美另类成人 | 二区三区av | 国产色拍拍拍拍在线精品 | 9999在线 | 成人一级片免费看 | 成人毛片一区二区三区 | 久久久高清一区二区三区 | av在线网站大全 | 免费人做人爱www的视 | 夜夜爽夜夜操 | av成人动漫在线观看 | 成人在线免费小视频 | 欧美一区二区三区在线视频观看 | 一区二区精品国产 | 国产免费嫩草影院 | 欧美久久久久 | 亚洲天堂精品视频在线观看 | 日本99精品 | 91精品国 | 欧美巨乳网 | 日日婷婷夜日日天干 | 久艹在线免费观看 | 99久久夜色精品国产亚洲96 | 午夜精品久久久久久99热明星 | 欧美极品少妇xxxx | 99热在线观看 | 色综合久久久久久久久五月 | 成人h视频在线播放 | 丁香久久激情 | 六月色丁香| 射九九| 久久精品一二三区 | 91麻豆精品国产91久久久无需广告 | 国产大片免费久久 | 怡红院av久久久久久久 | 国产 在线 高清 精品 | 亚洲精品在线观看不卡 | 91人人爽久久涩噜噜噜 | 日本久久电影网 | 色的网站在线观看 | 丁香花在线视频观看免费 | 五月天亚洲精品 | 久久精品免费播放 | 亚洲视频每日更新 | 日韩高清二区 | av电影在线不卡 | 九色91福利| 波多野结衣在线观看视频 | 国产欧美综合在线观看 | 久久美女免费视频 | 国产精品网站一区二区三区 | 精品国产一区二 | 五月丁婷婷 | 成年人在线观看免费视频 | 在线观看视频福利 | 中文字幕中文字幕在线中文字幕三区 | 国产精品免费视频久久久 | 色综合久久综合网 | 日韩高清免费在线观看 | 一级电影免费在线观看 | 一区二区三区在线免费播放 | 综合在线色 | 色狠狠综合天天综合综合 | 中文字幕av免费在线观看 | 久青草视频 | 中文字幕免费在线看 | 欧美黄在线 | 日韩极品在线 | 国产午夜精品一区二区三区在线观看 | 日韩三级视频在线观看 | 免费av在线网站 | 麻豆果冻剧传媒在线播放 | 国产一区二区日本 | 成人在线电影观看 | 国产亚洲精品久久 | 黄色在线观看www | 日本中文字幕免费观看 | 国产麻豆精品久久一二三 | 久久丁香 | 天天躁天天操 | 国产裸体视频bbbbb | 91精品国产99久久久久 | 久草视频免费播放 | 麻豆视频免费播放 | 超碰97久久 | 亚洲天堂va | 午夜国产福利在线 | 色婷婷久久久综合中文字幕 | 久久久在线视频 | 激情综合中文娱乐网 | 98超碰在线| 亚洲国产精品久久久久久 | 国产不卡精品视频 | 2023av在线| 99精品热视频只有精品10 | 色91在线| 日韩欧美在线综合网 | 97人人模人人爽人人少妇 | 999久久久久久久久久久 | 天天干天天操av | 永久免费在线 | 日批在线观看 | 成年人毛片在线观看 | 欧美一区二区精美视频 | 国产精品一区二区三区99 | 天天综合久久综合 | 欧美精品v国产精品v日韩精品 | 国产麻豆精品免费视频 | 国产美女在线精品免费观看 | 人人射人人射 | 免费亚洲精品视频 | 国产精品视频专区 | 日韩欧美电影 | 色九色| 精品久久久久久电影 | 欧美日韩观看 | 日韩视频一区二区三区在线播放免费观看 | 精品国内自产拍在线观看视频 | 美女国产精品 | 国产黄网站在线观看 | 国产亚洲午夜高清国产拍精品 | 99久久精品国产毛片 | 日韩黄在线观看 | 国产精品久久久久久久久久直播 | 久久久91精品国产一区二区三区 | 国内三级在线观看 | 国产精品国内免费一区二区三区 | 一区二区欧美日韩 | 午夜精品三区 | 九九视频精品在线 | 一区二区三区免费网站 | 日本在线观看中文字幕无线观看 | 黄色看片 | 亚洲精品久久久蜜桃 | 天天色棕合合合合合合 | 亚洲电影院 | 97超碰免费在线观看 | 欧美日韩xx | 日韩免费视频网站 | 天堂资源在线观看视频 | 中文字幕人成不卡一区 | 在线看成人| 久久激五月天综合精品 | 超碰人人草人人 | 99精品一区二区三区 | 91在线视频观看免费 | 国产手机在线视频 | 成人精品一区二区三区电影免费 | 在线观看亚洲电影 | 国产精品 日韩 欧美 | 热re99久久精品国产66热 | 天天干天天干天天 | 91在线免费视频观看 | 最新av在线网站 | 99精品久久久久 | 天天插天天狠 | 国产亚洲精品女人久久久久久 | 麻豆久久| 97超碰超碰 | 日韩免费一区二区三区 | 亚洲国产精品免费 | 日韩欧美国产精品 | 国产另类xxxxhd高清 | 日韩在线第一 | 在线免费观看黄网站 | 精品国产成人av在线免 | 亚洲成人黄色av | 一区二区精品视频 | 婷婷色网站| 欧美国产精品一区二区 | 免费在线播放黄色 | 亚洲视频2 | 久久精品国产精品亚洲 | 人人狠狠综合久久亚洲 | 中文字幕乱码一区二区 | 三级av免费| 成人av高清在线观看 | 亚洲精品视 | 国产精彩视频一区二区 | 亚洲黄色免费电影 | 91福利视频一区 | 你操综合 | 美女天天操 | 综合色在线 | 91精品1区| 日韩精品第一区 | av三级av | 在线日韩av | 成人一区电影 | 黄av免费在线观看 | 久久久久久亚洲精品 | 在线综合 亚洲 欧美在线视频 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 视频在线播放国产 | 日韩精品一二三 | 日韩久久精品一区二区 | 日韩系列在线 | 国产成人99av超碰超爽 | 国产精品一区二区av | 亚洲视频一区二区三区在线观看 | 久久深夜福利免费观看 | 黄色国产在线 | 日韩videos | 久久久综合九色合综国产精品 | 国产乱码精品一区二区蜜臀 | 久久精品网站视频 | 国产护士av| 免费大片黄在线 | 国产小视频在线免费观看 | 中文字幕在线免费观看 | 久久久久 免费视频 | 免费在线播放视频 | 中文字幕在线播放第一页 | 99中文字幕 | 欧美激情另类文学 | 久久超碰97| 午夜私人影院 | 日本公妇在线观看高清 | 草久在线播放 | 久爱精品在线 | 婷婷综合成人 | 国产成人精品在线观看 | 亚洲网久久 | 欧美精品视 | www.亚洲视频| 91漂亮少妇露脸在线播放 | 中文字幕国产一区二区 | 日女人免费视频 | 久久久免费 | 欧美性大战久久久久 | 婷婷色亚洲 | 免费av片在线| 亚洲综合少妇 | 日韩一区二区三区高清免费看看 | 精品一区二区在线观看 | 日韩mv欧美mv国产精品 | av免费在线网 | 欧美成人亚洲成人 | 亚洲无吗视频在线 | 久久中国精品 | 亚洲精品午夜久久久 | 91亚洲国产成人久久精品网站 | 国产精品1区2区3区 久久免费视频7 | 天堂v中文 | 麻豆久久 | 超碰在线观看av | 97电影在线观看 | 久久久午夜电影 | 日韩电影久久久 | 国产精品欧美久久久久天天影视 | 婷婷丁香在线视频 | 午夜精品婷婷 | 人人dvd | 美女视频黄免费网站 | 999在线视频 | 日韩福利在线观看 | 国产高清视频免费最新在线 | 日韩电影一区二区在线 | 精品国产久 | 91精品欧美一区二区三区 | 婷婷在线视频观看 | 日韩在线视频免费看 | 色久av | 缴情综合网五月天 | 国产系列精品av | 激情综合五月婷婷 | 午夜精品视频免费在线观看 | 日韩精品极品视频 | 久久99热久久99精品 | 国产精品女人网站 | 色婷婷在线播放 | 天天射天天干天天爽 | 国产97在线视频 | 色婷婷88av视频一二三区 | 精品影院 | 国产高清视频在线 | 人人爱在线视频 | 丁香花中文字幕 | 天天操天天干天天插 | 国产福利久久 | 久久成人麻豆午夜电影 | 高潮久久久久久久久 | av福利资源| 麻豆视频免费在线观看 | 日日狠狠| 国产精品久久久久久久久免费看 | 久久久久欧美精品 | 免费观看全黄做爰大片国产 | 激情久久一区二区三区 | 99精品免费网 | 久久亚洲美女 | 久99久精品| 九九热有精品 | 狠狠激情中文字幕 | 午夜精品久久久久 | 91视频高清免费 | 91成人在线观看高潮 | 成人免费观看在线视频 | 欧美性粗大hdvideo | 国产在线精品国自产拍影院 | 日产乱码一二三区别免费 | 日日躁你夜夜躁你av蜜 | 久久艹在线 | 国产香蕉av | 精品高清美女精品国产区 | 九色91福利| 韩国av在线 | 中文字幕丰满人伦在线 | 久久精品日韩 | 成片人卡1卡2卡3手机免费看 | 精品理论片 | 干综合网 | 成人免费在线看片 | 天海翼一区二区三区免费 | 国产v亚洲v | 日韩精品视频在线观看网址 | 国产69精品久久久久久久久久 | 伊人网站| 69久久久久久久 | 香蕉视频在线观看免费 | 在线精品视频在线观看高清 | 综合天堂av久久久久久久 | 最近中文字幕 | 久久精品女人毛片国产 | 色综合在| 91在线免费观看国产 | 国产不卡高清 | 欧美乱熟臀69xxxxxx | 1000部国产精品成人观看 | 在线看欧美| 国产91全国探花系列在线播放 | 国产精品久久久久久久久毛片 | 成人小视频在线免费观看 | 欧美午夜剧场 | 亚洲国产69 | 国产看片 色 | www黄免费| 亚洲精品乱码久久久久久蜜桃不爽 | 亚洲欧美经典 | 日韩精品91偷拍在线观看 | 少妇精品久久久一区二区免费 | 成人在线观看日韩 | 一级黄色av| 精品久久国产一区 | 亚洲黄色在线免费观看 | 91精品成人久久 | 超碰999 | 91av在线免费视频 | 欧美色综合天天久久综合精品 | 日韩一级片大全 | 国产特级毛片aaaaaa毛片 | av一区在线 | 国产精品久久久久久久电影 | 少妇资源站 | 免费在线观看视频a | 99久久精品国产观看 | a在线一区 | 久久久www免费电影网 | 波多野结衣亚洲一区二区 | 免费黄色av电影 | 国产精品久久视频 | 成人国产精品久久久春色 | 久草视频在线观 | 国产三级国产精品国产专区50 | 九九视频免费观看视频精品 | 99久热在线精品 | 久久国产亚洲精品 | 久久精品一二三区白丝高潮 | 国产裸体无遮挡 | 天堂在线视频中文网 | 高清在线观看av | 美女在线免费视频 | 超碰999| 久草精品免费 | 天堂资源在线观看视频 | 成人小视频在线观看免费 | 在线免费观看黄 | 亚洲精品xx | 亚洲综合成人婷婷小说 | 久久伦理电影 | 香蕉免费| 色视频成人在线观看免 | 日韩av免费一区二区 | 热re99久久精品国产66热 | 久久精品综合网 | 91视频91自拍| 午夜精品福利一区二区 | av最新资源| 国产福利91精品张津瑜 | 日韩性久久 | 最近中文字幕免费 | 国产一区二区高清不卡 | 99免费看片 | 在线免费观看黄色 | 午夜精品一区二区三区四区 | 成年人视频在线 | 成人丝袜 | 二区三区精品 | 国产精品99久久久久人中文网介绍 | 91av超碰| 麻豆影视在线免费观看 | 久久久高清免费视频 | 日本激情视频中文字幕 | 亚洲免费成人av电影 | 天天色天天干天天 | 免费观看一级成人毛片 | 超碰97中文 | 91片在线观看 | 91片在线观看 | 成人v| 亚洲视频免费在线看 | 日韩理论电影在线 | 欧美天堂久久 | 一级欧美日韩 | 国产99精品在线观看 | 伊人久久在线观看 | 亚洲综合视频在线 | 在线天堂亚洲 | 国产在线高清精品 | 色婷婷中文| 天天草综合网 | 超碰在线97观看 | 色噜噜在线观看视频 | 国产人免费人成免费视频 | 手机av电影在线观看 | 国产成人精品一区二区三区福利 | 免费手机黄色网址 | 国产一二区视频 | 久久理论电影网 | 最新日韩视频 | 制服丝袜在线 | 黄色网www | 午夜999| 日韩91精品| 久久久天堂 | 在线国产小视频 | 日韩欧美一区二区在线 | 欧美精品久久久久性色 | 国产精品久久久久影院 | 97国产一区二区 | 久草综合视频 | 91丨九色丨蝌蚪丨对白 | 日本久久久久 | 亚洲国产欧美在线看片xxoo | 青春草免费在线视频 | 激情综合亚洲 | 午夜久久久久久久 | 久草电影免费在线观看 | 一区二区电影网 | 亚洲欧美偷拍另类 | 国产资源在线视频 | 欧美日韩后 | 欧美久久久影院 | 欧美综合色在线图区 | 久久99深爱久久99精品 | 国产精品久久久久久久7电影 | 色婷婷av在线 | 久久久久久久免费 | 91人人视频在线观看 | 久久高清视频免费 | 欧美激情h| 亚洲aⅴ久久精品 | av在线不卡观看 | 九色视频网 | 91成年视频 | 亚洲 欧美日韩 国产 中文 | 国内精品亚洲 | 国产一卡二卡四卡国 | 3d黄动漫免费看 | 亚洲激情六月 | 成人污视频在线观看 | 久久久精品亚洲 | 日韩一区二区三 | 欧美调教网站 | 成人污视频在线观看 | 久久久久久久久久久黄色 | 最近中文字幕在线中文高清版 | 国产精品激情 | 91热精品| 国产一区在线视频播放 | 波多野结衣电影久久 | 国产视频18 | 国产视频69 | 日韩中午字幕 | 粉嫩av一区二区三区入口 | 在线免费观看的av网站 | 午夜影视剧场 | 色婷婷综合久久久久中文字幕1 | 久久中文字幕视频 | 激情黄色一级片 | 99视频在线精品国自产拍免费观看 | 精品亚洲va在线va天堂资源站 | 片网址 | 丁香五月亚洲综合在线 | 国产精品久久久久久久久久东京 | 亚洲国产黄色片 | 月下香电影 | 天天色天天搞 | 国产精品一区二区在线播放 | 日韩精品久久一区二区 | 日韩免费在线观看 | 91精品啪在线观看国产81旧版 | 精品国产伦一区二区三区观看说明 | 国产69精品久久久久久久久久 | 在线一区观看 | 美女视频网站久久 | 日韩精品一区二区三区丰满 | 国产小视频免费在线网址 | 永久免费精品视频网站 | 九九涩涩av台湾日本热热 | 久久av网址 | 福利视频网站 | 高清免费av在线 | 国产精品大片 | 国产精品一区二区三区四区在线观看 | 国产精品成人a免费观看 | www.亚洲激情.com | 久久69av | 亚洲激情p | 国产一级视频免费看 | 成人免费看片网址 | 色婷婷 亚洲 | 99精品偷拍视频一区二区三区 | 日日夜夜婷婷 | 成人av影视 | 久操中文字幕在线观看 | 欧美日韩在线观看一区二区 | 韩国av一区二区三区 | 亚洲日本一区二区在线 | 日韩精品一区二区三区在线播放 | 911精品视频 | 美女视频黄免费 | av高清网站在线观看 | 精品视频网站 | 久久精品国产免费看久久精品 | 精品久久久久国产免费第一页 | 五月天激情综合 | 91精品久久久久久久91蜜桃 | a视频免费看 | 成人免费一级片 | 中文一区二区三区在线观看 | 欧美日本一二三 | 这里只有精品视频在线 | 亚洲深夜影院 | 中文字幕国产精品 | 看国产黄色片 | 亚洲理论在线观看 | 天天综合色天天综合 | 国产亚洲欧美日韩高清 | www.天堂av| 国产精品剧情在线亚洲 | 五月天丁香 | 99视频国产精品 | 98涩涩国产露脸精品国产网 | 国产亚洲精品久久 | 搡bbbb搡bbb视频 | 蜜臀av免费一区二区三区 | 成人电影毛片 | 免费在线观看一区二区三区 | 一区二区精品在线 | 天天添夜夜操 | 日韩有码网站 | www日韩欧美 | 国产美女在线免费观看 | 91九色视频在线播放 | 免费在线观看日韩欧美 | 国产精品一区二区三区四 | 久久综合干 | av免费网 | 日韩在线视频精品 | 久久私人影院 | 国产午夜影院 | 午夜视频久久久 | 97超碰国产精品女人人人爽 | 欧美91精品久久久久国产性生爱 | 国产91精品一区二区麻豆亚洲 | 97超视频| 日韩国产精品毛片 | 91精品国产综合久久福利不卡 | 国产免费a| 人人干免费 | 免费a视频| 日韩视频免费观看高清完整版在线 | 色婷婷狠狠五月综合天色拍 | 日韩a在线观看 | 日韩三级不卡 | 欧美日韩国产色综合一二三四 | 丁香在线观看完整电影视频 | 日韩欧美网址 | 欧美夫妻性生活电影 | 高清有码中文字幕 | 四虎在线免费观看 | 国产香蕉97碰碰久久人人 | 丁香婷婷在线 | 成人免费影院 | 五月天伊人 | 91插插影库 | 久久久福利 | 91精品视频在线看 | 在线观看www. | 天天综合网 天天 | 日韩在线视频观看 | 999视频在线播放 | 久久首页| 国产精品久久久久久久久久了 | 在线观看视频亚洲 | 色综合天天综合在线视频 | 日韩精品久久久 | av免费网站在线观看 | 久久第四色 | 亚洲成av人片在线观看 | 亚洲日韩精品欧美一区二区 | 日韩视频1区 | 久久在线电影 | 亚洲h在线播放在线观看h | 91久久黄色 | 九九免费在线观看 | 中文字幕av在线不卡 | 日本久久久久久久久 | 美女在线观看网站 | 欧美成人免费在线 | 女人魂免费观看 | 亚洲成a人片综合在线 | 人人爽爽人人 | av免费试看 | 中文字幕91在线 | 午夜久久久久久久 | 免费欧美高清视频 | 亚洲狠狠丁香婷婷综合久久久 | 99这里只有 | 久久激情精品 | 亚洲精品视频在线观看免费视频 | 丰满少妇高潮在线观看 | 深夜男人影院 | 久久草草热国产精品直播 | 久久成人午夜视频 | 国产69精品久久久久99 | 夜夜干天天操 | 亚洲综合网| 久久午夜电影院 | 日韩精品免费在线视频 | 久草在线免费色站 | 在线视频 一区二区 | 国产午夜精品久久久久久久久久 | 特级黄录像视频 | 最新久久免费视频 | 国产精品色婷婷视频 | 久久精品电影网 | 中文字幕高清 | 免费看v片| 国产精品1000 | 久久久免费观看 | 色在线免费视频 | 久久在视频| 亚洲视频h | 亚洲精品免费观看 | 日韩视| 国产视频美女 | 成年人在线免费视频观看 | 欧美性色综合网 | 一区二区三区高清不卡 | 日韩av一区二区在线播放 | 91精品电影 | 色婷婷亚洲 | 91在线公开视频 | 日日草av | av日韩av| 韩国三级一区 | 精品久久久一区二区 | 中文字幕在线资源 | 精品国产一二三 | 国产精品精品久久久久久 | 国精产品满18岁在线 | 日韩视频免费 | 97超碰人 | 久久影院精品 | 日韩精品一区二区三区视频播放 | 成人黄色资源 | 欧美日韩免费看 | 2024国产精品视频 | 不卡在线一区 | 99精品黄色片免费大全 | 久久久久久国产精品免费 | 国产精品久久电影网 | 日韩欧美在线一区 | 天天操 夜夜操 | 日韩欧美在线播放 | 日韩三级视频在线看 | 综合铜03| 在线 高清 中文字幕 | 国产免费观看av | 日本精品视频网站 | 精品超碰 | 免费在线观看成人 | 美女网站视频久久 | 特黄色大片 | 亚洲免费在线播放视频 | 欧美日韩三级 | 欧美日韩一二三四区 | 国产黄免费在线观看 | 欧美韩国日本在线 | 亚州av免费 | 欧美一级专区免费大片 | 国产精品国产三级国产aⅴ9色 | 中文字幕免费国产精品 | 超碰97公开 | 最近中文字幕免费观看 | 日韩激情综合 | 久久久久97国产 | 少妇bbr搡bbb搡bbb | 夜夜婷婷 | 天天综合操 | 日本三级香港三级人妇99 | 精品国产一区二区三区噜噜噜 | 亚洲精品久久激情国产片 | 欧美精品亚洲精品日韩精品 | 国产精品人人做人人爽人人添 | 欧美成人在线免费 | 亚洲三级国产 | 精品免费99久久 | 91资源在线免费观看 | 日韩电影一区二区在线 | 在线成人一区 | 久久不射电影院 | 亚洲精品女人久久久 | 久久精品日韩 | 欧美一区二区三区在线播放 | 粉嫩av一区二区三区四区 | 国产精品久久久久久一二三四五 | 99热最新精品 | 黄色av电影一级片 | 国产久草在线 | 日韩最新av | 欧美一区二区三区在线看 | 五月天色丁香 | 在线免费高清一区二区三区 | 国产xxxx性hd极品 | 狠狠操精品 | 日韩精品一二三 | 黄在线 | 国产精品美女久久久久久免费 | 一本之道乱码区 | 精品亚洲二区 | 国产一级在线视频 | 久久国产视频网站 | 狠狠色丁香久久婷婷综合丁香 | 日韩 在线a| 久久久久国产精品视频 | 精品一二三区视频 | 97视频在线免费 | 天天干,夜夜爽 | 欧美午夜视频在线 | 久久福利| 亚洲精品伦理在线 | 日韩综合色 | 天天操夜夜干 | 911久久香蕉国产线看观看 | 欧美精品久久久久久久久久丰满 | av一级片 | 一本一本久久a久久精品牛牛影视 | 97超碰站 | 欧美激情视频一区二区三区 | 成人av在线直播 | 五月天综合婷婷 | 久久精品国产精品亚洲精品 | 在线观看韩国av | 中文字幕一区二区三区久久 | 视频国产 | 免费观看一级一片 | 国产精品免费一区二区 | www.亚洲黄 | 亚洲精品网站在线 | 国产精品视频99 | 欧洲亚洲国产视频 | 日韩av成人在线 | 亚洲精品综合久久 | 一本一道久久a久久精品蜜桃 | 久久久精品福利视频 | 在线亚洲午夜片av大片 | 狠狠的操狠狠的干 | 亚洲精品麻豆视频 | 亚洲视频综合 | 国产打女人屁股调教97 | 亚洲欧美综合 | 日韩av在线免费看 | 一区二区三区在线观看中文字幕 | 欧美国产大片 | 国产一区二区三区黄 | 日韩av快播电影网 | 国产精品免费成人 | 国产在线国产 | 日韩在线观看视频网站 | 亚洲精品乱码久久久久 | 国色天香永久免费 | 免费在线激情电影 | 国产一级视频在线免费观看 | 麻豆精品在线视频 | 天天爽夜夜爽人人爽曰av | 黄色大片免费播放 | 探花视频在线版播放免费观看 | 在线看小早川怜子av | 91高清视频 | 久久不射影院 | 麻花豆传媒一二三产区 | 中文免费观看 | 亚洲精品国产自产拍在线观看 | 日韩av高清在线观看 | 日韩欧美在线一区二区 | 人人揉人人揉人人揉人人揉97 | 日韩在线免费看 | 99一级片 | 精品福利视频在线观看 | 久草手机视频 | 成年人av在线播放 | 日韩精品在线免费播放 | 免费黄色网址网站 | 欧美日韩网址 | 人人看人人爱 | 久久天天综合网 | 日韩精品在线视频 | 亚洲视频资源在线 | 中文字幕在线观看完整版 | 国产女v资源在线观看 | 欧美日韩高清在线一区 | 日韩在线小视频 | 黄色片亚洲 | 在线视频免费观看 | 国产人成精品一区二区三 | 色黄久久久久久 | 中文字幕日韩在线播放 | 91日韩在线播放 | 中文字幕韩在线第一页 | 亚洲在线观看av | 成人黄色电影在线播放 | 久久精品国产v日韩v亚洲 | 欧美成人按摩 | 日韩在线视频网站 | 91超碰免费在线 | 午夜精品福利一区二区 | 久久婷婷国产色一区二区三区 | 精品a在线 | 在线精品视频在线观看高清 | 人人狠狠综合久久亚洲婷 | 亚洲一区日韩精品 | 人人躁 | 日韩精品中文字幕在线 | 亚洲精品视频在线观看视频 | 岛国一区在线 | 狠狠色丁香久久婷婷综合_中 | 日韩精品一区二区三区中文字幕 | 亚洲一级黄色大片 | 欧美成年人在线视频 | 亚洲精品在线观看不卡 | 91久久国产精品 | 一区二区久久 | 中文字幕国产精品一区二区 | 蜜臀久久99精品久久久无需会员 | 久久都是精品 | 又黄又爽又色无遮挡免费 | 国产一级片久久 | 精品福利视频在线 | 久久高清免费 | 亚洲网站在线 | 美女视频久久黄 | 91av成人| 91av影视 | 国产剧情一区在线 | 精品在线视频播放 | 涩涩伊人 | 18av在线视频| 这里只有精品视频在线 | aav在线 | 午夜丁香网| 九九导航 | 久久人人97超碰国产公开结果 | 亚洲第一区在线观看 | 久久国产99 | 99久久毛片 | 不卡视频国产 | 美女视频黄在线 | 98超碰在线 | 久久香蕉国产 | 免费看黄色小说的网站 | 欧美精品久久人人躁人人爽 | 天堂在线一区二区 | 91视频观看免费 | 欧美精品天堂 | 国产在线观看av | 五月婷婷深开心 | 国产视频2区 | 国产福利精品在线观看 | 欧美激情视频一区 | 亚洲精品午夜久久久 | 久久不卡国产精品一区二区 | 日韩影视精品 | 激情婷婷综合网 | 四虎国产精品免费观看视频优播 | 欧美视频日韩 | 欧美在线91 | 久久久影视 | 视频91在线| 麻豆传媒电影在线观看 | 国产免费叼嘿网站免费 |