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

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

生活随笔

當(dāng)前位置: 首頁(yè) > 前端技术 > javascript >内容正文

javascript

深入学习微框架:Spring Boot

發(fā)布時(shí)間:2025/3/21 javascript 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 深入学习微框架:Spring Boot 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Spring Boot是由Pivotal團(tuán)隊(duì)提供的全新框架,其設(shè)計(jì)目的是用來(lái)簡(jiǎn)化新Spring應(yīng)用的初始搭建以及開發(fā)過(guò)程。該框架使用了特定的方式來(lái)進(jìn)行配置,從而使開發(fā)人員不再需要定義樣板化的配置。通過(guò)這種方式,Boot致力于在蓬勃發(fā)展的快速應(yīng)用開發(fā)領(lǐng)域(rapid application development)成為領(lǐng)導(dǎo)者。

?

?

多年以來(lái),Spring IO平臺(tái)飽受非議的一點(diǎn)就是大量的XML配置以及復(fù)雜的依賴管理。在去年的SpringOne 2GX會(huì)議上,Pivotal的CTO Adrian Colyer回應(yīng)了這些批評(píng),并且特別提到該平臺(tái)將來(lái)的目標(biāo)之一就是實(shí)現(xiàn)免XML配置的開發(fā)體驗(yàn)。Boot所實(shí)現(xiàn)的功能超出了這個(gè)任務(wù)的描述,開發(fā)人員不僅不再需要編寫XML,而且在一些場(chǎng)景中甚至不需要編寫繁瑣的import語(yǔ)句。在對(duì)外公開的beta版本剛剛發(fā)布之時(shí),Boot描述了如何使用該框架在140個(gè)字符內(nèi)實(shí)現(xiàn)可運(yùn)行的web應(yīng)用,從而獲得了極大的關(guān)注度,該樣例發(fā)表在tweet上。

?

然而,Spring Boot并不是要成為Spring IO平臺(tái)里面眾多“Foundation”層項(xiàng)目的替代者。Spring Boot的目標(biāo)不在于為已解決的問(wèn)題域提供新的解決方案,而是為平臺(tái)帶來(lái)另一種開發(fā)體驗(yàn),從而簡(jiǎn)化對(duì)這些已有技術(shù)的使用。對(duì)于已經(jīng)熟悉Spring生態(tài)系統(tǒng)的開發(fā)人員來(lái)說(shuō),Boot是一個(gè)很理想的選擇,不過(guò)對(duì)于采用Spring技術(shù)的新人來(lái)說(shuō),Boot提供一種更簡(jiǎn)潔的方式來(lái)使用這些技術(shù)。

?

在追求開發(fā)體驗(yàn)的提升方面,Spring Boot,甚至可以說(shuō)整個(gè)Spring生態(tài)系統(tǒng)都使用到了Groovy編程語(yǔ)言。Boot所提供的眾多便捷功能,都是借助于Groovy強(qiáng)大的MetaObject協(xié)議、可插拔的AST轉(zhuǎn)換過(guò)程以及內(nèi)置的依賴解決方案引擎所實(shí)現(xiàn)的。在其核心的編譯模型之中,Boot使用Groovy來(lái)構(gòu)建工程文件,所以它可以使用通用的導(dǎo)入和樣板方法(如類的main方法)對(duì)類所生成的字節(jié)碼進(jìn)行裝飾(decorate)。這樣使用Boot編寫的應(yīng)用就能保持非常簡(jiǎn)潔,卻依然可以提供眾多的功能。

?

安裝Boot

從最根本上來(lái)講,Spring Boot就是一些庫(kù)的集合,它能夠被任意項(xiàng)目的構(gòu)建系統(tǒng)所使用。簡(jiǎn)便起見(jiàn),該框架也提供了命令行界面,它可以用來(lái)運(yùn)行和測(cè)試Boot應(yīng)用。框架的發(fā)布版本,包括集成的CLI(命令行界面),可以在Spring倉(cāng)庫(kù)中手動(dòng)下載和安裝。一種更為簡(jiǎn)便的方式是使用Groovy環(huán)境管理器(Groovy enVironment Manager,GVM),它會(huì)處理Boot版本的安裝和管理。Boot及其CLI可以通過(guò)GVM的命令行g(shù)vm install springboot進(jìn)行安裝。在OS X上安裝Boot可以使用Homebrew包管理器。為了完成安裝,首先要使用brew tap pivotal/tap切換到Pivotal倉(cāng)庫(kù)中,然后執(zhí)行brew install springboot命令。

要進(jìn)行打包和分發(fā)的工程會(huì)依賴于像Maven或Gradle這樣的構(gòu)建系統(tǒng)。為了簡(jiǎn)化依賴圖,Boot的功能是模塊化的,通過(guò)導(dǎo)入Boot所謂的“starter”模塊,可以將許多的依賴添加到工程之中。為了更容易地管理依賴版本和使用默認(rèn)配置,框架提供了一個(gè)parent POM,工程可以繼承它。Spring Boot工程的樣例POM文件定義如程序清單1所示。

程序清單1

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.example</groupId><artifactId>myproject</artifactId><version>1.0.0-SNAPSHOT</version><!-- Inherit defaults from Spring Boot --><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.0.0.RC1</version></parent><!-- Add typical dependencies for a web application --><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency></dependencies><repositories><repository><id>spring-snapshots</id><url>http://repo.spring.io/libs-snapshot</url></repository></repositories><pluginRepositories><pluginRepository><id>spring-snapshots</id><url>http://repo.spring.io/libs-snapshot</url></pluginRepository></pluginRepositories><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build> </project>

為了實(shí)現(xiàn)更為簡(jiǎn)單的構(gòu)建配置,開發(fā)人員可以使用Gradle構(gòu)建系統(tǒng)中簡(jiǎn)潔的Groovy DSL,如程序清單1.1所示。

程序清單1.1

buildscript {repositories {maven { url "http://repo.spring.io/libs-snapshot" }mavenCentral()}dependencies {classpath("org.springframework.boot:spring-boot-gradle-plugin:1.0.0.RC1")} }apply plugin: 'java' apply plugin: 'spring-boot'repositories {mavenCentral()maven { url "http://repo.spring.io/libs-snapshot" } }dependencies {compile 'org.springframework.boot:spring-boot-starter-actuator:1.0.0.RC1' }

為了快速地搭建和運(yùn)行Boot工程,Pivotal提供了稱之為“Spring Initializr” 的web界面,用于下載預(yù)先定義好的Maven或Gradle構(gòu)建配置。我們也可以使用Lazybones模板實(shí)現(xiàn)快速起步,在執(zhí)行l(wèi)azybones create spring-boot-actuator my-app命令后,它會(huì)為Boot應(yīng)用創(chuàng)建必要的工程結(jié)構(gòu)以及gradle構(gòu)建文件。

開發(fā)Spring Boot應(yīng)用

Spring Boot在剛剛公開宣布之后就將一個(gè)樣例發(fā)布到了Twitter上,它目前成為了最流行的一個(gè)應(yīng)用樣例。它的全部描述如程序清單1.2所示,一個(gè)非常簡(jiǎn)單的Groovy文件可以生成功能強(qiáng)大的以Spring為后端的web應(yīng)用。

程序清單1.2

@RestController class App {@RequestMapping("/")String home() {"hello"} }

這個(gè)應(yīng)用可以通過(guò)spring run App.groovy命令在Spring Boot CLI中運(yùn)行。Boot會(huì)分析文件并根據(jù)各種“編譯器自動(dòng)配置(compiler auto-configuration)”標(biāo)示符來(lái)確定其意圖是生成Web應(yīng)用。然后,它會(huì)在一個(gè)嵌入式的Tomcat中啟動(dòng)Spring應(yīng)用上下文,并且使用默認(rèn)的8080端口。打開瀏覽器并導(dǎo)航到給定的URL,隨后將會(huì)加載一個(gè)頁(yè)面并展現(xiàn)簡(jiǎn)單的文本響應(yīng):“hello”。提供默認(rèn)應(yīng)用上下文以及嵌入式容器的這些過(guò)程,能夠讓開發(fā)人員更加關(guān)注于開發(fā)應(yīng)用以及業(yè)務(wù)邏輯,從而不用再關(guān)心繁瑣的樣板式配置。

Boot能夠自動(dòng)確定類所需的功能,這一點(diǎn)使其成為了強(qiáng)大的快速應(yīng)用開發(fā)工具。當(dāng)應(yīng)用在Boot CLI中執(zhí)行時(shí),它們?cè)谑褂脙?nèi)部的Groovy編譯器進(jìn)行構(gòu)建,這個(gè)編譯器可以在字節(jié)碼生成的時(shí)候以編碼的方式探查并修改類。通過(guò)這種方式,使用CLI的開發(fā)人員不僅可以省去定義默認(rèn)配置,在一定程度上甚至可以不用定義特定的導(dǎo)入語(yǔ)句,它們可以在編譯的過(guò)程中識(shí)別出來(lái)并自動(dòng)進(jìn)行添加。除此之外,當(dāng)應(yīng)用在CLI中運(yùn)行時(shí),Groovy內(nèi)置的依賴管理器,“Grape”,將會(huì)解析編譯期和運(yùn)行時(shí)的類路徑依賴,與Boot編譯器的自動(dòng)配置機(jī)制類似。這種方式不僅使得框架更加對(duì)用戶友好,而且能夠讓不同版本的Spring Boot與特定版本的來(lái)自于Spring IO平臺(tái)的庫(kù)相匹配,這樣一來(lái)開發(fā)人員就不用關(guān)心如何管理復(fù)雜的依賴圖和版本結(jié)構(gòu)了。另外,它還有助于快速原型的開發(fā)并生成概念原型的工程代碼。

對(duì)于不是使用CLI構(gòu)建的工程,Boot提供了許多的“starter”模塊,它們定義了一組依賴,這些依賴能夠添加到構(gòu)建系統(tǒng)之中,從而解析框架及其父平臺(tái)所需的特定類庫(kù)。例如,spring-boot-starter-actuator依賴會(huì)引入一組基本的Spring項(xiàng)目,從而實(shí)現(xiàn)應(yīng)用的快速配置和即時(shí)可用。關(guān)于這種依賴,值得強(qiáng)調(diào)的一點(diǎn)就是當(dāng)開發(fā)Web應(yīng)用,尤其是RESTful Web服務(wù)的時(shí)候,如果包含了spring-boot-starter-web依賴,它就會(huì)為你提供啟動(dòng)嵌入式Tomcat容器的自動(dòng)化配置,并且提供對(duì)微服務(wù)應(yīng)用有價(jià)值的端點(diǎn)信息,如服務(wù)器信息、應(yīng)用指標(biāo)(metrics)以及環(huán)境詳情。除此之外,如果引入spring-boot-starter-security模塊的話,actuator會(huì)自動(dòng)配置Spring Security,從而為應(yīng)用提供基本的認(rèn)證以及其他高級(jí)的安全特性。它還會(huì)為應(yīng)用結(jié)構(gòu)引入一個(gè)內(nèi)部的審計(jì)框架,這個(gè)框架可以用來(lái)生成報(bào)告或其他的用途,比如開發(fā)認(rèn)證失敗的鎖定策略。

為了闡述在Java Maven工程中,如何快速地使Spring Web工程準(zhǔn)備就緒,考慮一下程序清單1.3中的應(yīng)用程序代碼。

程序清單1.3

package com.infoq.springboot;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.EnableAutoConfiguration; import org.springframework.web.bind.annotation.*;@RestController @EnableAutoConfiguration public class Application {@RequestMapping("/")public String home() {return "Hello";}public static void main(String[] args) {SpringApplication.run(Application.class, args);} }

在Application類上的@EnableAutoConfiguration注解會(huì)告知Boot要采用一種特定的方式來(lái)對(duì)應(yīng)用進(jìn)行配置。這種方法會(huì)將其他樣板式的配置均假設(shè)為框架默認(rèn)的約定,因此能夠聚焦于如何盡快地使應(yīng)用準(zhǔn)備就緒以便運(yùn)行起來(lái)。Application類是可運(yùn)行的,因此,當(dāng)我們以Java Application的方式運(yùn)行這個(gè)類時(shí),就能啟動(dòng)該應(yīng)用及其嵌入式的容器,這樣也能實(shí)現(xiàn)即時(shí)地開發(fā)。

為了發(fā)布版本而構(gòu)建工程時(shí),Boot的Maven和Gradle插件可以嵌入(hook)到這些構(gòu)建系統(tǒng)的打包過(guò)程中,以生成可執(zhí)行的“胖jar包(fat jar)”,這種jar包含了工程的所有依賴并且能夠以可運(yùn)行jar的方式執(zhí)行。使用Maven打包Boot應(yīng)用只需運(yùn)行mvn package命令,與之類似,使用Gradle時(shí),執(zhí)行g(shù)radle build命令將會(huì)在構(gòu)建的目標(biāo)地址下生成可運(yùn)行的jar。

開發(fā)微服務(wù)

Boot對(duì)Spring應(yīng)用的開發(fā)進(jìn)行了簡(jiǎn)化,提供了模塊化方式導(dǎo)入依賴的能力,強(qiáng)調(diào)了開發(fā)RESTful Web服務(wù)的功能并提供了生成可運(yùn)行jar的能力,這一切都清晰地表明在開發(fā)可部署的微服務(wù)方面Boot框架是一個(gè)強(qiáng)大的工具。正如前面的例子所示,借助于Boot,讓一個(gè)RESTful Web工程運(yùn)行起來(lái)是一件很容易的事情;不過(guò),為了了解Boot所有潛在的功能,我們會(huì)闡述在開發(fā)完整功能的微服務(wù)時(shí),會(huì)遇到的所有繁瑣的事情。在企業(yè)級(jí)基礎(chǔ)設(shè)施領(lǐng)域,微服務(wù)是一種越來(lái)越流行的應(yīng)用架構(gòu),因?yàn)樗軌驅(qū)崿F(xiàn)快速開發(fā)、更小的代碼庫(kù)、企業(yè)級(jí)集成以及模塊化部署。有眾多的框架致力于該領(lǐng)域的開發(fā),該章節(jié)將會(huì)討論使用Boot如何簡(jiǎn)化這一過(guò)程。

數(shù)據(jù)訪問(wèn)

我們可以基于各種目的來(lái)構(gòu)建微服務(wù),但有一點(diǎn)是肯定的,那就是大多數(shù)都需要讀取和寫入數(shù)據(jù)庫(kù)的能力。Spring Boot使數(shù)據(jù)庫(kù)集成變成了一項(xiàng)非常簡(jiǎn)單的任務(wù),因?yàn)樗哂凶詣?dòng)配置Spring Data以訪問(wèn)數(shù)據(jù)庫(kù)的能力。只需在你的工程中將spring-boot-starter-data-jpa包含進(jìn)來(lái),Boot的自動(dòng)配置引擎就能探測(cè)到你的工程需要數(shù)據(jù)訪問(wèn)功能,并且會(huì)在Spring應(yīng)用上下文中創(chuàng)建必要的Bean,這樣你就可以使用Repository和服務(wù)了。為了更具體地闡述這一點(diǎn),請(qǐng)參見(jiàn)程序清單1.4中的Gradle構(gòu)建文件,它列出了一個(gè)基于Groovy的微服務(wù)web應(yīng)用的構(gòu)建結(jié)構(gòu),該應(yīng)用使用了Spring Data對(duì)JPA的支持來(lái)實(shí)現(xiàn)數(shù)據(jù)訪問(wèn)。

程序清單1.4

