精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Java 日志管理的黃金組合: SLF4J+Logback

開發 前端
Log4J 最初是基于Java開發的日志框架,發展一段時間后,作者Ceki Gülcü將Log4j捐獻給了Apache軟件基金會,使之成為了Apache日志服務的一個子項目。 又由于Log4J出色的表現,后續又被孵化出了支持C, C++, C#, Perl, Python, Ruby等語言的子框架。

Log4J、Log4J2和LogBack的歷史故事

使用過Log4J和LogBack的同學肯定能發現,這兩個框架的設計理念極為相似,使用方法也如出一轍。其實這個兩個框架的作者都是一個人,Ceki Gülcü,俄羅斯程序員。

Log4J 最初是基于Java開發的日志框架,發展一段時間后,作者Ceki Gülcü將Log4j捐獻給了Apache軟件基金會,使之成為了Apache日志服務的一個子項目。 又由于Log4J出色的表現,后續又被孵化出了支持C, C++, C#, Perl, Python, Ruby等語言的子框架。

然而,偉大的程序員好像都比較有個性。Ceki Gülcü由于不滿Apache對Log4J的管理,決定不再參加Log4J的開發維護。“出走”后的Ceki Gülcü另起爐灶,開發出了LogBack這個框架(SLF4J是和LogBack一起開發出來的)。LogBack改進了很多Log4J的缺點,在性能上有了很大的提升,同時使用方式幾乎和Log4J一樣,許多用戶開始慢慢開始使用LogBack。

由于受到LogBack的沖擊,Log4J開始式微。終于,2015年9月,Apache軟件基金業宣布,Log4j不在維護,建議所有相關項目升級到Log4j2。Log4J2是Apache開發的一個新的日志框架,改進了很多Log4J的缺點,同時也借鑒了LogBack,號稱在性能上也是完勝LogBack。性能這塊后面我會仔細分析。

那slf4j和這些有什么關系?

SLF4J的全稱是Simple Logging Facade for Java,slf4j是門面模式的典型應用。

回答這個問題之前,我們先看看如果需要用上面幾個日志框架來打印日志,一般怎么做,具體代碼如下:

// 使用log4j,需要log4j.jar 
import org.apache.log4j.Logger; 
Logger logger_log4j = Logger.getLogger(Test.class); 
logger_log4j.info("Hello World!"); 

// 使用log4j2,需要log4j-api.jar、log4j-core.jar 
import org.apache.logging.log4j.LogManager; 
import org.apache.logging.log4j.Logger; 
Logger logger_log4j2 = LogManager.getLogger(Test.class); 
logger_log4j2.info("Hello World!"); 

// logback,需要logback-classic.jar、logback-core.jar 
import ch.qos.logback.classic.Logger; 
import ch.qos.logback.classic.LoggerContext; 
Logger logger_logback = new LoggerContext().getLogger(Test.class); logger_logback.info("Hello World!");

從上面不難看出,使用不同的日志框架,就要引入不同的jar包,使用不同的代碼獲取Logger。如果項目升級需要更換不同的框架,那么就需要修改所有的地方來獲取新的Logger,這將會產生巨大的工作量。

基于此,我們需要一種接口來將不同的日志框架的使用統一起來,這也是為什么要使用slf4j的原因。

SLF4J,即簡單日志門面(Simple Logging Facade for Java),不是具體的日志解決方案,它只服務于各種各樣的日志系統。按照官方的說法,SLF4J是一個用于日志系統的簡單Facade,允許最終用戶在部署其應用時使用其所希望的日志系統。


注意:類似的日志門面還有Jakarta Common logging(JCL),主要區別在于,SLF4J是一個比較新的日志框架,它更加靈活,性能更好,支持更多的日志實現,而且JCL基于classLoader在運行時動態加載日志框架,可能會產生很多意想不到的安全問題。

通過上面的介紹,我們可以知道JCL和SLF4J都是日志門面(Facade),而Log4J、Log4J2和LogBack都是子系統角色(SunSystem),也就是具體的日志實現框架。他們的關系如下,JUL是JDK本身提供的一種實現。

