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

媽媽再也不用擔心我把數據弄丟了

數據庫 MySQL
數據是現代大小廠的重要資產,保護和恢復數據成為了重要的技能,最近幾年,常有一些無良程序員刪庫跑路的情況,不僅給所在企業更是給自己造成重大的損失。

[[404372]]

本文轉載自微信公眾號「Python技術」,作者派森醬。轉載本文請聯系Python技術公眾號。

數據是現代大小廠的重要資產,保護和恢復數據成為了重要的技能,

最近幾年,常有一些無良程序員刪庫跑路的情況,不僅給所在企業更是給自己造成重大的損失。

另外,即使不是故意的情況下,也會因為疏忽造成數據誤操作,是一件及麻煩又頭疼的事情……

神器出場

最近的一個項目里,客戶數據因為維護不當,導致數據丟失,為了挽回數據,并建立一個跨網閘(內部組網之間不通,無法使用 MySql 主從同步)的數據備份機制,發現了一個神器 binlog2sql[1]。

研究了一番之后,不僅恢復了誤操作丟失的數據,還通過 binlog2sql 將主服務器上的 binlog[2] 轉化為 SQL 語句,存入文件,實現了數據同步!

安裝

binlog2sql 使用 Python 開發,所以需要 Python 環境,可參考 Python 環境搭建

將 binlog2sql 用 git 克隆的本地,GitHub 上的地址是: https://github.com/danfengcao/binlog2sql.git

  1. git clone https://github.com/danfengcao/binlog2sql.git 

通過 binlog2sql 目標下的 requirements.txt 安裝依賴包

提示:推薦在 Python 虛擬環境中安裝,創建虛擬環境可參考 Python 虛擬環境 看這一篇就夠了

  1. pip install -r requirements.txt 

一切順利的話,很快就可完成安裝。

命令行進入 binlog2sql 代碼目錄下測試一下

  1. > python binlog2sql.py 
  2.  
  3. usage: binlog2sql.py [-h HOST] [-u USER] [-p [PASSWORD ...]] [-P PORT] [--start-file START_FILE] [--start-position START_POS] [--stop-file END_FILE] [--stop-position END_POS] 
  4.                      [--start-datetime START_TIME] [--stop-datetime STOP_TIME] [--save-as SAVE_AS] [--stop-never] [--help] [-d [DATABASES ...]] [-t [TABLES ...]] [--only-dml] 
  5.                      [--sql-type [SQL_TYPE ...]] [-K] [-B] [--back-interval BACK_INTERVAL] 
  6.  
  7. Parse MySQL binlog to SQL you want 
  8.  
  9. ...<省略>... 

由于沒加任何參數,所以打印出使用說明,那說明安裝正常了。

簡介

binlog2sql 是通過分析 MySql 數據庫的 binlog 文件,從中解析出需要執行的 sql 語句的。

那么使用時需要提供一些必要的參數,其中重要的有數據庫服務器鏈接信息,需要分析的 binlog 文件名等,

還可以指定解析的起始和結束位置,以及開始和結束時間。

身手不凡

是騾子是馬拉出來溜溜。

恢復被刪數據

假如庫表 tb_user 中的數據如下:

  1. +----+--------+---------------------+ 
  2. | id | name   | createtime          | 
  3. +----+--------+---------------------+ 
  4. |  1 | 張三   | 2021-01-10 00:04:33 | 
  5. |  2 | 李四   | 2021-01-10 00:04:48 | 
  6. |  3 | 王五   | 2021-04-23 20:25:00 | 
  7. |  4 | 趙六   | 2021-06-04 11:21:23 | 
  8. +----+--------+---------------------+ 

這時不小心執行了一個刪操作,將數據誤刪了

  1. delete from tb_user 

如何恢復呢?

我們看一下數據庫的日志情況

  1. show master status; 

會看到類似這樣的結果

  1. +------------------+-----------+ 
  2. | File             | Position  | 
  3. +------------------+-----------+ 
  4. | mysql-bin.000002 |     13136 | 
  5. +------------------+-----------+ 