buildscript {repositories {maven { url "http://repo.spring.io/libs-snapshot" }mavenCentral()}dependencies {classpath("org.springframework.boot:spring-boot-gradle-plugin:1.0.0.RC1")} }apply plugin: 'groovy' apply plugin: 'spring-boot'repositories {mavenCentral()maven { url "http://repo.spring.io/libs-snapshot" } }ext {springBootVersion = "1.0.0.RC1" }dependencies {compile 'org.codehaus.groovy:groovy-all:2.2.1'compile "org.springframework.boot:spring-boot-starter-web:$springBootVersion"compile "org.springframework.boot:spring-boot-starter-data-jpa:$springBootVersion"compile "org.springframework.boot:spring-boot-starter-actuator:$springBootVersion" }

在這個(gè)配置中,Boot的actuator模塊提供了對(duì)hsqldb的依賴,這會(huì)搭建所有必要的依賴——包括模式的創(chuàng)建——因此Spring Data可以使用這個(gè)內(nèi)存數(shù)據(jù)庫(kù)作為數(shù)據(jù)源。這種簡(jiǎn)便的方式能夠讓開發(fā)人員免于在開發(fā)期創(chuàng)建和管理復(fù)雜的XML配置,進(jìn)而能夠快速地開發(fā)數(shù)據(jù)庫(kù)驅(qū)動(dòng)的微服務(wù)。如果在classpath中有H2或Derby數(shù)據(jù)庫(kù)的話,這種自動(dòng)化配置也會(huì)生效。Boot所提供的另一個(gè)便利之處就是能夠快速簡(jiǎn)便地使用相關(guān)數(shù)據(jù)啟動(dòng)應(yīng)用的數(shù)據(jù)庫(kù)模式。這在開發(fā)期是非常有用的,此時(shí)數(shù)據(jù)庫(kù)可能是在內(nèi)存中或者是不穩(wěn)定的,開發(fā)人員需要保證的是在應(yīng)用啟動(dòng)的時(shí)候能夠訪問(wèn)到這些特定的數(shù)據(jù)。為了闡述這一點(diǎn),考慮一下程序清單1.5中的示例JPA實(shí)體,它代表了微服務(wù)所提供的“User”數(shù)據(jù)結(jié)構(gòu)。

程序清單1.5

@Entity class User {@Id@GeneratedValueLong idString usernameString firstNameString lastNameDate createdDateDate lastAccessedBoolean isActive = Boolean.TRUE }

為了啟用代表User對(duì)象的通用數(shù)據(jù),我們只需創(chuàng)建一個(gè)名為schema.sql或data.sql的文件,并將其包含在classpath之中。這個(gè)文件會(huì)在模式創(chuàng)建完成之后執(zhí)行,所以基于程序清單1.5所給出的實(shí)體,我們可以使用SQL語(yǔ)句啟用一個(gè)用戶賬號(hào),如程序清單1.6所示。

程序清單1.6

insert into user(username, first_name, last_name, created_date) values ('danveloper', 'Dan', 'Woods', now())

在啟動(dòng)的時(shí)候,我們所提供的SQL代碼會(huì)執(zhí)行,這樣就能確保有一個(gè)測(cè)試賬號(hào)可以使用。微服務(wù)此時(shí)已經(jīng)具有了數(shù)據(jù)訪問(wèn)的起始點(diǎn),程序清單1.7展現(xiàn)了如何按照Spring Data的開發(fā)模式創(chuàng)建Repository接口,該接口會(huì)作為User實(shí)體的數(shù)據(jù)訪問(wèn)對(duì)象(Data Access Object)。

程序清單1.7

public interface UserRepository extends CrudRepository<User, Long> { }

CrudRepository提供了一些通用的接口方法來(lái)創(chuàng)建、查詢、更新以及刪除對(duì)象和對(duì)象集合。應(yīng)用所需的其他特定功能可以按照Spring Data的Repository開發(fā)約定進(jìn)行定義。一旦UserRepository接口創(chuàng)建成功,Boot的spring-data-jpa層會(huì)在工程中探測(cè)到它,并將其添加到Spring應(yīng)用上下文之中,這樣對(duì)于controller和sevice對(duì)象來(lái)說(shuō),它就成為可以進(jìn)行自動(dòng)注入的可選對(duì)象。這種自動(dòng)化的配置只有在Boot應(yīng)用要求按照這種方式初始化的時(shí)候才生效,這是通過(guò)存在@EnableAutoConfiguration注解來(lái)標(biāo)識(shí)的。借助程序清單1.8中所實(shí)現(xiàn)的controller,微服務(wù)現(xiàn)在就可以定義RESTful端點(diǎn)了,服務(wù)的使用者可以獲取到User的列表或單個(gè)User。

程序清單1.8

@RestController @EnableAutoConfiguration @RequestMapping("/user") class UserController {@AutowiredUserRepository repository@RequestMapping(method=[RequestMethod.GET])def get(Long id) {id ? repository.findOne(id) : repository.findAll()}public static void main(String[] args) {SpringApplication.run UserController, args} }

在啟動(dòng)的時(shí)候,應(yīng)用將會(huì)輸出日志,表明Hibernate按照User實(shí)體的定義創(chuàng)建數(shù)據(jù)庫(kù)結(jié)構(gòu),在應(yīng)用初始化的最后,Boot還會(huì)從schema.sql文件中導(dǎo)入數(shù)據(jù)。

在開發(fā)微服務(wù)應(yīng)用時(shí),需要特別注意的一點(diǎn)是使用了@RequestMapping注解。這不是Boot特定的注解。不過(guò),因?yàn)锽oot安裝了自己的端點(diǎn)以監(jiān)控應(yīng)用的性能、健康情況以及配置,所以需要確保應(yīng)用的代碼不要與這些內(nèi)置的提供詳情的路徑解析相沖突。鑒于此,如果有從請(qǐng)求路徑中解析屬性的需求(在我們的場(chǎng)景中,也就是user的id屬性),那么我們需要仔細(xì)考慮這個(gè)動(dòng)態(tài)的屬性解析會(huì)對(duì)微服務(wù)的其他行為產(chǎn)生什么影響。在本例中,只是簡(jiǎn)單地將controller映射到/user端點(diǎn)而不是根上下文,就能允許Boot的端點(diǎn)也可以進(jìn)行訪問(wèn)。

微服務(wù)所提供的數(shù)據(jù)并不一定全部適合關(guān)系型結(jié)構(gòu),針對(duì)這一點(diǎn)Spring Boot也暴露了一些模塊,從而讓開發(fā)人員可以使用Spring Data的MongoDB和Redis項(xiàng)目,不過(guò)依然采取特定的方式來(lái)進(jìn)行配置。Spring Data用來(lái)定義數(shù)據(jù)訪問(wèn)對(duì)象(Data Access Object)的高層框架,這樣快速切換JPA與非JPA數(shù)據(jù)源會(huì)變得非常容易。參見(jiàn)程序清單1.9,它展現(xiàn)了一個(gè)重新定義的UserRepository接口,這個(gè)接口設(shè)計(jì)為使用MongoDB取代JPA。

程序清單1.9

public interface UserRepository extends MongoRepository<User, Long> { }

MongoRepository接口也擴(kuò)展了CrudRepository,因此微服務(wù)的Controller代碼,也就是程序清單1.8所示并不需要修改。為了實(shí)現(xiàn)與MongoDB的集成,工程唯一要做的就是在應(yīng)用的classpath中包含spring-boot-starter-data-mongodb。程序清單1.4所示的Gradle構(gòu)建文件需要稍微調(diào)整一下依賴的部分,如程序清單1.10所示。

程序清單1.10

dependencies {compile 'org.codehaus.groovy:groovy-all:2.2.1'compile "org.springframework.boot:spring-boot-starter-web:$springBootVersion"compile "org.springframework.boot:spring-boot-starter-data-mongodb:$springBootVersion"compile "org.springframework.boot:spring-boot-starter-actuator:$springBootVersion" }

MongoDB依賴都置于classpath之中以后,Boot將會(huì)自動(dòng)配置Spring Data連接到localhost上的數(shù)據(jù)庫(kù),并且默認(rèn)的數(shù)據(jù)庫(kù)名為test。在這個(gè)庫(kù)中,將會(huì)自動(dòng)創(chuàng)建User集合(按照MongoDB的標(biāo)準(zhǔn)),微服務(wù)現(xiàn)在就能使用MongoDB作為后端了。對(duì)非JPA的數(shù)據(jù)存儲(chǔ)來(lái)說(shuō),初始化數(shù)據(jù)比其他的方式更為簡(jiǎn)單,這主要是因?yàn)樗荒茚槍?duì)MongoDB的文檔存儲(chǔ)和Redis的鍵值存儲(chǔ)運(yùn)行SQL文件。鑒于Spring Data會(huì)使用這些存儲(chǔ)的持久化實(shí)例,這就意味著開發(fā)期創(chuàng)建的數(shù)據(jù)需要在重啟后保留。為了持久化數(shù)據(jù),我們需要修改微服務(wù)的controller,這樣服務(wù)的使用者就能創(chuàng)建User實(shí)例了。我們也可以將微服務(wù)的UserController進(jìn)行修改,使其符合通用的RESTful API結(jié)構(gòu),讓controller以不同的方式處理不同的HTTP方法。程序清單1.11展現(xiàn)了為controller添加創(chuàng)建新User實(shí)例的功能。

程序清單1.11

@RestController @RequestMapping("/user") @EnableAutoConfiguration class UserController {@AutowiredUserRepository repository@RequestMapping(method=[RequestMethod.GET])def get(Long id) {id ? repository.findOne(id) : repository.findAll()}@RequestMapping(method=[RequestMethod.POST])def create(@RequestBody User user) {repository.save useruser}public static void main(String[] args) {SpringApplication.run UserController, args} }

當(dāng)微服務(wù)的使用者往應(yīng)用的端點(diǎn)上發(fā)送一個(gè)HTTP POST請(qǐng)求時(shí),Spring將會(huì)把請(qǐng)求體轉(zhuǎn)換為User實(shí)例。代碼接下來(lái)會(huì)使用UserRepository將這個(gè)對(duì)象存儲(chǔ)到MongoDB集合之中。使用curl創(chuàng)建User實(shí)例的樣例如程序清單1.12所示。

程序清單1.12

curl -v -H "Content-Type: application/json" -d "{ \"username\": \"danveloper\", \"firstName\": \"Dan\", \"lastName\": \"Woods\", \"createdDate\": \"2014-02-02T00:00:00\" }" http://localhost:8080/user

按照Boot針對(duì)Mongo數(shù)據(jù)源的特定配置,新的User實(shí)例默認(rèn)會(huì)持久化到本地Mongo實(shí)例的test數(shù)據(jù)庫(kù)的user集合之中。如果我們打開web瀏覽器并對(duì)微服務(wù)發(fā)起一個(gè)HTTP GET請(qǐng)求,我們就能看到所創(chuàng)建的user存在于返回的列表之中。

配置

我們可以很快地重寫Spring Boot的默認(rèn)配置。默認(rèn)情況下,應(yīng)用的配置可以使用Java屬性文件來(lái)進(jìn)行定義,這個(gè)文件名為application.properties并且位于應(yīng)用的classpath根目錄下。不過(guò),一種更好的方式是使用?YAML配置,它提供了結(jié)構(gòu)化以及嵌套的配置。在應(yīng)用的運(yùn)行時(shí)類路徑之中包含snakeyaml之后,你的工程就可以在application.yml文件中直接定義配置了。為了詳述這一點(diǎn),考慮程序清單1.13的示例YAML配置,這里列出了應(yīng)用的嵌入式HTTP服務(wù)器(默認(rèn)是Tomcat,也可選擇Jetty)的各種設(shè)置項(xiàng)。

程序清單1.13

# Server settings (ServerProperties) server:port: 8080address: 127.0.0.1sessionTimeout: 30contextPath: /# Tomcat specificstomcat:accessLogEnabled: falseprotocolHeader: x-forwarded-protoremoteIpHeader: x-forwarded-forbasedir:backgroundProcessorDelay: 30 # secs

允許重寫B(tài)oot的自動(dòng)化配置,這一點(diǎn)能夠使你的應(yīng)用從原型轉(zhuǎn)化為真正的產(chǎn)品,Boot使用相同的application.yml文件進(jìn)行配置,這樣就會(huì)非常容易。自動(dòng)化配置的指令被設(shè)計(jì)的盡可能簡(jiǎn)短,所以當(dāng)使用actuator構(gòu)建微服務(wù)時(shí),會(huì)安裝一個(gè)配置屬性的端點(diǎn),也就是/configprops,當(dāng)確定哪些指令需要重寫時(shí)可以進(jìn)行參考。如果我們的微服務(wù)要使用持久化數(shù)據(jù)源,如MySQL,那么只需將MySQL的Java驅(qū)動(dòng)添加到運(yùn)行時(shí)classpath中,然后在application.yml中添加必要的配置指令即可,如程序清單1.14所示。

程序清單1.14

spring:datasource:driverClassName: com.mysql.jdbc.Driverurl: jdbc:mysql://localhost:3306/proddb username: rootpassword

在一些場(chǎng)景下你可能需要更為靈活的配置,Boot允許你通過(guò)Java的系統(tǒng)屬性(System properties)重寫很多它的默認(rèn)配置。例如,如果你的應(yīng)用需要在部署到產(chǎn)品化環(huán)境中使用不同的數(shù)據(jù)庫(kù)用戶,那么username配置指令可以通過(guò)標(biāo)準(zhǔn)的Java系統(tǒng)屬性傳入到應(yīng)用之中,而這需要切換到命令行中執(zhí)行-Dspring.datasource.username=user。關(guān)于這一點(diǎn)更為現(xiàn)實(shí)的場(chǎng)景是云部署環(huán)境,如Cloud Foundry或Heroku,這些平臺(tái)需要應(yīng)用啟動(dòng)特定的HTTP端口,這一點(diǎn)通過(guò)操作系統(tǒng)的環(huán)境變量可以實(shí)現(xiàn)。Boot能夠從系統(tǒng)屬性繼承得到配置,這樣你的應(yīng)用就可以在命令行中使用-Dserver.port=$PORT來(lái)得到HTTP端口。在開發(fā)微服務(wù)時(shí),這是一種相當(dāng)有用的特性,因?yàn)樗梢宰屛⒎?wù)應(yīng)用運(yùn)行在各種環(huán)境配置之中。

外部化配置

微服務(wù)必須要支持的很重要的一點(diǎn)就是外部化配置。這種配置可以包含任何的內(nèi)容,從占位符信息到數(shù)據(jù)庫(kù)配置等等,在初始規(guī)劃和構(gòu)建應(yīng)用原型時(shí),這是必須要考慮的架構(gòu)內(nèi)容。在Spring IO平臺(tái)中,已經(jīng)存在各種導(dǎo)入配置的策略,但是應(yīng)用能夠以多種方式使用配置所造成的后果往往是產(chǎn)生冗長(zhǎng)的編碼性耦合。

Boot一個(gè)很棒的特性在于它能管理外部化的配置并將其轉(zhuǎn)換為對(duì)象結(jié)構(gòu),這個(gè)對(duì)象可以在整個(gè)應(yīng)用上下文中使用。創(chuàng)建一個(gè)簡(jiǎn)單老式的Java/Groovy對(duì)象(Plain Old Java/Groovy Object),并使用@ConfigurationProperties注解,那么這個(gè)對(duì)象就能使用Boot配置結(jié)構(gòu)中預(yù)先定義的name名下的配置項(xiàng)。更具體一點(diǎn)來(lái)講,考慮一下程序清單1.15中的POGO,它能夠得到application.key下的配置指令。

程序清單1.15

@ConfigurationProperties(name = "application") class ApplicationProperties {String nameString version }

