亭亭五月天在线观看,亭亭五月天在线观看,国产最新av一区二区,国产 高清 中文字幕,99re热久久亚洲综合精品成人,熟妇 一区二区三区,一级做a爰片性色毛片武则天,美女的骚穴视频播放,国产美女午夜免费视频

首頁(yè)>國(guó)內(nèi) > 正文

Information_Schema.tables 視圖中,表的最后修改時(shí)間靠譜嗎?

2023-06-27 18:13:36來(lái)源:一樹(shù)一溪

information_schema.tables 視圖中,update_time 字段記錄了表的最后修改時(shí)間,即某個(gè)表最后一次插入、更新、刪除記錄的事務(wù)提交時(shí)間。

update_time 字段有個(gè)問(wèn)題,就是它記錄的表的最后修改時(shí)間不一定靠譜。


(相關(guān)資料圖)

從省事的角度來(lái)說(shuō),既然它太不靠譜,我們不用它就好了。

但是,本著不放過(guò)一個(gè)壞蛋,不錯(cuò)過(guò)一個(gè)好蛋的原則,我們可以花點(diǎn)時(shí)間,摸清楚它的底細(xì)。

接下來(lái),我們圍繞下面 2 個(gè)問(wèn)題,對(duì) update_time 做個(gè)深入了解:

它記錄的表的最后修改時(shí)間從哪里來(lái)?它為什么不靠譜?本文基于 MySQL 8.0.32 源碼,存儲(chǔ)引擎為 InnoDB。

一、準(zhǔn)備工作

創(chuàng)建測(cè)試表:

USE test;CREATE TABLE t1 (id int unsigned NOT NULL AUTO_INCREMENT,i1 int DEFAULT "0",PRIMARY KEY (id) USING BTREE) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3;

插入測(cè)試數(shù)據(jù):

INSERT INTO t1(i1) VALUES (10), (20), (30);

順便看一眼 information_schema.tables 視圖的 update_time 字段:

-- 第 1 步:設(shè)置緩存時(shí)間為 0-- 忽略 mysql.table_stats 中--     持久化的 update_time 字段值-- 直接從 InnoDB 中獲取--     update_time 字段的最新值SET information_schema_stats_expiry = 0;-- 第 2 步:執(zhí)行查詢SELECT * FROM information_schema.tablesWHERE table_schema = "test"AND table_name = "t1"\GTABLE_CATALOG   | defTABLE_SCHEMA    | testTABLE_NAME      | t1TABLE_TYPE      | BASE TABLEENGINE          | InnoDBVERSION         | 10ROW_FORMAT      | DynamicTABLE_ROWS      | 3AVG_ROW_LENGTH  | 5461DATA_LENGTH     | 16384MAX_DATA_LENGTH | 0INDEX_LENGTH    | 0DATA_FREE       | 6291456AUTO_INCREMENT  | 4CREATE_TIME     | 2023-06-18 15:49:17UPDATE_TIME     | 2023-06-18 15:50:37CHECK_TIME      | CREATE_OPTIONS  |TABLE_COMMENT   |

因?yàn)橄到y(tǒng)變量 information_schema_stats_expiry 的值已經(jīng)設(shè)置為 0,所以能夠讀取到 t1 表最新的 update_time。

上面查詢結(jié)果中,update_time 就是插入測(cè)試數(shù)據(jù)的事務(wù)的提交時(shí)間。

二、來(lái)龍去脈1、標(biāo)記表發(fā)生了變化

某個(gè)表插入、更新、刪除記錄的過(guò)程中,寫(xiě) undo 日志之前,trx_undo_report_row_operation() 會(huì)先記下來(lái)這個(gè)表的數(shù)據(jù)發(fā)生了變化:

// storage/innobase/trx/trx0rec.ccdberr_t trx_undo_report_row_operation(...){...bool is_temp_table = index->table->is_temporary();...if (!is_temp_table) {trx->mod_tables.insert(index->table);}...}

有一點(diǎn)需要說(shuō)明:只有非臨時(shí)表的數(shù)據(jù)發(fā)生變化,才會(huì)被標(biāo)記。對(duì)于臨時(shí)表,就不管了。

trx->mod_tables 是個(gè)集合,類型是 std::set,定義如下:

// storage/innobase/include/trx0trx.h// 為了方便閱讀,這個(gè)定義經(jīng)過(guò)了格式化typedef std::set,ut::allocator>trx_mod_tables_t;// storage/innobase/include/trx0trx.hstruct trx_t {...trx_mod_tables_t mod_tables;...}

集合中保存的是 InnoDB 表對(duì)象的指針 dict_table_t *,dict_table_t 結(jié)構(gòu)體的 update_time 屬性用于保存表的最后修改時(shí)間:

// storage/innobase/include/dict0mem.hstruct dict_table_t {.../** Timestamp of the last modification of this table. */// 為了方便閱讀,這個(gè)定義經(jīng)過(guò)了格式化std::atomicupdate_time;...}

trx_undo_report_row_operation() 只會(huì)標(biāo)記表的數(shù)據(jù)發(fā)生了變化,不會(huì)修改表的 dict_table_t 對(duì)象的 update_time 屬性。

2、確定變化時(shí)間
// storage/innobase/trx/trx0trx.ccdberr_t trx_commit_for_mysql(trx_t *trx) /*!< in/out: transaction */{  ...  // 獲取事務(wù)狀態(tài)  switch (trx->state.load(std::memory_order_relaxed)) {    ...    // 事務(wù)為活躍狀態(tài)    case TRX_STATE_ACTIVE:    // 事務(wù)處于二階段提交的 PREPARE 階段    case TRX_STATE_PREPARED:      trx->op_info = "committing";      ...      // 說(shuō)明是讀寫(xiě)事務(wù)      if (trx->id != 0) {        // 確定表的最后修改時(shí)間        trx_update_mod_tables_timestamp(trx);      }      trx_commit(trx);      MONITOR_DEC(MONITOR_TRX_ACTIVE);      trx->op_info = "";      return (DB_SUCCESS);    case TRX_STATE_COMMITTED_IN_MEMORY:      break;  }  ...}

讀寫(xiě)事務(wù)提交時(shí),trx_commit_for_mysql() 調(diào)用 trx_update_mod_tables_timestamp(),把當(dāng)前時(shí)間保存到表的 dict_table_t 對(duì)象的 update_time 屬性中。

// storage/innobase/trx/trx0trx.ccstatic void trx_update_mod_tables_timestamp(trx_t trx) /!< in: transaction */{...// 獲取當(dāng)前時(shí)間const auto now = std::chrono::system_clock::from_time_t(time(nullptr));trx_mod_tables_t::const_iterator end = trx->mod_tables.end();// 迭代 trx->mod_tables 集合中的每個(gè)表for (trx_mod_tables_t::const_iterator it = trx->mod_tables.begin(); it != end;++it) {// 把當(dāng)前時(shí)間賦值給 dict_table_t 對(duì)象// 的 update_time 屬性(*it)->update_time = now;}

trx->mod_tables.clear();}trx->mod_tables 中保存的是數(shù)據(jù)發(fā)生變化的表的 dict_table_t 對(duì)象指針,for 循環(huán)每迭代一個(gè)對(duì)象指針,都把該對(duì)象的 update_time 屬性值設(shè)置為當(dāng)前時(shí)間。

這就說(shuō)明了 update_time 屬性中保存的表的最后修改時(shí)間是執(zhí)行 DML SQL 的事務(wù)提交時(shí)間。

循環(huán)結(jié)束之后,清空 trx->mod_tables 集合。

執(zhí)行流程進(jìn)行到這里,表的最后修改時(shí)間還只是存在于它的 dict_table_t 對(duì)象中,也就是僅僅位于內(nèi)存中。

此時(shí),如果某個(gè)(些)表的 dict_table_t 對(duì)象被從 InnoDB 的緩存中移除了,它(們)的 update_time 也就丟失了。

如果發(fā)生了更不幸的事:MySQL 掛了,或者服務(wù)器突然斷電了,所有表的 update_time 屬性值就全都丟失了。

那要怎么辦呢?當(dāng)然只能是持久化了。

3、持久化

dict_table_t 對(duì)象的 update_time 屬性值,會(huì)被保存(持久化)到 mysql.table_stats 表中,這個(gè)操作包含于表的統(tǒng)計(jì)信息持久化過(guò)程中,有兩種方式:

主動(dòng)持久化。被動(dòng)持久化。(1)主動(dòng)持久化

analyze table 執(zhí)行過(guò)程中,會(huì)把表的統(tǒng)計(jì)信息持久化到 mysql.table_stats 表中,這些統(tǒng)計(jì)信息里就包含了 dict_table_t 對(duì)象的 update_time 屬性。

我們把這種場(chǎng)景稱為主動(dòng)持久化,部分堆棧如下:

| > mysql_execute_command() sql/sql_parse.cc:4688| + > Sql_cmd_analyze_table::execute() sql/sql_admin.cc:1735| + - > mysql_admin_table() sql/sql_admin.cc:1128| + - x > handler::ha_analyze(THD*, HA_CHECK_OPT*) sql/handler.cc:4783| + - x = > ha_innobase::analyze(THD*, HA_CHECK_OPT*) storage/innobase/handler/ha_innodb.cc:18074| + - x = | > ha_innobase::info_low(unsigned int, bool) storage/innobase/handler/ha_innodb.cc:17221| + - x > info_schema::update_table_stats(THD*, Table_ref*) sql/dd/info_schema/table_stats.cc:338| + - x = > setup_table_stats_record() sql/dd/info_schema/table_stats.cc:179| + - x = > Dictionary_client::store() sql/dd/impl/cache/dictionary_client.cc:2595| + - x = | > Storage_adapter::store() sql/dd/impl/cache/storage_adapter.cc:334| + - x = | + > dd::Weak_object_impl_::store() sql/dd/impl/types/weak_object_impl.cc:106| + - x = | + - > Table_stat_impl::store_attributes() sql/dd/impl/types/table_stat_impl.cc:81

ha_innobase::analyze() 調(diào)用 ha_innobase::info_low(),從 dict_table_t 對(duì)象中獲取 update_time 屬性值(即表的最后修改時(shí)間)。

// storage/innobase/handler/ha_innodb.ccint ha_innobase::info_low(uint flag, bool is_analyze) {dict_table_t *ib_table;...if (flag & HA_STATUS_TIME) {...stats.update_time = (ulong)std::chrono::system_clock::to_time_t(ib_table->update_time.load());}...}

ib_table 是 dict_table_t 對(duì)象,事務(wù)提交過(guò)程中,trx_update_mod_tables_timestamp() 會(huì)把事務(wù)提交時(shí)間保存到 ib_table->update_time 中。

這里,dict_table_t 對(duì)象的 update_time 屬性值會(huì)轉(zhuǎn)移陣地,保存到 stats 對(duì)象中備用,stats 對(duì)象的類型為 ha_statistics。

說(shuō)到備用,我馬上想到的是教人做菜的節(jié)目,比如:炸好的茄子撈出瀝油,放在一旁備用。你想到了什么?

// sql/dd/info_schema/table_stats.ccbool update_table_stats(THD *thd, Table_ref *table) {// Update the object propertiesHA_CREATE_INFO create_info;TABLE *analyze_table = table->table;handler *file = analyze_table->file;// ha_innobase::info()if (analyze_table->file->info(HA_STATUS_VARIABLE |HA_STATUS_TIME |HA_STATUS_VARIABLE_EXTRA |HA_STATUS_AUTO) != 0)return true;file->update_create_info(&create_info);// 構(gòu)造 Table_stat 對(duì)象std::unique_ptr ts_obj(create_object());// 為 Table_stat 對(duì)象的各屬性賦值setup_table_stats_record(thd, ts_obj.get(),dd::String_type(table->db, strlen(table->db)),dd::String_type(table->alias, strlen(table->alias)),file->stats, file->checksum(),file->ha_table_flags() & (ulong)HA_HAS_CHECKSUM,analyze_table->found_next_number_field);// 持久化return thd->dd_client()->store(ts_obj.get()) &&report_error_except_ignore_dup(thd, "table");}