注意:只有 MySql 數據庫打開了日志記錄功能,才能查詢到,打開日志功能請參考 binlog日志開啟和使用[3]

可以看出,目前日志記錄在文件 mysql-bin.000002 中,當前最新的記錄位置是 12546 行

假如當時誤操作的時間是上午 11點半左右(可能著急吃飯,沒注意),那么預估一個時間范圍,比如 11點25 到 11點35,看看一下當時的操作:

  1. python binlog2sql -h127.0.0.1 -P3306 -uadmin -p'admin' -dtest -t tb_user --start-file='mysql-bin.000002' --start-datetime='2021-06-04 11:25:00' --stop-datetime='2021-06-04 11:35:00' 

輸出為:

  1. INSERT INTO `test`.`tb_user`(`createtime`, `id`, `name`) VALUES ('2021-06-04 11:21:23', 4, '李四'); #start 12317 end 12487 time 2021-06-04 11:21:23 
  2. DELETE FROM `test`.`tb_user` WHERE `createtime`='2021-01-10 00:04:33' AND `id`=1 AND `name`='張三' LIMIT 1; #start 12728 end 12829 time 2021-06-04 11:27:32 
  3. DELETE FROM `test`.`tb_user` WHERE `createtime`='2021-01-10 00:04:48' AND `id`=2 AND `name`='李四' LIMIT 1; #start 12728 end 12829 time 2021-06-04 11:27:32 
  4. DELETE FROM `test`.`tb_user` WHERE `createtime`='2021-04-23 20:25:00' AND `id`=3 AND `name`='王五' LIMIT 1; #start 12728 end 12829 time 2021-06-04 11:27:32 
  5. DELETE FROM `test`.`tb_user` WHERE `createtime`='2021-06-04 11:21:23' AND `id`=4 AND `name`='趙六' LIMIT 1; #start 12728 end 12829 time 2021-06-04 11:27:32 

可以看出,第二行開始到第五行為刪除語句,查看語句最后的起始和結束位置 start 12728 end 12829

即 binlog 中,刪除執行的位置在 12728-12829 之間,于是鎖定精確位置,生成回滾語句:

  1. python binlog2sql -h127.0.0.1 -P3306 -uadmin -p'admin' -dtest -t tb_user --start-file='mysql-bin.000002' --start-position=12728 --stop-position=12829 -B 

注意參數 -B,意思是生成回滾 SQL,即生成的是撤銷之前操作的語句

輸出為:

  1. INSERT INTO `test`.`tb_user`(`createtime`, `id`, `name`) VALUES ('2021-06-04 11:21:23', 4, '趙六'); #start 12728 end 12829 time 2016-12-13 20:28:05 
  2. INSERT INTO `test`.`tb_user`(`createtime`, `id`, `name`) VALUES ('2021-04-23 20:25:00', 3, '王五'); #start 12728 end 12829 time 2016-12-13 20:28:05 
  3. INSERT INTO `test`.`tb_user`(`createtime`, `id`, `name`) VALUES ('2021-01-10 00:04:48', 2, '李四'); #start 12728 end 12829 time 2016-12-13 20:28:05 
  4. INSERT INTO `test`.`tb_user`(`createtime`, `id`, `name`) VALUES ('2021-01-10 00:04:33', 1, '張三'); #start 12728 end 12829 time 2016-12-13 20:28:05 

從輸出的語句來看,順序是刪除的倒序,而且已經將原來的 delete 語句改為了 insert 語句,也就是原來操作的逆操作

如果確認語句沒問題,執行生成的語句就可以了

是不是既方便又高效呢?

解析 SQL

binlog2sql 功能強大,使用起來也很方便,看看其他功能吧。

作為一個命令行工具,功能都體現在參數里,可分為 解析模式、解析目標、解析范圍三部分。

解析模式