當(dāng)ApplicationProperties對(duì)象在Spring上下文中創(chuàng)建完成之后,Boot將會(huì)識(shí)別出它是一個(gè)配置對(duì)象,并且會(huì)按照運(yùn)行時(shí)classpath之中application.properties或application.yml文件中的配置指令填充它的屬性。因此,如果我們?cè)谖⒎?wù)的application.yml文件中添加application內(nèi)容區(qū)的話,如程序清單1.16所示,那么我們就可以在應(yīng)用的其他部分以編程的方式訪問(wèn)這些配置指令。

程序清單1.16

application:name: sb-ms-custdeplversion: 0.1-CUSTOMER

這些配置指令可以有各種用途,要訪問(wèn)這些指令的唯一要求就是代表它們的POJO/POGO必須是Spring應(yīng)用上下文的成員。Boot能夠?qū)⒁粋€(gè)controller作為Spring Java配置對(duì)象,這樣就能很容易地管理配置bean與應(yīng)用上下文的集成,如程序清單1.17所示。

程序清單1.17

@RestController @Configuration @RequestMapping("/appinfo") @EnableAutoConfiguration class AppInfoController {@AutowiredApplicationProperties applicationProperties@RequestMapping(method=[RequestMethod.GET])def get() {[name: applicationProperties.name,version: applicationProperties.version]}@BeanApplicationProperties applicationProperties() {new ApplicationProperties()}public static void main(String[] args) {SpringApplication.run UserController, args} }

程序清單1.17中的樣例代碼可能有些牽強(qiáng),不過(guò),即便是在更為復(fù)雜的場(chǎng)景下,如何使用Boot來(lái)訪問(wèn)應(yīng)用特定配置的原則是相同的。配置類也支持嵌套式的對(duì)象圖,這樣來(lái)自于配置中的深層數(shù)據(jù)就能更便利地進(jìn)行訪問(wèn),也有了更好的語(yǔ)義。例如,如果我們想要得到的配置指令是application.根下的那些metrics key,那么可以在ApplicationProperties?POGO中添加一個(gè)嵌套對(duì)象來(lái)表示這些值,如程序清單1.18所示。

程序清單1.18

@ConfigurationProperties(name = "application") class ApplicationProperties {String nameString versionfinal Metrics metrics = new Metrics()static class Metrics {String dbExecutionTimeKey} }

現(xiàn)在,我們的application.yml文件可以如程序清單1.19所示,它在application.代碼塊中包含了metrics配置。

程序清單1.19

application:name: sb-ms-custdeplversion: 0.1-CUSTOMERmetrics:dbExecutionTimeKey: user.get.db.time

當(dāng)我們需要訪問(wèn)application.metrics.dbExecutionTimeKey的值時(shí),能夠以編程的方式通過(guò)ApplicationProperties對(duì)象來(lái)進(jìn)行訪問(wèn)。

為了在整個(gè)應(yīng)用之中使用application.properties或application.yml文件中的這些配置指令,我們并不是必須要將其轉(zhuǎn)換為對(duì)象圖。Boot也為Spring應(yīng)用上下文提供了PropertySourcesPlaceholderConfiguration,這樣的話,來(lái)自于application.properties或application.yml文件的指令或者來(lái)自于Java系統(tǒng)的重寫屬性都可以作為Spring屬性占位符來(lái)使用。Spring的這種機(jī)制能夠讓你以一種特定的語(yǔ)法來(lái)為屬性定義占位符值,如果Spring發(fā)現(xiàn)了占位符配置的話,就會(huì)用這個(gè)配置來(lái)進(jìn)行填充。作為示例,我們可以在controller中使用@Value注解來(lái)直接訪問(wèn)application.metrics.dbExecutionTimeKey,如程序清單1.20所示。

程序清單1.20

@RestController @RequestMapping("/user") @EnableAutoConfiguration class UserController {@AutowiredUserRepository repository@AutowiredGaugeService gaugeService@Value('${application.metrics.dbExecutionTimeKey}')String dbExecutionKey@RequestMapping(method=[RequestMethod.GET])def get(Long id) {def start = new Date().timedef result = id ? repository.findOne(id) : repository.findAll()gaugeService.submit dbExecutionKey, new Date().time - startresult}public static void main(String[] args) {SpringApplication.run UserController, args} }

關(guān)于應(yīng)用指標(biāo)的報(bào)告,后面會(huì)有更為詳細(xì)的介紹,但現(xiàn)在重要的一點(diǎn)在于,理解@Value注解如何與Spring屬性占位符一起使用,使Boot能夠自動(dòng)注入值,從而滿足這個(gè)微服務(wù)的特定配置需求。

安全

在微服務(wù)的開發(fā)中,對(duì)于完備安全場(chǎng)景的需求會(huì)持續(xù)增長(zhǎng)。為了滿足這種需求,Boot引入了強(qiáng)大完整的Spring Security,并且提供了自動(dòng)配置的功能,以快速簡(jiǎn)便地啟用安全層。只需在應(yīng)用的classpath中包含spring-boot-starter-security模塊就能使Boot引入一些安全特性,如跨站腳本防護(hù)(cross-site scripting protection)并且會(huì)添加頭信息以防止點(diǎn)擊劫持(click-jacking)。除此之外,添加一條簡(jiǎn)單的配置指令就能啟用基本認(rèn)證來(lái)保護(hù)你的應(yīng)用,如程序清單1.21所示。

程序清單1.21

security:basic:enabled: true

Boot會(huì)為你提供一個(gè)默認(rèn)的用戶賬號(hào)user和默認(rèn)角色USER,并且會(huì)在應(yīng)用啟動(dòng)的時(shí)候在控制臺(tái)上輸出隨機(jī)生成的密碼。就像Boot的其他功能那樣,對(duì)于內(nèi)置的user賬號(hào),我們可以很容易地指定不同的用戶名和密碼(分別為“secured”和“foo”),這需要通過(guò)明確定義的配置指令來(lái)實(shí)現(xiàn),如程序清單1.22所示。

程序清單1.22

security:basic:enabled: trueuser:name: securedpassword: foo

對(duì)于簡(jiǎn)單的內(nèi)部應(yīng)用或開發(fā)原型來(lái)說(shuō),Boot內(nèi)置的基礎(chǔ)設(shè)施能夠快速地在微服務(wù)中啟用基本認(rèn)證,這是非常有用的。隨著需求的演化,你的應(yīng)用毫無(wú)疑問(wèn)會(huì)需要更細(xì)粒度的安全特性,如保護(hù)端點(diǎn)只能由特定的角色訪問(wèn)。從這個(gè)角度來(lái)看,我們可能希望具有USER角色的調(diào)用者只能讀取數(shù)據(jù)(即GET請(qǐng)求),而對(duì)具有ADMIN角色的調(diào)用者可以讀取和寫入數(shù)據(jù)(即POST請(qǐng)求)。為了做到這一點(diǎn),我們需要在工程的application.yml文件中禁用Boot的基本認(rèn)證自動(dòng)配置功能,并且定義我們自己的user和admin賬號(hào)以及對(duì)應(yīng)的角色。當(dāng)你的需求超過(guò)Boot所提供的默認(rèn)功能時(shí),它通常很快就能實(shí)現(xiàn),這可以作為佐證這一點(diǎn)的又一個(gè)例子。為了更具體地闡述這一點(diǎn),考慮一下程序清單1.23中的代碼。這個(gè)樣例可以闡述如何發(fā)揮Spring Security所有潛在的功能以及更為復(fù)雜的認(rèn)證策略,如基于JDBC后端、OpenID或單點(diǎn)登錄(Single-Sign On)。

程序清單1.23

@RestController @RequestMapping("/user") @Configuration @EnableGlobalMethodSecurity(securedEnabled = true) @EnableAutoConfiguration class UserController extends WebSecurityConfigurerAdapter {@AutowiredUserRepository repository@RequestMapping(method = [GET])@Secured(['ROLE_USER'])def get(Long id) {id ? repository.findOne(id) : repository.findAll()}@RequestMapping(method = [POST])@Secured(['ROLE_ADMIN'])def create(@RequestBody User user) {repository.save useruser}@Overridevoid configure(AuthenticationManagerBuilder auth) {auth.inMemoryAuthentication().withUser "user" password "password" roles "USER" and() withUser "admin" password "password" roles "USER", "ADMIN"}@Overridevoid configure(HttpSecurity http) throws Exception {BasicAuthenticationEntryPoint entryPoint = new BasicAuthenticationEntryPoint()entryPoint.realmName = "Spring Boot"http.exceptionHandling().authenticationEntryPoint(entryPoint)http.requestMatchers().antMatchers("/**").anyRequest().and().httpBasic().and().anonymous().disable().csrf().disable()}public static void main(String[] args) {SpringApplication.run UserController, args} }

在程序清單1.23的樣例之中,應(yīng)用現(xiàn)在被明確地配置為要基于user和admin用戶賬號(hào)進(jìn)行訪問(wèn),它們的密碼都是password,具有的角色分別是USER和ADMIN。微服務(wù)的GETPOST端點(diǎn)分別通過(guò)USER和ADMIN角色進(jìn)行保護(hù),這就意味著普通用戶可以訪問(wèn)只讀的數(shù)據(jù),而執(zhí)行讀取-寫入操作的話,需要admin用戶憑證。

對(duì)于微服務(wù)來(lái)說(shuō),基本認(rèn)證是很好的一個(gè)選擇,因?yàn)樗裱撕軐?shí)用且廣泛使用的認(rèn)證協(xié)議。換句話說(shuō),很多的API調(diào)用者,包括移動(dòng)應(yīng)用,能夠很容易地使用這一點(diǎn)來(lái)訪問(wèn)你的微服務(wù)。當(dāng)你的認(rèn)證需求超過(guò)了基本認(rèn)證的功能時(shí)(如OpenID或OAuth),微服務(wù)可以使用Spring Security的全部功能來(lái)滿足你的需求。

消息集成

在任何的應(yīng)用中,消息(messaging)都是一種很強(qiáng)大的工具,在一點(diǎn)上,微服務(wù)當(dāng)然也不能例外。使用消息驅(qū)動(dòng)架構(gòu)開發(fā)的應(yīng)用能夠更好地支持可重用性和擴(kuò)展性。Spring Boot能夠讓開發(fā)人員在編寫微服務(wù)時(shí)將消息作為架構(gòu)的核心組成部分,它使用到了Spring IO平臺(tái)的企業(yè)集成模式(Enterprise Integration Patterns)實(shí)現(xiàn),即Spring Integration。Spring Integration提供了開發(fā)消息驅(qū)動(dòng)架構(gòu)的基本結(jié)構(gòu),以及與分布式企業(yè)平臺(tái)集成的模塊。這種能力使得微服務(wù)可以使用來(lái)自抽象消息源的業(yè)務(wù)對(duì)象,這些消息源可以在應(yīng)用內(nèi)部,也可能是組織機(jī)構(gòu)內(nèi)部的其他服務(wù)所提供的。

盡管Boot并沒(méi)有提供明確的Spring上下文自動(dòng)化配置,但是它為Spring Integration提供了一個(gè)starter模塊,它會(huì)負(fù)責(zé)引入Spring Integration項(xiàng)目的一系列依賴。這些依賴包括Spring Integration的核心庫(kù)(Core library)、HTTP模塊(用來(lái)進(jìn)行面向HTTP的企業(yè)集成)、IP模塊(用來(lái)進(jìn)行基于Socket的集成操作)、File模塊(用于進(jìn)行文件系統(tǒng)集成)以及Stream模塊(用于支持使用Stream的操作,如stdin和stdout)。這個(gè)starter模塊為開發(fā)人員提供了健壯的消息功能的工具集,可以使已有的基礎(chǔ)設(shè)施適應(yīng)微服務(wù)API。

除了starter模塊,Boot也為通過(guò)CLI構(gòu)建的應(yīng)用提供了編譯器自動(dòng)配置的功能。對(duì)于需要快速構(gòu)建微服務(wù)原型并驗(yàn)證可行性的開發(fā)者來(lái)說(shuō),這種方式提供了一些捷徑。使用企業(yè)級(jí)平臺(tái)的應(yīng)用可以快速地進(jìn)行開發(fā),在轉(zhuǎn)移到正式的工程和構(gòu)建系統(tǒng)之前,就能確認(rèn)其價(jià)值。使用Spring Boot和Spring Integration使一個(gè)消息驅(qū)動(dòng)的微服務(wù)運(yùn)行起來(lái)非常簡(jiǎn)單,如程序清單1.24的樣例代碼所示。

程序清單1.24

@RestController @EnableIntegrationPatterns class App {@Beandef userLookupChannel() {new DirectChannel()}@Beandef userTemplate() {new MessagingTemplate(userLookupChannel())}@RequestMapping(method=[RequestMethod.GET])def get(@RequestParam(required=false) Long id) {userTemplate().convertSendAndReceive( id ? id : "")} }class User {Long id }@MessageEndpoint class UserLookupObject {@ServiceActivator(inputChannel="userLookupChannel")def get(Long id) {id ? new User(id:id) : new User()} }

使用消息驅(qū)動(dòng)的方式來(lái)進(jìn)行微服務(wù)的開發(fā)能提供很大的代碼可重用性,并且能夠與底層的服務(wù)提供者實(shí)現(xiàn)相解耦。在更為正式的場(chǎng)景之中,程序清單1.24的代碼可能會(huì)負(fù)責(zé)組合數(shù)據(jù),這些數(shù)據(jù)可能來(lái)自于數(shù)據(jù)庫(kù)調(diào)用和企業(yè)組織中某個(gè)外部的服務(wù)集成。Spring Integration具有內(nèi)置的設(shè)施用來(lái)進(jìn)行負(fù)載路由(payload routing)和處理器鏈(handler chaining),這對(duì)于組合不同的數(shù)據(jù)來(lái)說(shuō),是一個(gè)很有吸引力的方案,我們的微服務(wù)可以作為一個(gè)數(shù)據(jù)的提供者(provider)。

提供度量指標(biāo)

微服務(wù)最重要的一個(gè)特性可能就是為報(bào)表終端(reporting agent)提供度量指標(biāo)。不像那些功能完備的Web應(yīng)用,微服務(wù)是輕量級(jí)的,設(shè)計(jì)時(shí)可能就不會(huì)規(guī)劃提供報(bào)表界面或完備的接口來(lái)分析服務(wù)的活動(dòng)。這種類型的操作最好是留給專門進(jìn)行數(shù)據(jù)聚合和分析的應(yīng)用,這些數(shù)據(jù)能夠用來(lái)進(jìn)行穩(wěn)定性、性能以及商務(wù)智能的監(jiān)控。基于這樣的前提,微服務(wù)應(yīng)該為這些工具提供端點(diǎn),從而更加容易地獲取有關(guān)該服務(wù)活動(dòng)的數(shù)據(jù)。而報(bào)表工具負(fù)責(zé)將數(shù)據(jù)聚合到一個(gè)視圖或報(bào)告中,對(duì)于關(guān)心數(shù)據(jù)的人這才是有意義的。

微服務(wù)的一些指標(biāo)如穩(wěn)定性和性能,對(duì)所有的應(yīng)用都是通用的,但是與業(yè)務(wù)操作相關(guān)的指標(biāo)必須由應(yīng)用本身來(lái)具體進(jìn)行管理。針對(duì)這一點(diǎn),Spring Boot的actuator模塊為開發(fā)人員提供了一種機(jī)制,允許開發(fā)人員通過(guò)/metrics端點(diǎn)以編碼的方式暴露微服務(wù)狀態(tài)的細(xì)節(jié)。Boot將指標(biāo)拆分為“counter”和“gauge”兩種類別:counter是所有以Number類型來(lái)展現(xiàn)的指標(biāo),而gauge是衡量雙精度計(jì)算的指標(biāo)。為了讓微服務(wù)的開發(fā)人員更加容易地使用指標(biāo),Boot暴露了CounterService和GaugeService,它們可以自動(dòng)織入到應(yīng)用上下文之中。請(qǐng)參見(jiàn)程序清單1.25的樣例,它闡述了如何通過(guò)CounterService對(duì)外暴露點(diǎn)擊數(shù)。