update_table_stats() 調(diào)用 ha_innobase::info(),從 InnoDB 中獲取表的信息。

ha_innobase::info() 會(huì)調(diào)用 ha_innobase::info_low(),把 dict_table_t 對(duì)象的 update_time 屬性值保存到 stats 對(duì)象中(類型為 ha_statistics),也就是上面代碼中的 file->stats。

這是 update_time 屬性值第 1 次轉(zhuǎn)移陣地:

dict_table_t -> ha_statistics

analyze 過(guò)程中,ha_innobase::analyze()、ha_innobase::info() 都會(huì)調(diào)用 ha_innobase::info_low(),看起來(lái)是重復(fù)調(diào)用了,不過(guò),這兩次調(diào)用的參數(shù)值不完全一樣,我們就不深究了。

create_object() 構(gòu)造一個(gè)空的 Table_stat 對(duì)象,setup_table_stats_record() 為該對(duì)象的各屬性賦值。

inline void setup_table_stats_record(THD *thd, dd::Table_stat *obj, ...) {...// stats 的類型為 ha_statisticsif (stats.update_time) {// obj 的類型為 Table_statobj->set_update_time(dd::my_time_t_to_ull_datetime(stats.update_time));}...}

setup_table_stats_record() 調(diào)用 obj->set_update_time() 把 stats.update_time 賦值給 obj.update_time。

obj 對(duì)象的類型為 Table_stat,到這里,update_time 屬性值已經(jīng)是第 2 次轉(zhuǎn)移陣地了:

dict_table_t -> ha_statisticsha_statistics -> Table_stat

setup_table_stats_record() 為 Table_stat 對(duì)象各屬性賦值完成之后,update_table_stats() 接著調(diào)用 thd->dd_client()->store(),經(jīng)過(guò)多級(jí)之后,調(diào)用 Weak_object_impl_::store() 執(zhí)行持久化操作。

// sql/dd/impl/types/weak_object_impl.cc// 為了方便介紹,我們以 t1 表為例// 介紹表的統(tǒng)計(jì)信息持久化過(guò)程template bool Weak_object_impl_::store(Open_dictionary_tables_ctx *otx) {  ...  const Object_table &obj_table = this->object_table();  // obj_table.name() 的返回值為 table_stats  // 即 mysql 庫(kù)的 table_stats 表  Raw_table *t = otx->get_table(obj_table.name());  ...  do {    ...    // 構(gòu)造主鍵作為查詢條件    // 數(shù)據(jù)庫(kù)名:test、表名:t1    std::unique_ptr obj_key(this->create_primary_key());    ...    //     // 從 mysql.table_stats 表中    // 查詢之前持久化的 t1 表的統(tǒng)計(jì)信息    std::unique_ptr r;    if (t->prepare_record_for_update(*obj_key, r)) return true;    // 如果 mysql.table_stats 表中    // 不存在 t1 表的統(tǒng)計(jì)信息    // 則結(jié)束循環(huán)    if (!r.get()) break;    // Existing record found -- do an UPDATE.    // 如果 mysql.table_stats 表中    // 存在 t1 表的統(tǒng)計(jì)信息    // 則用 this 對(duì)象中 t1 表的最新統(tǒng)計(jì)信息    // 替換 Raw_record 對(duì)象中對(duì)應(yīng)的字段值    if (this->store_attributes(r.get())) {      my_error(ER_UPDATING_DD_TABLE, MYF(0), obj_table.name().c_str());      return true;    }    // 把 Raw_record 對(duì)象中 t1 表的最新統(tǒng)計(jì)信息    // 更新到 mysql.table_stats 表中    if (r->update()) return true;    return store_children(otx);  } while (false);  // No existing record exists -- do an INSERT.  std::unique_ptr r(t->prepare_record_for_insert());  // Store attributes.  // Table_stat_impl::store_attributes()  if (this->store_attributes(r.get())) {    my_error(ER_UPDATING_DD_TABLE, MYF(0), obj_table.name().c_str());    return true;  }    // t1 表的最新統(tǒng)計(jì)信息  // 插入到 mysql.table_stats 表中  if (r->insert()) return true;  ...}

在代碼注釋中,我們說(shuō)明了以 t1 表為例,來(lái)介紹 Weak_object_impl_::store() 的代碼邏輯。

obj_key 是一個(gè)包含數(shù)據(jù)庫(kù)名、表名的對(duì)象,用于調(diào)用 t->prepare_record_for_update() 從 mysql.table_stats 中查詢之前持久化的 t1 表的統(tǒng)計(jì)信息。

如果查詢到了 t1 表的統(tǒng)計(jì)信息,則保存到 Raw_record 對(duì)象中(指針 r 引用的對(duì)象),調(diào)用 this->store_attributes(),用 t1 表的最新統(tǒng)計(jì)信息替換 Raw_record 對(duì)象的相應(yīng)字段值,得到代表 t1 表最新統(tǒng)計(jì)信息的 Raw_record 對(duì)象。

這里,update_time 屬性值會(huì)第 3 次轉(zhuǎn)移陣地:

dict_table_t -> ha_statisticsha_statistics -> Table_statTable_stat -> Raw_record
// sql/dd/impl/types/table_stat_impl.ccbool Table_stat_impl::store_attributes(Raw_record *r) {return r->store(Table_stats::FIELD_SCHEMA_NAME, m_schema_name) ||r->store(Table_stats::FIELD_TABLE_NAME, m_table_name) ||r->store(Table_stats::FIELD_TABLE_ROWS, m_table_rows) ||r->store(Table_stats::FIELD_AVG_ROW_LENGTH, m_avg_row_length) ||r->store(Table_stats::FIELD_DATA_LENGTH, m_data_length) ||r->store(Table_stats::FIELD_MAX_DATA_LENGTH, m_max_data_length) ||r->store(Table_stats::FIELD_INDEX_LENGTH, m_index_length) ||r->store(Table_stats::FIELD_DATA_FREE, m_data_free) ||r->store(Table_stats::FIELD_AUTO_INCREMENT, m_auto_increment,m_auto_increment == (ulonglong)-1) ||r->store(Table_stats::FIELD_CHECKSUM, m_checksum, m_checksum == 0) ||r->store(Table_stats::FIELD_UPDATE_TIME, m_update_time,m_update_time == 0) ||r->store(Table_stats::FIELD_CHECK_TIME, m_check_time,m_check_time == 0) ||r->store(Table_stats::FIELD_CACHED_TIME, m_cached_time);}

調(diào)用 this->store_attributes() 得到 t1 表的最新統(tǒng)計(jì)信息之后,Weak_object_impl_::store() 接下來(lái)調(diào)用 r->update() 把 t1 表的最新統(tǒng)計(jì)信息更新到 mysql.table_stats 中,完成持久化操作。

如果 t->prepare_record_for_update() 沒(méi)有查詢到表的統(tǒng)計(jì)信息,執(zhí)行流程在 if (!r.get()) break 處會(huì)結(jié)束 while 循環(huán)。

之后,調(diào)用 t->prepare_record_for_insert() 構(gòu)造一個(gè)初始化狀態(tài)的 Raw_record 對(duì)象(指針 r 引用的對(duì)象),再調(diào)用 this->store_attributes() 把 t1 表的最新統(tǒng)計(jì)信息賦值給 Raw_record 對(duì)象的相應(yīng)字段。

最后,調(diào)用 r->insert() 把 t1 表的統(tǒng)計(jì)信息插入到 mysql.table_stats 中,完成持久化操作。

(2)被動(dòng)持久化

從 information_schema.tables 視圖查詢一個(gè)或多個(gè)表的信息時(shí),對(duì)于每一個(gè)表,如果該表的統(tǒng)計(jì)信息從來(lái)沒(méi)有持久化過(guò),或者上次持久化的統(tǒng)計(jì)信息已經(jīng)過(guò)期,MySQL 會(huì)從 InnoDB 中獲取該表的最新統(tǒng)計(jì)信息,并持久化到 mysql.table_stats 中。

上面的描述有一個(gè)前提:對(duì)于每一個(gè)表,該表的統(tǒng)計(jì)信息需要持久化。

那么,怎么判斷 mysql.table_stats 中某個(gè)表的統(tǒng)計(jì)信息是否過(guò)期?

邏輯是這樣的:對(duì)于每一個(gè)表,如果距離該表上一次持久化統(tǒng)計(jì)信息的時(shí)間,大于系統(tǒng)變量 information_schema_stats_expiry 的值,說(shuō)明該表的統(tǒng)計(jì)信息已經(jīng)過(guò)期了。

information_schema_stats_expiry 的默認(rèn)值為 86400s。

因?yàn)檫@種持久化是在查詢 information_schema.tables 視圖過(guò)程中觸發(fā)的,為了區(qū)分,我們把這種持久化稱為被動(dòng)持久化。

被動(dòng)持久化介紹起來(lái)會(huì)復(fù)雜一點(diǎn)點(diǎn),我們以查詢 t1 表的信息為例,SQL 如下:

SELECT * FROM information_schema.tablesWHERE table_schema = "test" ANDtable_name = "t1"\G

被動(dòng)持久化的部分堆棧如下:

| > Query_expression::ExecuteIteratorQuery() sql/sql_union.cc:1763| + > NestedLoopIterator::Read() sql/iterators/composite_iterators.cc:465| + > Query_result_send::send_data() sql/query_result.cc:100| + - > THD::send_result_set_row() sql/sql_class.cc:2878| + - x > Item_view_ref::send() sql/item.cc:8682| + - x = > Item_ref::send() sql/item.cc:8327| + - x = | > Item::send() sql/item.cc:7299| + - x = | + > Item_func_if::val_int() sql/item_cmpfunc.cc:3516| + - x = | + - > Item_func_internal_table_rows::val_int() sql/item_func.cc:9283| + - x = | + - x > get_table_statistics() sql/item_func.cc:9268| + - x = | + - x = > Table_statistics::read_stat() sql/dd/info_schema/table_stats.h:208| + - x = | + - x = | > Table_statistics::read_stat() sql/dd/info_schema/table_stats.cc:457| + - x = | + - x = | + > is_persistent_statistics_expired() sql/dd/info_schema/table_stats.cc:86| + - x = | + - x = | + > Table_statistics::read_stat_from_SE() sql/dd/info_schema/table_stats.cc:563| + - x = | + - x = | + - > innobase_get_table_statistics() storage/innobase/handler/ha_innodb.cc:17642| + - x = | + - x = | + - > Table_statistics::cache_stats_in_mem() sql/dd/info_schema/table_stats.h:163| + - x = | + - x = | + - > persist_i_s_table_stats() sql/dd/info_schema/table_stats.cc:247| + - x = | + - x = | + - x > store_statistics_record() sql/dd/info_schema/table_stats.cc:147| + - x = | + - x = | + - x = > Dictionary_client::store() sql/dd/impl/cache/dictionary_client.cc:2595| + - x = | + - x = | + - x = | > Storage_adapter::store() sql/dd/impl/cache/storage_adapter.cc:334| + - x = | + - x = | + - x = | + > dd::Weak_object_impl_::store() sql/dd/impl/types/weak_object_impl.cc:106

NestedLoopIterator::Read() 從 mysql.table_stats 表中讀取 t1 表的統(tǒng)計(jì)信息。

information_schema.tables 視圖會(huì)從 5 個(gè)基表(base table)中讀取數(shù)據(jù),執(zhí)行流程會(huì)嵌套調(diào)用 NestedLoopIterator::Read(),共 5 層,以實(shí)現(xiàn)嵌套循環(huán)連接,為了簡(jiǎn)潔,這里只保留了 1 層。