binlog2sql 支持兩個解析模式,默認的是單次解析,即運行一次解析一次,

還可以支持持續解析,即不間斷地從目標數據庫地 binlog 中解析出 sql 來,持續解析通過參數 --never-stop 開啟,

開啟之后,線程不會退出,一直處于運行狀態,會自動判斷 binlog 的變化,對變化部分增量式解析。

這種模式可以用于數據庫同步,不過生產上使用前,最好考慮各種異常情況,比如重啟,網絡中斷等情況。

參數 -K 或 --no-primany-key 表示的去除 INSERT 語句中的主鍵,這個在數據匯總的場景下很方便,可以避免多個數據源中主鍵沖突的問題。

參數 -B 或 --flashback,表示回滾模式,在上面的例子中展示過,即會解析成逆操作的 sql 語句。

在回滾模式下,每生成一千條 SQL 語句會加一個 SLEEP 語句,是為以免數據執行時產生擁堵,默認為 1 秒,可以通過 --back-interval 參數來設置,

例如 --back-interval 2 表示暫停 2 秒。

解析目標

MySql 設置 binlog 時可以指定記錄哪個庫,以及哪些表,即目標。

那么用 binlog2sql 也可以指定解析目標。

參數 -d 或 --databases 用于指定數據庫,如果多個庫,用空格分隔,例如 -d db1 db2;

參數 -t 或 --tables 用于指定庫表,多個庫表用空格分隔,例如 -t tb1 tb2。

如果指定解析目標不僅效率更高,而且分析和執行解析的結果也更方便。

解析范圍

范圍包括 binlog 文件范圍,時間范圍 以及 行范圍,例如前面例子中用到了 時間范圍 和 行范圍。

文件范圍 用 --start-file 和 --stop-file 參數來指定,只需要提供 binlog 文件名即可,不需要寫全路徑,這是因為,binlog2sql 會自動根據目標服務器配置讀取 binlog 文件;

時間范圍 用 --start-datetime 和 --stop-datetime 參數來指定,時間格式為 %Y-%m-%d %H:%M:%S;

行范圍 用 --start-position 和 --stop-position 參數來指定,也可以簡寫為 --start-pos 和 --end-pos。

深入了解

binlog2sql 不僅是一個實用的工具,而且也是個研究和學習的好例子。

只有不到 500 行代碼,很容易閱讀;

閱讀源碼,不僅能深入了解其實現原理,而且還可以學習到很多好用法。

實現原理

binlog2sql 的原理是,利用 pymysql 從目標服務器上獲取 binlog 信息,然后鎖定范圍,使用 pymysqlreplication 解析 binlog 文件,最后,得到需要解析出的 sql 語句。

在這基礎上,做了一些功能性擴展,比如解析范圍,解析模式等,相對來說比較簡單,很容易看懂。

命令行參數

編程時處理命令行參數是機械而繁瑣的,特別是有不同性質的性質和別名的參數

binlog2sql 中利用了 argparse 模塊[4],

argparse 模塊可以讓人輕松編寫用戶友好的命令行接口。程序定義它需要的參數,argparse 可以從 sys.argv 解析出提供的命令行參數。而且 argparse 模塊還會自動生成幫助和使用手冊,并在用戶給程序傳入無效參數時報出錯誤信息。

很容易就能編程高大上的命令行程序接口,再也不用為很 low 的程序接口發愁了。

文件處理上下文(context)

binlog2sql 在回滾模式(即提供了參數 -B)中,使用了一個臨時文件記錄解析出來的 SQL 語句,并且在完成之后刪除。

一般來說,在完成后主動刪除文件即可,不過如果能利用 with 塊的資源回收功能就更好了。

查看源碼,會看到一個創建文件寫法:

  1. @contextmanager 
  2. def temp_open(filename, mode): 
  3.     f = open(filename, mode) 
  4.     try: 
  5.         yield f 
  6.     finally: 
  7.         f.close() 
  8.         os.remove(filename) 