程序清單1.25

@RestController @RequestMapping("/user") @EnableAutoConfiguration class UserController {@AutowiredUserRepository repository@AutowiredCounterService counterService@RequestMapping(method = [GET])def get() {get(null)}@RequestMapping(value="/{id}", method = [GET])def get(@PathVariable Long id) {counterService.increment id ? "queries.by.id.$id" : "queries.without.id"id ? repository.findOne(id) : repository.findAll()} }

在點(diǎn)擊/user端點(diǎn)時(shí),有可能提供ID也有可能不提供ID,/metrics端點(diǎn)都會(huì)在counter.父節(jié)點(diǎn)下記錄新的key。例如,如果我們只是查詢/user端點(diǎn)而不帶有ID的話,那么就會(huì)注冊(cè)counter.queries.without.id指標(biāo)。類似的,如果我們帶有ID的話,那么就會(huì)看到有一個(gè)counter.queries.by.id.<id>的key,它能用來(lái)標(biāo)記對(duì)于給定的ID已經(jīng)進(jìn)行了多少次查詢。這些指標(biāo)可能會(huì)有助于掌握最經(jīng)常訪問(wèn)的User對(duì)象并指導(dǎo)要采取的行為,如緩存或數(shù)據(jù)庫(kù)索引。類似于遞增指標(biāo)的數(shù)值,CounterService也允許將指標(biāo)的值將為零。這對(duì)于跟蹤打開的連接數(shù)或其他頻率分布(histographic)的測(cè)量都是很有用處的。

gauge是稍微有所不同的一種類型指標(biāo),它會(huì)進(jìn)行探索性的計(jì)算或基于請(qǐng)求來(lái)確定值。如GaugeService的JavaDocs所述,“gauge”可以測(cè)量任意的值,從方法執(zhí)行的次數(shù)到會(huì)議室的溫度。當(dāng)需要為報(bào)表工具暴露細(xì)節(jié)時(shí),這種類型的測(cè)量尤其適合于使用GaugeService。gauge的指標(biāo)會(huì)在/metrics端點(diǎn)之下進(jìn)行訪問(wèn),并且?guī)в術(shù)auge.前綴。它們的注冊(cè)方式與counter有些差別,如程序清單1.26所示。

程序清單1.26

@RestController @RequestMapping("/user") @EnableAutoConfiguration class UserController {@AutowiredUserRepository repository@AutowiredCounterService counterService@RequestMapping(method = [GET])def get() {get(null)}@RequestMapping(value="/{id}", method = [GET])def get(@PathVariable Long id) {def start = new Date().timedef result = id ? repository.findOne(id) : repository.findAll()def time = new Date().time - startgaugeService.submit("user.get.db.time", time.doubleValue())result} }

默認(rèn)情況下,指標(biāo)會(huì)存儲(chǔ)在一個(gè)易失的內(nèi)存數(shù)據(jù)庫(kù)之中,但Boot同時(shí)也為應(yīng)用上下文提供了MetricsRepository實(shí)現(xiàn),它能支持更為持久化的行為。Boot自帶了一個(gè)RedisMetricsRepository,它能夠自動(dòng)織入進(jìn)來(lái),從而將指標(biāo)存儲(chǔ)到Redis值存儲(chǔ)之中,另外,可以編寫自定義的實(shí)現(xiàn)將指標(biāo)存儲(chǔ)到任意的數(shù)據(jù)存儲(chǔ)形式之中。

Boot還提供了對(duì)Coda Hale Metrics庫(kù)的支持,它會(huì)將以特定名稱開頭的指標(biāo)強(qiáng)制轉(zhuǎn)換為對(duì)應(yīng)的Metrics類型。例如,如果有一個(gè)指標(biāo)是以histogram.開頭,那么這個(gè)值將會(huì)作為Histogram對(duì)象類型。這種自動(dòng)化的強(qiáng)制轉(zhuǎn)換對(duì)于meter.和timer.key也是有效的,而普通的指標(biāo)將會(huì)作為Gauge類型。

一旦微服務(wù)的指標(biāo)在Boot中進(jìn)行了注冊(cè),那么報(bào)表工具就可以通過(guò)/metrics端點(diǎn)來(lái)檢索它們。已命名的指標(biāo)可以通過(guò)/metrics端點(diǎn)獲取,只需將指標(biāo)的key名作為查詢字符串的一部分即可。例如,如果只是訪問(wèn)gauge指標(biāo)下的“user.get.db.time”,報(bào)表工具可以針對(duì)/metrics/gauge.user.get.db.time進(jìn)行查詢。

打包Boot應(yīng)用

正如前面所討論的,Boot提供了Maven和Gradle插件,它為構(gòu)建系統(tǒng)的打包階段提供了一種鉤子(hook),以產(chǎn)生所謂的“胖jar”,在這種jar中包含了工程的所有依賴。當(dāng)這個(gè)胖jar包執(zhí)行時(shí),應(yīng)用將會(huì)運(yùn)行在與工程開發(fā)期相同的嵌入式容器之中。這種簡(jiǎn)便的方式能夠讓開發(fā)人員省去很多麻煩,因?yàn)樗麄兊牟渴鸢陂_發(fā)期和運(yùn)行時(shí)環(huán)境之中具有相同的依賴結(jié)構(gòu)。這也能夠緩解運(yùn)維團(tuán)隊(duì)的焦慮,他們不用擔(dān)心部署的場(chǎng)景,因?yàn)樵诓渴饡r(shí)一個(gè)錯(cuò)誤配置的運(yùn)行時(shí)容器可能會(huì)帶有某個(gè)特定的依賴,而在項(xiàng)目的開發(fā)期所依賴的可能是另外一個(gè)。

為了在Maven下執(zhí)行打包,只需執(zhí)行mvn package命令。Spring Boot的插件會(huì)備份工程所創(chuàng)建的原始jar并且在文件名上添加“.original”。在這里,能夠得到可運(yùn)行的jar,文件符合Maven artifact的命名約定,它可以按照工程最合適的方式進(jìn)行部署。使用Gradle構(gòu)建Boot工程同樣很簡(jiǎn)單,只需執(zhí)行標(biāo)準(zhǔn)的gradle build命令即可。類似于Maven,Boot插件在原有的打包任務(wù)之后使用Gradle安裝了一個(gè)生命周期事件,并且會(huì)在build/libs目錄下創(chuàng)建胖jar包。對(duì)所生成的胖jar包進(jìn)行檢查的一種方式就是所有依賴的jar都會(huì)位于歸檔文件的lib/目錄下。

打包完成之后,胖jar包就能夠像其他可運(yùn)行的jar文件那樣在命令行中執(zhí)行了,也就是使用$JAVA_HOME/bin/java -jar path/to/myproject.jar命令。啟動(dòng)后,Boot應(yīng)用的日志將會(huì)顯示在控制臺(tái)上。

對(duì)于需要部署到傳統(tǒng)servlet容器之中的應(yīng)用,Boot提供了一種方式以編碼的方式初始化Web配置。為了使用這一點(diǎn),Boot提供了可選的WebApplicationInitializer,它會(huì)使用servlet容器來(lái)注冊(cè)應(yīng)用,這會(huì)通過(guò)Servlet 3.0 API以編碼的方式注冊(cè)servlet并且會(huì)用到ServletContext。通過(guò)提供SpringBootServletInitializer的子類,Boot應(yīng)用能夠使用嵌入的Spring上下文來(lái)注冊(cè)配置,這個(gè)Spring上下文是在容器初始化的時(shí)候創(chuàng)建的。為了闡述這個(gè)功能,考慮程序清單1.27中的示例代碼。

程序清單1.27

@RestController @EnableAutoConfiguration class Application extends SpringBootServletInitializer {@RequestMapping(method = RequestMethod.GET)String get() {"home"}static void main(String[] args) {SpringApplication.run this, args}@OverrideSpringApplicationBuilder configure(SpringApplicationBuilder application) {application.sources Application} }

Application類中被重寫的configure方法就是使用嵌入式的Spring上下文注冊(cè)應(yīng)用的地方。在更為正式的場(chǎng)景之中,這個(gè)方法可能會(huì)用來(lái)注冊(cè)Spring Java配置類,它會(huì)定義應(yīng)用中所有controller和服務(wù)的bean。

當(dāng)將應(yīng)用打包部署到servlet容器之中時(shí),工程要構(gòu)建為一個(gè)war文件。在Maven工程中,為了適應(yīng)這一點(diǎn),需要移除Boot插件,并且packaging需要明確定義為“war”類型,如程序清單1.28所示。

程序清單1.28

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.example</groupId><artifactId>myproject</artifactId><version>1.0.0-SNAPSHOT</version><packaging>war</packaging><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.0.0.RC1</version></parent><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency></dependencies><repositories><repository><id>spring-snapshots</id><url>http://repo.spring.io/libs-snapshot</url></repository></repositories> </project>

對(duì)這個(gè)工程執(zhí)行mvn install命令會(huì)在target目錄下生成myproject-1.0.0-SNAPSHOT.war文件。使用Gradle構(gòu)建的工程可以使用Gradle War Plugin,它為構(gòu)建war文件暴露了一個(gè)war任務(wù)。類似于Maven的配置,Boot Gradle工程也需要移除所包含的Boot插件。產(chǎn)生war文件的示例Gradle構(gòu)建腳本如程序清單1.29所示。

程序清單1.29

apply plugin: 'java' apply plugin: 'war'repositories {mavenCentral()maven { url "http://repo.spring.io/snapshot" }maven { url "http://repo.spring.io/milestone" } }ext {springBootVersion = '1.0.0.BUILD-SNAPSHOT' }dependencies {compile "org.springframework.boot:spring-boot-starter-web:${springBootVersion}"compile "org.springframework.boot:spring-boot-starter-actuator:${springBootVersion}" }

對(duì)于Boot工程,使用這個(gè)構(gòu)建腳本運(yùn)行Gradle的war任務(wù)將會(huì)在build/libs目錄下產(chǎn)生war文件。

不管是Maven還是Gradle的配置,一旦war文件產(chǎn)生,它就可以部署到任意兼容Servlet 3.0的應(yīng)用服務(wù)器之中。部分兼容的容器包括Tomcat 7+、Jetty 8、Glassfish 3.x、JBoss AS 6.x/7.x以及Websphere 8.0。

延伸閱讀

Spring Boot團(tuán)隊(duì)已經(jīng)編寫了完整的指導(dǎo)和樣例來(lái)闡述框架的功能。Blog文章、參考資料以及API文檔都可以在Spring.IO網(wǎng)站上找到。項(xiàng)目的GitHub頁(yè)面上可以找到示例的工程,更為具體的細(xì)節(jié)可以閱讀Spring Boot的參考手冊(cè)。SpringSourceDev YouTube頻道有一個(gè)關(guān)于Spring Boot的webinar,它概述了這個(gè)項(xiàng)目的目標(biāo)和功能。在去年在倫敦舉行的Groovy & Grails Exchange上,David Dawson做了一個(gè)使用Spring Boot開發(fā)微服務(wù)的演講。

?

總結(jié)

以上是生活随笔為你收集整理的深入学习微框架:Spring Boot的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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