NestedLoopIterator::Read() 從 information_schema.tables 視圖的 5 個(gè)基表各讀取一條對(duì)應(yīng)的記錄,并從中抽取客戶端需要的字段,合并成為一條記錄,用于發(fā)送給客戶端。

MySQL 中實(shí)際只有抽取字段的過(guò)程,沒(méi)有合并成為一條記錄的過(guò)程,只是為了方便理解,才引入了合并這一描述。

不過(guò),最終發(fā)送給客戶端的記錄的各個(gè)字段,不一定取自 5 個(gè)基表中讀取的記錄。

因?yàn)?,從其中一個(gè)基表(mysql.table_stats)讀取的 t1 表的統(tǒng)計(jì)信息,帶有過(guò)期邏輯,如果統(tǒng)計(jì)信息過(guò)期了,會(huì)觸發(fā)從 InnoDB 獲取 t1 表的最新統(tǒng)計(jì)信息,替換掉從 mysql.table_stats 中讀取到的相應(yīng)字段,用于發(fā)送給客戶端。

information_schema.tables 視圖定義中,table_rows 是從基表 mysql.table_stats 讀取的第 1 個(gè)字段,所以,發(fā)送 table_rows 字段值給客戶端的過(guò)程中,會(huì)調(diào)用 is_persistent_statistics_expired() 判斷 mysql.table_stats 中持久化的 t1 表的統(tǒng)計(jì)信息是否過(guò)期。

// sql/dd/info_schema/table_stats.cc// 為了方便理解,以 t1 表為例,// 介紹判斷持久化統(tǒng)計(jì)信息是否過(guò)期的邏輯inline bool is_persistent_statistics_expired(THD *thd, const ulonglong &cached_timestamp) {// Consider it as expired if timestamp or timeout is ZERO.// !cached_timestamp = true,// 表示 t1 表的統(tǒng)計(jì)信息從來(lái)沒(méi)有持久化過(guò)// !information_schema_stats_expiry = true,// 表示不需要持久化任何表的統(tǒng)計(jì)信息if (!cached_timestamp || !thd->variables.information_schema_stats_expiry)return true;// Convert longlong time to MYSQL_TIME format// cached_timestamp 表示上次持久化//     t1 表統(tǒng)計(jì)信息的時(shí)間,// 對(duì)應(yīng) mysql.table_stats//     表的 cached_time 字段,// 變量值的格式為 20230619063657// 這里會(huì)從 cached_timestamp 中抽取//     年、月、日、時(shí)、分、秒,// 分別保存到 cached_mysql_time 對(duì)象的相應(yīng)屬性中MYSQL_TIME cached_mysql_time;my_longlong_to_datetime_with_warn(cached_timestamp, &cached_mysql_time,MYF(0));/*Convert MYSQL_TIME to epoc second according to local time_zone ascached_timestamp value is with local time_zone*/my_time_t cached_epoc_secs;bool not_used;// 上次持久化 t1 表的時(shí)間,轉(zhuǎn)換為時(shí)間戳cached_epoc_secs =thd->variables.time_zone->TIME_to_gmt_sec(&cached_mysql_time, ?_used);// 當(dāng)前 SQL 開(kāi)始執(zhí)行的時(shí)間戳// 在 dispatch_command() 中賦值long curtime = thd->query_start_in_secs();ulonglong time_diff = curtime - static_cast(cached_epoc_secs);// 當(dāng)前 SQL 開(kāi)始執(zhí)行的時(shí)間戳//     - 上一次持久化 t1 表的時(shí)間戳// 是否大于系統(tǒng)變量 information_schema_stats_expiry 的值return (time_diff > thd->variables.information_schema_stats_expiry);}

is_persistent_statistics_expired() 有 3 個(gè)判斷條件:

條件 1:!cached_timestamp = true,說(shuō)明 t1 表的統(tǒng)計(jì)信息從來(lái)沒(méi)有持久化過(guò),接下來(lái)需要從 InnoDB 獲取 t1 表的最新統(tǒng)計(jì)信息,用于持久化和返回給客戶端。

條件 2:!thd->variables.information_schema_stats_expiry = true,說(shuō)明系統(tǒng)變量 information_schema_stats_expiry 的值為 0,表示不需要持久化任何表(當(dāng)然包含 t1 表)的統(tǒng)計(jì)信息,接下來(lái)需要從 InnoDB 獲取 t1 表的最新統(tǒng)計(jì)信息,用于返回給客戶端。

條件 3:time_diff > thd->variables.information_schema_stats_expiry,這是 return 語(yǔ)句中的判斷條件。

如果此條件值為 true,說(shuō)明當(dāng)前 SQL 的開(kāi)始執(zhí)行時(shí)間減去上一次持久化 t1 表統(tǒng)計(jì)信息的時(shí)間,大于系統(tǒng)變量 information_schema_stats_expiry 的值,說(shuō)明之前持久化的 t1 表統(tǒng)計(jì)信息已經(jīng)過(guò)期,接下來(lái)需要從 InnoDB 獲取 t1 表的最新統(tǒng)計(jì)信息,用于持久化和返回給客戶端。

對(duì)于 t1 表,不管上面 3 個(gè)條件中哪一個(gè)成立,is_persistent_statistics_expired() 都會(huì)返回 true。

接下來(lái),Table_statistics::read_stat() 都會(huì)調(diào)用 Table_statistics::read_stat_from_SE() 從 InnoDB 獲取 t1 表的最新統(tǒng)計(jì)信息。

// sql/dd/info_schema/table_stats.cc// 為了方便理解,同樣以 t1 表為例// 代碼中 table_name_ptr 對(duì)應(yīng)的表就是 t1ulonglong Table_statistics::read_stat_from_SE(...) {...if (error == 0) {...if ...// 調(diào)用 innobase_get_table_statistics()// 從 InnoDB 獲取 t1 表的統(tǒng)計(jì)信息else if (!hton->get_table_statistics(schema_name_ptr.ptr(),table_name_ptr.ptr(),se_private_id,*ts_se_private_data_obj.get(),*tbl_se_private_data_obj.get(),HA_STATUS_VARIABLE | HA_STATUS_TIME |HA_STATUS_VARIABLE_EXTRA | HA_STATUS_AUTO,&ha_stat)) {error = 0;}...}// Cache and return the statisticsif (error == 0) {if (stype != enum_table_stats_type::INDEX_COLUMN_CARDINALITY) {cache_stats_in_mem(schema_name_ptr, table_name_ptr, ha_stat);...// 調(diào)用 can_persist_I_S_dynamic_statistics()// 判斷是否要持久化 t1 表的統(tǒng)計(jì)信息// 如果需要持久化,// 則調(diào)用 persist_i_s_table_stats()// 把 t1 表的最新統(tǒng)計(jì)信息//     保存到 mysql.table_stats 表中if (can_persist_I_S_dynamic_statistics(...) &&persist_i_s_table_stats(...)) {error = -1;} else// 持久化成功之后,從 ha_stat 中讀取//     stype 對(duì)應(yīng)的字段值返回// 對(duì)于 SELECT * FROM information_schema.tables// stype 的值為//     enum_table_stats_type::TABLE_ROWSreturn_value = get_stat(ha_stat, stype);}...}...}

Table_statistics::read_stat_from_SE() 先調(diào)用 hton->get_table_statistics() 從存儲(chǔ)引擎獲取 t1 表的統(tǒng)計(jì)信息,對(duì)于 InnoDB,對(duì)應(yīng)的方法為 innobase_get_table_statistics()。

獲取 t1 表的統(tǒng)計(jì)信息之后,先調(diào)用 can_persist_I_S_dynamic_statistics() 判斷是否需要持久化表的統(tǒng)計(jì)信息到 mysql.table_stats 中。

// sql/dd/info_schema/table_stats.cc// 為了方便閱讀,以下代碼的格式被修改過(guò)了inline bool can_persist_I_S_dynamic_statistics(...) {  handlerton *ddse = ha_resolve_by_legacy_type(thd, DB_TYPE_INNODB);  if (ddse == nullptr || ddse->is_dict_readonly()) return false;  return (/* 1 */ thd->variables.information_schema_stats_expiry &&          /* 2 */ !thd->variables.transaction_read_only &&           /* 3 */ !super_read_only &&          /* 4 */ !thd->in_sub_stmt &&           /* 5 */ !read_only &&           /* 6 */ !partition_name &&          /* 7 */ !thd->in_multi_stmt_transaction_mode() &&          /* 8 */ (strcmp(schema_name, "performance_schema") != 0));}

return 語(yǔ)句中,所有判斷條件的值都必須為true,t1 表的統(tǒng)計(jì)信息才會(huì)被持久化到mysql.table_stats中,這些條件的含義如下:

條件 1:thd->variables.information_schema_stats_expiry = true,表示系統(tǒng)變量 information_schema_stats_expiry 的值大于 0。

條件 2:!thd->variables.transaction_read_only = true,表示系統(tǒng)變量 transaction_read_only 的值為 false,MySQL 能夠執(zhí)行讀寫(xiě)事務(wù)。

條件 3、5:!super_read_only = true,并且 !read_only = true,表示系統(tǒng)變量 super_read_only、read_only 的值都為 false,MySQL 沒(méi)有被設(shè)置為只讀模式。

條件 4:!thd->in_sub_stmt = true,表示當(dāng)前執(zhí)行的 SQL 不是觸發(fā)器觸發(fā)執(zhí)行的、也不是存儲(chǔ)過(guò)程中的 SQL。

條件 6:!partition_name = true,表示 t1 表不是分區(qū)表。

條件 7:!thd->in_multi_stmt_transaction_mode(),表示當(dāng)前事務(wù)是自動(dòng)提交事務(wù),即一個(gè)事務(wù)只會(huì)執(zhí)行一條 SQL。

條件 8:strcmp(schema_name, "performance_schema") != 0),表示 t1 表的數(shù)據(jù)庫(kù)名不是 performance_schema。

如果 Table_statistics::read_stat_from_SE() 調(diào)用 can_persist_I_S_dynamic_statistics() 得到的返回值為 true,說(shuō)明需要持久化 t1 表的統(tǒng)計(jì)信息,調(diào)用 persist_i_s_table_stats() 執(zhí)行持久化操作。

// sql/dd/info_schema/table_stats.ccstatic bool persist_i_s_table_stats(...) {// Create a object to be stored.std::unique_ptr ts_obj(dd::create_object());setup_table_stats_record(thd, ts_obj.get(),dd::String_type(schema_name_ptr.ptr(), schema_name_ptr.length()),dd::String_type(table_name_ptr.ptr(), table_name_ptr.length()), stats,checksum, true, true);return store_statistics_record(thd, ts_obj.get());}

persist_i_s_table_stats() 調(diào)用 setup_table_stats_record() 構(gòu)造 Table_stat 對(duì)象,其中包含統(tǒng)計(jì)信息的各個(gè)字段。

然后,調(diào)用 store_statistics_record(),經(jīng)過(guò)多級(jí)之后,最終會(huì)調(diào)用 Weak_object_impl_::store() 方法執(zhí)行持久化操作。

主動(dòng)持久化小節(jié)已經(jīng)介紹過(guò) setup_table_stats_record()、Weak_object_impl_::store() 這 2 個(gè)方法的代碼,這里就不再重復(fù)了。

三、為什么不靠譜

上一小節(jié),我們以 t1 表為例,介紹了一個(gè)表的統(tǒng)計(jì)信息的持久化過(guò)程。

持久化的統(tǒng)計(jì)信息中包含 update_time,按理來(lái)說(shuō),既然已經(jīng)持久化了,那它沒(méi)有理由不靠譜對(duì)不對(duì)?

其實(shí),update_time 之所以不靠譜,有 2 個(gè)原因:

原因 1:某個(gè)表的 update_time 發(fā)生變化之后,并不會(huì)馬上被持久化。

需要執(zhí)行 analyze table,才會(huì)觸發(fā)主動(dòng)持久化,而這個(gè)操作并不會(huì)經(jīng)常執(zhí)行。