@contextmanager[5] 指示器可以將一個生成器[6],作為一個上下文管理器[7],

那么:

with 聲明部分,會執行前會執行 yield 語句之前的部分

with 范圍內,會執行 yield 語句,即返回一個需要后續處理的對象,比如文件,后續處理是關閉

with 執行完成前,會執行 yield 語句之后的代碼

那么這段代碼的意義就是,當文件使用完成后,關閉文件,并且刪除掉。

使用方式為:

  1. with temp_open(tmp_file, "w"as f_tmp 
  2.     ... 
  3.     f_tmp.write(sql + '\n'
  4.     ... 

這樣無論如何只要 with 塊執行完,文件就會被刪除,不用擔心忘記,是不是很優雅?

除了這兩點,還有很多值得把玩的地方,有興趣的話可以讀讀源碼。

總結

無論是什么工具,都需要有一定的基礎和良好的習慣上才會發揮作用,比如得開啟 MySql 的 binlog 日志,并由記錄工作的習慣。

同時,任何工具方法都有它的特點,可以在了解功能的同時,研究一下其使用原理,是一個很好的技能提升機會。

很多人在抱怨,沒有應用場景,沒有實際項目,其實研究這些工具,就會有事半功倍的效果。

比心

參考資料

[1]binlog2sql: https://github.com/danfengcao/binlog2sql

[2]binlog: https://laijianfeng.org/2019/03/MySQL-Binlog-%E4%BB%8B%E7%BB%8D/

[3]binlog日志開啟和使用: https://juejin.cn/post/6854573218485944333

[4]argparse 模塊: https://docs.python.org/zh-cn/3/library/argparse.html

[5]@contextmanager: https://www.liaoxuefeng.com/wiki/1016959663602400/1115615597164000

[6]生成器: https://www.programiz.com/python-programming/generator

[7]上下文管理器: https://www.geeksforgeeks.org/context-manager-in-python/

 

責任編輯:武曉燕 來源: Python技術
相關推薦

2019-09-04 10:00:07

手機人臉識別

2015-10-22 10:38:43

Wi-Fi燃氣報警器

2016-08-09 16:17:37

高德地圖TFBOYS大數據

2021-12-21 09:05:46

命令Linux敲錯

2015-05-29 09:01:48

2019-12-14 15:50:51

編程元知識代碼開發

2020-06-15 08:03:17

大文件OOM內存

2021-08-13 22:38:36

大數據互聯網技術

2020-03-02 00:01:25

Linux字符目錄

2022-09-14 08:02:25

加密算法Bcryp

2024-04-29 12:13:43

2025-05-30 09:12:00

2019-01-14 00:43:08

可視化圖表數據分析數據可視化

2020-04-10 09:55:28

Git 工具黑魔法

2021-06-11 07:14:04

QQ音樂微信翻譯

2018-10-11 15:51:32

ChromeGoogle瀏覽器

2023-09-13 07:23:22

顯卡NVIDIAIntel

2021-09-30 22:46:05

微信安全支付

2020-04-30 09:01:27

路由器安全網絡安全路由器
點贊
收藏

51CTO技術棧公眾號

97se亚洲国产综合自在线不卡| 国产原创av在线| 欧美在线免费| 精品久久久网站| 精品视频免费观看| 国产ts丝袜人妖系列视频| aa视频在线观看| 免费精品视频在线| 欧美男插女视频| 小毛片在线观看| 亚洲www免费| 日本欧美久久久久免费播放网| 欧美日韩卡一卡二| 亚洲欧美日产图| 亚洲第一色视频| 精品不卡一区| 成人免费在线观看入口| 国产高清一区二区三区| 精品国产av色一区二区深夜久久| 黄色片在线播放| 蜜臀精品久久久久久蜜臀| 日韩中文在线中文网三级| 无码人妻丰满熟妇区毛片蜜桃精品 | 欧美网站免费观看| 9i精品一二三区| 国产揄拍国内精品对白| 亚州成人av在线| 午夜国产福利视频| 欧美日本三级| 欧美亚洲综合另类| 伊人成色综合网| 国产一区久久精品| 久久精品中文| 91.成人天堂一区| 鲁一鲁一鲁一鲁一色| 日韩子在线观看| 91免费观看视频在线| 91精品视频免费| 日本韩国欧美中文字幕| 中文字幕一区二区三区欧美日韩| 亚洲网站在线播放| 在线观看亚洲免费视频| 欧美激情亚洲综合| 草草视频在线| 一区二区三区四区在线免费观看 | 日韩精品电影一区二区三区| 国产成人在线中文字幕| 91精品福利在线| 精品久久久久久一区| 在线观看日韩一区二区| 欧美特黄一级大片| 亚洲欧美激情另类校园| 2018国产精品| 久久久久黄色| 在线观看欧美日本| 99精品人妻少妇一区二区| 亚洲精品中文字幕成人片| 免费不卡在线观看| 日本欧美国产在线| 在线精品免费视| 亚洲精品在线二区| 日韩午夜在线播放| 中文字幕在线综合| 2020国产在线视频| 中文字幕一区二区在线播放| 日本欧洲国产一区二区| 水莓100在线视频| 美女日韩在线中文字幕| 性欧美xxxx| xxxx日本少妇| 亚洲欧美网站在线观看| 久久久av亚洲男天堂| 9191在线视频| av高清不卡| 日韩欧美成人网| 国产免费黄视频| 中文字幕在线高清| 日本一区免费视频| 亚洲国产成人不卡| 欧美人xxx| 中文字幕日韩精品一区| 三年中文高清在线观看第6集| wwwav在线播放| 懂色av中文字幕一区二区三区| 7777精品伊久久久大香线蕉语言| 精品久久久久成人码免费动漫| 国产成人在线视频网站| 91久久精品国产91性色| 国产黄色片免费观看| 国产一区二区在线观看免费| 91香蕉亚洲精品| 成人午夜免费福利| 欧美亚洲视频| 日本一区二区在线播放| 国产美女www爽爽爽| 日韩av一区二区在线影视| 91久久久久久久久久久| av一区二区三| 久久天天做天天爱综合色| 亚洲最大av在线| 狠狠躁夜夜躁av无码中文幕| 久久综合五月天婷婷伊人| 久久久影院一区二区三区| 波多野结衣一区二区| 自拍av一区二区三区| 久久国产午夜精品理论片最新版本| av老司机在线观看| 欧美视频中文字幕| 国产a级片视频| 综合干狼人综合首页| 日韩午夜精品视频| 国产肉体xxxx裸体784大胆| 精品国产91| 不卡中文字幕av| 日韩精品1区2区| 国内精品在线播放| 久热国产精品视频一区二区三区| avav免费在线观看| 亚洲精品国久久99热| 国产午夜福利视频在线观看| 96sao精品免费视频观看| 日韩av网址在线| 性生交大片免费全黄| 99国产精品自拍| 久久久久久久久久久免费| 中文字幕日韩经典| 久久精品一区二区| koreanbj精品视频一区| 91亚洲无吗| 久久久精品久久| 91黑人精品一区二区三区| 99精品久久久久久| 免费av手机在线观看| 一区二区三区在线免费看| 日韩一区av在线| 中文字幕+乱码+中文| 久久久美女毛片| 欧洲av无码放荡人妇网站| 国产亚洲成av人片在线观黄桃| 中文字幕日韩专区| 国产美女www爽爽爽| 国产日韩欧美不卡在线| 中文字幕剧情在线观看一区| 日日夜夜天天综合| 亚洲天天在线日亚洲洲精| 国产成人无码一区二区在线播放| av电影在线观看完整版一区二区| 日韩黄色片在线| av综合网址| 亚州国产精品久久久| 五月婷婷开心中文字幕| 五月婷婷激情综合| 天堂久久久久久| 久久中文欧美| 水蜜桃一区二区三区| huan性巨大欧美| 91精品国产免费| 亚洲熟女www一区二区三区| 国产精品久久久免费| 国产亚洲精品自在久久| 麻豆国产在线| 亚洲欧美日韩中文在线制服| 黑人精品无码一区二区三区AV| 91香蕉视频mp4| 国产免费视频传媒| 国产精品久久观看| av免费观看久久| 日本三级一区| 最好看的2019的中文字幕视频| 中文字幕人妻色偷偷久久| 综合分类小说区另类春色亚洲小说欧美 | 91xxx在线观看| 日韩一区二区免费视频| 国产亚洲精品久久久久久无几年桃 | 91精品视频免费看| 欧美videossex| 日韩av在线免费播放| а中文在线天堂| 亚洲黄色片在线观看| 日本一卡二卡在线| 奇米综合一区二区三区精品视频| 超碰在线免费观看97| 电影一区二区在线观看| 日韩女优人人人人射在线视频| 在线观看免费版| 欧美mv日韩mv| 看黄色一级大片| 亚洲精品视频在线看| 97人妻天天摸天天爽天天| 麻豆一区二区99久久久久| 又大又硬又爽免费视频| 欧美丝袜丝交足nylons172| 91在线精品观看| 亚洲成人av观看| 久久99亚洲热视| 国产福利免费在线观看| 亚洲高清免费视频| 538精品视频| 丁香天五香天堂综合| 欧美日韩在线免费播放| 国产精品xvideos88| 91视频免费进入| 欧美大胆成人| 欧美激情视频网| av中文字幕一区二区三区| 精品国内片67194| 中文字幕在线播放不卡| 图片区小说区国产精品视频| 中文字幕美女视频| 久久久蜜臀国产一区二区| 精品国产免费久久久久久婷婷| 日本在线不卡视频| 欧美在线观看www| 激情文学一区| 欧美三级午夜理伦三级老人| 国产99亚洲| 精品日韩电影| 伊人久久噜噜噜躁狠狠躁| 国产精品视频一区国模私拍| 韩日毛片在线观看| 欧美高清电影在线看| av在线第一页| 亚洲欧美日韩精品久久奇米色影视| www.香蕉视频| 日韩欧美一级二级| 国产精品玖玖玖| 亚洲精品中文在线| 女人裸体性做爰全过| 2024国产精品| 中文字幕在线永久| 不卡一区二区中文字幕| 男插女视频网站| 韩国理伦片一区二区三区在线播放| 毛片av免费在线观看| 免费视频一区| 尤物av无码色av无码| 亚洲三级影院| 免费一级特黄毛片| 亚洲激情精品| 精品视频免费在线播放| 国产欧美精品久久| 国产精品50p| 国产精品夜夜夜| 亚洲人成色77777| 欧美综合二区| 不卡av免费在线| 蜜臀91精品一区二区三区| 色免费在线视频| 麻豆传媒一区二区三区| 91高清国产视频| 精品一区二区三区的国产在线播放 | 午夜av在线播放| 日韩精品视频在线观看免费| 免费国产精品视频| 日韩av中文字幕在线免费观看| 欧美一区二区三区成人片在线| 欧美精品一区二| 深爱五月激情五月| 国产视频精品xxxx| 国产高清在线观看| 久久精品国产亚洲精品| а天堂中文在线官网| 色综合老司机第九色激情| 波多野一区二区| 国产精品久久久久久久久久久不卡 | 国产日韩欧美综合一区| 四虎国产成人精品免费一女五男| 国产精品卡一卡二| 欧美日韩精品亚洲精品| 午夜精品一区二区三区三上悠亚| 中文字幕第15页| 欧美日韩综合在线| 亚洲爱爱综合网| 亚洲欧美日韩图片| 国产在线高潮| 97人人模人人爽人人喊中文字 | 亚洲无线一线二线三线区别av| 男人添女人下部高潮视频在观看| 亚洲欧美日韩国产综合精品二区| 亚洲成色www.777999| 国产宾馆实践打屁股91| 精品人妻一区二区三区视频| 国产精品全国免费观看高清| 欧美黄片一区二区三区| 色婷婷精品大视频在线蜜桃视频| 在线免费看av片| 亚洲精品国产精品国自产观看浪潮 | 国产精品黄色大片| 欧美日韩成人综合天天影院 | 中文字幕综合| 久久精品一二三区| 婷婷综合在线| 中文字幕乱码人妻综合二区三区 | 国产字幕视频一区二区| 国产精品69页| 国产精品一卡二| 毛片网站免费观看| 亚洲人亚洲人成电影网站色| 久久免费精彩视频| 欧美日韩精品一区二区三区 | 最近2019年好看中文字幕视频 | 国产成人亚洲综合91精品| 日韩精品免费视频一区二区三区| 欧美主播一区二区三区美女 久久精品人| 久久精品免费一区二区三区| 日本少妇高潮喷水视频| 国产精品一区二区在线看| 亚洲区自拍偷拍| 亚洲第一精品在线| 国产成人精品亚洲精品色欲| 亚洲天堂男人天堂| sm在线播放| 99电影在线观看| 97精品一区| 久久精品免费网站| 91免费视频大全| 欧美成人aaaaⅴ片在线看| 91精品国产色综合久久| 97视频在线观看网站| 日本sm极度另类视频| 盗摄牛牛av影视一区二区| 日本丰满大乳奶| 九九视频精品免费| 91社区视频在线观看| 日韩欧美福利视频| 手机在线精品视频| 国内久久久精品| 亚洲va欧美va人人爽成人影院| 一区二区不卡在线观看| 久久三级视频| 野外性满足hd| 欧美色xxxx| 日韩欧美亚洲系列| 91高清视频免费观看| 国内精品国产成人国产三级粉色| 免费cad大片在线观看| 久久精品72免费观看| 中文字幕第二区| 欧美日韩在线三级| h网站视频在线观看| 国产成人鲁鲁免费视频a| 亚洲肉体裸体xxxx137| 成人综合视频在线| 26uuu亚洲婷婷狠狠天堂| 国产成人无码一区二区三区在线| 欧美性猛交xxxxx水多| 色哟哟中文字幕| 3344国产精品免费看| 日韩精品免费一区二区夜夜嗨| 五月丁香综合缴情六月小说| 国产高清一区日本| 九九热国产视频| 亚洲国产日韩欧美综合久久 | 五月天久久久| 日本亚洲一区二区三区| 亚洲综合色区另类av| 狠狠综合久久av一区二区| 97人人做人人爱| 国产精品羞羞答答在线观看| 天天干在线影院| 亚洲日本在线视频观看| 国产黄色一区二区| 高清欧美电影在线| 青青草原在线亚洲| 日韩中文字幕亚洲精品欧美| 国产麻豆成人传媒免费观看| 国模无码国产精品视频| 亚洲第一视频网站| 久草中文在线| 超碰97在线资源| 久久狠狠婷婷| 国产精品丝袜一区二区| 精品国产欧美一区二区| 不卡av影片| 一区二区三区四区欧美日韩| 国产成人综合自拍| 毛片毛片女人毛片毛片| 色七七影院综合| 99re6热只有精品免费观看| 成人羞羞国产免费网站| 亚洲视频在线一区观看| 亚洲 小说区 图片区 都市| 国产精品第2页| 在线精品亚洲| 青青青手机在线视频| 精品av综合导航| 美女色狠狠久久| 丁香花在线影院观看在线播放 | 亚洲国产精品久久久久久女王| 国产一区二区在线观看视频| 九九九在线观看| 久久99亚洲热视| 成人一级毛片| 污片免费在线观看| 欧美一区二区三区成人| 欧美xx视频| 91动漫在线看| 18欧美乱大交hd1984| 精品av中文字幕在线毛片| 91久久大香伊蕉在人线|