圖片圖片

SLF4J 的核心價值在于它提供了解耦設計:應用程序代碼只依賴 slf4j-api,而具體日志實現(如 Logback、Log4j2)可以在部署時動態綁定。這種架構使得項目升級或更換日志框架變得非常簡單,無需修改業務代碼中的日志記錄語句。

slf4j怎么和日志框架結合使用?

使用slf4j后,當我們在打印日志時,就可以使用下面的方式:

import org.slf4j.Logger; 
import org.slf4j.LoggerFactory; 
Logger logger = LoggerFactory.getLogger(Test.class); 
logger.info("Hello World!")

這又引入了另外一個問題,slf4j如何決定使用哪個框架日志呢,并且引入哪些jar包呢?官方為我們準備了組合依賴:

  • slf4j + logback: slf4j-api.jar + logback-classic.jar + logback-core.jar
  • slf4j + log4j: slf4j-api.jar + slf4j-log412.jar + log4j.jar
  • slf4j + jul: slf4j-api.jar + slf4j-jdk14.jar
  • 也可以只用slf4j無日志實現:slf4j-api.jar + slf4j-nop.jar

SLF4J 的基本使用

在代碼中使用 SLF4J 非常簡單,首先需要通過 Maven 添加依賴:

<!-- Maven 依賴配置 -->
<dependencies>
    <!-- SLF4J API -->
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>2.0.9</version>
    </dependency>
    <!-- Logback Classic 實現 -->
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>1.4.11</version>
    </dependency>
</dependencies>

在代碼中獲取 Logger 并記錄日志:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class ExampleService {
    // 獲取Logger實例
    private static final Logger logger = LoggerFactory.getLogger(ExampleService.class);
    
    public void processUser(String userId) {
        logger.debug("Processing user: {}", userId); // 使用占位符,避免字符串拼接
        logger.info("User processing started");
        
        try {
            // 業務邏輯
            logger.info("User {} processed successfully", userId);
        } catch (Exception e) {
            logger.error("Failed to process user: " + userId, e); // 記錄異常信息
        }
    }
}

SLF4J 的 參數化日志消息(使用 {}占位符)是其一個重要特性,它不僅有更好的可讀性,還能提升性能——當日志級別高于當前配置時(如配置為 INFO 級別時調用 debug 語句),不會執行字符串拼接操作。

Logback 架構與核心組件

Logback 是 SLF4J 的原生實現框架,由三個相互協作的模塊組成,每個模塊都有獨特的功能定位。

Logback 的模塊化設計

模塊

說明

logback-core

核心模塊,提供基礎日志服務,其他兩個模塊都依賴它

logback-classic

實現 SLF4J API,完全兼容 SLF4J 接口,同時兼容 Log4j

logback-access

與 Servlet 容器集成,用于 HTTP 訪問日志記錄

Logback 相比 Log4j 有顯著性能提升,特別是在異步日志記錄方面,減少了線程阻塞和上下文切換開銷。它還支持自動重載配置,可以在不重啟應用的情況下修改日志配置。

Logback 核心概念

Logback 架構基于三個核心概念:Logger、Appender 和 Layout/Encoder。