從 information_schema.tables 視圖讀取表的信息(其中包含統(tǒng)計(jì)信息),這個(gè)操作也不一定會(huì)經(jīng)常執(zhí)行,退一步說(shuō),就算是監(jiān)控場(chǎng)景下,會(huì)頻繁查詢這個(gè)視圖,但也不會(huì)每次都觸發(fā)被動(dòng)持久化。

因?yàn)楸粍?dòng)持久化還要受到系統(tǒng)變量 information_schema_stats_expiry 的控制,它的默認(rèn)值是 86400s。

information_schema_stats_expiry 使用默認(rèn)值的情況下,即使頻繁查詢 information_schema.tables 視圖,一個(gè)表的統(tǒng)計(jì)信息,一天最多只會(huì)更新一次。

這里的統(tǒng)計(jì)信息,單指 mysql.table_stats 表中保存的統(tǒng)計(jì)信息。

原因 2:持久化之前,update_time 只位于內(nèi)存中的 dict_table_t 對(duì)象中。

一旦 MySQL 掛了、服務(wù)器斷電了,下次啟動(dòng)之后,所有表的 update_time 都丟了。

以及,如果打開(kāi)的 InnoDB 表過(guò)多,緩存的 dict_table_t 對(duì)象數(shù)量達(dá)到上限(由系統(tǒng)變量 table_definition_cache 控制),導(dǎo)致 dict_table_t 對(duì)象被從 InnoDB 的緩存中移除,這些對(duì)象對(duì)應(yīng)表的 update_time 也就丟了。

那么,既然都已經(jīng)把表的統(tǒng)計(jì)信息持久化到 mysql.table_stats 中了,為什么不做的徹底一點(diǎn),保證該表中的持久化信息和 InnoDB 內(nèi)存中的信息一致呢?

根據(jù)代碼中的實(shí)現(xiàn)邏輯來(lái)看,mysql.table_stats 中的持久化信息只是作為緩存使用,表中多數(shù)字段值都來(lái)源于其它持久化信息,而 update_time 字段值來(lái)源于內(nèi)存中,這就決定了它的不靠譜。

我認(rèn)為 update_time 的不靠譜行為是個(gè) bug,給官方提了 bug,但是官方回復(fù)說(shuō)這不是 bug。

感興趣的讀者可以了解一下,bug 鏈接如下:https://bugs.mysql.com/bug.php?id=111476

四、說(shuō)說(shuō) mysql.table_stats 表

默認(rèn)情況下,我們是沒(méi)有權(quán)限查看 mysql.table_stats 表的,因?yàn)檫@是 MySQL 內(nèi)部使用的表。

但是,MySQL 也給我們留了個(gè)小門(mén)。

如果我們通過(guò)源碼編譯 Debug 包,并且告訴 MySQL 不檢查數(shù)據(jù)字典表的權(quán)限,我們就能一睹 mysql.table_stats 表的芳容了。

關(guān)閉數(shù)據(jù)字典表的權(quán)限檢查之前,看不到:

SELECT * FROM mysql.table_stats LIMIT 1\G(3554, "Access to data dictionary table"mysql.table_stats" is rejected.")

關(guān)閉數(shù)據(jù)字典表的權(quán)限檢查之后,看到了:

SET SESSION debug="+d,skip_dd_table_access_check";SELECT * FROM mysql.table_stats LIMIT 1\G[ 1. row ]schema_name     | testtable_name      | citytable_rows      | 462avg_row_length  | 177data_length     | 81920max_data_length | 0index_length    | 16384data_free       | 0auto_increment  | 3013checksum        | cached_time     | 2023-06-20 06:09:14
五、總結(jié)

為了方便介紹和理解,依然以 t1 表為例進(jìn)行總結(jié)。

t1 表插入、更新、刪除記錄過(guò)程中,寫(xiě) undo 日志之前,它的 dict_table_t 對(duì)象指針會(huì)被保存到 trx->mod_tables 集合中。

事務(wù)提交過(guò)程中,迭代 trx->mod_tables 集合(只包含 t1 表),把當(dāng)前時(shí)間賦值給 t1 表 dict_table_t 對(duì)象的 update_time 屬性,這就是 t1 表的最后修改時(shí)間。

如果執(zhí)行 analyze table t1,會(huì)觸發(fā)主動(dòng)持久化,把 t1 表的統(tǒng)計(jì)信息持久化到 mysql.table_stats 表中。

如果通過(guò) information_schema.tables 視圖讀取 t1 表的信息,其中的統(tǒng)計(jì)信息來(lái)源于 mysql.table_stats 表,從 mysql.table_stats 中讀取 t1 表的統(tǒng)計(jì)信息之后,把 table_rows 字段值發(fā)送給客戶端之前,會(huì)判斷 t1 表的統(tǒng)計(jì)信息是否已過(guò)期。

如果已經(jīng)過(guò)期,會(huì)觸發(fā)被動(dòng)持久化,把 t1 表的最新統(tǒng)計(jì)信息持久化到 mysql.table_stats 表中。

t1 表的統(tǒng)計(jì)信息中包含 update_time 字段,不管是主動(dòng)還是被動(dòng)持久化,t1 表 dict_table_t 對(duì)象的 update_time 屬性值都會(huì)隨著統(tǒng)計(jì)信息的持久化保存到 mysql.table_stats 表的 update_time 字段中。

雖然 t1 表 dict_table_t 對(duì)象的 update_time 屬性值會(huì)持久化到 mysql.table_stats 表中,但是在持久化之前,update_time 只存在于內(nèi)存中,一旦 MySQL 掛了、服務(wù)器斷電了,或者 t1 表的 dict_table_t 對(duì)象被從 InnoDB 的緩存中移除了,未持久化的 update_time 屬性值也就丟失了,這就是 update_time 不靠譜的原因。

本文轉(zhuǎn)載自微信公眾號(hào)「一樹(shù)一溪」,可以通過(guò)以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系一樹(shù)一溪公眾號(hào)。

關(guān)鍵詞:

相關(guān)新聞