精品国产青草久久久久福利 | 国产香蕉尹人视频在线 | 亚洲自偷自拍另类第1页 | 97夜夜澡人人双人人人喊 | 国产精品多人p群无码 | 国产色精品久久人妻 | 97久久国产亚洲精品超碰热 | 国产精品久久久一区二区三区 | 丰满少妇熟乱xxxxx视频 | 国产午夜福利亚洲第一 | 永久黄网站色视频免费直播 | 国产成人人人97超碰超爽8 | 欧美怡红院免费全部视频 | 蜜臀av无码人妻精品 | 亚洲国产欧美国产综合一区 | 成人片黄网站色大片免费观看 | 国产精品沙发午睡系列 | 久久99精品久久久久久动态图 | 欧洲欧美人成视频在线 | 国产在线精品一区二区三区直播 | 亚洲一区二区三区 | 4hu四虎永久在线观看 | 中文字幕人妻丝袜二区 | 精品人妻中文字幕有码在线 | 亚洲另类伦春色综合小说 | 精品国产一区二区三区av 性色 | 思思久久99热只有频精品66 | 国内综合精品午夜久久资源 | 精品国产麻豆免费人成网站 | 欧美性色19p | 国产成人亚洲综合无码 | 麻豆果冻传媒2021精品传媒一区下载 | 精品乱码久久久久久久 | 国产做国产爱免费视频 | 亚洲精品一区二区三区在线观看 | 日本肉体xxxx裸交 | 女高中生第一次破苞av | 大乳丰满人妻中文字幕日本 | 久久国产精品二国产精品 | 欧美日韩综合一区二区三区 | 亚洲精品成a人在线观看 | 亚洲欧洲中文日韩av乱码 | 狠狠色欧美亚洲狠狠色www | 日日鲁鲁鲁夜夜爽爽狠狠 | 无码吃奶揉捏奶头高潮视频 | 欧美喷潮久久久xxxxx | av香港经典三级级 在线 | 激情内射亚州一区二区三区爱妻 | 国产成人精品视频ⅴa片软件竹菊 | 日日天干夜夜狠狠爱 | 欧美 日韩 人妻 高清 中文 | 暴力强奷在线播放无码 | 中文字幕乱码亚洲无线三区 | 欧美人与动性行为视频 | 精品一区二区不卡无码av | 宝宝好涨水快流出来免费视频 | 性欧美videos高清精品 | 欧美xxxx黑人又粗又长 | 纯爱无遮挡h肉动漫在线播放 | 久久aⅴ免费观看 | 国产在线无码精品电影网 | 性生交大片免费看女人按摩摩 | 日韩精品无码免费一区二区三区 | 亚洲人成影院在线无码按摩店 | 成人免费无码大片a毛片 | 中文字幕人妻无码一夲道 | 亚洲成av人影院在线观看 | 国精产品一品二品国精品69xx | 日本乱偷人妻中文字幕 | 牲交欧美兽交欧美 | 国产精品亚洲一区二区三区喷水 | 免费观看激色视频网站 | 少妇人妻大乳在线视频 | 又大又硬又黄的免费视频 | 天天做天天爱天天爽综合网 | 成熟人妻av无码专区 | 国产色视频一区二区三区 | 午夜不卡av免费 一本久久a久久精品vr综合 | 亚洲va欧美va天堂v国产综合 | 精品国产一区二区三区av 性色 | 小sao货水好多真紧h无码视频 | 精品久久8x国产免费观看 | 亚洲成av人在线观看网址 | 国产九九九九九九九a片 | 噜噜噜亚洲色成人网站 | 免费人成在线视频无码 | 久久久久久国产精品无码下载 | 国产亚洲视频中文字幕97精品 | 久久久久久av无码免费看大片 | 亚洲欧美精品aaaaaa片 | 台湾无码一区二区 | 搡女人真爽免费视频大全 | 无码国产激情在线观看 | 国产精品国产自线拍免费软件 | 亚洲精品久久久久久久久久久 | 久久久精品456亚洲影院 | 欧洲精品码一区二区三区免费看 | 成人欧美一区二区三区 | 久久精品中文字幕一区 | www一区二区www免费 | 白嫩日本少妇做爰 | 国产午夜福利亚洲第一 | 一二三四在线观看免费视频 | 欧美性猛交内射兽交老熟妇 | 99久久亚洲精品无码毛片 | 天堂一区人妻无码 | 国产超级va在线观看视频 | 黑人巨大精品欧美黑寡妇 | 久久综合九色综合欧美狠狠 | 波多野结衣av在线观看 | 国产精品-区区久久久狼 | 粉嫩少妇内射浓精videos | 夜夜夜高潮夜夜爽夜夜爰爰 | 国产成人无码av一区二区 | 无码国产激情在线观看 | 国产在线无码精品电影网 | 国产无遮挡又黄又爽又色 | 精品一区二区三区波多野结衣 | 午夜无码人妻av大片色欲 | 国产麻豆精品一区二区三区v视界 | 亚洲中文字幕乱码av波多ji | 国产黄在线观看免费观看不卡 | 性欧美videos高清精品 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 暴力强奷在线播放无码 | 中文字幕日韩精品一区二区三区 | 国产成人精品一区二区在线小狼 | 亚洲精品午夜国产va久久成人 | 99精品视频在线观看免费 | 亚洲精品一区二区三区婷婷月 | 麻豆精品国产精华精华液好用吗 | 超碰97人人做人人爱少妇 | 鲁鲁鲁爽爽爽在线视频观看 | 午夜无码人妻av大片色欲 | 久久www免费人成人片 | 波多野结衣av一区二区全免费观看 | 亚洲小说图区综合在线 | 久久精品国产日本波多野结衣 | 久久久无码中文字幕久... | 久久久久久国产精品无码下载 | 成人无码精品一区二区三区 | 成在人线av无码免观看麻豆 | 人妻天天爽夜夜爽一区二区 | 在线精品亚洲一区二区 | 亚洲 激情 小说 另类 欧美 | аⅴ资源天堂资源库在线 | 十八禁真人啪啪免费网站 | 亚洲精品国产a久久久久久 | 人妻中文无码久热丝袜 | 67194成是人免费无码 | 国产精品沙发午睡系列 | 国产精品亚洲综合色区韩国 | 国产美女极度色诱视频www | 成人影院yy111111在线观看 | 丝袜人妻一区二区三区 | 99久久亚洲精品无码毛片 | 欧美成人午夜精品久久久 | 偷窥日本少妇撒尿chinese | 97精品国产97久久久久久免费 | 伊人久久大香线焦av综合影院 | 亚洲 日韩 欧美 成人 在线观看 | 午夜熟女插插xx免费视频 | 成 人影片 免费观看 | 国产成人综合美国十次 | 国产日产欧产精品精品app | 丰满人妻精品国产99aⅴ | 欧美兽交xxxx×视频 | 奇米影视888欧美在线观看 | 欧美 日韩 亚洲 在线 | 丝袜美腿亚洲一区二区 | 曰本女人与公拘交酡免费视频 | 少妇太爽了在线观看 | 鲁一鲁av2019在线 | 日韩人妻无码一区二区三区久久99 | 最新国产麻豆aⅴ精品无码 | 亚洲成a人片在线观看无码 | 成人精品视频一区二区 | 亚洲成av人片天堂网无码】 | 国产亚洲美女精品久久久2020 | 超碰97人人做人人爱少妇 | 欧美一区二区三区视频在线观看 | 中文精品久久久久人妻不卡 | 午夜不卡av免费 一本久久a久久精品vr综合 | 内射后入在线观看一区 | 国产69精品久久久久app下载 | 亚洲大尺度无码无码专区 | 少妇人妻av毛片在线看 | 一区二区传媒有限公司 | 国产精品久久久久久亚洲毛片 | 精品国产一区二区三区四区在线看 | 六月丁香婷婷色狠狠久久 | 欧美激情内射喷水高潮 | 1000部夫妻午夜免费 | 亚洲国产欧美在线成人 | 国产片av国语在线观看 | 天天躁日日躁狠狠躁免费麻豆 | 久久国产36精品色熟妇 | www国产亚洲精品久久网站 | 玩弄中年熟妇正在播放 | 欧美日韩人成综合在线播放 | 中文字幕乱码人妻无码久久 | 国产综合久久久久鬼色 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产精品18久久久久久麻辣 | 色婷婷av一区二区三区之红樱桃 | 中文字幕人妻丝袜二区 | √天堂资源地址中文在线 | 少妇无套内谢久久久久 | 蜜桃臀无码内射一区二区三区 | 亚洲精品国产精品乱码视色 | 无码av岛国片在线播放 | 久久国产精品萌白酱免费 | 性做久久久久久久免费看 | 六十路熟妇乱子伦 | 亚洲自偷自拍另类第1页 | 中文字幕 人妻熟女 | 蜜桃av抽搐高潮一区二区 | 久热国产vs视频在线观看 | 国产精品久久久一区二区三区 | 波多野结衣av一区二区全免费观看 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲精品久久久久久久久久久 | 久久久久成人精品免费播放动漫 | 日韩精品无码一区二区中文字幕 | 一本久久a久久精品vr综合 | 性做久久久久久久免费看 | 人人爽人人澡人人人妻 | 在线天堂新版最新版在线8 | 国内综合精品午夜久久资源 | 久久亚洲日韩精品一区二区三区 | 国产成人亚洲综合无码 | 狠狠亚洲超碰狼人久久 | 人人妻人人澡人人爽精品欧美 | 玩弄中年熟妇正在播放 | 国产莉萝无码av在线播放 | 免费无码午夜福利片69 | 亚洲色偷偷偷综合网 | 亚洲熟妇色xxxxx欧美老妇y | 精品无码av一区二区三区 | 鲁鲁鲁爽爽爽在线视频观看 | 青青青手机频在线观看 | 福利一区二区三区视频在线观看 | 国产精品无套呻吟在线 | 精品国产成人一区二区三区 | 精品无码一区二区三区爱欲 | 免费人成在线观看网站 | 国产精华av午夜在线观看 | 久久久久av无码免费网 | 欧美国产日产一区二区 | 亚洲 欧美 激情 小说 另类 | 桃花色综合影院 | 亚洲一区二区三区无码久久 | 欧美人与动性行为视频 | 丝袜人妻一区二区三区 | 精品久久久无码中文字幕 | 国产精品内射视频免费 | 99麻豆久久久国产精品免费 | 强辱丰满人妻hd中文字幕 | 亚洲精品国产a久久久久久 | 国产办公室秘书无码精品99 | 国产av无码专区亚洲awww | 国产精品人人妻人人爽 | 久久精品人人做人人综合试看 | 又湿又紧又大又爽a视频国产 | 亚洲精品一区三区三区在线观看 | www一区二区www免费 | 精品国产aⅴ无码一区二区 | 亚洲男人av香蕉爽爽爽爽 | 4hu四虎永久在线观看 | 亚洲精品www久久久 | 久久精品中文字幕大胸 | 樱花草在线社区www | 无码免费一区二区三区 | 久久久久av无码免费网 | 无码国模国产在线观看 | 99精品国产综合久久久久五月天 | 日产精品99久久久久久 | 精品久久久久香蕉网 | 国产成人午夜福利在线播放 | 日韩精品一区二区av在线 | 日韩欧美中文字幕在线三区 | 成人动漫在线观看 | 婷婷六月久久综合丁香 | 少妇无套内谢久久久久 | 国内精品久久毛片一区二区 | 久久99久久99精品中文字幕 | 伊人久久婷婷五月综合97色 | 欧美国产亚洲日韩在线二区 | 粉嫩少妇内射浓精videos | 波多野结衣乳巨码无在线观看 | 野狼第一精品社区 | av人摸人人人澡人人超碰下载 | 免费网站看v片在线18禁无码 | 人人妻人人澡人人爽欧美一区九九 | 久久婷婷五月综合色国产香蕉 | 日本www一道久久久免费榴莲 | 中文字幕日韩精品一区二区三区 | 亚洲色www成人永久网址 | 亚洲欧美日韩综合久久久 | 免费无码的av片在线观看 | 国产av人人夜夜澡人人爽麻豆 | 久久婷婷五月综合色国产香蕉 | 麻豆av传媒蜜桃天美传媒 | 久久久无码中文字幕久... | 3d动漫精品啪啪一区二区中 | 国产精品久久国产精品99 | 夜夜夜高潮夜夜爽夜夜爰爰 | 国产精品高潮呻吟av久久4虎 | 国产精品va在线观看无码 | 欧美国产日韩久久mv | 欧美精品免费观看二区 | 国产精品久久久av久久久 | 午夜精品久久久久久久 | 久久久久国色av免费观看性色 | 国产亲子乱弄免费视频 | 激情内射亚州一区二区三区爱妻 | 全黄性性激高免费视频 | www成人国产高清内射 | 久久午夜无码鲁丝片秋霞 | 亚洲の无码国产の无码步美 | 动漫av网站免费观看 | www成人国产高清内射 | 亚洲精品国产第一综合99久久 | 成人亚洲精品久久久久软件 | 欧美xxxx黑人又粗又长 | 成 人 网 站国产免费观看 | 精品一区二区三区波多野结衣 | 奇米影视7777久久精品人人爽 | 午夜福利试看120秒体验区 | 国色天香社区在线视频 | 欧美午夜特黄aaaaaa片 | 内射爽无广熟女亚洲 | 亚洲第一无码av无码专区 | 乌克兰少妇性做爰 | 老熟女重囗味hdxx69 | 国产亚洲精品久久久久久 | 亚洲日本va午夜在线电影 | 亚洲精品中文字幕久久久久 | 日本高清一区免费中文视频 | 香蕉久久久久久av成人 | 中文字幕日韩精品一区二区三区 | 天堂无码人妻精品一区二区三区 | 中文字幕无码免费久久9一区9 | 亚洲精品一区二区三区四区五区 | 亚洲精品久久久久avwww潮水 | 18禁止看的免费污网站 | 88国产精品欧美一区二区三区 | 亚洲国产一区二区三区在线观看 | 夜夜影院未满十八勿进 | 国产精品va在线观看无码 | 欧美丰满熟妇xxxx | 人妻插b视频一区二区三区 | 中文字幕乱码人妻二区三区 | 国产亚洲视频中文字幕97精品 | 在线视频网站www色 | www一区二区www免费 | 欧美精品在线观看 | 国产亚洲欧美日韩亚洲中文色 | 少妇人妻av毛片在线看 | 无码国产乱人伦偷精品视频 | 国产av无码专区亚洲a∨毛片 | 乌克兰少妇xxxx做受 | 丝袜 中出 制服 人妻 美腿 | 久久精品视频在线看15 | 国产成人无码一二三区视频 | 久久精品99久久香蕉国产色戒 | 亚洲一区二区观看播放 | 婷婷五月综合激情中文字幕 | 国产猛烈高潮尖叫视频免费 | 久久久精品人妻久久影视 | 日产精品高潮呻吟av久久 | 未满成年国产在线观看 | 国产精品怡红院永久免费 | 夜精品a片一区二区三区无码白浆 | 扒开双腿吃奶呻吟做受视频 | 久久无码专区国产精品s | 无码人妻黑人中文字幕 | 久久综合香蕉国产蜜臀av | 国产福利视频一区二区 | 国精产品一品二品国精品69xx | 在线播放免费人成毛片乱码 | 一个人免费观看的www视频 | 国产乱码精品一品二品 | а天堂中文在线官网 | 131美女爱做视频 | 日日摸日日碰夜夜爽av | 欧美国产日韩久久mv | 国产乱码精品一品二品 | 国产极品美女高潮无套在线观看 | 麻豆精品国产精华精华液好用吗 | 99久久精品国产一区二区蜜芽 | 人人妻人人澡人人爽人人精品浪潮 | 夜精品a片一区二区三区无码白浆 | 欧美熟妇另类久久久久久多毛 | 正在播放老肥熟妇露脸 | 东京热一精品无码av | 三上悠亚人妻中文字幕在线 | 精品国产精品久久一区免费式 | 图片区 小说区 区 亚洲五月 | 九月婷婷人人澡人人添人人爽 | 波多野结衣 黑人 | 国产精品久久久久久无码 | 精品无码国产自产拍在线观看蜜 | 无码人妻丰满熟妇区毛片18 | 精品夜夜澡人妻无码av蜜桃 | 久久国产劲爆∧v内射 | 一区二区传媒有限公司 | 成在人线av无码免费 | 无码国内精品人妻少妇 | 无码人妻丰满熟妇区五十路百度 | 亚洲国产精品毛片av不卡在线 | 成人无码视频在线观看网站 | 中文字幕+乱码+中文字幕一区 | 水蜜桃亚洲一二三四在线 | 伊在人天堂亚洲香蕉精品区 | 老太婆性杂交欧美肥老太 | 国产乱子伦视频在线播放 | 漂亮人妻洗澡被公强 日日躁 | 色老头在线一区二区三区 | 日韩精品无码免费一区二区三区 | 亚洲精品久久久久久久久久久 | 欧美亚洲日韩国产人成在线播放 | 内射欧美老妇wbb | 精品人妻人人做人人爽夜夜爽 | 十八禁真人啪啪免费网站 | 国产精品久久久久久亚洲毛片 | 无码午夜成人1000部免费视频 | аⅴ资源天堂资源库在线 | 亚洲精品久久久久久久久久久 | 亚洲日韩av片在线观看 | 久久这里只有精品视频9 | 永久免费观看国产裸体美女 | 99在线 | 亚洲 | 亚洲精品欧美二区三区中文字幕 | 国产内射老熟女aaaa | 玩弄中年熟妇正在播放 | 小泽玛莉亚一区二区视频在线 | 国色天香社区在线视频 | 久久亚洲精品中文字幕无男同 | 性色欲网站人妻丰满中文久久不卡 | 国产绳艺sm调教室论坛 | 亚洲综合色区中文字幕 | 一区二区传媒有限公司 | 欧美老妇交乱视频在线观看 | 波多野结衣av在线观看 | 水蜜桃色314在线观看 | 亚洲啪av永久无码精品放毛片 | 中文字幕日产无线码一区 | 欧美精品国产综合久久 | 亚洲综合在线一区二区三区 | 亚洲国产精华液网站w | 女人色极品影院 | 麻豆果冻传媒2021精品传媒一区下载 | 亚洲欧美精品aaaaaa片 | 精品少妇爆乳无码av无码专区 | 色情久久久av熟女人妻网站 | 一本精品99久久精品77 | 秋霞成人午夜鲁丝一区二区三区 | 国产香蕉97碰碰久久人人 | 在教室伦流澡到高潮hnp视频 | 亚洲精品无码人妻无码 | 亚洲熟妇色xxxxx欧美老妇 | 国产一区二区不卡老阿姨 | 久激情内射婷内射蜜桃人妖 | 久久人人97超碰a片精品 | 国产精品18久久久久久麻辣 | 18精品久久久无码午夜福利 | 中国女人内谢69xxxx | 国产九九九九九九九a片 | 67194成是人免费无码 | 乌克兰少妇xxxx做受 | 欧美人与动性行为视频 | 97人妻精品一区二区三区 | 欧美人与物videos另类 | 欧美性猛交内射兽交老熟妇 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲一区二区三区含羞草 | 精品国产一区二区三区四区 | av无码不卡在线观看免费 | 日日碰狠狠躁久久躁蜜桃 | 午夜无码区在线观看 | 久久久久久久人妻无码中文字幕爆 | 国精产品一区二区三区 | 国产精品无码成人午夜电影 | 国产精品人妻一区二区三区四 | 国产亚洲精品久久久久久大师 | 成人无码精品一区二区三区 | 国产午夜视频在线观看 | 十八禁真人啪啪免费网站 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲娇小与黑人巨大交 | 婷婷五月综合激情中文字幕 | 色窝窝无码一区二区三区色欲 | 欧美日韩一区二区三区自拍 | 一本色道久久综合狠狠躁 | 成人无码视频免费播放 | 强奷人妻日本中文字幕 | yw尤物av无码国产在线观看 | 日韩亚洲欧美中文高清在线 | 人人爽人人爽人人片av亚洲 | 大地资源中文第3页 | 成人欧美一区二区三区 | 精品国产一区二区三区四区 | 国产小呦泬泬99精品 | 美女扒开屁股让男人桶 | 最近中文2019字幕第二页 | 精品少妇爆乳无码av无码专区 | 俺去俺来也www色官网 | 老熟女重囗味hdxx69 | 久在线观看福利视频 | 欧美午夜特黄aaaaaa片 | 午夜精品一区二区三区的区别 | 亚洲天堂2017无码中文 | 精品无人区无码乱码毛片国产 | 国内综合精品午夜久久资源 | 极品嫩模高潮叫床 | 纯爱无遮挡h肉动漫在线播放 | 国产成人一区二区三区在线观看 | 国产美女精品一区二区三区 | 噜噜噜亚洲色成人网站 | 1000部啪啪未满十八勿入下载 | 中文精品无码中文字幕无码专区 | 久久99精品国产麻豆蜜芽 | 国产精品内射视频免费 | 5858s亚洲色大成网站www | 少妇一晚三次一区二区三区 | 国产人妖乱国产精品人妖 | 久久国语露脸国产精品电影 | 偷窥日本少妇撒尿chinese | 无码乱肉视频免费大全合集 | 中文字幕日韩精品一区二区三区 | 欧美成人免费全部网站 | 欧美xxxx黑人又粗又长 | 野外少妇愉情中文字幕 | 久久 国产 尿 小便 嘘嘘 | 欧美35页视频在线观看 | 国产人妻精品一区二区三区不卡 | 成人免费视频一区二区 | 国产无遮挡吃胸膜奶免费看 | 国产绳艺sm调教室论坛 | 亚洲 高清 成人 动漫 | 精品国产av色一区二区深夜久久 | 欧美黑人性暴力猛交喷水 | 人妻尝试又大又粗久久 | 免费国产成人高清在线观看网站 | 99精品无人区乱码1区2区3区 | 欧洲vodafone精品性 | 青青青手机频在线观看 | 日日躁夜夜躁狠狠躁 | 亚洲 高清 成人 动漫 | 狠狠色色综合网站 | 在线视频网站www色 | 欧美zoozzooz性欧美 | 日韩少妇内射免费播放 | 青青草原综合久久大伊人精品 | 无码福利日韩神码福利片 | 欧美第一黄网免费网站 | 亚洲精品一区国产 | 亚洲日韩av一区二区三区四区 | 精品国产精品久久一区免费式 | 伊在人天堂亚洲香蕉精品区 | 国产精品欧美成人 | 伊人久久大香线蕉av一区二区 | 国产成人人人97超碰超爽8 | 久久久国产一区二区三区 | 免费国产黄网站在线观看 | 国产精品99爱免费视频 | 亚洲日本va午夜在线电影 | 国产精品视频免费播放 | av香港经典三级级 在线 | 国产人妻人伦精品 | 老熟妇乱子伦牲交视频 | 国产特级毛片aaaaaaa高清 | 欧美人与禽zoz0性伦交 | 女人被男人躁得好爽免费视频 | 亚洲综合色区中文字幕 | 麻豆人妻少妇精品无码专区 | 国产色视频一区二区三区 | 国产在线精品一区二区高清不卡 | 久久99久久99精品中文字幕 | 久久伊人色av天堂九九小黄鸭 | 午夜熟女插插xx免费视频 | 欧洲熟妇精品视频 | 夫妻免费无码v看片 | 欧美日韩一区二区三区自拍 | 国产亚洲精品久久久久久大师 | 亚洲色大成网站www国产 | 小sao货水好多真紧h无码视频 | 人人妻人人澡人人爽精品欧美 | 中文字幕无码日韩专区 | 波多野结衣aⅴ在线 | 国产9 9在线 | 中文 | 国产综合在线观看 | 小sao货水好多真紧h无码视频 | 亚洲人成网站免费播放 | 成人免费视频视频在线观看 免费 | 99久久久无码国产aaa精品 | av无码不卡在线观看免费 | 野狼第一精品社区 | 午夜精品久久久内射近拍高清 | 精品久久久久久人妻无码中文字幕 | av无码久久久久不卡免费网站 | 麻豆成人精品国产免费 | 在教室伦流澡到高潮hnp视频 | 激情内射亚州一区二区三区爱妻 | 青草视频在线播放 | 亚洲色偷偷男人的天堂 | 亚洲成色www久久网站 | 国内综合精品午夜久久资源 | 久久综合网欧美色妞网 | 国产精品久久久久9999小说 | 未满小14洗澡无码视频网站 | 77777熟女视频在线观看 а天堂中文在线官网 | 欧美野外疯狂做受xxxx高潮 | 大色综合色综合网站 | 日欧一片内射va在线影院 | 国产猛烈高潮尖叫视频免费 | 久久99精品国产麻豆 | 亚洲色欲色欲天天天www | 亚洲成av人片天堂网无码】 | 色婷婷久久一区二区三区麻豆 | 2020久久香蕉国产线看观看 | 久久精品人人做人人综合 | 日本丰满熟妇videos | 野外少妇愉情中文字幕 | 亚洲一区二区观看播放 | 中文字幕人成乱码熟女app | 国产精品多人p群无码 | 久久精品99久久香蕉国产色戒 | 又大又硬又爽免费视频 | 国产成人综合在线女婷五月99播放 | 亚洲国产综合无码一区 | 内射白嫩少妇超碰 | 无码人妻出轨黑人中文字幕 | 亚洲色欲久久久综合网东京热 | 久久97精品久久久久久久不卡 | 美女毛片一区二区三区四区 | 影音先锋中文字幕无码 | 亚洲精品国产精品乱码视色 | 人妻无码αv中文字幕久久琪琪布 | 少妇久久久久久人妻无码 | 中文字幕无码日韩专区 | 日本xxxx色视频在线观看免费 | 久久亚洲国产成人精品性色 | 青青草原综合久久大伊人精品 | 成人试看120秒体验区 | 亚洲色大成网站www国产 | 精品久久久久久亚洲精品 | 国产成人精品必看 | 国产av无码专区亚洲awww | 色 综合 欧美 亚洲 国产 | 日韩欧美中文字幕在线三区 | 丰满少妇人妻久久久久久 | 精品乱子伦一区二区三区 | 人人澡人人妻人人爽人人蜜桃 | 久久99精品久久久久婷婷 | 真人与拘做受免费视频一 | 动漫av网站免费观看 | 伊人久久大香线蕉午夜 | 国产人妻人伦精品1国产丝袜 | 国产一区二区三区日韩精品 | 国产深夜福利视频在线 | 伊在人天堂亚洲香蕉精品区 | 精品无人国产偷自产在线 | 亚洲精品美女久久久久久久 | 熟女体下毛毛黑森林 | 国产乱人偷精品人妻a片 | 欧美兽交xxxx×视频 | 乱码av麻豆丝袜熟女系列 | 天堂亚洲2017在线观看 | 无码国产激情在线观看 | 国产精品怡红院永久免费 | 久久亚洲国产成人精品性色 | 2020久久香蕉国产线看观看 | 免费播放一区二区三区 | 在线观看免费人成视频 | 无码一区二区三区在线 | 人人妻人人澡人人爽精品欧美 | 国产亚洲欧美日韩亚洲中文色 | 亚洲乱码国产乱码精品精 | 无码人妻出轨黑人中文字幕 | 亚洲国产精品无码久久久久高潮 | 国产成人一区二区三区在线观看 | 亚洲色偷偷偷综合网 | 免费观看的无遮挡av | 欧美激情综合亚洲一二区 | 丰满少妇熟乱xxxxx视频 | 综合人妻久久一区二区精品 | 欧洲欧美人成视频在线 | √天堂中文官网8在线 | 中文字幕精品av一区二区五区 | 国产精品国产三级国产专播 | 精品久久综合1区2区3区激情 | 蜜桃视频韩日免费播放 | 欧美乱妇无乱码大黄a片 | 亚洲另类伦春色综合小说 | 97人妻精品一区二区三区 | ass日本丰满熟妇pics | 亚洲性无码av中文字幕 | 野外少妇愉情中文字幕 | 精品国产一区二区三区四区 | 精品少妇爆乳无码av无码专区 | 国产情侣作爱视频免费观看 | 亚拍精品一区二区三区探花 | 欧美熟妇另类久久久久久多毛 | 疯狂三人交性欧美 | 男女猛烈xx00免费视频试看 | 熟妇人妻无码xxx视频 | 中文字幕色婷婷在线视频 | 国产精品亚洲专区无码不卡 | 亚洲国产精品久久久天堂 | 国产人妻人伦精品1国产丝袜 | 97资源共享在线视频 | 免费观看的无遮挡av | 国产性生大片免费观看性 | 亚洲精品成人福利网站 | 99精品久久毛片a片 | 白嫩日本少妇做爰 | 久久久成人毛片无码 | 亚洲国产欧美日韩精品一区二区三区 | 中文字幕无码日韩欧毛 | 色窝窝无码一区二区三区色欲 | 亚洲中文字幕成人无码 | 九九热爱视频精品 | 99er热精品视频 | 色婷婷av一区二区三区之红樱桃 | 亚洲成色www久久网站 | 无码人妻久久一区二区三区不卡 | 欧美激情一区二区三区成人 | 又湿又紧又大又爽a视频国产 | 国产无遮挡吃胸膜奶免费看 | 久久精品国产亚洲精品 | 国产精品久久久久无码av色戒 | 亚洲 另类 在线 欧美 制服 | 鲁大师影院在线观看 | 夜夜躁日日躁狠狠久久av | 国产在线无码精品电影网 | 亚洲一区二区三区四区 | 国产精品自产拍在线观看 | 亚洲精品国产品国语在线观看 | 3d动漫精品啪啪一区二区中 | 午夜无码人妻av大片色欲 | 人妻aⅴ无码一区二区三区 | 成人三级无码视频在线观看 | 欧洲美熟女乱又伦 | 中文字幕久久久久人妻 | 无码人妻久久一区二区三区不卡 | 免费无码午夜福利片69 | 免费中文字幕日韩欧美 | 精品久久久久久人妻无码中文字幕 | 欧美日韩在线亚洲综合国产人 | 成熟人妻av无码专区 | 久久久精品456亚洲影院 | 午夜熟女插插xx免费视频 | 亚洲国产精品久久久天堂 | 在线天堂新版最新版在线8 | 人妻夜夜爽天天爽三区 | 人人妻人人澡人人爽人人精品 | 麻豆成人精品国产免费 | 国産精品久久久久久久 | 久久久国产精品无码免费专区 | 欧美 亚洲 国产 另类 | 久久国产劲爆∧v内射 | 午夜免费福利小电影 | 中文无码伦av中文字幕 | 久久久亚洲欧洲日产国码αv | 久久精品中文字幕大胸 | 成在人线av无码免观看麻豆 | 国产精品久久久 | 久久久久久久人妻无码中文字幕爆 | 成人欧美一区二区三区黑人免费 | 性欧美疯狂xxxxbbbb | 无码人妻av免费一区二区三区 | 人人妻在人人 | 成人试看120秒体验区 | 天堂久久天堂av色综合 | 性做久久久久久久久 | 亚洲伊人久久精品影院 | 久久亚洲中文字幕精品一区 | 成在人线av无码免费 | 18黄暴禁片在线观看 | 免费无码一区二区三区蜜桃大 | 久久五月精品中文字幕 | 国产成人无码a区在线观看视频app | 人人妻人人藻人人爽欧美一区 | 内射老妇bbwx0c0ck | www国产亚洲精品久久久日本 | 久久国产精品萌白酱免费 | 欧美日本日韩 | 亚洲人亚洲人成电影网站色 | 大肉大捧一进一出好爽视频 | 亚洲国产高清在线观看视频 | 久久伊人色av天堂九九小黄鸭 | 一个人看的www免费视频在线观看 | 国产成人av免费观看 | 无码av最新清无码专区吞精 | 国产9 9在线 | 中文 | 亚洲精品久久久久中文第一幕 | 成人精品视频一区二区 | 无码人妻丰满熟妇区五十路百度 | 福利一区二区三区视频在线观看 | 欧美性猛交xxxx富婆 | 国内老熟妇对白xxxxhd | 欧美怡红院免费全部视频 | 又大又硬又爽免费视频 | 国产亚洲精品久久久久久大师 | 国产色在线 | 国产 | 国产乱人伦av在线无码 | 呦交小u女精品视频 | 精品国产青草久久久久福利 | 成熟人妻av无码专区 | 国产真人无遮挡作爱免费视频 | 乱中年女人伦av三区 | 欧美老妇与禽交 | 久久99精品国产.久久久久 | 好屌草这里只有精品 | 亚洲自偷自偷在线制服 | 亚洲の无码国产の无码步美 | 欧洲精品码一区二区三区免费看 | 亚洲一区二区三区偷拍女厕 | 国产激情精品一区二区三区 | 狂野欧美性猛交免费视频 | 久久熟妇人妻午夜寂寞影院 | 国产午夜无码精品免费看 | 性生交大片免费看女人按摩摩 | 久久综合香蕉国产蜜臀av | 亚洲精品成a人在线观看 | 久久国产劲爆∧v内射 | 亚洲一区二区三区国产精华液 | 亚洲一区av无码专区在线观看 | 丰满护士巨好爽好大乳 | 色五月丁香五月综合五月 | 思思久久99热只有频精品66 | 伊人久久大香线焦av综合影院 | 自拍偷自拍亚洲精品被多人伦好爽 | 精品夜夜澡人妻无码av蜜桃 | 久久人人爽人人爽人人片av高清 | 中文字幕色婷婷在线视频 | 纯爱无遮挡h肉动漫在线播放 | 在线播放免费人成毛片乱码 | 国产免费无码一区二区视频 | 午夜福利一区二区三区在线观看 | 久久人人爽人人爽人人片av高清 | 亚洲日韩av片在线观看 | 黑森林福利视频导航 | 99国产精品白浆在线观看免费 | 99麻豆久久久国产精品免费 | 欧美xxxx黑人又粗又长 | 性啪啪chinese东北女人 | 狠狠cao日日穞夜夜穞av | 成在人线av无码免观看麻豆 | 黑人巨大精品欧美一区二区 | 人妻少妇精品久久 | 国产午夜精品一区二区三区嫩草 | 亚洲欧美综合区丁香五月小说 | 18禁止看的免费污网站 | аⅴ资源天堂资源库在线 | 亚洲国产欧美日韩精品一区二区三区 | 无码av免费一区二区三区试看 | 久久婷婷五月综合色国产香蕉 | 玩弄少妇高潮ⅹxxxyw | 欧美xxxx黑人又粗又长 | 波多野结衣乳巨码无在线观看 | 国产av无码专区亚洲awww | 全黄性性激高免费视频 | 99久久99久久免费精品蜜桃 | 狠狠色噜噜狠狠狠狠7777米奇 | 色欲人妻aaaaaaa无码 | 亚洲一区二区三区 | 日本护士毛茸茸高潮 | 久久综合给久久狠狠97色 | 欧美真人作爱免费视频 | 无码国模国产在线观看 | 国产精品亚洲专区无码不卡 | 亚洲无人区午夜福利码高清完整版 | 精品国产成人一区二区三区 | 日韩欧美中文字幕在线三区 | 奇米影视7777久久精品 | 九九在线中文字幕无码 | 中文字幕无码av激情不卡 | 少妇太爽了在线观看 | 精品人妻中文字幕有码在线 | 国产成人无码午夜视频在线观看 | 久久人人爽人人爽人人片av高清 | 亚洲中文字幕在线观看 | 国产精品自产拍在线观看 | 久久久久久久久888 | 国产精品第一区揄拍无码 | 久久久久久亚洲精品a片成人 | 日韩欧美中文字幕在线三区 | 亚洲熟妇自偷自拍另类 | 国产亚洲精品久久久闺蜜 | 九九久久精品国产免费看小说 | 麻豆果冻传媒2021精品传媒一区下载 | 图片区 小说区 区 亚洲五月 | 在线天堂新版最新版在线8 | yw尤物av无码国产在线观看 | 国产精品高潮呻吟av久久 | 亚洲精品国偷拍自产在线观看蜜桃 | 精品一区二区三区波多野结衣 | 国产又粗又硬又大爽黄老大爷视 | 久久久久成人精品免费播放动漫 | 久久久国产精品无码免费专区 | 日韩av激情在线观看 | 亚洲中文字幕在线无码一区二区 | 国产精品久久久午夜夜伦鲁鲁 | 成人精品视频一区二区三区尤物 | 国内揄拍国内精品少妇国语 | 熟女少妇在线视频播放 | 午夜无码区在线观看 | 精品无码av一区二区三区 | 少妇高潮一区二区三区99 | 黄网在线观看免费网站 | 伊人久久大香线蕉av一区二区 | 欧美日韩在线亚洲综合国产人 | 亚洲天堂2017无码 | 大地资源网第二页免费观看 | 欧美变态另类xxxx | 人人澡人人透人人爽 | 中文字幕av日韩精品一区二区 | 中文字幕精品av一区二区五区 | 亚洲性无码av中文字幕 | 日本护士xxxxhd少妇 | 国产极品美女高潮无套在线观看 | 久久国产自偷自偷免费一区调 | 国产精品久久久久久亚洲影视内衣 | 国产网红无码精品视频 | 久久久久久久久888 | 亚洲综合无码久久精品综合 | 国产激情精品一区二区三区 | 扒开双腿疯狂进出爽爽爽视频 | 四虎永久在线精品免费网址 | 又大又硬又爽免费视频 | 人人妻人人澡人人爽精品欧美 | 真人与拘做受免费视频 | 日韩人妻无码中文字幕视频 | 日韩欧美中文字幕在线三区 | 未满成年国产在线观看 | 欧美熟妇另类久久久久久多毛 | 欧美怡红院免费全部视频 | 精品久久久久久人妻无码中文字幕 | 熟妇人妻激情偷爽文 | 野外少妇愉情中文字幕 | 中文无码精品a∨在线观看不卡 | 性做久久久久久久免费看 | 国产偷国产偷精品高清尤物 | 国产一区二区三区四区五区加勒比 | 国产区女主播在线观看 | 色 综合 欧美 亚洲 国产 | 久久成人a毛片免费观看网站 | 久久久www成人免费毛片 | 51国偷自产一区二区三区 | 国产精品久久久久影院嫩草 | 亚洲乱亚洲乱妇50p | 国产精品亚洲综合色区韩国 | 色一情一乱一伦 | 欧美精品一区二区精品久久 | 久久精品国产一区二区三区 | 欧美精品国产综合久久 | 亚洲а∨天堂久久精品2021 | 久久亚洲精品中文字幕无男同 | 国产超级va在线观看视频 | 国内精品久久毛片一区二区 | 国产成人精品一区二区在线小狼 | 日韩视频 中文字幕 视频一区 | 欧美三级a做爰在线观看 | 欧美三级不卡在线观看 | 国产午夜视频在线观看 | 国产精品第一区揄拍无码 | 东京无码熟妇人妻av在线网址 | 国产一区二区三区影院 | 国产麻豆精品精东影业av网站 | 国产无av码在线观看 | 久久99精品国产麻豆蜜芽 | 亚洲人成无码网www | 性生交大片免费看l | 成人试看120秒体验区 | 欧美 亚洲 国产 另类 | 国产成人一区二区三区在线观看 | 亚洲精品中文字幕 | 成在人线av无码免费 | 偷窥日本少妇撒尿chinese | 精品无人区无码乱码毛片国产 | 在线看片无码永久免费视频 | 55夜色66夜色国产精品视频 | 午夜精品久久久久久久 | 国产农村乱对白刺激视频 | 黑人巨大精品欧美一区二区 | 在线观看免费人成视频 | 熟女少妇人妻中文字幕 | 桃花色综合影院 | 亚洲熟妇色xxxxx亚洲 | 日本熟妇大屁股人妻 | 久久99久久99精品中文字幕 | 国内老熟妇对白xxxxhd | 欧美性生交活xxxxxdddd | 亚洲欧洲日本无在线码 | 成人性做爰aaa片免费看不忠 | 乱人伦人妻中文字幕无码 | 天堂亚洲2017在线观看 | 97资源共享在线视频 | 丰满少妇熟乱xxxxx视频 | 少妇厨房愉情理9仑片视频 | 国产 浪潮av性色四虎 | а天堂中文在线官网 | 波多野结衣一区二区三区av免费 | 97久久超碰中文字幕 | 伊在人天堂亚洲香蕉精品区 | 无码成人精品区在线观看 | 亚洲国产高清在线观看视频 | 精品无人区无码乱码毛片国产 | 日韩精品一区二区av在线 | 人妻有码中文字幕在线 | 亚洲人成影院在线无码按摩店 | 久久久久成人片免费观看蜜芽 | 成熟人妻av无码专区 | 国产内射老熟女aaaa | 久久99国产综合精品 | 成年女人永久免费看片 | 97夜夜澡人人爽人人喊中国片 | av在线亚洲欧洲日产一区二区 | 久久久久久亚洲精品a片成人 | 国产激情一区二区三区 | 小鲜肉自慰网站xnxx | 免费无码肉片在线观看 | 国语精品一区二区三区 | 窝窝午夜理论片影院 | 国产精品无码一区二区桃花视频 | 四虎永久在线精品免费网址 | 日韩欧美中文字幕在线三区 | 国色天香社区在线视频 | 丰满岳乱妇在线观看中字无码 | 久久久av男人的天堂 | 欧美第一黄网免费网站 | 正在播放东北夫妻内射 | 中文字幕人妻无码一区二区三区 | 老子影院午夜伦不卡 | 精品一区二区不卡无码av | 无码av岛国片在线播放 | 少妇性l交大片 | 熟妇女人妻丰满少妇中文字幕 | 国内精品人妻无码久久久影院 | 丰满人妻一区二区三区免费视频 | 宝宝好涨水快流出来免费视频 | 国产一精品一av一免费 | 色综合久久中文娱乐网 | 亚洲精品午夜国产va久久成人 | 99国产精品白浆在线观看免费 | 久久无码中文字幕免费影院蜜桃 | 国产激情无码一区二区 | 国产女主播喷水视频在线观看 | 婷婷六月久久综合丁香 | 亚洲一区二区观看播放 | 国产做国产爱免费视频 | 久久精品99久久香蕉国产色戒 | 日本精品人妻无码免费大全 | 国产精华av午夜在线观看 | 99精品视频在线观看免费 | 骚片av蜜桃精品一区 | 国产高清av在线播放 | 久久久久se色偷偷亚洲精品av | 亚洲精品久久久久中文第一幕 | 久久亚洲国产成人精品性色 | 特黄特色大片免费播放器图片 | 正在播放老肥熟妇露脸 | 日本va欧美va欧美va精品 | 国产性生交xxxxx无码 | 少女韩国电视剧在线观看完整 | 国产真人无遮挡作爱免费视频 | 免费人成在线视频无码 | 精品久久久久久人妻无码中文字幕 | 色综合久久久无码网中文 | 人人妻在人人 | 国产精品久久久久久无码 | 久久久久久亚洲精品a片成人 | 露脸叫床粗话东北少妇 | 九月婷婷人人澡人人添人人爽 | www成人国产高清内射 | 曰韩无码二三区中文字幕 | 97色伦图片97综合影院 | 欧美 日韩 人妻 高清 中文 | 久久这里只有精品视频9 | 日本一区二区更新不卡 | 在线成人www免费观看视频 | 欧美日本精品一区二区三区 | 国产精品-区区久久久狼 | 男人和女人高潮免费网站 | 亚无码乱人伦一区二区 | 好男人社区资源 | 亚洲一区二区三区在线观看网站 | 色综合久久久久综合一本到桃花网 | 久久熟妇人妻午夜寂寞影院 | 色综合久久88色综合天天 | 国产成人综合色在线观看网站 | 国产精品久久久 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产猛烈高潮尖叫视频免费 | 国产精品内射视频免费 | 日欧一片内射va在线影院 | 成人免费视频一区二区 | 人人超人人超碰超国产 | 扒开双腿吃奶呻吟做受视频 | 人妻少妇被猛烈进入中文字幕 | 性色欲网站人妻丰满中文久久不卡 | 搡女人真爽免费视频大全 | 国产精品鲁鲁鲁 | 成在人线av无码免费 | 日本精品少妇一区二区三区 | 国产偷国产偷精品高清尤物 | 中文字幕+乱码+中文字幕一区 | 给我免费的视频在线观看 | 一本久道久久综合婷婷五月 | 中文字幕无码日韩欧毛 | 精品人妻人人做人人爽夜夜爽 | 少妇性l交大片欧洲热妇乱xxx | 黄网在线观看免费网站 | 岛国片人妻三上悠亚 | 婷婷五月综合激情中文字幕 | 久久亚洲中文字幕精品一区 | 国模大胆一区二区三区 | 99麻豆久久久国产精品免费 | 亚洲国产午夜精品理论片 | 香蕉久久久久久av成人 | 亚洲春色在线视频 | 国产又粗又硬又大爽黄老大爷视 | 欧洲精品码一区二区三区免费看 | 福利一区二区三区视频在线观看 | 国产精品久久福利网站 | 国产精品国产三级国产专播 | ass日本丰满熟妇pics | √天堂资源地址中文在线 | 久久综合久久自在自线精品自 | 漂亮人妻洗澡被公强 日日躁 | 图片区 小说区 区 亚洲五月 | 国产精品18久久久久久麻辣 | 日韩欧美中文字幕公布 | 日韩精品无码一区二区中文字幕 | 欧美 亚洲 国产 另类 | 美女极度色诱视频国产 | 狠狠躁日日躁夜夜躁2020 | 亚洲小说图区综合在线 | 波多野结衣av一区二区全免费观看 | 老太婆性杂交欧美肥老太 | 强开小婷嫩苞又嫩又紧视频 | 久久久中文久久久无码 | 美女黄网站人色视频免费国产 | 久久精品国产99久久6动漫 | av在线亚洲欧洲日产一区二区 | 无码国产激情在线观看 | 亚洲国产欧美在线成人 | 亚洲码国产精品高潮在线 | 99精品久久毛片a片 | 国产精品怡红院永久免费 | 国产sm调教视频在线观看 | 亚洲国产精品一区二区第一页 | 中文字幕人妻无码一区二区三区 | 樱花草在线播放免费中文 | 东北女人啪啪对白 | 欧美日韩久久久精品a片 | 国产香蕉尹人视频在线 | 国产精品无码mv在线观看 | 国产一区二区三区精品视频 | 正在播放东北夫妻内射 | 亚洲精品午夜国产va久久成人 | 福利一区二区三区视频在线观看 | 精品无码成人片一区二区98 | 牲交欧美兽交欧美 | 国产一区二区三区日韩精品 | 成 人 免费观看网站 | 天天躁夜夜躁狠狠是什么心态 | 久久亚洲中文字幕无码 | 色综合久久久久综合一本到桃花网 | 亚洲精品一区二区三区在线观看 | 国产麻豆精品精东影业av网站 | aⅴ亚洲 日韩 色 图网站 播放 | 性欧美牲交在线视频 | 国产人妻大战黑人第1集 | 久久无码中文字幕免费影院蜜桃 | 午夜精品久久久久久久久 | 狠狠cao日日穞夜夜穞av | 色综合久久久无码中文字幕 | 性啪啪chinese东北女人 | 小sao货水好多真紧h无码视频 | 欧美日韩一区二区三区自拍 | 国内精品人妻无码久久久影院蜜桃 | 国产网红无码精品视频 | 国产精品无码一区二区三区不卡 | 青草视频在线播放 | 男女爱爱好爽视频免费看 | aⅴ在线视频男人的天堂 | 一本久道久久综合狠狠爱 | 老熟妇仑乱视频一区二区 | 丰满少妇女裸体bbw | 人妻少妇被猛烈进入中文字幕 | 在线a亚洲视频播放在线观看 | 波多野结衣一区二区三区av免费 | 中文无码成人免费视频在线观看 | 国产在线无码精品电影网 | 精品久久久久久人妻无码中文字幕 | 性欧美疯狂xxxxbbbb | 午夜肉伦伦影院 | 成人av无码一区二区三区 | 乌克兰少妇性做爰 | 亚洲综合在线一区二区三区 | 免费国产黄网站在线观看 | 亚洲午夜无码久久 | 国产成人无码专区 | 国产无套粉嫩白浆在线 | 久久亚洲中文字幕无码 | 久久99精品国产.久久久久 | 夜精品a片一区二区三区无码白浆 | 久久久精品456亚洲影院 | 国产 浪潮av性色四虎 | 中文字幕日韩精品一区二区三区 | 久久天天躁狠狠躁夜夜免费观看 | 国产乱人无码伦av在线a | 欧美日本日韩 | 亚洲精品一区二区三区四区五区 | 一个人看的视频www在线 | 无码成人精品区在线观看 | 夜夜躁日日躁狠狠久久av | 无遮挡国产高潮视频免费观看 | 亚洲精品成人福利网站 | 国精品人妻无码一区二区三区蜜柚 | 成人av无码一区二区三区 | 日本精品少妇一区二区三区 | 性欧美熟妇videofreesex | 亚洲s码欧洲m码国产av | 最近免费中文字幕中文高清百度 | 国产精品无码成人午夜电影 | 无码人妻出轨黑人中文字幕 | 精品国产福利一区二区 | 黑人巨大精品欧美黑寡妇 | 任你躁在线精品免费 | 自拍偷自拍亚洲精品10p | 少妇性俱乐部纵欲狂欢电影 | 最近的中文字幕在线看视频 | 最近的中文字幕在线看视频 | 成 人 网 站国产免费观看 | 国产成人一区二区三区别 | 97夜夜澡人人爽人人喊中国片 | 欧美老妇交乱视频在线观看 | 波多野结衣一区二区三区av免费 | 久久国产精品二国产精品 | 成人免费视频一区二区 | 黄网在线观看免费网站 | 国产猛烈高潮尖叫视频免费 | 高清无码午夜福利视频 | 中文字幕无码日韩专区 | 久久伊人色av天堂九九小黄鸭 | 亚洲熟熟妇xxxx | 女人被男人躁得好爽免费视频 | 乱人伦人妻中文字幕无码久久网 | 在线 国产 欧美 亚洲 天堂 | 成人综合网亚洲伊人 | 狠狠色丁香久久婷婷综合五月 | 久青草影院在线观看国产 | 夜精品a片一区二区三区无码白浆 | 亚洲色无码一区二区三区 | 国产香蕉尹人视频在线 | 丝袜美腿亚洲一区二区 | 国产精品a成v人在线播放 | 天堂а√在线地址中文在线 | 成人免费无码大片a毛片 | 国产色视频一区二区三区 | 强奷人妻日本中文字幕 | 天天爽夜夜爽夜夜爽 | 久久午夜夜伦鲁鲁片无码免费 | 国产av久久久久精东av | 欧美日本免费一区二区三区 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 人人爽人人澡人人人妻 | 乱人伦人妻中文字幕无码久久网 | 国产精品嫩草久久久久 | 中文字幕人妻无码一夲道 | 无码国产色欲xxxxx视频 | 亚洲成a人片在线观看无码 | 国产熟女一区二区三区四区五区 | 99久久婷婷国产综合精品青草免费 | 性色av无码免费一区二区三区 | 狂野欧美性猛xxxx乱大交 | 成人aaa片一区国产精品 | 学生妹亚洲一区二区 | 97人妻精品一区二区三区 | 98国产精品综合一区二区三区 | 日本精品人妻无码免费大全 | 中文字幕av日韩精品一区二区 | 国产成人无码av在线影院 | 亚洲国产精品成人久久蜜臀 | 激情人妻另类人妻伦 | 噜噜噜亚洲色成人网站 | 日韩精品无码一区二区中文字幕 | 999久久久国产精品消防器材 | 久久精品人妻少妇一区二区三区 | 国产精品久久久久影院嫩草 | 国产熟女一区二区三区四区五区 | 欧美黑人性暴力猛交喷水 | 色爱情人网站 | 大地资源网第二页免费观看 | 东京热无码av男人的天堂 | 一个人看的视频www在线 | 性做久久久久久久久 | 日韩av无码一区二区三区 | 国内丰满熟女出轨videos | 国产精品无码永久免费888 | a国产一区二区免费入口 | 国内丰满熟女出轨videos | 激情内射亚州一区二区三区爱妻 | 夜夜影院未满十八勿进 | 一本一道久久综合久久 | 亚洲 a v无 码免 费 成 人 a v | 天天做天天爱天天爽综合网 | 男人扒开女人内裤强吻桶进去 | 十八禁真人啪啪免费网站 | 天天躁日日躁狠狠躁免费麻豆 | 久久久婷婷五月亚洲97号色 | 欧美老人巨大xxxx做受 | 熟妇激情内射com | 久久亚洲日韩精品一区二区三区 | 男女性色大片免费网站 | 狂野欧美性猛xxxx乱大交 | 荫蒂被男人添的好舒服爽免费视频 | 婷婷五月综合激情中文字幕 | 国产亚洲精品久久久久久久久动漫 | 国产69精品久久久久app下载 | 欧美喷潮久久久xxxxx | 亚洲性无码av中文字幕 | 色欲av亚洲一区无码少妇 | 中文字幕无码乱人伦 | 一本久道久久综合狠狠爱 | 中国大陆精品视频xxxx | 日日摸天天摸爽爽狠狠97 | 狠狠cao日日穞夜夜穞av | 国产熟女一区二区三区四区五区 | 牲欲强的熟妇农村老妇女 | 国产精品福利视频导航 | 精品aⅴ一区二区三区 | 成人影院yy111111在线观看 | 日本一卡二卡不卡视频查询 | 中文字幕久久久久人妻 | 日本一本二本三区免费 | 九九久久精品国产免费看小说 | 亚洲成av人综合在线观看 | 亚拍精品一区二区三区探花 | 亚洲欧美精品伊人久久 | 牲欲强的熟妇农村老妇女视频 | 成人亚洲精品久久久久 | 99精品国产综合久久久久五月天 | 无码国模国产在线观看 | 无码任你躁久久久久久久 | 亚洲啪av永久无码精品放毛片 | 在线观看免费人成视频 | 亚洲日本va午夜在线电影 | 国产肉丝袜在线观看 | 一本加勒比波多野结衣 | 欧美成人免费全部网站 | 少妇太爽了在线观看 | 麻豆蜜桃av蜜臀av色欲av | 妺妺窝人体色www在线小说 | 精品少妇爆乳无码av无码专区 | 高潮毛片无遮挡高清免费 | 老司机亚洲精品影院 | 十八禁视频网站在线观看 | 精品无码一区二区三区爱欲 | 亚洲欧美中文字幕5发布 | 亚洲 激情 小说 另类 欧美 | 日韩亚洲欧美中文高清在线 | 樱花草在线播放免费中文 | 欧美日韩久久久精品a片 | 国产精品久久久久久久影院 | 久久午夜无码鲁丝片午夜精品 | 5858s亚洲色大成网站www | 超碰97人人射妻 | 人妻插b视频一区二区三区 | 久久综合激激的五月天 | 国产精品亚洲五月天高清 | 国产成人精品久久亚洲高清不卡 | 蜜桃av抽搐高潮一区二区 | 欧美性生交xxxxx久久久 | 色窝窝无码一区二区三区色欲 | 国产麻豆精品一区二区三区v视界 | 国产精品美女久久久网av | 欧美三级不卡在线观看 | 久久精品中文字幕一区 | 欧美成人家庭影院 | 精品国产av色一区二区深夜久久 | 国产精品无码永久免费888 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 男女下面进入的视频免费午夜 | 精品国产精品久久一区免费式 | 人人妻人人澡人人爽人人精品 | 久久综合激激的五月天 | 67194成是人免费无码 | 大乳丰满人妻中文字幕日本 | 黑人巨大精品欧美一区二区 | 亚洲经典千人经典日产 | 国产精品久免费的黄网站 | 玩弄人妻少妇500系列视频 | 亚洲色在线无码国产精品不卡 | 亚洲区欧美区综合区自拍区 | aⅴ在线视频男人的天堂 | 又紧又大又爽精品一区二区 | 少妇一晚三次一区二区三区 | 88国产精品欧美一区二区三区 | 欧美成人高清在线播放 | 亚洲爆乳精品无码一区二区三区 | 任你躁国产自任一区二区三区 | 国产国语老龄妇女a片 | 精品欧洲av无码一区二区三区 | 内射老妇bbwx0c0ck | 中文字幕亚洲情99在线 | 久久这里只有精品视频9 | 伦伦影院午夜理论片 | 55夜色66夜色国产精品视频 | 日本精品人妻无码免费大全 | 成人aaa片一区国产精品 | 国产 精品 自在自线 | 国产av一区二区精品久久凹凸 | 精品久久久中文字幕人妻 | ass日本丰满熟妇pics | 无码人妻出轨黑人中文字幕 | 久久久精品456亚洲影院 | 老头边吃奶边弄进去呻吟 | 亚洲精品成a人在线观看 | 久青草影院在线观看国产 | 久久久中文字幕日本无吗 | 久久精品99久久香蕉国产色戒 | 精品人妻人人做人人爽夜夜爽 | 小鲜肉自慰网站xnxx | 亚洲日本va中文字幕 | 丁香啪啪综合成人亚洲 | 久久国产精品精品国产色婷婷 | 波多野结衣aⅴ在线 | 夫妻免费无码v看片 | 国产色视频一区二区三区 | 国产精品亚洲一区二区三区喷水 | 国产精品无码一区二区三区不卡 | 欧美三级不卡在线观看 | 国产成人无码午夜视频在线观看 | 免费无码肉片在线观看 | 久久国产自偷自偷免费一区调 | 无码一区二区三区在线观看 | 国模大胆一区二区三区 | 国产另类ts人妖一区二区 | 97人妻精品一区二区三区 | 久久99精品国产麻豆蜜芽 | 国产办公室秘书无码精品99 | 狠狠色丁香久久婷婷综合五月 | 国产日产欧产精品精品app | 国产精品久久久一区二区三区 | 国产精品久久久久久久9999 | 影音先锋中文字幕无码 | 狠狠躁日日躁夜夜躁2020 | 国产精品办公室沙发 | 风流少妇按摩来高潮 | 曰韩无码二三区中文字幕 | 国产精品无码一区二区桃花视频 | 成人毛片一区二区 | 男人的天堂2018无码 | 国产激情综合五月久久 | 99国产欧美久久久精品 | 波多野42部无码喷潮在线 | 亚洲精品国产a久久久久久 | 久久久久久久久蜜桃 | 欧美黑人巨大xxxxx | 成人性做爰aaa片免费看 | 欧美xxxx黑人又粗又长 | 精品aⅴ一区二区三区 | 又黄又爽又色的视频 | 日韩 欧美 动漫 国产 制服 | 亚洲人成网站在线播放942 | 亚洲精品国产精品乱码不卡 | 熟女体下毛毛黑森林 | 精品亚洲成av人在线观看 | 午夜福利电影 | 丰满少妇高潮惨叫视频 | 色综合久久久无码网中文 | 成人欧美一区二区三区 | 波多野结衣aⅴ在线 | 日本又色又爽又黄的a片18禁 | 久久久久久a亚洲欧洲av冫 | 国产精品久久久久久亚洲毛片 | 欧美野外疯狂做受xxxx高潮 | 亚洲大尺度无码无码专区 | 中文字幕无码免费久久9一区9 | 亚洲熟妇色xxxxx亚洲 | 蜜桃视频插满18在线观看 | 人妻少妇精品视频专区 | 亚洲人成网站免费播放 | 爆乳一区二区三区无码 | 蜜臀aⅴ国产精品久久久国产老师 | 欧美成人午夜精品久久久 | 久久午夜夜伦鲁鲁片无码免费 | 高潮毛片无遮挡高清免费视频 | 男人扒开女人内裤强吻桶进去 | 性色欲网站人妻丰满中文久久不卡 | 无码人妻精品一区二区三区下载 | 麻豆av传媒蜜桃天美传媒 | 女人被爽到呻吟gif动态图视看 | 亚洲欧洲日本综合aⅴ在线 | 色一情一乱一伦 | 午夜丰满少妇性开放视频 | 玩弄中年熟妇正在播放 | 日本高清一区免费中文视频 | 国产精品久久久久久久9999 | 人人妻人人藻人人爽欧美一区 | 小鲜肉自慰网站xnxx | 欧美亚洲国产一区二区三区 | 1000部夫妻午夜免费 | 国产午夜亚洲精品不卡 | 中文字幕av伊人av无码av | 亚洲色欲色欲天天天www | 精品久久久久久亚洲精品 | 少妇一晚三次一区二区三区 | 人人妻人人藻人人爽欧美一区 | 噜噜噜亚洲色成人网站 | 人妻少妇精品无码专区动漫 | 兔费看少妇性l交大片免费 | 人妻无码久久精品人妻 | 日本饥渴人妻欲求不满 | 国产精品18久久久久久麻辣 | 亚洲精品一区二区三区在线观看 | 国产一精品一av一免费 | 无码毛片视频一区二区本码 | 又粗又大又硬毛片免费看 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 嫩b人妻精品一区二区三区 | 国产精品无套呻吟在线 | 久久久久久久久蜜桃 | 97资源共享在线视频 | 奇米影视7777久久精品人人爽 | 久久精品人人做人人综合试看 | 色婷婷综合激情综在线播放 | 久久精品视频在线看15 | 亚洲精品鲁一鲁一区二区三区 | 亚洲国产精品成人久久蜜臀 | 色综合久久久无码网中文 | 婷婷六月久久综合丁香 | 欧美激情一区二区三区成人 | 国产成人午夜福利在线播放 | 九九久久精品国产免费看小说 | 2020久久香蕉国产线看观看 | 久久久亚洲欧洲日产国码αv | 日本饥渴人妻欲求不满 | 国产手机在线αⅴ片无码观看 | 亚洲小说图区综合在线 | 国产福利视频一区二区 | 午夜福利不卡在线视频 | 日本欧美一区二区三区乱码 | 成人一在线视频日韩国产 | 国产精品久久精品三级 | 久久精品国产99精品亚洲 | 国产免费观看黄av片 | 欧美三级a做爰在线观看 | 成人无码影片精品久久久 | 人人妻人人澡人人爽精品欧美 | 自拍偷自拍亚洲精品10p | 成人性做爰aaa片免费看不忠 | 国产偷抇久久精品a片69 | 国产欧美熟妇另类久久久 | 久久综合色之久久综合 | 成人女人看片免费视频放人 | 中文亚洲成a人片在线观看 | 十八禁视频网站在线观看 | 日本在线高清不卡免费播放 | 国产亚洲欧美日韩亚洲中文色 | 精品国产福利一区二区 | 欧美日韩人成综合在线播放 | 亚洲国产精品成人久久蜜臀 | 日本熟妇乱子伦xxxx | 最近免费中文字幕中文高清百度 | 四十如虎的丰满熟妇啪啪 | 纯爱无遮挡h肉动漫在线播放 | 国产精品久久久久无码av色戒 | 国产午夜手机精彩视频 | 伊在人天堂亚洲香蕉精品区 | 中文精品无码中文字幕无码专区 | 亚洲热妇无码av在线播放 | 无套内射视频囯产 | 日本大乳高潮视频在线观看 | 精品一区二区三区波多野结衣 | 国产在线精品一区二区三区直播 | 亚洲精品无码人妻无码 | 国语精品一区二区三区 | 亚洲色在线无码国产精品不卡 | 97人妻精品一区二区三区 | yw尤物av无码国产在线观看 | 中文无码成人免费视频在线观看 | 欧美喷潮久久久xxxxx | 人妻少妇被猛烈进入中文字幕 | 亚洲综合无码久久精品综合 | 亚洲 欧美 激情 小说 另类 | 成人影院yy111111在线观看 | 久久久久久久久蜜桃 | 丰满人妻翻云覆雨呻吟视频 | 国产成人综合美国十次 | 麻豆果冻传媒2021精品传媒一区下载 | 亚洲乱亚洲乱妇50p | 一本色道久久综合亚洲精品不卡 | 亚洲日韩乱码中文无码蜜桃臀网站 | 网友自拍区视频精品 | 久久精品中文字幕一区 | 亚洲综合无码一区二区三区 | 成人动漫在线观看 | 男女猛烈xx00免费视频试看 | 欧美高清在线精品一区 | 狂野欧美激情性xxxx | 国内精品久久久久久中文字幕 | 欧美精品免费观看二区 | 蜜桃视频插满18在线观看 | 亚洲欧美日韩国产精品一区二区 | 成人性做爰aaa片免费看 | 在线播放无码字幕亚洲 | 欧美日韩色另类综合 | 亚洲成av人在线观看网址 | 丰满岳乱妇在线观看中字无码 | 日韩欧美中文字幕公布 | 无码人妻精品一区二区三区下载 | 色五月丁香五月综合五月 | 蜜臀av无码人妻精品 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 国产97在线 | 亚洲 | 精品无码一区二区三区爱欲 | 久久熟妇人妻午夜寂寞影院 | 亚洲成a人片在线观看无码 | 久久99精品国产.久久久久 | 亚洲s码欧洲m码国产av | 日韩欧美群交p片內射中文 | 国内丰满熟女出轨videos | 国产偷抇久久精品a片69 | 在线欧美精品一区二区三区 | 午夜性刺激在线视频免费 | 久久国产劲爆∧v内射 | 樱花草在线播放免费中文 | 九九在线中文字幕无码 | 免费人成在线视频无码 | 在线a亚洲视频播放在线观看 | 樱花草在线社区www | 在线观看国产一区二区三区 | 18精品久久久无码午夜福利 | 精品久久久久久人妻无码中文字幕 | 免费乱码人妻系列无码专区 | 亚洲日韩av一区二区三区中文 | 熟妇女人妻丰满少妇中文字幕 | 精品人妻人人做人人爽 | 丰满少妇高潮惨叫视频 | 2020最新国产自产精品 | 无码人妻av免费一区二区三区 | www国产精品内射老师 | 色婷婷香蕉在线一区二区 | 国产性生大片免费观看性 | 少妇被粗大的猛进出69影院 | 精品午夜福利在线观看 | 欧美丰满熟妇xxxx | 99久久精品日本一区二区免费 | 久久 国产 尿 小便 嘘嘘 | 国产熟妇高潮叫床视频播放 | 国产成人一区二区三区在线观看 | 免费国产成人高清在线观看网站 | 久久99精品国产.久久久久 | 野狼第一精品社区 | 狂野欧美性猛交免费视频 | 精品国产一区二区三区av 性色 | 亚洲精品综合五月久久小说 | 国产精品资源一区二区 | 亚洲精品久久久久久久久久久 | 美女极度色诱视频国产 | 成人免费视频视频在线观看 免费 | 四虎影视成人永久免费观看视频 | 国语自产偷拍精品视频偷 | 国产sm调教视频在线观看 | 18黄暴禁片在线观看 | 人人妻人人澡人人爽人人精品浪潮 | 丰满护士巨好爽好大乳 | 亚洲日本va中文字幕 | 好男人www社区 |