亭亭五月天在线观看,亭亭五月天在线观看,国产最新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热在线只有的精品| 天天弄天天草天天日天天| 日韩国产欧美久久一区| 老司机免费视频福利0| 自拍偷拍 亚洲性图 欧美另类| 国长拍拍视频免费孕妇| av成人三级高清日韩| 亚洲理论在线a中文字幕97| 女人高潮潮呻吟喷水网站| 女人高潮潮呻吟喷水网站| 制服丝袜 中文字幕 日韩| 涩涩黄片在线免费观看| 成人黄色录像在线观看| 一区二区三区五区六区| 国产精品蝌蚪自拍视频| 亚洲乱熟女一区二区三区山| 人妻中文字幕亚洲在线| 午夜一区二区三区视频在线观看| 68福利精品在线视频| 中文字字幕在线精品乱码| 一区二区三区国产在线成人av| 国产大桥未久一区二区| 亚洲蜜桃久久久久久| 99精品久久99久久久久一| 四虎国产精品国产精品国产精品| av一区二区三区蜜桃| 5566熟女人妻人妻| 三级欧美日韩一区二区三区| 久久人人爽人人爽人人av东京热| 91色乱一区二区三区| 夜夜骚av一二三区| 交换的一天中文字幕在线视频| 18岁禁一二三区免费体验| 日本人妻少妇xxxxxxx| 久久99精品热在线观看| 免费中文字幕a级激情| 亚洲综合天堂av网站在线观看| 最新日韩中文字幕啪啪啪| 日韩精品欧美一区二区| 夜夜骚av一二三区| 无人区一码二码三码区别在哪| 97人妻人人揉人人躁人人夜夜爽| aaaa级少妇高潮在线观看| 午夜情色一区二区三区| 美女网站福利在线观看| 69av精品国产探花| 激情久久在线免费观看视频| 亚洲精品乱码久久久久app| 国产一区二区手机在线观看| 欧美日韩亚洲国产视频二区| 无人区一码二码三码区别在哪| 久久久久九九九九九12| 红桃视频国产av在线| 国产av精品一区二区三区久久| 中日韩又粗又硬又大精品| 欧美成人红桃视频在线观看| 麻豆午夜激情在线观看| 99久久99九九九99九| 裸日本资源在线午夜| 亚av一二三在线观看| 亚洲精品国品乱码久久久久| 女人的天堂 av在线| 熟女一区二区三区综合| 国产在线观看一区二区三区四区| 午夜3p福利视频合集| 五月激情婷婷四射基地| 久久久视频在线播放| 日本东京热视频欧美视频| av成人三级高清日韩| 中文字字幕在线精品乱码| 97超碰人人爽人人做| av男人站在线观看| 亚洲成人激情在线综合| 国产美女主播av在线| 亚洲美女a级黄色在线播放| 九九九九九久久久国产| 天天色天天射天天日天天干| 无码人妻丰满熟妇区五路| 国内自拍第一区二区三区| 国产人妻熟女ⅹxx丝袜| 超碰在线观看97资源| 日产国产欧美精品另类| 午夜福利片无码10000| 插鸡视频免费网站在线播放| 9999久久久久老熟妇二区| 天堂在线中文字幕av| 亚洲av三级电影在线观看| 国产精品亚洲精品亚洲| 国产一级一国产一级毛片| 高潮喷水在线视频观看| xxnxx国产美女| 青青在线免费手机播放视频| 国产在线小视频一区二区| 午夜宅男电影av网站| 午夜在线成人免费电影| 九一精品人妻一区二区三区| 日韩黄色在线观看网站上| 亚洲三级综合在线观看| 国产漂亮白嫩美女在线图片| 男女插鸡巴视频软件| 麻豆白洁少妇在线播放| 亚洲在线免费观看18| 中文字幕欧美一区二区视频| 午夜野花视频在线观看| 二十四小时日本高清在线观看 | 亚洲图片另类综合小说| 国产av精品一区二区三区久久| 国产成人情侣av在线| 熟女俱乐部jukujoclub| 日本免费人爱做视频在线观看不卡| 欧美区一区二区三视频| 日韩欧美一区二区三区免费看| 凹凸视频一区二区在线观看| 日本亚洲精品视频在线观看| lutu玩弄人妻短视频| 亚洲成人 国产精品| 亚洲妹妹我爱你在线观看| 午夜福利国产精品久久久久| 欧美情色av在线观看| 成人做爰av在线观看网站| 全球高清中文字幕av| 羞羞漫画无限免费观看秋蝉| 91美女在线观看视频| 一区二区三区四区久久久久韩日| 亚洲欧美精品海量播放| 东京热男人的天堂视频| 奇米网首页神马久久| 亚洲一区二区在线激情| 人人妻人人爽人人爽欧美一区 | 免费看一级高潮喷水片 | 天天爽天天操天天插| 成人免费视频现网站99在线观看 | 午夜92福利1000| 日本高清有码在线视频| 911美女片黄在线观看| 熟女俱乐部jukujoclub| 欧美丝袜亚洲国产日韩| 午夜国产成人精品视频观看| 麻豆午夜激情在线观看| 青青免费观看视频| 在线人成视频免费观看尤物| 亚洲 综合 欧美 一区| 50熟妇一区二区三区| 熟女国内精品一区二区三区| 午夜精品老牛av一区二区三区| 99久久久久久久久久久久久| 黑人巨大精品一区二区在线| 国产精品乱码高清在线观看h| 国产天堂av不卡网| 亚洲一区二区在线视频观看免费| 2021国产在线视频| 亚洲 自拍 激情 另类| 亚洲a级视频在线播放| 亚洲欧美日韩中文在线观看| 亚洲中文字幕无线乱码人妻精品| 亚洲激情视频在线观看免费| 国内精品一区二区2021在线| 夜夜爽夜夜操夜夜爱| 呻吟求饶的人妻中文字幕| 在线观看中文字幕少妇av | 50熟妇一区二区三区| 色欲AV蜜桃一区二区三| 国产福利一区二区三区在线观看 | 欧美情色av在线观看| 91超碰九色porny| 精品美女洗澡一区二区| 欧美日韩精品aaa| 欧美黄色一区二区三区视频| 国产视频成人自拍蝌蚪视频| 九九九九九久久久国产| 日韩成人免费观看电影| 国产精品久久久久精品三级18| 国产做A爱免费视频在线观看| 女人高潮潮呻吟喷水网站| 午夜偷拍的视频久久久免费大全| 亚洲综合天堂av网站在线观看 | 亚洲最大先锋资源采集站| 黄色片免费网站在线| 亚洲在线观看中文字幕av| 一区二区三区四区 在线播放 | 男女真人做带声音视频图片| 婷婷色九月综合激情丁香| 91 精品视频在线看| av在线观看视频免费| 五月的婷婷综合视频| 日韩av电影中文在线免费观看| 大陆中文字幕视频在线| 啪啪啪网站免费看视频| ysl蜜桃色7425| 久久国产精品久精国产爱| 人妻女侠被擒受辱记| 人妻少妇精品二三区| 日本午夜福利免费在线播放| 极品少妇高潮喷水日出白浆| 成人做爰av在线观看网站| yy4080黄色片| 久久免费视频ww一区| 最新激情中文字幕视频| 青青操久久综合激情| 最近最新欧美日韩精品| 午夜在线观看一级毛| 91久久久久久最新网站| 日韩无码国产一区二区| 大乳丰满人妻中文字幕韩国hd| 人妻少妇的va视频| 国产最新av在线免费观看| av 资源在线播放| 亚洲情色777中文字幕| 日韩av水蜜桃一区二区三区| 老色鬼精品视频在线观看播放| 欧美成人少妇人妻精品| 亚洲激情视频在线观看免费| 国产资源在线观看二区| caopeng97在线观看视频| 操死你美女在线视频| 中文字幕福利视频在线一区| 熟女一区二区视频在线| 果冻麻豆一区二区三区| 网友自拍第一页99热| 欧美性受黑人猛交裸体视频| www国产亚洲精品久久久| a级片特黄免费看| 户外露出视频在线观看| 99热这里只有精品免费播放| 三区美女视频在线观看| av天堂a亚洲va天堂va里番| 夫妻黄色一级性生活片| 极品少妇高潮喷水日出白浆| 亚洲国产日韩a在线欧美| 熟妇高潮久久久久久久| 国产精品亚洲精品亚洲| 男人av一区二区三区| 制服丝袜 中文字幕 日韩 | 美国十次了亚洲天堂网国产| 黑吊操欧美极品美女| 亚州av嫩草av极品在线观看| 午夜精品一区二区三区不卡顿| av毛片在线观看网址| 荣立三等功退休有什么待遇| 夜夜操天天干夜夜操| 丰满少妇高潮喷水视频| 精品视频一区二区三区◇| 中文字幕麻绳捆绑的人妻| 91精品资源在线观看| 午夜精品久久久久久久精品乱码| 上床啪啪啪免费视频| 顶级欧美色妇xxxx| 亚洲男人的天堂最新网址| 91九色国产在线视频| 91系列视频在线播放| 日本成人福利电影网| 天天干夜夜撸天天操| 国产夫妻视频在线观看免费| 99在线视频精品观看高| 国产精品无码无卡免费观| 亚洲一区二区在线激情| 91精品国产人妻麻豆| 91精品一区一区三区| 日本免费人爱做视频在线观看不卡| 四虎精品久久免费最新| 亚洲av激情综合网| 裸露视频免费在线观看| 神马不卡视频在线视频| 日韩av熟妇在线观看| 日韩精品视频一区二区三区在线| 国产午夜羞羞一区二区三区| 久久99国产中文丝袜| 亚洲最强的25个城市| 后入日韩翘臀蜜桃臀美女| 欧美大鸡吧男操女啊啊啊视频| 亚洲va999天堂va| 天天干天天弄天天日| 最近中文字幕免费视频一| 亚洲AV无码久久精品国产一区老 | 在线视频自拍第三页| 18岁禁一二三区免费体验| 免费观看在线中文字幕视频| 中文字幕av特黄毛片| 亚洲|久久久久久一二三区丝袜 | 色噜噜噜噜色噜噜色合久一| 亚洲欧美成人午夜一区二区| 2018中文字字幕人妻| 欧美日韩一区二区三区成人影院| 亚洲欧美日韩中文视频| alisontyler和黑人| 99精品久久精品一区二区| 天天早上头和脸出汗是怎么办 | 五月天色婷婷狠狠爱| 四虎国产精品国产精品国产精品| 女人扒开逼让男人操 | 亚洲一区二区精品三区视频| 欧美久久一区二区伊人| 国产视频成人一区二区| 在线免费观看欧美小视频| 蜜乳视频一区二区三区| a级片特黄免费看| 超级黄肉动漫在线观看| 亚洲最强的25个城市| 在线观看中文字幕少妇av| 69精品互换人妻4p| 在线人成视频免费观看尤物| 欧美亚洲精品色图网站| 东京热日韩av在线| 4438x亚洲最大的成人| 青青在线免费手机播放视频| 玖玖资源站在线观看亚洲| 河北全程露脸对白自拍| 日本少妇三级交换做爰做| 久久午夜免费鲁丝片| 国产探花自拍亚洲av| 青青草原在线播放日韩| 国产av高清二区三区| 日本不卡 中文字幕| 国产熟妇色xxⅹ交白浆视频| 欧美成人屋影院在线视频观看| ysl蜜桃色7425| 日本男女免费福利视频| 欧美日韩不卡视频合集| 午夜国产免费视频亚洲| 亚洲国产日韩a在线欧美| 亚洲一区二区精品在线播放| 亚洲免费在线不卡视频| 亚洲熟女一区二区三区250p| 青青草原在线播放日韩| 麻豆国产精品777777在| 午夜亚洲国产精品中字| 国产黑色丝袜 在线日韩欧美| 91精品夜夜夜一区二区| 全彩漫画口工18禁| 国产高清自拍偷拍在线| 亚洲 自拍 激情 另类| 日韩av熟妇在线观看| 午夜精品老牛av一区二区三区 | 国际日韩日韩日韩日韩日韩| 亚洲精品1卡2卡3卡| 欧美日韩亚洲tv不卡久久| 日本四十路人妻熟女| 欧美日韩综合精品无人区| 99久久久久久久久久久久久| 91精品国产91久久久久久密臀| 中文字字幕在线精品乱码| julia人妻av一区二区三区| 中文字幕免费啪啪啪| 国产精品亚洲精品亚洲| 青青操久久综合激情| 二十四小时日本高清在线观看| 人妻系列在线免费视频| 国产精品免费看一区二区三区| 可以直接看av网站| 视频在线+欧美十亚洲曰本| 夜色福利视频免费观看| 国产剧情av在线免费观看| 青青草成人免费自拍视频| 蜜乳视频一区二区三区| 999精品视频免费在线观看| 一区二区在线观看视频观看| 最新中文字幕久久久久| 国产极品气质外围av| 真人一进一出抽搐大尺度视频| 公侵犯人妻中文字幕巨| 最新日韩av电影在线播放| 日本老熟老熟妇七十路| 2021国产在线视频| 国产成人情侣激情视频| 久久国产半精品99精品国产| av激情四射五月婷婷| 青青青在线视频免费播放| 美女av色播在线播放| 亚洲成人中文无码在线| 国产三级自拍视频在线观看网站| 亚洲欧美激情久久久| 欧美成人屋影院在线视频观看| 亚洲av日韩久久网站| 亚洲国产日韩欧美一区二区三区, 精久久久久久久久久久久 | 久草视频在线视频在线视频| 熟女俱乐部jukujoclub| 男生和女生羞羞91在线看| 中文字幕日韩首页欧美在线激情| 亚洲av中文无码网站| 午夜福利在线不卡视频| 99女福利女女视频在线播放| 99在线视频精品观看高| 欧洲成熟女人色惰片| 中文乱码字幕人妻熟女人妻| 国产黑色丝袜 在线日韩欧美| 最新日韩av电影在线播放| 中文字幕在线免费观看人妻| 鸡巴插进美女的嫩小穴视频| 超碰在线免费观看视频97| 欧美成人红桃视频在线观看| 天天操天天日天天插天天舔| 一区二区三区资源视频| 2018中文字字幕人妻| 亚洲同性同志一二三专区| 日本欧美视频在线免费| 91精品视频在线观看视频| 91麻豆精品国产在线| 98热视频精品在线观看| 国际精品熟女一区二区| 福利视频免费在线播放| 狠狠干狠狠操免费视频| 午夜福利在线不卡视频| 日本少妇精品免费视频| 人妻系列在线免费视频| 伊人综合在线视频免费观看| 天天干夜夜操夜夜骑| 中文字幕av特黄毛片| 欧美精品乱码99久久蜜桃免费| 制服丝袜中文字幕熟女人妻| 91亚洲最新蜜桃在线| 国产乱码有码一区二区三区| 一级毛片特级毛片免费的| 亚洲综合首页综合在线观看| 日本国产亚洲欧美色综合| 国产一区二区三区四区精| 国产成人深夜福利短视频99| 亚洲色图日韩在线视频观看| 豆豆专区操逼性视频在线| 国产在线小视频一区二区| 亚洲精品色图1234| 黄色av网址在线播放| 亚洲一区二区三区四区入口| 亚洲乱码国产乱码精品精视频| 日韩美精品成人一区二区三区四区 | 精品国产污污污污免费观看| 91激情四射婷婷综合| 久草视频在线视频在线视频| 婷婷六月天在线视频| 漂亮人妻口爆久久精品| 中文字幕一区二区人妻视频| 99热这里只有精品免费播放| 九热精品视频在线观看| 亚洲午夜高清在线观看| 亚洲av中文免费在线| 夜夜骚av一二三区| 国模伊人久久精品一区二区三区| 福利小视频免费在线| 天天日天天亲天天操| 日本少妇人妻中文在线| 日本人妻少妇xxxxxxx| 男女真人做带声音视频图片| 在线中文字幕人妻av| 成人午夜麻豆大胆视频| 青青操久久综合激情| 日本黄色一级电影网址| 亚洲激情噜噜噜久久久| 先锋人妻啪啪中文字幕| 丰满少妇_区二区三区| 18禁男女啪啪啪无遮挡| lutu玩弄人妻短视频| 日本少妇精品免费视频| 92麻豆一区二区三区| 国产精品午夜无码AV体验区| 伊人精品成人综合网| 伊人综合在线视频免费观看| 亚洲韩精品一区二区三区 | 啪啪啪网站免费看视频| 欧美视频免费观看777| 午夜福利国产精品久久久久| 999国产精品视频免费看| 亚洲欧美精品海量播放| 大香蕉在线欧美在线视频| 欧美成人红桃视频在线观看| 91大神在线免费观看视频| 亚洲少妇色小说综合| 国产成人在线观看视频播放| 日本欧美亚洲国产啊啊啊| 一区二区欧美 国产日韩| 欧美在线视频不卡一区| 一区二区三区午夜福利在线| 欧美一级aaaaaaa片| 蜜乳av中文字幕一区二区| 加勒比不卡在线视频| 日本a级2020在线观看| 91久久久久久最新网站| 91精品久久久久久久久99蜜臀| 日本老熟妇av老熟妇| 国产成人深夜福利短视频99| 99精品久久精品一区二区| 福利美女视频在线观看| 日本亚洲精品视频在线观看| 日韩人妻中文字幕二区| 福利一二三在线视频观看| 亚洲制服丝袜资源网| 中文字幕亚洲无线乱码| 精品国产无乱码一区二区三区| 超碰在线观看97资源| 女人的天堂av在线网| 一区二区三区四区视频精品免费| 99久久久久久亚洲精品免费| 一区二区三区av免费天天看| 日本一区二区三区调教性奴视频 | 亚洲av手机免费在线| 欧美色视频网址大全| 东京热日本一区二区三区| 精品国产av虐杀两警花| 亚洲全国精品女人久久久| 免费在线观看视频啪啪| 日本小视频一区二区| 亚洲成人,国产精品| 99久久久久久久久久久久久| 熟女人妻精品视频一区| 夜夜人人干人人爱人人操| 天天色 天天操 天天好逼| 亚洲精品9999蜜桃| 精品av天堂毛片久久久| 久久热在线免费观看| 超peng视频在线免费播放97| 国产三级自拍视频在线观看网站| 97精品人妻免费视频| 国产 亚洲 欧美 自拍| 国产白丝一区二区三区av| 丰满放荡熟妇在线播放 | 天天综合久久无人区| 亚洲韩精品一区二区三区| 在线有码人妻自拍视频| 欧美精品熟妇免费在线| 亚洲欧美激情国产综合久久久| 亚洲av毛片在在线播放| 精品人妻人人做人人爽| 国产熟妇色xxⅹ交白浆视频| 亚洲欧美日韩电影一区| 九十九步都是爱最后一步是尊严| 2021国产在线视频| 欧美日韩在线观看免费播放| 中文字幕观看中文字幕免费 | 9420高清视频在线观看国语版| 中文字幕久久久国产| 在线观看中文字幕精品av | 中文字幕熟女乱一区二区| 久久午夜免费鲁丝片| 伊人网在线免费观看| 日本亚洲精品视频在线观看| 亚洲欧美国产一本综合首页| 午夜情色一区二区三区| 亚洲自拍偷拍一区二区中文字幕| 熟女国内精品一区二区三区 | 黑川堇人妻88av| 夜夜人人干人人爱人人操| 99热在线只有的精品| 亚洲精品一区二区gif| 欧美日韩亚洲tv不卡久久| 中文字幕久久久国产| 果冻麻豆一区二区三区| 人妻少妇的va视频| 91亚洲国产成人久久精品| 成人人妻h在线观看| 在线视频自拍第三页| 欧美色区国产日韩亚洲区| 女女抠逼白虎白丝袜| av成人三级高清日韩| 天天看片天天摸天天操| 日本少妇人妻凌辱在线| 国产激情免费在线视频| 一区二区三区不卡免费视频网站 | 最新日韩中文字幕啪啪啪| 人妻视频网站快射视频网站| 视频免费在线观看网站| 最新国产精品久久精品app| 在线观看2022av| 精品国产无乱码一区二区三区 | 人妻超清中文字幕在线乱码| 68福利精品在线视频| 人妻超清中文字幕在线乱码 | 国产精品性感美女视频| 黄片视频免费观看视频| 国产午夜羞羞一区二区三区| 都市激情校园春色 亚洲| 美女网站福利在线观看| 天天操天天干加勒比久久| tobu8日本高清| 亚洲国产精品青青草| 国产精品福利久久久久| 2019年中文字幕在线播放视频| 国产午夜羞羞一区二区三区| 亚洲午夜精品一级毛片app| 亚洲国产中文字幕在线看| 操烂你的骚逼天天欧美| 国产天堂av不卡网| avjpm亚洲伊人久久| 熟女人妻少妇一区二区| 中国特黄色性生活片| 国产激情视频在线观看的| 亚洲另类激情视频在线看| 七色福利视频在线观看| 中文字幕久久久国产| 精品一区二区三区免费毛片W| avjpm亚洲伊人久久| 91精品国产欧美在线| 国产激情一区二区视频| 亚洲av激情综合网| 91九色人妻在线播放| 中文字幕熟女人妻丝袜丝在线| 97人妻人人揉人人躁人人夜夜爽| 天天爽天天操天天插| 美女张开腿给男人桶爽的软件| 日本黄色一级电影网址| 亚洲熟女乱一区二区精品成人| 美女欧美视频在线观看免费| 瑟瑟干视频在线观看| 亚洲一区二区偷拍女厕所| 国产精品中文字幕丝袜| 漂亮人妻口爆久久精品| 国产最新av在线免费观看| 加勒比东京热绿帽人妻多人操| 亚洲成年人精品国产| 久久免费视频ww一区| 2020国产成人精品视频| av里面的动作是真进去吗| 欧美视频亚洲视频在线| 中文字幕综合网91| 午夜呻吟亚洲精品中文字幕在上面| 福利视频免费在线播放| 在线观看中文字幕精品av| 日韩女同与成人用品电影免费看| 1级黄色片在线观看| 乱子伦国产一区二区三区| 中文字幕观看中文字幕免费| 亚洲全国精品女人久久久| av激情四射五月婷婷| 中文字幕人妻精品精品| 五十岁熟妇高潮喷水| 熟妇精品午夜久久久久| 波多野结衣在线一区别| 日本人妻熟妇丰满成熟HD系列| 天天操天天射天天操天天日| 熟妇人妻av无码中文字幕| 中文字幕在线观看av观看| 91九色国产在线视频| 最新中文字幕久久久久| 18福利视频在线观看| 青娱乐免费最新视频| 桃色成人开心激情网| 人人妻人人爽人人摸| 国产高清视频www夜色资源| 天天想要天天操天天干| 免费中文三级在线观看| 熟妇人妻丰满久久久久久久| 超碰在线观看97资源| 狠狠操av一区二区三区| 麻豆国产精品777777在| 午夜福利国产精品久久久久| 日本韩国福利在线播放| 欧美最新一区二区三区| 麻豆国产精品777777在| 青青草一个释放的网站| 97精品视频,全部免费| 91亚洲精品久久蜜桃| 久久人妻诱惑我视频| 日本不卡 中文字幕| 亚洲码av一区二区三区| 福利一二三在线视频观看| 91精品91久久久久| 国产激情一区二区视频| 99久久免费播放在线观看视频| 国产三级自拍视频在线观看网站| 久久人妻诱惑我视频| 9999久久久久老熟妇二区| 狠狠操狠狠操狠狠插| 老色鬼精品视频在线观看播放| 国产精品美女免费视频观看| jiee日本美女视频网站| 91性高湖久久久久久久久久| 女同性恋av在线播放| 少妇熟女天堂网av| 人人妻人人爽人人摸| 色视频在线播放免费观看| 久久精品国产亚洲av清纯| 国产剧情av在线免费观看 | 91香蕉国产亚洲一二三区| 美利坚合众国av天堂| 77亚洲视频在线观看| 另类欧美激情校园春色| 免费成人av麻豆| 亚洲欧美国产一本综合首页| 欧美大鸡吧男操女啊啊啊视频| 97人妻av人人澡人人爽| 老司机在线视频福利观看| 男人和女人的逼视频| 天天摸天天干夜夜操| 国产精品美女免费视频观看| 日本少妇熟女乱码一区二区| 熟妇高潮久久久久久久| 女生裸体视频免费网站 | 国产激情免费在线视频| 美女福利网站在线播放| 亚洲欧美日韩中文视频| 青青操久久综合激情| 熟女人妻少妇一区二区| 亚洲精品1卡2卡3卡| 看女人大BB群伦交| 欧美日韩综合精品无人区| 偷拍熟女大胆免费视频| 久久99久久99久久97的人| 国产成人情侣激情视频| 2020年亚洲男人天堂网| 女人的天堂av在线网| 天天看片天天摸天天操| 亚洲情色777中文字幕| 日韩一级欧美一级片| 91色哟哟视频在线观看| 天天日天天干天天日天天干天天| 干逼又爽又黄又免费的视频| 国产精品国产三级在线高清观看| a级黄片免费观看| 97精品久久久久久无码人妻| 松本菜奈实最新av在线| 999国产精品视频免费看| 中文字幕人妻一区二区视频系列| 女同大尺度视频网站在线观看| 天天碰天天摸天天搞| 日韩欧美国产一区二区在线观看 | 91超碰国产在线观看| 91精品国产91久久久久久密臀| 天天操天天干天天谢| 欧美视频免费观看777| 乱子伦国产一区二区三区| 日韩成人在线电影首页| 久久国产半精品99精品国产| 国产视频1区2区3区| 最新日韩中文字幕啪啪啪| 亚洲高清一区二区三区久久| 99在线视频精品观看高| 99女福利女女视频在线播放| 久久久精品人妻无码专区不卡 | 日韩男女视频网站在线观看| 琪琪日本福利伦理视频| 91精品久久久久久久99蜜月| 黄很色很在线免费视频网站| 青青青免费手机视频在线观看| 9420高清视频在线观看国语版| 亚洲乱码国产乱码精品精视频| 91麻豆精品国产在线| 99福利一区二区视频| 99久久国产精品免费热| 熟妇人妻av无码中文字幕| 国产91免费在线观看| 午夜精品小视频在线播放| 91超精品碰国产在线观看| 午夜野花视频在线观看| 99999久久久精品| 日本香港韩国三级黄色| 午夜在线观看一级毛| 日本人妻少妇xxxxxxx| 国产91黑丝小视频在线观看| av天堂hezyo| 一区二区三区午夜福利在线| 欧美成人区一区二区三| 五月天色婷婷狠狠爱| 欧美vr专区日韩vr专区| 放荡人妻极品少妇全集| 亚洲自拍偷拍av在线| 天天干夜夜操夜夜骑| 青青国产95免看视频| 欧美aaaa性bbbbaaaa| 久久中文字幕av一区二区| 农村大炕有肉大屁股熟妇| 大香蕉在线欧美在线视频| 欧美精品一区二区三区观看| 七色福利视频在线观看| 日本男女免费福利视频| 美女黄色啊啊啊啊视频| 制服丝袜中文字幕熟女人妻| 亚洲自拍偷拍一区二区中文字幕| 港台美女明星av天堂| 亚洲第一中文字幕成人| 国产人妻熟女ⅹxx丝袜| 99热在线只有的精品| 91精品夜夜夜一区二区蜜桃| 亚洲全国精品女人久久久| 两个奶被揉得又硬又翘怎么回事| 日本电影一级人妻在线播放四区| 91久久精品美女高潮喷水白浆| 日韩欧美中文字幕老司机三分钟| 日韩成人在线电影首页| 亚洲色视频在线播放网站| 欧美一区二区播放视频| 黑吊操欧美极品美女| 九热精品视频在线观看| 日本欧美高清在线观看视频| 国产高清在线观看av| 不卡在线一区二区三区| 在线成人教育平台排名| 熟女人妻精品视频一区| 久久av色噜噜ai换脸| 操人妻人妻天天爽天天偷| 青青操久久综合激情| 国产精品蝌蚪自拍视频| iga肾三级算严重吗| 性色蜜桃臀x88av天美传媒| 99re这里是国产精品首页| a级黄片免费观看| 制服丝袜 中文字幕 日韩| av一区二区三区蜜桃| 九九热在线精品播放| 天天夜夜久久精品综合| 亚洲精品乱码久久久久app | 农村大炕有肉大屁股熟妇| 亚洲欧美韩国日本一区二区| 91精品国产91久久久久久密臀| 在线 激情 亚洲 视频| 中文字幕中文字幕在线中…一区| 亚洲成人五月婷婷久久综合| 青娱乐免费视频一二三| 亚洲永远av在线播放| 亚洲午夜高清在线观看| 中文字幕人妻一区色偷偷久久| 夫妻黄色一级性生活片| 一二区二区不卡视频| 青青国产95免看视频| 亚洲黄色免费在线观看网站| 天天搞天天操天天干| 亚洲高清免费在线观看视频| 99国产精品国产精品毛片19| 久久内射天天玩天天懂色| 羞羞漫画无限免费观看秋蝉| 夜夜操天天干夜夜操| 国产一区二区手机在线观看| 欧美日本在线免费视频| 欧美日本亚欧在线观看| 十八禁黄色免费污污污亚洲| 伊人网在线免费观看| 可在线免费观看av| 中文字幕人妻精品精品| 99久久久久久亚洲精品免费| 中文字幕 中文字幕 亚洲| 中文字幕熟女人妻一区| 两个奶被揉得又硬又翘怎么回事| 亚洲成人,国产精品| 人妻色综合aaaaaa网| 黄色片免费国产精品| 国产免费久久精品99re丫丫| 亚洲欧美激情国产综合久久久| 日本不卡视频一二三区| 91porny九色视频偷拍| 欧美日本国产一区二区| 老熟女 露脸 嗷嗷叫| 天天搞天天操天天干| 超碰在线观看97资源| 午夜久久人妻一级内射av网址 | 中文字幕人妻一区色偷偷久久| 亚洲av中文免费在线| 国产亚洲精品啪啪视频| 人妻色综合aaaaaa网| 最新国产精品综合网高清| 日本熟妇乱妇熟色视频| 999久久久人妻精品一区| 日本午夜福利免费在线播放| 亚洲黄色免费在线观看网站| 亚洲经典av中文字幕| 日本香港韩国三级黄色| 午夜8050免费小说| 亚洲人精品午夜射精日韩| 亚洲成人三级黄色片| 亚洲一区二区三区无码在线| 东京热日本一区二区三区| 日本老熟老熟妇七十路| 天天操天天日天天插天天舔| 福利美女视频在线观看| 男女插鸡巴视频软件| 日韩久久九九精品视频| 亚洲熟妇在线视频观看| 99国产精品久久99久久久| 91精品国产人妻麻豆| av一区二区三区蜜桃| 亚洲黄色成人一级片| 最近中文字幕免费视频一| julia人妻av一区二区三区| 国产av精品一区二区三区久久| 台湾18禁久久久久久久激情视频| 最近最新最好看的中文字幕| 中文字幕 人妻 熟女| 伊人情人成综合视频| 女人扒开逼让男人操| 91精品资源在线观看| 91污污在线观看视频| 亚洲最强的25个城市| 国产精品内射婷婷一级| 青青在线视频看看| 我爱搞在线观看视频| 亚洲欧美成人午夜一区二区| 人人妻人人爽人人爽欧美一区 | 视频免费在线观看网站| 成人精品动漫一区二区| 伊人免费观看视频一 | 日韩人妻中文字幕二区| 深夜福利免费观看在线看| 天天操天天舔天天爽| 久久99嫩草99久久精品| avtt中文字幕手机版| 免费在线观看黄色小网站| 久久久久夜色国产精品电影| 亚av一二三在线观看| 国产亚洲精品啪啪视频| 精品国产污污污污免费观看| 日韩成人免费观看电影| 亚洲熟女少妇中文字幕系列| 亚洲精品久久久人妻| 91中文字幕视频网站| 亚洲一区二区在线激情| 亚洲欧美精品日韩偷拍| 久久久久久免费观看av| 91系列视频在线播放| 午夜精品老牛av一区二区三区| 最新日韩中文字幕免费在线观看 | 大乳人妻一区二区三区| 都市激情校园春色 亚洲| 日韩久久九九精品视频| 日本高清 中文字幕| 免费在线小视频你懂的| 成人18禁高潮片免费日本| 黄色片免费国产精品| 中文字字幕在线精品乱码| 日韩人妻精品久久久久| 五月的婷婷综合视频| 人妻色综合aaaaaa网| 天天爽天天操天天插| 岛国av成人午夜高清| 69国产在线视频网站| avtt中文字幕手机版| 久久久久国产精品二区| 中文字幕丰满子伦无码专区 | 中文字幕福利视频第四页| 日本福利网站一区二区| 奇米网首页神马久久| 蜜桃臀av在线一区二区| 日本东京热视频欧美视频| 日本电影一级人妻在线播放四区| 欧美操大黑鸡巴视频在线观看| 香港日本台湾经典三级| 午夜精品老牛av一区二区三区| 91精品资源在线观看| 日本福利片在线播放| 欧美情色av在线观看| 强乱人妻中文字幕日本| 青娱乐免费最新视频| 日韩av电影中文在线免费观看| 国产精品内射婷婷一级| 美女网站福利在线观看| 国产男人的天堂一区| 国产精品久久久久久成人久| 一区二区三区观看在线| 五十岁熟女高潮喷水| 欧美久久蜜臀蜜桃资源吧| 亚洲自拍偷拍av在线| 免费中文字幕a级激情| 亚洲国产综合久久精品| 午夜福利在线不卡视频| 大鸡扒操大逼大片免费关看| —区二区三区女厕偷拍| 亚洲熟妇在线视频观看| 亚洲宅男噜噜噜66在线观看| 国产视频1区2区3区| 欧美操大黑鸡巴视频在线观看 | 38av一区二区三区| 国产福利一区二区三区在线观看| 午夜8050免费小说| 又爽又粗又猛又色又黄视频| 日本有码精品一区二区三区| 日本韩国欧美在线视频| 中文字幕人妻一区色偷偷久久| 日本一区二区三区调教性奴视频 | 99久久国产精品免费热| 天天干天天操天天日天天日| 精品久久久久久久久久久久久 | 可以直接看av网站| 国产精品乱码高清在线观看h| 日本韩国欧美在线视频| 亚洲av中文免费在线| 男人电影天堂在线观看| 亚州av嫩草av极品在线观看| 午夜精品小视频在线播放| 久久久精品人妻无码专区不卡| 少妇被粗大的猛进69视频| 日本高清在线观看不卡视频| 一看就是假奶的av| 天天摸天天干夜夜操| 美利坚合众国av天堂| 亚洲va999天堂va| 92麻豆一区二区三区| 极品内射老女人操逼视频| 黄色片免费网站在线| 五月天男人的天堂中文字幕| 久久免费视频ww一区| 4438x亚洲最大的成人| 成熟了的熟妇毛茸茸| 中文字幕人妻一区色偷偷久久| 五月婷婷激情视频网| 可以免费观看日韩av| 国产原创一区二区三区在线播放| 狠狠操深爱婷婷综合一区| 亚洲中文字幕在线视频观看二区| 中字幕人妻熟女人妻a62v网| 裸露视频免费在线观看| 蜜桃臀av在线一区二区| iga肾三级算严重吗| 国产三级自拍视频在线观看网站| 99久久国产精品免费热| 精品精品精品精品精品污污污污| 国产精品蝌蚪自拍视频| 午夜五十路久久福利| 黄很色很在线免费视频网站| 91人妻人人做人人爽高清| 91九色尤物无套内射| 性感人妻 中文字幕| 国语对白性爱三级片免费看| 中文字幕 首页 人妻| 18岁禁一二三区免费体验| 在线观看免费啪啪啪| 可以免费观看日韩av| 77亚洲视频在线观看| 日韩成人在线电影首页| 96在线观看免费播放| av天堂a亚洲va天堂va里番| 大奶熟妇激情操逼逼| 伊人免费观看视频一| 得得爱在线视频观看| 中文字幕中文字幕在线中…一区| 欧美日本在线免费视频| 中国精品人妻一区二区| 360偷拍蜜桃臀69式| 鸡巴在里面福利视频在线观看| 港台美女明星av天堂| 国产成人情侣av在线| 在线观看黄页网站视频网站| 国产精品成人免费电影| 福利小视频免费在线| 操操操操操操操操操网| 黑人黄色免费一级av| 久久人妻人人草人人爽| 美女扒开逼逼给你看| 国产成人深夜福利短视频99| 最新日韩av电影在线播放| 911美女片黄在线观看| 亚洲综合另类欧美久久| 精品av天堂毛片久久久| 日本高清有码在线视频| 久久亚洲国产成人精品麻豆| 久久中文字幕av一区二区 | 亚洲成人欧洲成人在线| 亚洲欧美日韩电影一区| 亚洲av毛片在在线播放| 得得爱在线视频观看| 国产,亚洲,欧美综合| 五十岁熟女高潮喷水| 女生裸体视频免费网站| 97精品视频,全部免费| avjpm亚洲伊人久久| 91精品久久久久久久99蜜月| 欧美一级aaaaaaa片| 丰满少妇_区二区三区| 99亚偷拍自图区亚洲| 91porny九色视频偷拍| 顶级欧美色妇xxxx| 60路70路日本熟妇| 强乱人妻中文字幕日本| 美女网站视频久久精品| 99久久99九九九99九| 精品一区二区三区免费毛片W| 亚洲综合另类欧美久久| 欧美日韩综合精品无人区| 欧美大胆a级视频秒播| 午夜免费福利老司机| 岛国av成人午夜高清| 老司机免费视频福利0| 九九热精品视频在线播放| 松本菜奈实最新av在线| 一区二区三区四区视频精品免费| 在线看日韩av不卡| 四虎精品久久免费最新| 天天天天天天天天日日日| 午夜呻吟亚洲精品中文字幕在上面 | 亚洲一区二区三区无码在线| 亚洲女人自熨在线视频| av天堂a亚洲va天堂va里番| 亚洲女人自熨在线视频| 特级aaaaa黄色片| avtt中文字幕手机版| 中文字幕精品人妻久久久久| 精品人妻在线激情视频| 国模伊人久久精品一区二区三区| 欧美大胆a级视频秒播| 国产一区二区三区四区精| 日韩欧美一区二区三区免费看| 精品av天堂毛片久久久| 亚洲av日韩久久网站| 天天色天天射天天日天天干| 日韩免费黄色片在线观看| 欧美精品一区二区三区观看| 老司机在线视频福利观看| 久久无码高清免费视频| 亚洲另类激情视频在线看| 顶级欧美色妇xxxx| 一区二区在线观看视频观看| 999久久久人妻精品一区| 老司机伊人99久久精品| 夫亡人妻被强干中文字幕| 视频在线 一区二区| 欧美精品999不卡| 9662av在线视频| 国产精品久久久99| av天堂新资源在线| 91精品一区一区三区| 亚洲黄色成人一级片| 伊人网国产在线播放| 美女把逼扒开让男人桶| 亚洲成人中文无码在线| 午夜情色一区二区三区| 亚洲综合熟女乱中文| 大乳人妻一区二区三区| 亚洲熟女乱色一区二区三区视频| 亚洲综合首页综合在线观看| 中文字幕在线免费观看成人| 亚洲成人自拍av在线| 成人av中文字幕在线看 | 自拍偷拍亚洲综合第一页| 99久久国产精品免费消防器材| 午夜亚洲国产精品中字| 久久久亚洲综合国产精品| 亚洲黄色成人一级片| 一区二区九日韩美女| 97人妻在线视频自拍| 人妻少妇的va视频| 亚洲最大先锋资源采集站| 久久99热精品免费观看视| 午夜国产免费视频亚洲| 国产一区二区三区四区精| 99热在线只有的精品| 另类欧美激情校园春色| 亚洲欧美精品海量播放 | 欧洲成熟女人色惰片| 5d蜜桃臀女无痕裸感| 内地精品毛片在线观看| 亚洲色大WWW永久网站| 最近最新最好看的中文字幕| 久久久久久久岛国免费观看| 羞羞漫画无限免费观看秋蝉| 桃色成人开心激情网| 999久久久人妻精品一区 | 欧美日韩亚洲国产视频二区| 国产精品内射婷婷一级| 最近最新最好看的中文字幕| 日韩欧美中文字幕老司机三分钟 | 婷婷色九月综合激情丁香| 大陆中文字幕视频在线| 天天干天天色综合久久| 国内精品一区二区2021在线 | 果冻麻豆一区二区三区| 亚洲va999天堂va| 91九色91在线视频| 国产精品视频网站污污污| 精品国产人伦一区二区三区| 69国产精品成人aaaaa片| av毛片在线观看网址| av资源中文字幕在线观看| 欧美日韩综合精品无人区| 午夜国产一区二区三区| 91超精品碰国产在线观看| 中文字幕综合网91| 美女欧美视频在线观看免费| 一区二区欧美 国产日韩| 日韩久久九九精品视频| 成年人免费福利在线| 欧美日韩综合精品无人区| 国产熟妇色xxⅹ交白浆视频| 九色porny91国产| 最新日韩中文字幕啪啪啪| 精品人妻 色中文熟女 oo| 大香焦一道本一区二区三区| 欧美亚洲精品色图网站| 久久久视频在线播放| 欧美日本在线免费视频| 国产大桥未久一区二区| 亚洲成a人片777777张柏芝| 97香蕉久久国产超碰| 日本电影一级人妻在线播放四区| 欧美一级aaaaaaa片| 日产国产欧美精品另类| 天天碰天天摸天天搞| 香港日本台湾经典三级| 日日躁夜夜躁狠狠操| 99女福利女女视频在线播放| 99999久久久精品| 男人av一区二区三区| 亚洲熟女乱色一区二区三区视频| 久久久亚洲熟女一区二区| 黑人大巨屌操美女逼| 少妇熟女天堂网av| 亚洲天堂男人的天堂| 手机看片1024精品国产| 亚洲同性同志一二三专区| 黑人侵犯人妻森泽佳奈| 午夜精品秘一区二区三区| 色就色综合偷拍区欧美在线| 核xp工厂精品久久亚洲| 污视频在线观看地址| 久久久久久久久久久久久国产| 中文字幕人妻精品精品| 亚洲第一区av中文字幕| 亭亭五月天在线观看| 免费24小时人妻视频| 蜜臀久久精品久久久久久av| 一区二区三区婷婷中文字幕| 最近最新最好看的中文字幕 | 极品风骚人妻3p视频| 午夜亚洲国产精品中字| 欧美在线观看一区二区不卡| 大香蕉在线欧美在线视频| 日本熟妇乱妇熟色视频| 琪琪日本福利伦理视频| 欧美插插插插插插| 午夜情色一区二区三区| 亚洲中文字幕最新地址| 日本成人福利电影网| 国产 亚洲 欧美 自拍| 夏目彩春av在线看| 中文字幕熟女人妻丝袜丝在线| 四季av人妻一区二区三区| 免费绝清毛片a在线播放| 午夜在线成人免费电影| 99久久久久久久久久久久久| 亚洲欧美激情久久久| 亚洲欧美不卡专业视频| 亚洲蜜桃久久久久久| 女生裸体视频免费网站 | 不卡在线一区二区三区| 伊人情人成综合视频| 日本国产亚洲欧美色综合| 综合激情网,激情五月| 中文字幕观看中文字幕免费 | 91超碰九色porny| 不卡高清一区二区三区| 欧美一级日韩一级亚洲一级va| 国产精品剧情在线亚洲| 中日韩又粗又硬又大精品| av日韩视频在线观看| 成人做爰av在线观看网站| 天天干夜夜撸天天操| 女人的天堂 av在线| 中文字幕亚洲乱码精品无限| 国内销魂老女人老泬| 天天躁狠狠躁狠狠躁性色| 天天日天天亲天天操| 夜色17s精品人妻熟女av| 自拍偷拍 亚洲性图 欧美另类| 成人资源中文在线观看| 亚洲中文字幕在线视频观看二区| 国产极品气质外围av| 天天干天天色综合久久| 黑吊操欧美极品美女| 精品一区二区三区喷水内射高潮| 女人高潮潮呻吟喷水网站| —区二区三区女厕偷拍| 琪琪日本福利伦理视频| 亚洲欧美成人激情在线| 欧美一区二区三区爽爽| 亚洲成人三级黄色片| 国产精品 亚洲欧美 自拍偷拍| 国产91免费在线观看| 黑人大巨屌操美女逼| 黄片视频免费观看视频| 午夜92福利1000| 可以直接看av网站| 后入日韩翘臀蜜桃臀美女| 五月天天堂视频在线| 亚洲全国精品女人久久久| 91九色人妻在线播放| 欧美男女一区二区三区| 92麻豆一区二区三区| 中文字幕久久久国产| 人妻系列中文字幕大乳丰满人妻| 亚洲第一页欧美第一页| 亚洲在线观看中文字幕av| 欧美日韩国产在线中文字幕| 男人的天堂aⅴ在线| 日韩精品视频一区二区三区在线| 成人十欧美亚洲综合在线| 成人黄色录像在线观看| 91大神福利视频网| 天天干天天色综合久久| 国产在线观看一区二区三区四区| 国产探花自拍亚洲av| 91超碰九色porny| 精品国模一区二区三区欧美| 亚洲中文字幕在线av| 亚洲乱码av一区二区蜜桃av| 黄片视频免费观看视频| 亚洲国产精品青青草| 欧洲成熟女人色惰片| av 资源在线播放| 人妻系列在线免费视频| 国产成人在线观看视频播放| 中文字幕av人妻一区二区三区 | 欧美成人屋影院在线视频观看| 精品不卡一区二区三区| 亚洲精品一区二区gif| 日产国产欧美精品另类| 亚洲av综合av一去二区三区| 2020国产成人精品视频| 最近中文字幕免费视频一| 美国十次了亚洲天堂网国产| 国产激情免费在线视频| 久久久久国产精品二区| 亚洲成人三级黄色片| 日韩久久九九精品视频| 亚洲av在线免费播放| 99福利一区二区视频 | 男人av一区二区三区| 大尺度av毛片在线网址| 18福利视频在线观看| 天堂av在线最新地址| 夜夜躁av麻豆男| 蜜乳av中文字幕一区二区| 老熟妇一区二区三区v∧88| 超级黄肉动漫在线观看| 亚洲全国精品女人久久久| 人妻色综合aaaaaa网| 亚洲熟女一区二区三区250p| 天天想要天天操天天干| 91 精品视频在线看| 外国美女舔男人坤坤| 亚洲制服丝袜资源网| 玖辛奈18禁同人污本子| 久久精品国产亚洲av清纯| 婷婷综合缴情亚洲五月伊人| 国产精品性感美女视频| 天堂一区二区三区在线等| 亚洲一区亚洲二区成人福利| 女女抠逼白虎白丝袜| 日日夜夜免费视频精品| 在线能看视频你懂的| 四虎精品久久免费最新| 视频在线 一区二区| 一区二区三区 国产日韩欧美| 国产精品福利久久久久| 午夜精品秘一区二区三区| 97精品人妻免费视频| 青青操久久综合激情| 亚洲国产美女主播在线观看| 亚洲a级视频在线播放| 91色哟哟视频在线观看| 久久亚洲国产成人精品麻豆 | 最新日韩av电影在线播放| 久久综合狠狠综合久久综| 69精品互换人妻4p| 亚洲国产中文字幕在线看| 欧美aaaa性bbbbaaaa| 日本黄色一级电影网址| 男人的天堂av中文字幕| 日韩三级黄色大片在线观看| 日本少妇三级交换做爰做| 国产免费久久精品99re丫丫 | 日本黄页在线观看视频| 免费中文三级在线观看| 天天爽天天操天天插| 四虎精品久久免费最新| 奇米网首页神马久久| av在线免费在线观看| 亚洲中文字幕无线乱码人妻精品 | 国产成人在线观看视频播放| 午夜在线观看一级毛| 中文字幕 中文字幕 亚洲| 亚洲成人自拍av在线| 每日更新日韩欧美在线| 午夜夫妻性生活视频| 91精品视频在线观看视频| 女人扒开逼让男人操| 911精产国品一二三产区区| 女生抠逼自慰啊啊啊啊啊啊啊下载| 2020年亚洲男人天堂网| 精品美女洗澡一区二区| 黑人黄色免费一级av| 91九色国产在线视频| 中文字字幕在线精品乱码| av 一区二区三区 熟女| 日韩少妇免费在线播放| 放荡人妻极品少妇全集| 亚洲av 综合av| 中出小骚货在线观看| 青青草一个释放的网站| 99久久国产精品免费热| 五月天男人的天堂中文字幕 | 自拍偷拍视频亚洲一区| 得得爱在线视频观看| 蜜臀一区二区日韩美女少妇视频| 亚洲自拍偷拍一区二区中文字幕| 欧美熟女xx00视频| 午夜精品久久久久久久精品乱码| 日韩美精品成人一区二区三区四区| 日本老熟老熟妇七十路| 妈妈的朋友2中文字幕在线| 杜达雄啪啪毛片视频| 97成人老师在线视频| 欧美丝袜亚洲国产日韩| 中国特黄色性生活片| 国产视频成人自拍蝌蚪视频| 性感人妻 中文字幕| 色老头一区二区三区四区五区 | 亚洲国产精品 久久久| 亚洲av激情综合网| 在线有码人妻自拍视频| 中日韩又粗又硬又大精品| 亚洲少妇色小说综合| 国产女主播在线观看一区| 国产熟女五十路一区二区三区| 日韩av电影中文在线免费观看| 日本少妇丰满大bbb的小乳沟| 亚洲国产精品青青草| 最新国产午夜激情视频| 亚洲最大的自拍偷拍网| 69xx精品久久久久| 午夜宅男电影av网站| 东京热日韩av在线| 午夜美女福利视频在线| 欧美熟女xx00视频| 亚洲中文字幕无线乱码人妻精品| www国产亚洲精品久久久| 欧美巨大另类极品video| 色欲天天媓色媓香视频综合网| 一区二区三区四区 在线播放 | 国产男女无套?免费网站下载| 欧美色区国产日韩亚洲区| 99福利一区二区视频| 天天想要天天操天天干| 亚洲综合天堂av网站在线观看| 在线看的免费网站黄| 五月天天堂视频在线| 欧美黄色一区二区三区视频| 自拍偷拍 亚洲性图 欧美另类| 91人妻人人爽色啊啊啊| 欧美日本亚欧在线观看| 最新日韩中文字幕免费在线观看| 亚洲免费在线不卡视频| 一区二区三区不卡免费视频网站| 可以直接看av网站| 婷婷一区二区三区五月丁| 福利视频导航在线观看| 男女69视频在线观看免费| 性感人妻 中文字幕| 国产精品久久久久久成人久| 午夜精品久久秘?18免费观看| 日本美女爱爱视频网站| 九九热在线精品播放| 精产国品一二三77777| 性感美女人妻久久久| 色狠狠色综合久久久绯色| 四虎国产精品国产精品国产精品| 欧美久久蜜臀蜜桃资源吧| 国产在线小视频一区二区| 91九色91在线视频| 免费在线观看黄色小网站| 台湾18禁久久久久久久激情视频| 亚洲激情视频在线观看免费| 日本成年视频在线免费观看| 中文字幕综合网91| 夫亡人妻被强干中文字幕| 青青青青午夜手机国产视频| 性高潮视频在线观看日韩| 日本久久久久久黄色| 猫咪亚洲中文在线中文字幕| 亚洲一区二区中文字幕久久| 最新国产精品久久精品app| 国产自拍偷拍视频在线免费观看| 狂操鸡巴小骚逼视频免费观看| avjpm亚洲伊人久久| 欧美黑人1区2区3区| 伊人网在线观看 视频一区| 老司机在线视频福利观看| 国产精品蝌蚪自拍视频| 最新福利二区三区视频| 亚洲一区二区偷拍女厕所| 国产激情视频在线观看的| 熟女俱乐部jukujoclub| 99re这里是国产精品首页 | 亚洲精品一区二区gif| 性感美女人妻久久久| 日韩精品欧美一区二区| 99久久免费播放在线观看视频| 老牛影视在线一区二区三区|