Copyright 2015-2020   三好網(wǎng)  版權(quán)所有 聯(lián)系郵箱:435 22 640@qq.com  備案號(hào): 京ICP備2022022245號(hào)-21
福利视频导航在线观看| 新亚洲天堂男子av| 日韩激情文学在线视频| 午夜呻吟亚洲精品中文字幕在上面| 久久国产半精品99精品国产| 国产在线小视频一区二区| 中文字幕国产一区在线视频| 一区二区三区四区影片| 超级黄肉动漫在线观看| 黄色av网址在线播放| 美女欧美视频在线观看免费| 九热精品视频在线观看| 亚洲全国精品女人久久久| 网友自拍第一页99热| 青青青免费手机视频在线观看| 顶级欧美色妇xxxx| 欧美肥妇久久久久久| 久久国产精品久精国产爱| 亚洲gay视频在线观看| 99久久免费播放在线观看视频| 九九六视频,这里只有精品| 顶级欧美色妇4khd| 天天干夜夜操91视频网站| 日韩人妻中文字幕二区| 亚洲激情噜噜噜久久久| 荣立三等功退休有什么待遇| 亚洲成人偷拍自拍在线| 久久久久九九九九九12| 极品内射老女人操逼视频| 日韩人妻一区二区三区在线观看 | 天天日天天玩天天摸| 久久久久国产精品二区| 日本福利网站一区二区| 亚洲第一区av中文字幕| 日韩一级视频一区二区三区 | 亚洲|久久久久久一二三区丝袜| 最新国产精品久久精品app| 裸露视频免费在线观看| 久久久国产精品免费视频网| 亚洲欧美另类丝袜另类自拍 | 人妻色综合aaaaaa网| 精久久久久久久久久久久| 欧美一区二区三区爽爽| 女生抠逼自慰啊啊啊啊啊啊啊下载| 一区二区三区婷婷中文字幕| 911精产国品一二三产区区| 久久无码高清免费视频| 99免费观看在线视频| 免费中文字幕a级激情| 97视频人人爱麻豆| 亚洲成人中文无码在线| 日本东京热视频欧美视频| 久久久久久久久久久久久国产| 无码人妻丰满熟妇区五路| 日本在线免费观看国产精品| 中文字幕熟女乱一区二区| a级片特黄免费看| 99久久久久久亚洲精品免费| 亚洲制服丝袜美腿在线| 最新国产午夜激情视频| 亚洲自拍偷拍一区二区中文字幕| 欧美极品少妇高潮喷水| 96在线观看免费播放| 伊人久久综合国产精品| 欧美成人一二三在线网| 老牛影视在线一区二区三区| 福利视频免费在线播放| 青青青国产精品视频| iga肾三级算严重吗| 老熟妇一区二区三区v∧88| 免费在线小视频你懂的| tushy一区二区三区视频| 美女扒开逼逼给你看| 天堂一区二区三区在线等| 裸露视频免费在线观看| 亚洲欧美精品海量播放| 黄色片免费网站在线| 亚洲欧美另类校园春色| 最新久久这里只有精品| 国产精品蝌蚪自拍视频| 97人妻人人揉人人躁人人夜夜爽| 91进入蜜桃臀在线播放| 91porny九色视频偷拍| 日本少妇人妻中文在线| 天天操天天舔天天射天天日天天干 | 可在线免费观看av| 亚洲av毛片在在线播放| 亚洲人成大片在线观看| 91进入蜜桃臀在线播放| 午夜8050免费小说| 久久精品久久久久观看99水蜜桃| 91超碰国产在线观看| 69av精品国产探花| 国长拍拍视频免费孕妇| 精久久久久久久久久久久| a级黄片免费观看| 综合激情网,激情五月| 一区二区三区高清视频3| 天天碰天天摸天天搞| 一区二区三区午夜福利在线| 黄色片免费网站在线| 亚洲AV无码久久精品国产一区老 | 特级aaaaa黄色片| 九九九九九久久久国产| 99久久精品视频16| 亚洲精品乱码久久久久app| 一二区二区不卡视频| 嗯~嗯~啊啊啊~高潮了软件| 蜜臀一区二区日韩美女少妇视频| av一区二区三区四区五区在线| 一区二区九日韩美女| 国产精品中文字幕丝袜| 人人妻人人爽人人摸| 91精品91久久久久| 三区美女视频在线观看| 亚洲国产精品自产拍在线观看| 河北全程露脸对白自拍| 亚洲国产精品自产拍在线观看| 午夜久久久久欠久久久久| 开心五月综合激情婷婷| 性高潮视频在线观看日韩| 亚洲精品乱码久久久久app| 美女妩媚午夜诱惑网站| 久久久亚洲综合国产精品| 第一福利视频在线观看| 成人人妻h在线观看| 亚洲欧美综合另类最新| av 资源在线播放| 中文人妻av一区二区三区| 亚洲精品乱码久久久久app | 成人精品影视一区二区| 亚洲激情噜噜噜久久久| 网站在线观看蜜臀91| 亚洲欧美激情国产综合久久久| 人人妻人人狠人人爽| 91精品久久久久久久久99蜜臀| 两个人在一起靠逼啊啊啊| 97精品人妻免费视频| 久久热在线免费观看| 青娱乐免费视频一二三| 国产成人情侣av在线| 一区二区三区午夜福利在线| 啪啪啪网站免费在线看| 福利视频免费在线播放| 成人精品影视一区二区| 黄片视频免费观看视频| 亚洲欧美一级特黄大片| 黄在线看片免费人成视频| 午夜偷拍的视频久久久免费大全 | 最新免费在线观看污视频| 国内销魂老女人老泬| 夜夜操天天干夜夜操| 岳母的诱惑电影在线观看| 天天操天天舔天天爽| 欧美啪啪一区二区三区| 裸露视频免费在线观看| 最近日韩免费在线观看| 亚洲人妻系列在线视频| 三区美女视频在线观看| 可在线免费观看av| av在线中文字幕在线| 最新日韩av电影在线播放| 日韩精品欧美一区二区| 亚洲av 综合av| 国产极品气质外围av| 婷婷色综合五月天视频| 69久久夜色精品国产69乱电影| 午夜久久久久欠久久久久| 天天想要天天操天天干| 国产精品视频网站污污污| 亚洲欧美精品海量播放| 老鸭窝在线毛片观看免费播放| 日韩美精品成人一区二区三区四区| 亚洲熟女在线免费观看| 日本欧美国产在线一区| 爱搞视频在线观看视频91| 中文字幕 首页 人妻| 不卡高清一区二区三区| 国产大桥未久一区二区| 国内精品一区二区2021在线| 精品美女洗澡一区二区| 中文字幕丰满子伦无码专区| 日本小视频一区二区| 黑人侵犯人妻森泽佳奈| 午夜亚洲国产精品中字| 国产精品成人免费电影| 在线观看2022av| 日本高清在线观看不卡视频| 亚洲精品激情视频在线观看| 亚洲中文字幕在线视频观看二区 | 黑川堇人妻88av| 亚洲欧美另类丝袜另类自拍| 午夜亚洲国产精品中字| yellow在线亚洲精品一区| 91亚洲国产成人久久精品| 国产午夜在线播放视频| 最新日韩av电影在线播放| 三区美女视频在线观看| 69av精品国产探花| 丝袜美女诱惑佐佐三上| 岳母的诱惑电影在线观看| 开心激情五月天作爱片| 伊人网在线免费观看| 国色天香一二三期区别大象| 久久精品久久久久观看99水蜜桃| 中文字幕在线免费观看成人| 夜色福利视频免费观看| 欧美成人少妇人妻精品| 大片a免费观看在线视频观看| av里面的动作是真进去吗| 在宿舍强奷两个清纯校花| 77亚洲视频在线观看| 国产激情在线观看一区二区三区| tushy一区二区三区视频| 午夜精品小视频在线播放| 92在线播放观看视频| 国产亚洲综合5388| 亚洲国产精品 久久久| 欧美猛少妇色ⅹⅹⅹⅹⅹ猛叫| 日本福利网站一区二区| 熟女人妻少妇一区二区 | 亚洲国产日韩a在线欧美| 亚洲国产精品一区51动漫| 成人午夜av电影网| av在线播放观看h| www,日韩av,com| 国产在线观看av一区| 98热视频精品在线观看| 亚洲av网站一区二区三区| 亚洲第一中文字幕成人| 免费高清av一区二区| 天天早上头和脸出汗是怎么办| 河北全程露脸对白自拍| 五月在线视频免费播放91| 亚洲美女午夜激情视频在线观看| 青青草原在线播放日韩| 好看的日本中文字幕在线观看二区| 亚洲激情视频在线观看免费| 国产亚洲精品啪啪视频| 国产av在线免费视频| 天天躁狠狠躁狠狠躁性色| 夜夜操天天干夜夜操| 全彩漫画口工18禁| 亚洲熟女在线免费观看| 91亚洲国产成人久久精品| 午夜免费福利老司机| 日韩激情亚洲国产欧美另类激情 | 久久无码高清免费视频| 五月婷婷伊人久久中文字幕| 青青青青午夜手机国产视频| 天天弄天天草天天日天天| 国产精品蝌蚪自拍视频| 亚洲黄色免费在线观看网站| 1级黄色片在线观看| 欧美vs亚洲vs日韩| 日韩av水蜜桃一区二区三区| 久久久视频在线播放| 少妇被粗大的猛进69视频| 91精品久久久久久久99蜜月| 偷拍熟女大胆免费视频| 日本午夜福利免费在线播放| 天天天天天天天天干夜夜| 欧美成人性生活视频播放| 日本福利片在线播放| 日本五六十路熟女视频| 亚洲一区二区中文字幕久久| 4日日夜夜精品视频免费| 亚洲三级综合在线观看| 欧美日韩久久丝袜在线| 日韩人妻一区二区三区在线观看| 我爱搞在线观看视频| 免费绝清毛片a在线播放| 成人黄色录像在线观看| 猫咪亚洲中文在线中文字幕| 久久久久久久久久久久久国产| 亚洲国产精品自拍偷拍视频在线| 欧美成人红桃视频在线观看| 久草视频在线视频在线视频| jiee日本美女视频网站| 国际日韩日韩日韩日韩日韩| 2018中文字字幕人妻| 伊人综合在线视频免费观看| 中文字幕一区二区三区久久久| 男生和女生羞羞91在线看| 大乳丰满人妻中文字幕韩国hd| 97精品视频,全部免费| 日本一区二区三区区别| 国产原创一区二区三区在线播放| 久久99热精品免费观看视| 中文字幕精品人妻久久久久 | 高清欧美色欧美综合网站| 成熟了的熟妇毛茸茸| 一区二区三区婷婷中文字幕| 老司机在线视频福利观看| 自拍偷拍亚洲综合第一页| 手机看电影一区二区三区| 精品欧美黑人一区二区三区| 最近日韩免费在线观看| 干逼又爽又黄又免费的视频| 女人高潮潮呻吟喷水网站| 婷婷色综合五月天视频| 天天在线播放日韩av| 国产高清在线观看av| 欧美极品少妇高潮喷水| 色老头一区二区三区四区五区 | 午夜精品视频免费观看| 成人资源中文在线观看| 色老头一区二区三区四区五区 | 日本四十路人妻熟女| 欧美熟女xx00视频| 2026天天操天天干| 一区二区三区免费版在线| 少妇被粗大的猛进69视频| 性色蜜桃臀x88av天美传媒| 2019年中文字幕在线播放视频| 夏目彩春av在线看| 日本高清久久人人爽| 豆豆专区操逼性视频在线| 亚洲人人爽人人澡起碰av| 中文字幕人妻一区色偷偷久久 | 国产精品网站亚洲发布| 干逼又爽又黄又免费的视频| 超级黄肉动漫在线观看| 放荡人妻极品少妇全集| 97人妻av人人澡人人爽| 免费在线小视频你懂的| 日日躁夜夜躁狠狠操| 91污污在线观看视频| 狂操鸡巴小骚逼视频免费观看| 最近最新最好看的中文字幕 | 人妻系列中文字幕大乳丰满人妻| 2020精品视频在线| 美国伦理片午夜理论片| 精产国品一二三产品区别97| 黑人3p日本女优中出| 中文字幕麻绳捆绑的人妻| 日本不卡 中文字幕| 最新国产精品综合网高清| 天天插天天干天天狠| 国产精品美女免费视频观看 | 东京热日韩av在线| 成人精品动漫一区二区| 色网站在线观看免费| 亚洲欧美国产一本综合首页| 99福利一区二区视频| lutu玩弄人妻短视频| 中文字幕在线免费观看成人| 天堂一区二区三区在线等| 无码精品黑人一区二区老人| 可在线免费观看av| 男人的天堂在线2025| 伊人免费观看视频一| 亚洲同性同志一二三专区| 午夜精品久久秘?18免费观看| 天天操天天日天天插天天舔| 日本韩国欧美在线视频| 天天操天天干天天谢| 日韩黄色在线观看网站上| 一区二区在线观看视频网站| 丰满放荡熟妇在线播放| 四虎国产精品国产精品国产精品| 亚洲人人爽人人澡起碰av| 亚洲成人自拍图片网站| 美女把逼扒开让男人桶| 日本四十路人妻熟女| 国产福利一区二区三区在线观看| 开心激情五月天作爱片| 青青国产95免看视频| 二十四小时日本高清在线观看| 视频免费在线观看网站| 91在线九色porny| 精产国品一二三产品区别97 | 人人妻人人狠人人爽| 97人妻人人揉人人躁人人夜夜爽| 国产精品视频网站污污污| 99热在线只有的精品| 天天做天天日天天搞| 亚洲一区亚洲二区成人福利| 日本亚洲精品视频在线观看| 亚洲熟女在线免费观看| 99国产精品国产精品毛片19| 色欲AV亚洲AV无码精品| 天天色 天天操 天天好逼| 亚洲色图日韩在线视频观看| 91精品国产人妻麻豆| 乱子伦国产一区二区三区| 加勒比不卡在线视频| 38av一区二区三区| 美女妩媚午夜诱惑网站| 国产精品午夜无码AV体验区 | 四虎精品久久免费最新| 中文字幕人妻一区二区视频系列 | 成熟了的熟妇毛茸茸| 日韩激情亚洲国产欧美另类激情 | 美女露阴道让男人捅| 91精品国产欧美在线| 日本午夜福利免费在线播放| 亚洲av中文无码网站| 91亚洲最新蜜桃在线| 日日夜夜免费视频精品| 亚洲激情视频在线观看免费| 免费在线观看视频啪啪| 高潮喷水在线视频观看| 亚洲欧美成人午夜一区二区| 亚洲熟女乱色一区二区三区视频| 大成色亚洲一二三区| 人妻被强av系列一区二区| 亚洲免费在线不卡视频| 91偷拍被偷拍在线播放| 夜夜人人干人人爱人人操| 老色鬼精品视频在线观看播放| 欧美性感美女热舞视频| 在线观看免费啪啪啪| 都市激情校园春色 亚洲| 日本欧美国产在线一区| 成年人免费黄色av| 在线观看中文字幕少妇av| 中文字幕精品人妻久久久久| 亚洲熟女少妇中文字幕系列| 区一区二区三免费观看视频| 老色鬼精品视频在线观看播放| 亚洲综合首页综合在线观看| 日本东京热最新中文字幕| 色999日韩偷自拍拍免费| av在线中文字幕在线| 69视频在线精品国自产拍| 美女把腿张开给男的捅| 天天干天天色综合久久| 公侵犯人妻中文字幕巨| 91大神在线免费观看视频| 人妻人妻在线视频网站| 亚洲第一页欧美第一页| 伊人网在线免费观看| 亚洲人人爽人人澡起碰av| 91人妻人人做人人爽高清| 亚洲精品国产99999| 黑人黄色免费一级av| 色哟哟亚洲乱码国产乱码精品精| 一区二区三区不卡免费视频网站| 桃色成人开心激情网| 欧美情色av在线观看| 日韩一级欧美一级片| 抽插小穴啊啊啊视频| 午夜亚洲国产精品中字| 一区二区三区四区影片| 国产高清自拍偷拍在线| 国产在线观看av一区| 夜色福利视频免费观看| 人妻中文字幕亚洲在线| 91福利高清在线播放| 国产精品乱码高清在线观看h| 中国特黄色性生活片| 日本小视频一区二区| 日本香港韩国三级黄色| 亚洲欧美激情久久久| 在线观看中文字幕精品av| 久久久西西gogo日本美女人体| 美利坚合众国av天堂| 内地精品毛片在线观看| av 资源在线播放| 日本a级2020在线观看| 最近日韩免费在线观看| 免费在线小视频你懂的| 日本少妇人妻中文在线| 青青在线免费手机播放视频| 55夜色66夜色亚洲精品| 久久精品久久久久观看99水蜜桃| 国产经典精品欧美日韩| 精品国产污污污污免费观看| 免费在线观看视频啪啪| 中文字幕日韩首页欧美在线激情| 在线观看2022av| 91精品国产成人久久久久久| 天天操天天舔天天做| 99福利一区二区视频| 亚洲成人中文无码在线| 交换的一天中文字幕在线视频| 99福利一区二区视频| 婷婷色九月综合激情丁香| 瑟瑟干视频在线观看| 欧美巨大另类极品video| 日本人妻熟妇丰满成熟HD系列 | 中文字幕观看中文字幕免费 | 女人扒开逼让男人操| 人人妻人人爽人人爽欧美一区| 亚洲男人的天堂最新网址| 一区二区三区内射美女| 国产精品剧情在线亚洲| 美国男的操女孩的小嫩逼| 亚洲国产精品一区51动漫| 老熟女xxxⅹhd老熟女性| 日韩黄色在线观看网站上 | 98热视频精品在线观看| 91麻豆精品国产在线| 亚洲欧美综合另类最新| 开心激情五月天作爱片| 高潮喷水一区二区三区| 性感人妻 中文字幕| 红桃视频国产av在线| 精产国品一二三产品区别97| 精品久久久久久久久久久久久| 美国男的操女孩的小嫩逼| 国产av剧变态维修工虐杀美女 | 欧美精品熟妇免费在线| 日韩国产欧美一区二区三区粉嫩| 亚洲欧美精品海量播放| 亚洲成人激情在线综合| 性色蜜桃臀x88av天美传媒| 国产精品国产三级在线高清观看 | 午夜亚洲国产精品中字| 天堂av国产av伦理av| 熟妇精品午夜久久久久| 欧美一区二区三区视频看 | 婷婷一区二区三区五月丁| 一区二区在线观看视频观看| 亚洲欧美另类校园春色| 青娱乐不卡视频在线| 少妇熟女天堂网av| 国产精品免费看一区二区三区| 亭亭五月天在线观看| aa福利影视在线观看| 大香蕉尹人在线最新| 中文字幕丰满子伦无码专区| 欧美久久蜜臀蜜桃资源吧| 操人妻人妻天天爽天天偷| 人人妻人人爽人人爽欧美一区| 情趣视频在线观看91| 大香蕉伊人97在线| 91超精品碰国产在线观看| 久久久久夜色国产精品电影| 午夜精品久久久久久久精品乱码| 熟女阿高潮合集一区二区| 欧美亚洲国产一区二区| 日本一区二区三区的资源| 国产自拍偷拍在线精品| 夜色福利视频免费观看| 最新日韩中文字幕免费在线观看| av 一区二区三区 熟女| 女人扒开逼让男人操| 日本少妇丰满大bbb的小乳沟| 亚洲国产精品自产拍在线观看| 精产国品一二三产品区别97 | 91大神在线免费观看视频| 成人黄色录像在线观看| 亚洲欧美韩国日本一区二区| 97视频人人爱麻豆| 狠狠操深爱婷婷综合一区| 老鸭窝在线毛片观看免费播放| 欧美黄色一区二区三区视频| 两个奶被揉得又硬又翘怎么回事| 一区二区三区免费版在线| 川上优所有中文字幕在线| 蜜臀一区二区日韩美女少妇视频| caopeng97在线观看视频| 美女扒开逼逼给你看| 99 re国产精品| 久久久久久久精品乱码| 少妇被粗大的猛进69视频| 最新免费在线观看污视频| 少妇熟女天堂网av| 97视频538在线观看| 欧美视频免费观看777| 日本高清久久人人爽| 亚洲gay视频在线观看| 51精品视频在线免费观看| 亚洲中文字幕在线视频观看二区| 国产av啊啊啊啊啊啊啊| 98热视频精品在线观看| 欧美日韩一区二区三区成人影院| 999精品视频免费在线观看| 福利视频导航在线观看| 黑鸡巴肏少妇逼视频| 免费看超污视频在线观看| 午夜精品久久秘?18免费观看| 欧美色视频网址大全| 国产精品福利久久久久| 成熟了的熟妇毛茸茸| 综合激情网,激情五月| 顶级欧美色妇xxxx| a级片特黄免费看| 欧美丝袜亚洲国产日韩| 户外露出视频在线观看| 两个人在一起靠逼啊啊啊| 天天天天天天天天日日日| 北野中文字幕一区二区| 得得爱在线视频观看| 国产白丝一区二区三区av| 老司机在线视频福利观看| 亚洲av网站一区二区三区| 黄色片黄色片黄色片黄色片黄色| 亚洲综合一区二区三区四区| av中文字幕国产精品| 青娱乐不卡视频在线| 中文字幕国产一区在线视频| 午夜偷拍的视频久久久免费大全 | 懂色av之国产精品| 青青青青青爽视频在线| 亚洲欧美国产一本综合首页| 中文字幕中文字幕在线中…一区| 日韩成人免费观看电影| 松本菜奈实最新av在线| 国产精品久久久99| 丝袜美女诱惑佐佐三上| 最新日韩中文字幕免费在线观看| 波多野结衣在线一区别| 亚洲中文字幕在线av| 老鸭窝在线毛片观看免费播放| 色屁屁一区二区三区在线观看| 97精品国产91久久久| 成人午夜麻豆大胆视频| 黄色av网址在线播放| 午夜野花视频在线观看| 91系列视频在线播放| 精品人妻在线激情视频| 一区二区三区观看在线| www国产亚洲精品久久久| 懂色av之国产精品| 最新久久这里只有精品| 黄色网络中文字幕日本| 精品国产人伦一区二区三区| 99福利一区二区视频| 看女人大BB群伦交| 每日更新日韩欧美在线| 美女精品久久久久久久久| 人妻在线中文视频视频| 午夜精品秘一区二区三区| 国产不卡免费在线观看| 欧美日韩在线观看免费播放| 秋霞成人午夜鲁丝一区二区三区| 免费的啪啪视频软件| 日本韩国福利在线播放| yy4080黄色片| 欧美插插插插插插| 欧美情色av在线观看| 一区二区三区国产精华液区别大吗| 久久99国产中文丝袜| 女人的天堂 av在线| 青青草一个释放的网站| 午夜呻吟亚洲精品中文字幕在上面| 亚洲一区二区偷拍女厕所| 黄色片黄色片黄色片黄色片黄色| 亚洲va999天堂va| 极品风骚人妻3p视频| 天天摸天天干夜夜操| 亚洲第一页欧美第一页| 东京热男人的天堂视频| 亚洲美女a级黄色在线播放| 亚洲熟女一区二区三区250p| 日本欧美高清在线观看视频| 久久久久久久精品乱码| 操烂你的骚逼天天欧美| 日本不卡视频一二三区| 久99久视频免费观看中文字幕| 天天在线播放日韩av| 国产午夜羞羞一区二区三区| 可以直接看av网站| 欧美黄色一区二区三区视频| 黄色片免费网站在线| 丰满少妇人妻一区二区三区蜜桃| 羞羞漫画无限免费观看秋蝉| 中文字幕熟女乱一区二区| 中文字幕 一区二区在线观看| 污网址在线观看视频| 夜夜爽夜夜操夜夜爱| 日本丰满熟妇浓密多毛| 蜜桃臀av在线一区二区| 二十四小时日本高清在线观看| 中文字幕av特黄毛片| 裸露视频免费在线观看| 公侵犯人妻中文字幕巨| 亚洲 偷拍 自拍 欧美| 天天干夜夜操夜夜骑| 亚洲综合一区二区三区四区 | 91精品视频在线观看视频| 男生和女生羞羞91在线看| 宅男噜噜噜66国产在线观看| 天天操天天射天天操天天日 | 国产自拍偷拍视频在线免费观看 | 亚洲欧美成人激情在线| 999久久久人妻精品一区| 亚洲AV无码久久精品国产一区老| 瑟瑟干视频在线观看| 久久99精品久久久久久三级| 青青草一个释放的网站| 日韩激情亚洲国产欧美另类激情 | 国产精品美女免费视频观看| 亚洲午夜高清在线观看| 日韩欧美中文字幕老司机三分钟| 国产自拍偷拍视频在线免费观看 | 欧美插插插插插插| 成人午夜麻豆大胆视频| 天天干夜夜撸天天操| 美女福利网站在线播放| 国际日韩日韩日韩日韩日韩| 四虎精品久久免费最新| 在线视频自拍第三页| 韩国在线播放一区二区三区| www一区二区91| 国语精品视频自产自拍| 国产成人综合久久婷婷| 九九六视频,这里只有精品| 黄版视频在线免费观看| 69久久夜色精品国产69乱电影| 欧美肥妇久久久久久| 欧洲精品在线免费观看| 嗯~嗯~啊啊啊~高潮了软件| jiee日本美女视频网站| 99久久国产精品免费消防器材| av一区二区三区四区五区在线| 日韩一级视频一区二区三区| 日本久久久久久黄色| 最新久久这里只有精品| 开心五月综合激情婷婷| 亚洲一区二区三区四区入口| 日韩欧美黄色免费网站| 精品视频在线观看免费99| 一区二区三区午夜福利在线| 欧美成人少妇人妻精品| 台湾18禁久久久久久久激情视频| 美女欧美视频在线观看免费| 国产精品美女免费视频观看| 伊人网在线观看 视频一区| 日韩国产欧美久久一区| 天天做天天日天天搞| 嗯~嗯~啊啊啊~高潮了软件| 九色91操最新在线观看网址| 欧美日韩黄片免费在线观看| 偷拍欧美日韩另类图片| 玖玖资源站在线观看亚洲| 亚洲制服丝袜资源网| 午夜福利在线不卡视频| 国产做A爱免费视频在线观看| 亚洲第一页欧美第一页| 午夜五十路久久福利| 国长拍拍视频免费孕妇| 色噜噜噜噜色噜噜色合久一| 在线观看中文字幕视频成人| www一区二区91| 天天爽天天操天天插| 亚洲日本欧美韩国另类综合| 欧美第一激情综合网欧美激情| 亚洲精品乱码久久久久app| 成人资源中文在线观看| 最近在线中文字幕免费| 亚洲色大WWW永久网站| 精品国产久久久久午夜精品av| 少妇被中出一区二区| 欧美久久蜜臀蜜桃资源吧| 大成色亚洲一二三区| 欧美vs亚洲vs日韩| 天天干天天色综合久久| 日韩久久不卡免费视频 | 人妻被强av系列一区二区| 国际日韩日韩日韩日韩日韩| 强乱人妻中文字幕日本| 免费啪啪啪网站在线观看| 2020精品视频在线| 国内自拍第一区二区三区| 公侵犯人妻中文字幕巨| 2026天天操天天干| 亚洲综合成人精品成人精品| 亚洲第一页欧美第一页| 国产清纯一区二区在线观看| 快使劲弄我视频在线播放| 另类欧美激情校园春色| 亚洲熟妇在线视频观看| 玖辛奈18禁同人污本子| 亚洲在线免费观看18| 亚洲日本欧美韩国另类综合| 久久久亚洲熟女一区二区| 9久re热视频在线精品| 上床啪啪啪免费视频| 69国产精品成人aaaaa片| 青青操天堂在线观看视频| 久久久亚洲熟女一区二区| 美女露阴道让男人捅| 国产,亚洲,欧美综合| 午夜福利国产精品久久久久| 午夜宅男电影av网站| 成人人妻h在线观看| 日本小视频一区二区| 伊人网在线欧美日韩在线| 久久久视频在线播放| lutu玩弄人妻短视频| 人妻色综合aaaaaa网| 男插女视频大全免费| 天天干夜夜操91视频网站| 国产福利一区二区三区在线观看| 久久久久性感美女偷拍视频| 三级欧美日韩一区二区三区| 天天天天天天天天日日日| 欧美情色av在线观看| 亚洲最大先锋资源采集站| 杜达雄啪啪毛片视频| 嗯~嗯~啊啊啊~高潮了软件 | 久久人妻人人草人人爽| 天天躁狠狠躁狠狠躁性色| 午夜福利午夜福利影院| 亚洲无人区乱码中文字幕一区| 精品免费一区二区三区四区视频 | 中文字幕国产一区在线视频| 男人资源站中文字幕| 亚洲精品1卡2卡3卡| 成年男女免费视频网站无毒| 黑鸡巴肏少妇逼视频| 亚洲欧美另类丝袜另类自拍| 在线成人教育平台排名| 911精产国品一二三产区区| 国产资源网站在线播放| xxxx69在线观看视频| 大屁股熟女一区二区视频| 日本a级2020在线观看| 亚洲精品国产99999| 3344永久在线观看视频下载| 汤姆提醒30秒中转进站口| 天天干天天日天天弄| 亚洲国产精品一区51动漫| 欧美极品少妇高潮喷水| 精久久久久久久久久久久| 不卡一二三区别视频| 免费在线观看黄色小网站| 18福利视频在线观看| 亚洲一区在线视频观看地址| 最新国产精品久久精品app| 美女扒开逼逼给你看| 亚洲熟妇在线视频观看| 伊人网国产在线播放| 最新日韩中文字幕免费在线观看 | 精品人妻在线激情视频| 五月激情婷婷四射基地| 国际日韩日韩日韩日韩日韩| 亚洲成人自拍图片网站| 欧美日本在线免费视频| 大乳丰满人妻中文字幕韩国hd| 久久久亚洲熟女一区二区| 亚洲宅男噜噜噜66在线观看| 可在线免费观看av| 国产精品视频网站污污污| 青青草一个释放的网站| 九色91操最新在线观看网址| 美女激情久久久久久久| 超级黄肉动漫在线观看| 亚洲欧美不卡专业视频| 欧美精品激情在线不卡| 日本欧美亚洲国产啊啊啊| 丝袜美腿日韩av一区| 中国精品人妻一区二区| 日本一区二区三区的资源| avtt中文字幕手机版| 福利一二三在线视频观看| 亚洲乱码国产乱码精品精视频| 亚洲成a人片777777张柏芝| 欧美久久蜜臀蜜桃资源吧| 欧美精品乱码99久久蜜桃免费| 中文字幕熟女乱一区二区| 亚洲精品久久久人妻| 天天操,天天射,天天爽| 黄片操操操操操操c| 国产一区二区手机在线观看| 男人用大鸡巴狂操女人肉穴| 搞乱在线在线观看视频| 亚洲图片另类综合小说| 日韩人妻精品久久久久| 国产一区二区三区四区精| 精品欧美黑人一区二区三区| 熟女人妻少妇一区二区| 91九色91在线视频| 亚洲精品国品乱码久久久久| 在线视频国产精品欧美| 裸露视频免费在线观看| 91精品一区一区三区| 国产人妻熟女ⅹxx丝袜| 亚洲gay视频在线观看| 182tv精品免费在线观看| 我爱搞在线观看视频| julia人妻av一区二区三区| 亚洲精品国品乱码久久久久| 熟女人妻精品视频一区| 亚洲成人自拍图片网站| 中文字幕人妻一区二区视频系列 | 黑人黄色免费一级av| 一区二区三区高清视频3| 天天干夜夜操91视频网站| 大尺度久久久久久久| 天天操天天日天天插天天舔| 国产自拍偷拍视频在线免费观看| 都市激情校园春色 亚洲| 亚洲欧美不卡专业视频| 美利坚合众国av天堂| 天天天天天天天天干夜夜| 欧美日韩亚洲tv不卡久久| 欧美情色av在线观看| 久久久久久久岛国免费观看| 亚洲欧美成人激情在线| 女人扒开逼让男人操| 可以免费观看日韩av| 亚洲avav天堂av在线网毛片| 男生用大肌巴操美女骚穴| 999国产精品视频免费看| 国产高清自拍偷拍在线| 天天操天天日天天碰| 男人的天堂在线2025| 亚洲成人,国产精品| 青青青青午夜手机国产视频| av资源中文字幕在线观看| 亚洲第一页欧美第一页| 九九九九九久久久国产 | 不卡视频在线 欧美日韩| 亚洲码av一区二区三区| 久久久久九九九九九12| 人人妻人人爽人人爽欧美一区| 狠狠操狠狠操狠狠插| 亚洲欧美另类校园春色| 97超碰人人爽人人做| 青青青在线视频免费播放| 国产成人91色精品免费看片| 一区二区三区四区 在线播放| 92在线播放观看视频| 午夜野花视频在线观看| 成人精品动漫一区二区| 日韩男女视频网站在线观看| 91亚洲最新蜜桃在线| 欧美黑人1区2区3区| 午夜宅男电影av网站| 4438全国成人免费视频| 网站在线观看蜜臀91| 欧美肥妇久久久久久| 77亚洲视频在线观看| 汤姆提醒30秒中转进站口| 男女插鸡巴视频软件| 亚洲高清免费在线观看视频| 国产精品内射婷婷一级| 人妻中文字幕亚洲在线| 国产精品网站亚洲发布| 麻豆白洁少妇在线播放| 欧美丝袜亚洲国产日韩| 鸡巴在里面福利视频在线观看| 9久re热视频在线精品| 欧美日本国产一区二区| 核xp工厂精品久久亚洲| av人摸人人人澡人人超碰小说| 人人人妻人人人妻精品少妇| 性感美女人妻久久久| 亚洲精品久久久人妻| 伊人免费观看视频一| 亚洲一级熟妇丰满的女人| 亚洲欧美日韩中文在线观看 | 中日韩又粗又硬又大精品| 青青青在线观看国产| av一区二区三区蜜桃| 欧美一区二区三区爽爽| 麻豆国产精品777777在| 亚洲一区视频中文字幕在线播放 | 亚洲天堂av最新在线| 亚洲美女露隐私av一区二区精品| 99999久久久精品| 大香蕉在线欧美在线视频| 在线视频自拍第三页| 欧美第一激情综合网欧美激情| 天天日天天玩天天摸| 国产精品无码无卡免费观| 伊人免费观看视频一| 大陆中文字幕视频在线| 免费看超污视频在线观看| 日本高清激情乱一区二区三区| 国产黄色主播网址大全在线播放| 91精品久久久久久久99蜜月| 天天操天天舔天天做| 高清国产美女a一级毛片| 麻豆出品视频在线观看| 成人午夜麻豆大胆视频| 欧美日本亚欧在线观看| 亚洲人人爽人人澡起碰av| 国产av高清二区三区| 国产精品性感美女视频| 99福利一区二区视频 | 国产免费久久精品99re丫丫| 青青免费观看视频| 国产在线小视频一区二区| 国产熟女五十路一区二区三区 | 在线成人教育平台排名| 成人精品动漫一区二区| 欧美成人久久久桃色aa| 美女网站福利在线观看| 中文字幕一区二区三区久久久| —区二区三区女厕偷拍| 国产激情一区二区视频| 五月天天堂视频在线| 91超碰国产在线观看| 亚洲色视频在线播放网站| 一区二区三区国产精华液区别大吗| 欧美一区日韩二区三区四区| 乌克兰美女操逼高清内射视频| 91超精品碰国产在线观看| 亚洲成a人77777| 91精品国产成人久久久久久| 视频在线 一区二区| jizzjizz国产精品传媒| 日本熟妇乱妇熟色视频| 亚洲欧美日韩中文视频| 成熟了的熟妇毛茸茸| 免费啪啪啪网站在线观看| 69xx精品久久久久| 久久久人妻免费视频| 高清av在线婷一区二区色日韩| 在线看日韩av不卡| 黑人和日本人av一区二区| 在线视频国产精品欧美| 日本高清在线观看不卡视频| av天堂hezyo| 天天色 天天操 天天好逼| 人妻在线中文视频视频| 午夜国产成人精品视频观看| 自拍偷自拍亚洲精品10p| 欧美精品999不卡| 中国特黄色性生活片| 日韩欧美一区二区三区免费看| 国产亚洲综合5388| 中文字幕 中文字幕 亚洲| 91精品国产91久久久久久密臀| 国产天堂av不卡网| 日韩激情亚洲国产欧美另类激情| 天天操天天舔天天做| 国产av精品一区二区三区久久| 一区二区三区国产在线成人av| 天天操天天日天天碰| 日本欧美视频在线免费| 第一福利视频在线观看| 亚洲午夜精品视频节目| 亚洲综合成人精品成人精品| 国产原创一区二区三区在线播放| 国产美女视频带a∨黄色片| 97香蕉久久国产超碰| 亚洲精品国产99999| 久久99久久99久久97的人| 天天看片天天摸天天操| 天天插天天操天天射天天干| 美女妩媚午夜诱惑网站| 女人高潮潮呻吟喷水网站| 日本一区二区三区的资源| 99久久久久久亚洲精品免费| 亚洲成a人77777| 人人妻人人爽人人摸| 交换的一天中文字幕在线视频| 大屁股熟女一区二区视频| xxxx69在线观看视频| 欧美性感美女热舞视频| 天天干夜夜操91视频网站| 欧美日本在线免费视频| 亚洲全国精品女人久久久| 午夜宅男电影av网站| 高潮喷水一区二区三区| 亚洲精品色图1234| 夜夜爽夜夜操夜夜爱| 亚洲综合色一区二区三区| 台湾18禁久久久久久久激情视频| 久久一级片三上悠亚| 制服丝袜 中文字幕 日韩| 国产精品久久久99| 99久久国产精品免费热| 亚洲|久久久久久一二三区丝袜| 一区二区三区免费版在线| 免费中文三级在线观看| 中文字幕在线观看av观看| 人妻色综合aaaaaa网| 亚洲日本欧美韩国另类综合 | 五月在线视频免费播放91| 色视频免费观看网址| 日本黄页在线观看视频| 天天夜夜久久精品综合| 久久av色噜噜ai换脸| 亚洲精品乱码久久久久app| 不卡一区二区视频在线| 久操资源在线免费播放| 日韩三级精品电影久久久久| 午夜精品久久久久久久久久蜜桃| 2019年中文字幕在线播放视频| 九九热精品视频在线播放| av在线免费在线观看| 91九色尤物无套内射| 一区二区九日韩美女| 日本a级2020在线观看| 中文字幕中文字幕在线中…一区| 青青操久久综合激情| 国产av啊啊啊啊啊啊啊| 在线免费视频999| 人妻系列在线免费视频| 午夜92福利1000| 99精品久久精品一区二区| 激情九月天在线视频| 黑人侵犯人妻森泽佳奈| 日韩三级精品电影久久久久| 18禁网站在线点击观看| 日韩国产欧美一区二区三区粉嫩| 中文字幕人妻一区二区视频系列 | —区二区三区女厕偷拍| 亚洲熟女一区二区三区250p| 亚洲成人三级黄色片| yy4080黄色片| 91色老久久精品偷偷蜜臀| 久久久精品人妻无码专区不卡| 亚洲高清一区二区三区久久| 日韩av水蜜桃一区二区三区| 国产女人18毛片水真多精选| 一区二区三区午夜福利在线| 日本东京热最新中文字幕| jandara在线观看| 一区二区欧美 国产日韩| 亚洲gay视频在线观看| 亚洲国产精品一区二区第二页| 亚洲男人天堂最新网址大全| 午夜在线成人免费电影| 成人免费视频现网站99在线观看| 亚洲欧洲一区二区三区在线| 亚洲欧美不卡专业视频| 可在线免费观看av| 91精品资源在线观看| 91福利高清在线播放| 18在线观看免费观看| 日本老熟老熟妇七十路| 九十九步都是爱最后一步是尊严| 开心激情五月天作爱片| 中国精品人妻一区二区| 在线观看黄页网站视频网站| 午夜精品久久久久久久久久蜜桃| 一区二区三区国产在线成人av | 放荡人妻极品少妇全集| 亚洲乱码av一区二区蜜桃av| 91超碰九色porny| 欧美亚洲另类精品第一页| 亚洲唯美激情综合四射| 在线观看2022av| 午夜精品秘一区二区三区| 天天夜夜久久精品综合| 亚洲中文字幕无线乱码人妻精品| 9999久久久久老熟妇二区| 亚洲一区二区精品在线播放| 中文字幕综合网91| 欧美黄色性视频网站| 制服丝袜中文字幕熟女人妻| 国产人妻熟女ⅹxx丝袜| 亚洲gay视频在线观看| 午夜福利午夜福利影院| 国产原创一区二区三区在线播放| 国产av啊啊啊啊啊啊啊| 黄版视频在线免费观看| 少妇被粗大的猛进69视频| 亚洲成人,国产精品| 啊~插得好快别揉我胸了视频| 国产精品久久人人添| 亚洲国产日韩a在线欧美| 国产在线观看av一区| 自拍偷拍 亚洲性图 欧美另类| 亚洲成人av在线一区二区| 日韩欧美国产一区二区在线观看| 激情九月天在线视频| 99精品久久99久久久久一| 欧美日韩黄片免费在线观看| 国产在线观看一区二区三区四区| 91色乱一区二区三区| 91精品在线视频免费视频| 911美女片黄在线观看| 日韩欧美国产一区二区在线观看| 欧美在线观看一区二区不卡| 精产国品一二三77777| 久久久久久久久久久久久国产| 亚洲黑人欧美二区三区| 老鸭窝在线毛片观看免费播放| 亚洲精品乱码久久久久app| 99久久久久久亚洲精品免费| 亚洲国产精品自产拍在线观看| 92午夜免费福利视频www| 9久re热视频在线精品| 污视频在线观看地址| 天天色天天射天天日天天干| 青青在线视频看看| av在线男人的天堂亚洲| 青青青青青爽视频在线| 一级毛片特级毛片免费的| 伊人网在线欧美日韩在线| 国产白丝一区二区三区av| 免费在线观看视频啪啪| 久久久久久a女人处女| 99久久国语露脸国产精品| 日本人妻少妇xxxxxxx| 蜜桃tv一区二区三区| 一区二区欧美 国产日韩| 快色视频在线观看免费| 日本福利片在线播放| 色视频在线播放免费观看| 欧美视频亚洲视频在线| 精品高潮呻吟久久av| 92午夜免费福利视频www| 中文人妻av一区二区三区| 国产自拍偷拍在线精品| 又粗又长又硬又黄又爽| 青青青在线视频免费播放| 亚洲最大先锋资源采集站| 中文字幕人妻一区二区视频系列| 大尺度av毛片在线网址| 日本一区二区高清av中文| 欧美在线视频不卡一区| 川上优所有中文字幕在线| 亚洲熟女乱一区二区精品成人| 亚洲a级视频在线播放| 天天夜夜久久精品综合| 亚洲人妻系列在线视频| 一区二区三区婷婷中文字幕| 欧美一区二区三区视频看| 最新日韩中文字幕啪啪啪| 最新国产午夜激情视频| 360偷拍蜜桃臀69式| 十八禁黄色免费污污污亚洲| 凹凸视频一区二区在线观看 | 成人资源中文在线观看| 免费在线观看亚洲福利| 国语精品视频自产自拍| 日本高清 中文字幕| 68福利精品在线视频| 日本五六十路熟女视频| 91九色国产在线视频| 69精品互换人妻4p| 欧美 日韩 精品 中文| 玖玖资源站在线观看亚洲| 最新国产午夜激情视频| 欧美巨大另类极品video| 港台美女明星av天堂| 天天做天天日天天搞| 中文字幕av特黄毛片| 国产精品久久久久精品三级18| 91精品夜夜夜一区二区| 亚洲乱码av一区二区蜜桃av| 色噜噜噜噜色噜噜色合久一| 欧美成人红桃视频在线观看| 中文字幕 人妻 熟女| 久久内射天天玩天天懂色| 天天干夜夜操夜夜骑| 国产视频成人一区二区| 午夜精品久久久久久久久久蜜桃 | 99久久国产精品免费热| 最新日韩中文字幕啪啪啪| 五月婷婷伊人久久中文字幕| 呻吟求饶的人妻中文字幕| 一区二区三区婷婷中文字幕| 日韩人妻中文字幕二区| 美女把腿张开给男的捅| 欧美国产精品久久久免费| 欧美日本在线免费视频| 一区二区三区免费版在线| 日本久久久久久黄色| 欧美插插插插插插| 自拍偷拍 国产激情| av在线播放观看h| 91精品国产91久久久久久密臀| www,日韩av,com| 亚洲欧美成人午夜一区二区| 天天做天天日天天搞| 亚洲一区视频中文字幕在线播放 | 亚洲女人自熨在线视频| 亚洲综合第一区二区| 天天看片天天摸天天操| 五月天天堂视频在线| 天天操天天舔天天做| 青青在线免费手机播放视频| 女女抠逼白虎白丝袜| 户外露出视频在线观看| 久久sm人妻中出精品一区二区| av网页免费在线观看| 亚洲少妇视频在线观看| 亚洲人妻系列在线视频| 国产91免费在线观看| tobu8日本高清| 日韩A级毛片免费视频| 欧美亚洲国产一区二区| 亚洲成人激情在线综合| 亚州av嫩草av极品在线观看| 一区二区九日韩美女| 一区二区在线观看视频观看| 夫妻黄色一级性生活片| 亚洲经典av中文字幕| 天天曰天天摸天天爽| 欧美一区二区三区视频看| 日本韩国欧美在线视频| 日本a级2020在线观看| 亚洲av毛片一区二区三区网| 最新久久这里只有精品| 天天操天天日天天插天天舔| av在线观看视频免费| 精产国品一二三产品区别97| 人妻视频网站快射视频网站| 不卡高清一区二区三区| 欧美国产精品久久久免费| 裸露视频免费在线观看| 99 re国产精品| 欧美日韩成人高清中文网| 亚洲中文字幕在线视频观看二区| 精品一区二区三区免费毛片W| 女生抠逼自慰啊啊啊啊啊啊啊下载| 川上优所有中文字幕在线| 久久av色噜噜ai换脸| 亚洲精品一区二区gif| 宅男噜噜噜66国产在线观看| 久久99久久99久久97的人| 午夜免费福利老司机| 亚洲熟女一区二区三区250p | 色狠狠色综合久久久绯色| 国产清纯一区二区在线观看 | 天天弄天天草天天日天天| 国产精品福利久久久久| www国产亚洲精品久久久| 99女福利女女视频在线播放| 自拍丝袜国产欧美日韩| 精品人妻在线激情视频| 日本福利视频网站导航| 婷婷色综合五月天视频| 制服丝袜中文字幕熟女人妻| 伊人网在线免费观看| 日本一区二区三区区别| 一区二区三区观看在线| 日本美女爱爱视频网站| 中文字幕欧美人妻在线.| 七色福利视频在线观看| 超碰在线免费观看视频97| 女人扒开逼让男人操| 美女福利视频一区二区三区四区| 国产精品 亚洲欧美 自拍偷拍| 99 re国产精品| 精品国产av虐杀两警花| 国产激情免费在线视频| 美女av色播在线播放| 色噜噜噜噜色噜噜色合久一| 色屁屁一区二区三区在线观看| 男女啪啪啪啪91av日韩| 91偷拍被偷拍在线播放| 九九视频在线观看全部| 网友自拍第一页99热| 成年男女免费视频网站无毒| 一区二区三区免费版在线| 亚洲中文字幕在线av| 大屁股熟女一区二区视频| 日本免费人爱做视频在线观看不卡 | 嗯~嗯~啊啊啊~高潮了软件| 99久久精品视频16| 日本黄色一级电影网址| 亚洲一区二区三区四区入口| 亚洲国产精品青青草| 久久免费视频ww一区| 麻豆白洁少妇在线播放| 黄片操操操操操操c| 熟女人妻精品视频一区| 亚洲在线免费观看18| 开心激情五月天作爱片| 国产福利三级在线观看| 成人超碰一区二区三区| 中文字幕人妻精品精品| 天天透天天舔天天操| 亚洲成人三级黄色片| 一区二区九日韩美女| 国产女人18毛片水真多精选| 91麻豆精品国产在线| 天堂av在线最新地址| 国产伦理二区三区在干嘛呢| 超peng视频在线免费播放97| 大香蕉在线欧美在线视频| lutu玩弄人妻短视频| 无人区一码二码三码区别在哪| 亚洲高清一区二区三区久久| 操死你美女在线视频| 欧美成人性生活视频播放| 国际精品熟女一区二区| 荣立三等功退休有什么待遇| 国产av剧变态维修工虐杀美女 | 91九色人妻在线播放| 亚洲一区亚洲二区成人福利| 人妻少妇精品二三区| 男女爱爱好爽视频免费看| 亚洲精品一区二区gif| 中文字幕观看中文字幕免费| 人妻少妇的va视频| 欧美成人区一区二区三| 老司机免费视频福利0| 天天干夜夜操夜夜骑| 日韩精品欧美一区二区| 放荡人妻极品少妇全集| 久久99嫩草99久久精品| 蜜桃臀av在线一区二区| 中文字幕中文字幕在线中…一区| 日本亚洲午夜福利一区二区三区| 色网站在线观看免费| 羞羞漫画无限免费观看秋蝉| 91 精品视频在线看| 都市激情校园春色 亚洲| 一区二区三区四区 在线播放| 欧美性感美女热舞视频| 91久久精品美女高潮喷水白浆| 亚洲国产精品一区51动漫| 18禁男女啪啪啪无遮挡| 91亚洲国产成人久久精品| 久久精品久久久久观看99水蜜桃 | 精产国品一二三产品区别97| av男人站在线观看| 大成色亚洲一二三区| 男人资源站中文字幕| 92午夜免费福利视频www| 国产熟女五十路一区二区三区 | 高清国产美女a一级毛片| 在线成人教育平台排名| 亚洲欧美综合另类最新| 99精品久久一区二区| 精品不卡一区二区三区| 国模伊人久久精品一区二区三区| 西野翔人妻中文字幕中字在| 自拍偷拍视频亚洲一区| 亚洲高清免费在线观看视频| 国产视频成人自拍蝌蚪视频| 亚洲国产精品久久久久久无码| 亚洲在线观看中文字幕av| 白白色在线免费视频发布视频| 黄版视频在线免费观看| 懂色av之国产精品| 91人妻人人做人人爽高清| 亚洲AV无码一二三四区在线播放| 激情九月天在线视频| 91偷拍被偷拍在线播放| 松本菜奈实最新av在线| 日本丰满熟妇浓密多毛| 男人电影天堂在线观看| 在线观看中文字幕少妇av| 亚洲国产精品一区二区第二页| 天天搞天天操天天干| 青青青青青爽视频在线| av 一区二区三区 熟女| 日本人妻熟妇丰满成熟HD系列 | 大陆中文字幕视频在线| 啊~插得好快别揉我胸了视频 | 亚洲国产精品 久久久| 国产男女无套?免费网站下载| 亚洲另类激情视频在线看| 国产精品蝌蚪自拍视频| 福利在线国产小视频| 欧美一区二区三区视频看| 污网址在线观看视频| xxoo福利视频导航| 人妻免费视频黄片在线视频| 欧美性感美女热舞视频| 啊~插得好快别揉我胸了视频| 91精产国品一二三产区区别网站 | 91九色91在线视频| 久久综合狠狠综合久久综| 日本福利视频网站导航| 91人妻人人爽色啊啊啊| 97精品国产91久久久| 国产精品剧情av在线播放| 中文字幕精品人妻久久久久| 91色哟哟视频在线观看| 亚洲在线免费观看18| 日本国产亚洲欧美色综合| 天天综合久久无人区| 熟女俱乐部jukujoclub| 久久午夜免费鲁丝片| 国产一区两区三区福利小视频| 青青在线免费手机播放视频| 超碰在线免费观看视频97 | 中国特黄色性生活片| 在线免费视频999| av成人三级高清日韩| 日韩国产欧美久久一区| 欧美日韩亚洲tv不卡久久| 亚洲a级视频在线播放| av 一区二区三区 熟女| 免费在线观看视频啪啪| —区二区三区女厕偷拍| 夫妻黄色一级性生活片| 七色福利视频在线观看| 欧美精品乱码99久久蜜桃免费| 欧美日韩综合精品无人区| av网页免费在线观看| 成人精品影视一区二区| 亚洲成人自拍图片网站| 91精品一区一区三区| 男女爱爱好爽视频免费看|