Logger(日志記錄器)

  • 采用層次化命名(如 com.example.service.UserService
  • 具有繼承性:子 Logger 繼承父 Logger 的 Appender 和 Level
  • 通過 LoggerFactory.getLogger()獲取實例

Appender(輸出目的地)

Appender 負責將日志事件發送到不同目標,Logback 支持多種 Appender:

Appender 類型

說明

ConsoleAppender

輸出到控制臺

FileAppender

輸出到文件

RollingFileAppender

滾動文件(按大小/時間)

SocketAppender

發送到遠程服務器

SMTPAppender

郵件告警

KafkaAppender

發送到 Kafka(需擴展)

Layout/Encoder(格式化器)

定義日志輸出格式,常用占位符包括:

  • %d{yyyy-MM-dd HH:mm:ss.SSS}:時間戳
  • %level:日志級別
  • %thread:線程名
  • %logger{36}:Logger 名(縮寫)
  • %msg:日志消息
  • %n:換行符

Logback 配置詳解與案例

Logback 支持 XML 和 Groovy 兩種配置格式,其中 XML 是最常用的方式。下面通過實際案例詳細講解 Logback 的配置。

基礎配置結構

Logback 配置文件通常命名為 logback.xml或 logback-spring.xml(Spring 環境),放置在 src/main/resources/目錄下。

<?xml versinotallow="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="30 seconds">
    
    <!-- 定義變量 -->
    <property name="LOG_HOME" value="./logs"/>
    <property name="APP_NAME" value="myapp"/>
    
    <!-- 開發環境開關 -->
    <springProfile name="dev">
        <property name="LOG_LEVEL" value="DEBUG"/>
    </springProfile>
    <springProfile name="prod">
        <property name="LOG_LEVEL" value="INFO"/>
    </springProfile>
    
    <!-- 控制臺輸出 -->
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %level %logger{36} - %msg%n</pattern>
        </encoder>
    </appender>
    
    <!-- 更多Appender配置 -->
    
    <!-- 根日志器 -->
    <root level="${LOG_LEVEL:-INFO}">
        <appender-ref ref="CONSOLE"/>
    </root>
    
    <!-- 特定包的日志級別 -->
    <logger name="com.example.service" level="DEBUG"/>
</configuration>

Console Appender 配置

Console Appender 用于將日志輸出到控制臺,是開發環境中最常用的 Appender:

<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
        <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </encoder>
    <!-- 過濾器:只輸出INFO及以上級別 -->
    <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
        <level>INFO</level>
    </filter>
</appender>

File Appender 與滾動策略

生產環境中通常需要將日志輸出到文件,并使用滾動策略防止文件過大:

<!-- 滾動文件輸出(按天) -->
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${LOG_HOME}/${APP_NAME}.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <!-- 每天生成一個文件 -->
        <fileNamePattern>${LOG_HOME}/archive/%d{yyyy-MM-dd}/${APP_NAME}.%i.log.gz</fileNamePattern>
        <!-- 保留30天 -->
        <maxHistory>30</maxHistory>
        <!-- 單個文件最大100MB -->
        <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
            <maxFileSize>100MB</maxFileSize>
        </timeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
    <encoder>
        <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </encoder>
</appender>

日志級別配置

Logback 支持多個日志級別,合理配置級別對系統性能和可觀測性至關重要。

<!-- 根日志器設置 -->
<root level="${LOG_LEVEL:-INFO}">
    <appender-ref ref="CONSOLE"/>
    <appender-ref ref="FILE"/>
</root>

<!-- 特定包/類級別設置 -->
<!-- 特定日志器:將 com.example.service 包的日志級別設為 DEBUG,且日志僅輸出到文件,不傳遞給根日志器(避免控制臺重復輸出) -->
<logger name="com.example.service" level="DEBUG" additivity="false">
    <appender-ref ref="FILE" />
</logger>

<!-- 特定日志器:將 org.springframework 包的日志級別設為 WARN,減少不必要的日志輸出 -->
<logger name="org.springframework" level="WARN" />

在這個配置中:

  • 絕大多數日志遵循根的 INFO級別設置。
  • 唯獨 com.example.service包下的日志可以輸出 DEBUG級別及以上的內容,并且這些調試信息只寫入文件,不會出現在控制臺(因為 additivity="false")。
  • 所有來自 org.springframework包的日志,只有 WARN和 ERROR級別才會被記錄。

根日志器 (<root>) 和特定包/類日志器 (<logger>) 的設置是日志配置的兩個核心層面,主要在于作用和范圍的區別:

特性

根日志器 (<root>)

特定包/類日志器 (<logger>)

作用范圍

全局默認

。影響所有未被特定 <logger>明確配置的日志記錄器。

局部特定

。僅影響通過 name屬性指定的包或類及其子包/子類。

配置目的

設置應用程序的基礎日志級別和輸出策略

特定模塊提供更精細的日志控制(如更詳細或更嚴格的級別)。

繼承性

是所有日志器層次的根節點,其他日志器默認繼承其配置。

從其父日志器(可能是根或其他上層日志器)繼承未被自身覆蓋的設置。

常用級別

生產環境常設為 INFO或 WARN;開發環境可設為 DEBUG

根據需求靈活設置,如將關注模塊設為 DEBUG,將嘈雜的第三方庫設為 ERROR

Logback 支持的日志級別從低到高依次為:

  • TRACE:最細粒度的信息,通常只在開發過程中使用
  • DEBUG:logger.debug信息
  • INFO:logger.info 信息
  • WARN:logger.warn 信息
  • ERROR:logger.error 信息

高級特性與性能優化

Logback 提供了多種高級功能,可以滿足復雜場景下的日志需求。

MDC(Mapped Diagnostic Context)

MDC 用于在日志中添加上下文信息(如請求 ID、用戶 ID),非常適合分布式系統跟蹤:

// 在代碼中使用MDC
import org.slf4j.MDC;

public class UserService {
    public void processUserRequest(String userId, String requestId) {
        // 將上下文信息放入MDC
        MDC.put("userId", userId);
        MDC.put("requestId", requestId);
        
        logger.info("Processing user request"); // 自動包含MDC信息
        
        // 業務處理...
        
        // 清理MDC
        MDC.clear();
    }
}

在配置中使用 MDC:

<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{userId}] [%X{requestId}] %-5level %logger{36} - %msg%n</pattern>

異步日志提升性能

對于生產環境,特別是高并發場景,使用異步日志可以顯著提升性能。

<!-- 異步日志(提升性能) -->
<appender name="ASYNC_FILE" class="ch.qos.logback.classic.AsyncAppender">
    <appender-ref ref="FILE"/>
    <!-- 隊列大小 -->
    <queueSize>256</queueSize>
    <!-- 丟棄級別低于ERROR的日志(可選) -->
    <discardingThreshold>0</discardingThreshold>
</appender>

條件化配置

Logback 支持根據不同的環境(如開發、測試、生產)使用不同的配置。

<!-- 開發環境配置 -->
<springProfile name="dev">
    <root level="DEBUG">
        <appender-ref ref="CONSOLE"/>
    </root>
</springProfile>

<!-- 生產環境配置 -->
<springProfile name="prod">
    <root level="INFO">
        <appender-ref ref="ASYNC_FILE"/>
    </root>
</springProfile>

自定義過濾器

Logback 允許創建自定義過濾器來實現復雜的日志過濾邏輯。

<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <!-- 只記錄ERROR級別日志 -->
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
        <level>ERROR</level>
        <onMatch>ACCEPT</onMatch>
        <onMismatch>DENY</onMismatch>
    </filter>
</appender>


責任編輯:武曉燕 來源: SevenCoding
相關推薦

2013-02-20 09:42:34

JavaLogbackSLF4J

2020-01-07 10:06:26

Slf4jLog4JLogback

2023-10-28 16:19:18

Android日志

2023-08-14 23:23:56

2024-06-11 08:50:43

xlwingsPython庫Excel

2023-11-09 08:28:06

DDDCQRS黃金組合

2024-03-01 16:52:02

SLF4J日志框架

2025-05-20 03:00:00

2025-03-03 08:49:59

2009-06-22 16:19:27

無線路由器產品華碩

2021-04-02 07:58:36

LogbackLog4j2日志

2020-11-04 12:33:08

Log4j 2日志Logback

2021-03-15 18:47:25

日志開發源碼

2022-08-30 16:38:30

阿里巴巴JavaLog4j

2025-08-20 09:34:57

2023-01-11 21:22:32

Java服務器

2023-10-07 10:08:54

2023-05-06 07:51:22

JavaFacade設計模式

2016-10-21 13:10:18

javalog4jslf4j

2022-05-12 11:38:26

Java日志Slf4j
點贊
收藏

51CTO技術棧公眾號

小嫩嫩精品导航| 国产乱人伦精品一区| 国产精品美女视频| 亚洲自拍偷拍视频| 精品91久久久| 日韩精品1区| 日韩欧美一区二区三区在线| 自慰无码一区二区三区| av国产在线观看| 国产99精品视频| 欧美最近摘花xxxx摘花| 国产美女久久久久久| 激情视频极品美女日韩| 欧美日韩三级视频| 国精产品一区一区三区视频| 日本精品一区二区三区在线播放| 99精品国产一区二区三区不卡| 国产欧美一区二区三区久久人妖| 日本熟妇毛茸茸丰满| 四季av一区二区三区免费观看| 日韩成人中文字幕| 日本黄色一级网站| 巨大黑人极品videos精品| 精品二区三区线观看| 精品国产三级a∨在线| 免费在线一级视频| 成人免费毛片片v| 成人在线一区二区| 美女黄页在线观看| 久久成人亚洲| 97视频在线播放| 久久r这里只有精品| 欧美大黑bbbbbbbbb在线| 亚洲女人被黑人巨大进入al| 性猛交╳xxx乱大交| 成人在线分类| 欧美伦理视频网站| 日本激情综合网| 外国成人直播| 欧美性猛交xxxx富婆弯腰| 成人精品视频在线播放| 91麻豆免费在线视频| 国产精品免费丝袜| 亚洲成色最大综合在线| 国产小视频在线播放| 久久综合色8888| 久久国产精品高清| 无码国产精品高潮久久99| 国产a区久久久| 91在线在线观看| 亚洲精品一级片| 欧美日韩福利在线观看| 日本黄色网址大全| 牛牛精品成人免费视频| 亚洲成人免费在线视频| 国产精品嫩草69影院| 1313精品午夜理伦电影| 日韩美女主播在线视频一区二区三区| 日本77777| 国产精品第一| 欧美精品在欧美一区二区少妇| 欧美日韩亚洲自拍| 狠狠久久综合| 717成人午夜免费福利电影| xxww在线观看| 日韩一区中文| 欧美一区二区三级| 中文字幕1区2区| 老牛精品亚洲成av人片| 亚洲精品影视在线观看| av网站免费在线看| 久久激情电影| 欧美人成在线视频| 日本五十路女优| 久久黄色网页| 成人h片在线播放免费网站| 99精品国产99久久久久久97| 久久精品一级| 91精品国产综合久久久蜜臀图片| 亚洲制服在线观看| av男人一区| 日韩精品一区二区三区第95| 一级肉体全黄裸片| 亚洲h色精品| 久久久久久免费精品| 九九九在线观看| 另类中文字幕网| 国产v亚洲v天堂无码| 日本v片在线免费观看| 国产精品视频看| 成年人视频网站免费| 亚洲欧洲高清| 51精品视频一区二区三区| 色综合久久久无码中文字幕波多| 九九综合在线| 欧美成人午夜激情| 欧美在线观看不卡| 国产一区二区三区精品视频| 久久国产手机看片| 国产黄色小视频在线| 午夜精品123| 一区二区三区 日韩| 亚洲国产精品免费视频| 亚洲人成电影在线观看天堂色| 欧美老熟妇一区二区三区| 99热精品在线| 91在线免费网站| 每日更新在线观看av| 最新成人av在线| 日本黄色三级大片| 日本高清精品| 在线精品国产欧美| 欧美bbbbbbbbbbbb精品| 国产综合久久久久久鬼色 | 在线视频欧美日韩| 日本少妇吞精囗交| 国产在线精品一区二区夜色| 美女主播视频一区| 亚洲h片在线看| 欧美无砖砖区免费| 久久久久国产精品区片区无码| 91精品秘密在线观看| 日韩av大片在线| 农村少妇久久久久久久| 亚洲欧美日韩综合aⅴ视频| 日日鲁鲁鲁夜夜爽爽狠狠视频97 | 91精品国产综合久久国产大片 | 自拍自偷一区二区三区| 久久久久久九九九| 999久久久久久| 中文字幕一区二区在线观看| 欧美日韩在线不卡视频| 猫咪成人在线观看| 久久久久久12| 不卡的日韩av| 亚洲人成在线播放网站岛国| xx欧美撒尿嘘撒尿xx| 亚洲福利天堂| 欧美一级免费视频| 天堂在线观看免费视频| 亚洲国产精品久久人人爱蜜臀| 极品粉嫩美女露脸啪啪| 久久一区91| 国产精品视频免费在线观看| 成人欧美一区| 欧美性猛交xxxx黑人交| 波多野结衣一二三四区| 奇米在线7777在线精品| 欧美在线3区| 欧美不卡高清一区二区三区| 亚洲人成在线观| 国产嫩bbwbbw高潮| 91在线小视频| 激情网站五月天| 精品久久久亚洲| 国产精品免费看久久久香蕉| 成人高清网站| 7777精品伊人久久久大香线蕉的 | 一区二区影视| 亚洲a一级视频| xvideos国产在线视频| 日韩三级视频在线观看| 亚洲国产美女视频| 国产成人av福利| 18禁裸男晨勃露j毛免费观看| 99re6热只有精品免费观看| 久久久视频精品| 污视频在线免费| 色噜噜狠狠成人中文综合 | 国产激情视频在线播放| 亚洲精品第一国产综合野| 91亚洲一线产区二线产区 | 国产精品萝li| 日韩av片免费观看| 99久久夜色精品国产亚洲狼| 亚洲综合最新在线| а√天堂8资源中文在线| 黄网站免费久久| 亚洲男人天堂2023| 国产精品老女人| 欧美国产一区二区| 1314成人网| 亚洲国产三级| 神马一区二区影院| 日韩一区二区三区色| 欧美亚洲视频一区二区| 国产精品日韩二区| 超碰在线无需免费| 亚洲精品久久久久中文字幕二区| 国产99久久久久久免费看| 亚洲欧美日韩久久精品| 少妇被狂c下部羞羞漫画| 日韩成人一级大片| 一二三在线视频| 九色精品91| 91精品啪aⅴ在线观看国产| 日韩av一卡| 久久精品夜夜夜夜夜久久| 五月婷婷开心中文字幕| 欧美日韩成人综合天天影院| 日本在线视频免费观看| 中文字幕中文在线不卡住| 女同性恋一区二区三区| 六月丁香婷婷久久| 欧美a在线视频| 欧美视频久久| 亚洲欧洲中文| 亚洲人成亚洲精品| 91黄色国产视频| 成人全视频在线观看在线播放高清| 欧美极品美女视频网站在线观看免费| 国产小视频福利在线| 欧美本精品男人aⅴ天堂| 中文字幕久久久久| 欧美日韩午夜视频在线观看| 尤物在线免费视频| 国产精品婷婷午夜在线观看| 日韩免费高清一区二区| 韩国精品在线观看| 久久久国产欧美| 亚洲综合好骚| 国产日本在线播放| 一区二区影院| 一区二区在线观看网站| 九九热精品视频在线观看| 精品国产乱码久久久久久88av| 亚洲国产aⅴ精品一区二区三区| 欧美一区二区大胆人体摄影专业网站| 日本大片在线播放| 久久精品精品电影网| 国产日韩精品在线看| 精品调教chinesegay| 亚洲国产精彩视频| 欧美一级在线视频| 国产女主播福利| 在线成人小视频| 国产乱淫片视频| 欧美日韩国产免费| 亚洲天堂视频网| 欧美亚洲一区三区| av首页在线观看| 在线精品视频一区二区| 你懂的国产在线| 色综合久久久久综合| 一本一道无码中文字幕精品热| 亚洲va国产天堂va久久en| 日本一区二区欧美| 亚洲成人激情av| 天天操天天爽天天干| 亚洲成人高清在线| 日韩和一区二区| 黄网站色欧美视频| 91午夜视频在线观看| 欧美日韩国产一区在线| 在线观看日韩中文字幕| 色婷婷精品久久二区二区蜜臂av | 国产精品久久久免费观看| 成人中文字幕在线| 波多野结衣加勒比| 91美女片黄在线观看| 永久免费看mv网站入口78| 久久久.com| 三级黄色片在线观看| 亚洲欧洲日产国码二区| 丝袜 亚洲 另类 欧美 重口| 一区二区三区在线视频免费观看 | 调教视频免费在线观看| 久久视频国产精品免费视频在线| av超碰免费在线| 国产69精品久久久久99| 中文字幕在线视频久| 国产精品国产三级国产aⅴ浪潮| 国外成人福利视频| 3d动漫啪啪精品一区二区免费| 粉嫩一区二区三区四区公司1| 精品欧美一区二区精品久久| 久久久久97| 五月天色一区| 欧美日韩专区| 国模吧无码一区二区三区| 蜜桃视频在线一区| 91精品人妻一区二区三区四区| 2014亚洲片线观看视频免费| 在线观看日本黄色| 亚洲午夜视频在线观看| 啪啪小视频网站| 日韩色在线观看| 国产小视频在线观看| 九九热r在线视频精品| 一本大道色婷婷在线| 国产美女精品视频免费观看| 超碰cao国产精品一区二区| 欧美一区二区综合| 欧美激情91| 北条麻妃在线一区| 大白屁股一区二区视频| 国产aⅴ激情无码久久久无码| 综合婷婷亚洲小说| 亚洲av中文无码乱人伦在线视色| 3d动漫精品啪啪一区二区竹菊| 三级网站在线看| 久久av资源网站| 天堂网在线最新版www中文网| 国产日韩欧美成人| 久久激情av| 亚洲一区二区自拍偷拍| 一本色道久久精品| 一个人看的视频www| 国产欧美va欧美不卡在线| www.youjizz.com亚洲| 欧美日韩在线播放| 色视频在线观看免费| 不用播放器成人网| 色豆豆成人网| 久久av一区二区| 欧美日韩岛国| 国产无色aaa| 欧美国产日韩a欧美在线观看 | 欧美成人性生活视频| 日本最新高清不卡中文字幕| www.神马久久| 国产精品88久久久久久妇女 | 天天av天天翘天天综合网| 99热这里只有精品1| 中文字幕国产亚洲2019| 欧美1级2级| 久久综合给合久久狠狠色| 国内一区二区三区| 91大神免费观看| 国产精品久久久久国产精品日日| 无码人妻丰满熟妇精品| 亚洲黄色www| a国产在线视频| caoporn国产精品免费公开| 亚洲国产不卡| 三区视频在线观看| 亚洲国产精品二十页| 亚洲精品成人在线视频| 亚洲国产一区二区三区在线观看| 香蕉成人app免费看片| 91手机在线观看| 欧美1区2区| 波多野结衣免费观看| 成人免费在线视频观看| 91精品国产乱码久久久久| 主播福利视频一区| 久久精品xxxxx| 在线视频不卡一区二区| 激情欧美一区二区| 色老板免费视频| 制服视频三区第一页精品| 好吊日视频在线观看| 91|九色|视频| 午夜视频一区| 又黄又色的网站| 婷婷中文字幕综合| 亚洲 精品 综合 精品 自拍| 欧美亚洲成人xxx| 国产亚洲一区| 污网站在线免费| 亚洲精品va在线观看| 黄色小视频免费观看| 国产91精品高潮白浆喷水| 免费看日本一区二区| 依人在线免费视频| 亚洲欧美日韩久久| 少妇精品视频一区二区| 91高清视频免费观看| 第四色成人网| 波多野结衣网页| 欧美日韩精品在线播放| jizz在线观看中文| 亚洲精品日产aⅴ| 国产精品美女久久久浪潮软件| 天天躁日日躁aaaa视频| 欧美日韩国产一二三| 欧美videosex性欧美黑吊| 久久久一本精品99久久精品66| 日本视频一区二区三区| 国产三级国产精品国产国在线观看| 日韩免费看网站| 一区一区三区| 97超碰人人爱| 91视频91自| 国产美女永久免费| 97久久精品在线| 日韩成人精品一区| 2018国产精品| 欧美性生交片4| 波多野结依一区| 亚洲一区bb| 91视频91自| 99在线精品视频免费观看20| 亚洲欧洲三级电影| 在线观看日本黄色| 日韩欧美国产一二三区| 高清电影一区| 97在线国产视频| 国产精品久久久久桃色tv| 国精产品一品二品国精品69xx|