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

Citus 分布式 PostgreSQL 集群 - SQL Reference(攝取、修改數據 DML)

數據庫 PostgreSQL
向分布式表中插入行時,必須指定插入行的分布列。根據分布列,Citus 確定插入應該路由到的正確分片。然后,查詢被轉發到正確的分片,并在該分片的所有副本上執行遠程插入命令。

插入數據

要將數據插入分布式表,您可以使用標準 PostgreSQL INSERT 命令。例如,我們從 Github 存檔數據集中隨機選擇兩行。

  • INSERT

http://www.postgresql.org/docs/current/static/sql-insert.html

/*
CREATE TABLE github_events
(
event_id bigint,
event_type text,
event_public boolean,
repo_id bigint,
payload jsonb,
repo jsonb,
actor jsonb,
org jsonb,
created_at timestamp
);
*/

INSERT INTO github_events VALUES (2489373118,'PublicEvent','t',24509048,'{}','{"id": 24509048, "url": "https://api.github.com/repos/SabinaS/csee6868", "name": "SabinaS/csee6868"}','{"id": 2955009, "url": "https://api.github.com/users/SabinaS", "login": "SabinaS", "avatar_url": "https://avatars.githubusercontent.com/u/2955009?", "gravatar_id": ""}',NULL,'2015-01-01 00:09:13');

INSERT INTO github_events VALUES (2489368389,'WatchEvent','t',28229924,'{"action": "started"}','{"id": 28229924, "url": "https://api.github.com/repos/inf0rmer/blanket", "name": "inf0rmer/blanket"}','{"id": 1405427, "url": "https://api.github.com/users/tategakibunko", "login": "tategakibunko", "avatar_url": "https://avatars.githubusercontent.com/u/1405427?", "gravatar_id": ""}',NULL,'2015-01-01 00:00:24');

向分布式表中插入行時,必須指定插入行的分布列。根據分布列,Citus 確定插入應該路由到的正確分片。然后,查詢被轉發到正確的分片,并在該分片的所有副本上執行遠程插入命令。

有時將多個 insert 語句放在一個包含多行的單個 insert 中會很方便。它也比重復數據庫查詢更有效。例如,上一節中的示例可以像這樣一次性加載:

INSERT INTO github_events VALUES
(
2489373118,'PublicEvent','t',24509048,'{}','{"id": 24509048, "url": "https://api.github.com/repos/SabinaS/csee6868", "name": "SabinaS/csee6868"}','{"id": 2955009, "url": "https://api.github.com/users/SabinaS", "login": "SabinaS", "avatar_url": "https://avatars.githubusercontent.com/u/2955009?", "gravatar_id": ""}',NULL,'2015-01-01 00:09:13'
), (
2489368389,'WatchEvent','t',28229924,'{"action": "started"}','{"id": 28229924, "url": "https://api.github.com/repos/inf0rmer/blanket", "name": "inf0rmer/blanket"}','{"id": 1405427, "url": "https://api.github.com/users/tategakibunko", "login": "tategakibunko", "avatar_url": "https://avatars.githubusercontent.com/u/1405427?", "gravatar_id": ""}',NULL,'2015-01-01 00:00:24'
);

“From Select”子句(分布式匯總)

Citus 還支持 INSERT ... SELECT 語句 —— 根據選擇查詢的結果插入行。這是一種方便的填充表的方法,并且還允許使用 ON CONFLICT 子句進行“更新插入(upserts)”,這是進行分布式匯總的最簡單方法。

  • 分布式匯總

https://docs.citusdata.com/en/v11.0-beta/develop/reference_dml.html#rollups

在 Citus 中,可以通過三種方式從 select 語句中插入。第一個是如果源表和目標表位于同一位置,并且 select/insert 語句都包含分布列。在這種情況下,Citus 可以將 INSERT ... SELECT 語句下推以在所有節點上并行執行。

當 SELECT 查詢不需要協調器上的合并步驟時,可能會發生重新分區優化。它不適用于以下需要合并步驟的 SQL 功能:

  • ORDER BY
  • LIMIT
  • OFFSET
  • GROUP BY 當分布列不是 group 鍵的一部分時
  • 按源表中的非分布列分區時的 Window(窗口)函數
  • 非同位表之間的Join(連接)(即重新分區連接)

當源表和目標表沒有在同一位置,并且無法應用重新分區優化時,Citus 使用第三種方式執行 INSERT ... SELECT。它從工作節點中選擇結果,并將數據拉到協調節點。協調器將行重定向回適當的分片。因為所有數據都必須通過單個節點,所以這種方法效率不高。

如果對 Citus 使用哪種方法有疑問,請使用 EXPLAIN 命令,如 PostgreSQL 調優中所述。當目標表的分片數量非常大時,禁用重新分區可能是明智之舉, 請參閱 citus.enable_repartitioned_insert_select (boolean)。

  • PostgreSQL 調優

https://docs.citusdata.com/en/v11.0-beta/performance/performance_tuning.html#postgresql-tuning

  • citus.enable_repartitioned_insert_select (boolean)

https://docs.citusdata.com/en/v11.0-beta/develop/api_guc.html#enable-repartitioned-insert-select

COPY 命令(批量加載)

要從文件中批量加載數據,您可以直接使用 PostgreSQL 的 \COPY 命令。

首先通過運行下載我們的示例 github_events 數據集:

wget http://examples.citusdata.com/github_archive/github_events-2015-01-01-{0..5}.csv.gz
gzip -d github_events-2015-01-01-*.gz

然后,您可以使用 psql 復制數據(注意,此數據需要數據庫具有 UTF8 編碼):

\COPY github_events FROM 'github_events-2015-01-01-0.csv' WITH (format 
CSV)

注意:

沒有跨分片的快照隔離的概念,這意味著與 COPY 并發運行的多分片 SELECT 可能會看到它在某些分片上提交,但在其他分片上沒有。如果用戶正在存儲事件數據,他可能偶爾會觀察到最近數據中的小間隙。如果這是一個問題,則由應用程序來處理(例如,從查詢中排除最新數據,或使用一些鎖)。

如果 COPY 未能打開分片放置的連接,那么它的行為方式與 INSERT 相同,即將放置標記為非活動,除非沒有更多活動的放置。如果連接后發生任何其他故障,事務將回滾,因此不會更改元數據。

使用匯總緩存聚合

事件數據管道和實時儀表板等應用程序需要對大量數據進行亞秒級查詢。使這些查詢快速的一種方法是提前計算和保存聚合。這稱為“匯總”數據,它避免了在運行時處理原始數據的成本。作為一個額外的好處,將時間序列數據匯總到每小時或每天的統計數據中也可以節省空間。當不再需要其全部詳細信息并且聚合足夠時,可能會刪除舊數據。

例如,這是一個通過 url 跟蹤頁面瀏覽量的分布式表:

CREATE TABLE page_views (
site_id int,
url text,
host_ip inet,
view_time timestamp default now(),

PRIMARY KEY (site_id, url)
);

SELECT create_distributed_table('page_views', 'site_id');

一旦表中填充了數據,我們就可以運行聚合查詢來計算每個 URL 每天的頁面瀏覽量,限制到給定的站點和年份。

-- how many views per url per day on site 5?
SELECT view_time::date AS day, site_id, url, count(*) AS view_count
FROM page_views
WHERE site_id = 5 AND
view_time >= date '2016-01-01' AND view_time < date '2017-01-01'
GROUP BY view_time::date, site_id, url;

上述設置有效,但有兩個缺點。首先,當您重復執行聚合查詢時,它必須遍歷每個相關行并重新計算整個數據集的結果。如果您使用此查詢來呈現儀表板,則將聚合結果保存在每日頁面瀏覽量表中并查詢該表會更快。其次,存儲成本將隨著數據量和可查詢歷史的長度成比例增長。在實踐中,您可能希望在短時間內保留原始事件并查看較長時間窗口內的歷史圖表。

為了獲得這些好處,我們可以創建一個 daily_page_views 表來存儲每日統計信息。

CREATE TABLE daily_page_views (
site_id int,
day date,
url text,
view_count bigint,
PRIMARY KEY (site_id, day, url)
);

SELECT create_distributed_table('daily_page_views', 'site_id');

在此示例中,我們在 site_id 列上同時分配了 page_views 和 daily_page_views。這確保了與特定站點相對應的數據將位于同一節點上。在每個節點上將兩個表的行保持在一起可以最大限度地減少節點之間的網絡流量并實現高度并行執行。

一旦我們創建了這個新的分布式表,我們就可以運行 INSERT INTO ... SELECT 將原始頁面視圖匯總到聚合表中。在下文中,我們每天匯總頁面瀏覽量。Citus 用戶通常在一天結束后等待一段時間來運行這樣的查詢,以容納遲到的數據。

-- roll up yesterday's data
INSERT INTO daily_page_views (day, site_id, url, view_count)
SELECT view_time::date AS day, site_id, url, count(*) AS view_count
FROM page_views
WHERE view_time >= date '2017-01-01' AND view_time < date '2017-01-02'
GROUP BY view_time::date, site_id, url;

-- now the results are available right out of the table
SELECT day, site_id, url, view_count
FROM daily_page_views
WHERE site_id = 5 AND
day >= date '2016-01-01' AND day < date '2017-01-01';

上面的匯總查詢匯總了前一天的數據并將其插入 daily_page_views。每天運行一次查詢意味著不需要更新匯總表行,因為新一天的數據不會影響之前的行。

當處理遲到的數據或每天多次運行匯總查詢時,情況會發生變化。如果任何新行與匯總表中已有的天數匹配,則匹配計數應增加。 PostgreSQL 可以使用 “ON CONFLICT” 來處理這種情況, 這是它進行 upserts 的技術。這是一個例子。

  • upserts

https://www.postgresql.org/docs/current/static/sql-insert.html#SQL-ON-CONFLICT

-- roll up from a given date onward,
-- updating daily page views when necessary
INSERT INTO daily_page_views (day, site_id, url, view_count)
SELECT view_time::date AS day, site_id, url, count(*) AS view_count
FROM page_views
WHERE view_time >= date '2017-01-01'
GROUP BY view_time::date, site_id, url
ON CONFLICT (day, url, site_id) DO UPDATE SET
view_count = daily_page_views.view_count + EXCLUDED.view_count;

更新和刪除

您可以使用標準 PostgreSQL UPDATE 和 DELETE 命令更新或刪除分布式表中的行。

DELETE FROM github_events
WHERE repo_id IN (24509048, 24509049);

UPDATE github_events
SET event_public = TRUE
WHERE (org->>'id')::int = 5430905;
  • UPDATE

http://www.postgresql.org/docs/current/static/sql-update.html

  • DELETE

http://www.postgresql.org/docs/current/static/sql-delete.html

當更新/刪除影響如上例中的多個分片時,Citus 默認使用單階段提交協議。為了提高安全性,您可以通過設置啟用兩階段提交。

SET citus.multi_shard_commit_protocol = '2pc';

如果更新或刪除僅影響單個分片,則它在單個工作節點內運行。在這種情況下,不需要啟用 2PC。當按表的分布列更新或刪除過濾器時,通常會發生這種情況:

-- since github_events is distributed by repo_id,
-- this will execute in a single worker node

DELETE FROM github_events
WHERE repo_id = 206084;

此外,在處理單個分片時,Citus 支持 SELECT ... FOR UPDATE。這是對象關系映射器 (ORM) 有時使用的一種技術,用于安全地:

  • 加載行
  • 在應用程序代碼中進行計算
  • 根據計算更新行

選擇要更新的行會對它們設置寫鎖定,以防止其他進程導致“丟失更新(lost update)”異常。

BEGIN;

-- select events for a repo, but
-- lock them for writing
SELECT *
FROM github_events
WHERE repo_id = 206084
FOR UPDATE;

-- calculate a desired value event_public using
-- application logic that uses those rows...

-- now make the update
UPDATE github_events
SET event_public = :our_new_value
WHERE repo_id = 206084;

COMMIT;

僅哈希分布表和引用表支持此功能,并且僅那些具有 replication_factor 為 1 的表支持。

  • replication_factor

https://docs.citusdata.com/en/v11.0-beta/develop/api_guc.html#replication-factor

最大化寫入性能

在大型機器上,INSERT 和 UPDATE/DELETE 語句都可以擴展到每秒約 50,000 個查詢。但是,要達到這個速度,您將需要使用許多并行的、長期存在的連接并考慮如何處理鎖定。有關更多信息,您可以查閱我們文檔的橫向擴展數據攝取部分。

  • 橫向擴展數據攝取

https://docs.citusdata.com/en/v11.0-beta/performance/performance_tuning.html#scaling-data-ingestion

責任編輯:武曉燕 來源: 黑客下午茶
相關推薦

2022-03-29 23:17:52

PostgreSQL集群Citus

2022-03-30 19:18:31

PostgreSQL分布式I/O

2022-03-27 06:37:37

SQLPostgreSQL集群

2022-03-31 19:20:39

集群PostgreSQLCitus

2022-04-01 19:26:15

PostgreSQLCitus分布式

2022-03-21 06:45:22

PostgreSQL數據庫Citus

2022-03-17 18:52:41

PostgreSQ序列數據集群

2022-03-06 21:43:05

Citus架構PostgreSQL

2022-03-22 11:35:10

數據建模PostgreSQLCitus

2022-03-24 14:11:25

KubernetesCitusPostgreSQL

2022-03-21 19:44:30

CitusPostgreSQ執行器

2022-03-16 19:15:32

PostgreSQL日志Kafka

2022-03-15 19:19:04

分布式PostgreSQL集群

2022-03-14 19:40:40

PostgreSQL多租戶應用程序Citus

2022-10-21 16:16:42

分布式系統優化

2022-02-25 17:38:15

Citus

2025-03-27 11:03:18

2020-04-14 11:14:02

PostgreSQL分布式數據庫

2020-06-02 14:45:48

PostgreSQL架構分布式

2017-09-11 15:17:01

分布式集群負載均衡
點贊
收藏

51CTO技術棧公眾號

婷婷av一区二区三区| 国产又粗又猛大又黄又爽| 天天干天天草天天射| 在线观看一区| 亚洲美女自拍视频| 能在线观看的av网站| www.亚洲免费| 韩国一区二区在线观看| 欧美激情视频给我| 免费看污黄网站在线观看| 亚洲成人av观看| 亚洲日本护士毛茸茸| 99视频免费观看蜜桃视频| 日韩乱码一区二区| 欧美极品在线观看| 3atv一区二区三区| 精品这里只有精品| 天堂中文8资源在线8| 国产精品99精品久久免费| 亚州成人av在线| 午夜影院黄色片| 超碰在线亚洲| 欧美视频一区二区在线观看| 青青草免费在线视频观看| 天天射天天操天天干| 日韩电影在线观看网站| 欧美成人精品一区二区| 亚洲精品鲁一鲁一区二区三区| 蜜桃视频在线观看播放| 国产精品久久久久永久免费观看| 不卡日韩av| 中文字幕第315页| 亚洲麻豆一区| 日韩在线观看免费网站| 色婷婷激情视频| 在线天堂中文资源最新版| 亚洲欧洲三级电影| 久久综合九色欧美狠狠| av免费在线观看不卡| 久久一二三区| 午夜精品福利视频| 久久免费看少妇高潮v片特黄 | 最近日韩中文字幕| 免费av一区二区三区| 国产成a人亚洲精v品无码| 日韩在线播放一区二区| 91黑丝高跟在线| 国产盗摄x88av| 色综合五月天| 夜夜嗨av一区二区三区免费区 | 日产欧产va高清| 亚洲人metart人体| 色吧影院999| 美女爆乳18禁www久久久久久| jizz性欧美2| 欧美精品欧美精品系列| 日韩精品你懂的| 日韩国产激情| 日韩欧美成人精品| 黄色片免费在线观看视频| 欧美精品电影| 国产精品久久久久一区| 欧美最大成人综合网| 天堂а√在线8种子蜜桃视频 | 国内av免费观看| 国产精品一区三区在线观看| 欧美特级限制片免费在线观看| 欧美 国产 日本| 涩涩视频在线播放| 疯狂做受xxxx高潮欧美日本| 免费不卡av在线| 97蜜桃久久| 婷婷激情综合网| 免费在线观看视频a| 2020国产在线| 欧美日韩国产精品一区二区不卡中文| 草b视频在线观看| 91豆花视频在线播放| 亚洲国产成人va在线观看天堂 | 国产精品大片| 欧美—级高清免费播放| 国产三级精品三级观看| 一区二区三区国产精华| 欧美理论片在线观看| 国产中文字字幕乱码无限| 亚洲毛片网站| 国产精品国产自产拍高清av水多 | 欧美暴力喷水在线| 欧美国产一区二区三区| 国产乡下妇女做爰视频| 免费久久99精品国产自在现线| 日韩av电影在线网| 在线观看亚洲国产| 国产资源在线一区| 国产精品播放| 免费在线国产| 国产精品久久久久久久久免费桃花| 亚洲精品一区二| 呦呦在线视频| 色综合久久九月婷婷色综合| 中国丰满人妻videoshd | 国产精品久久网| 国产jzjzjz丝袜老师水多| 懂色av一区二区三区蜜臀| 激情小说综合区| 国产精品久久久久久久龚玥菲| 中文字幕日韩精品一区| 无码 制服 丝袜 国产 另类| 中文在线中文资源| 欧美日韩国产成人在线91| 少妇愉情理伦片bd| 999久久精品| 亚洲欧洲国产伦综合| 国产av无码专区亚洲av毛网站| 一区二区动漫| 国产在线久久久| 四虎精品一区二区三区| 国产精品久久久久一区二区三区 | 亚洲在线视频一区| 国产成人手机视频| 538任你躁精品视频网免费| 国产亚洲人成网站在线观看| 中文字幕av免费在线观看| 亚洲免费综合| 亚洲影院污污.| 国产在线日本| 亚洲电影在线播放| 日本一二区免费| 亚欧日韩另类中文欧美| 精品少妇v888av| 亚洲免费黄色网址| 国产麻豆成人传媒免费观看| 日韩精品久久一区| huan性巨大欧美| 欧美三级乱人伦电影| 国产精品无码一区二区三区免费| 婷婷久久综合| 国产精品欧美激情| 色猫av在线| 亚洲国产另类av| 日本在线观看免费视频| 日韩精品免费一区二区三区竹菊 | 亚洲一区二区在线播放| 黄色av免费在线观看| 亚洲国产精品一区二区www| 色天使在线观看| 日韩欧美二区| 97精品国产97久久久久久| a级片在线视频| 久久久久九九视频| 成熟了的熟妇毛茸茸| 亚洲伊人影院| 欧美美女18p| 91午夜交换视频| 久久综合成人精品亚洲另类欧美 | 国产亚洲精品v| 国产成人免费电影| mm1313亚洲国产精品美女| 欧美高清视频www夜色资源网| 97伦伦午夜电影理伦片| 亚洲综合欧美| 久久这里精品国产99丫e6| 69av成人| 亚洲毛片一区二区| 久久国产视频播放| 91在线视频免费观看| 黄色片网址在线观看| 国产精品网站在线看| 久久久久这里只有精品| 欧洲精品久久一区二区| 午夜免费久久看| 喷水视频在线观看| 亚洲一区二区三区四区五区午夜| 精品国产电影| 成人香蕉视频| 中文日韩在线观看| 国产原创中文av| 亚洲欧美日韩在线不卡| 日韩欧美国产片| 成人影院在线| 91美女片黄在线观看游戏| 日本伦理一区二区| 日韩av在线网站| 中文字幕人妻精品一区| 一区二区三区在线免费视频 | 国产亚洲va综合人人澡精品| 男生操女生视频在线观看| 欧美人成在线| 欧美一级二级三级九九九| 国产精品久久免费视频| 国外成人性视频| av在线免费播放网站| 欧美一区2区视频在线观看| 国产无遮无挡120秒| 日本一区二区视频在线| 日本黄色www| 久久性天堂网| 久久久久久av无码免费网站下载| 日本在线中文字幕一区| 成人国产精品av| 九色porny自拍视频在线播放| 一区二区欧美激情| 肥臀熟女一区二区三区| 欧美图片一区二区三区| 久久草视频在线| 亚洲男人的天堂在线观看| 中文字幕 亚洲一区| 国内精品久久久久影院色| 亚洲熟妇av日韩熟妇在线| 天天av综合| 日本一区高清不卡| 久久影视三级福利片| 国产日韩在线亚洲字幕中文| 天堂电影一区| 欧美噜噜久久久xxx| yw193.com尤物在线| 亚洲国产精品电影在线观看| 国产一区二区波多野结衣| 日韩欧美亚洲范冰冰与中字| 青青草免费av| 国产精品麻豆视频| 99久久久无码国产精品性| 成人国产精品免费观看视频| 在线观看网站黄| 精品一区二区三区免费播放| 国产天堂在线播放| 男人的天堂亚洲| www.av毛片| 国产专区一区| 国产免费一区二区三区四在线播放| 深爱激情综合| 欧美日韩国产一二| 你懂的在线观看一区二区| 91在线精品观看| 国产精一区二区| 国产日韩av在线播放| 在线看欧美视频| 国产国产精品人在线视| 秋霞伦理一区| 91精品国产91久久久久福利| 免费看电影在线| 欧美国产乱视频| 日皮视频在线观看| 欧美美最猛性xxxxxx| a视频在线免费看| 欧美不卡视频一区发布| www视频在线免费观看 | 国产色播av在线| 欧美激情极品视频| 欧美卡一卡二| 久久久亚洲影院你懂的| av老司机在线观看| 国内自拍欧美激情| 美女一区网站| 国产精品视频xxx| 不卡精品视频| 国产99视频精品免费视频36| 狠狠久久伊人| 蜜桃av久久久亚洲精品| 免费看av成人| 色综合电影网| 91精品国产自产拍在线观看蜜| 国产免费一区二区三区四在线播放| 欧美~级网站不卡| 亚洲色欲久久久综合网东京热| 伊人成人在线视频| 中文字幕日本最新乱码视频| 日韩专区欧美专区| 午夜天堂在线视频| 风间由美性色一区二区三区| 狠狠人妻久久久久久综合蜜桃| 久久综合给合久久狠狠狠97色69| 日韩中文字幕有码| 综合久久国产九一剧情麻豆| 欧美爱爱小视频| 日韩欧美一区二区三区| 中文字幕久久久久| 日韩欧美国产综合| 深夜福利在线看| 最新的欧美黄色| 欧美videosex性极品hd| 国产精品88a∨| 欧美a在线观看| 美媛馆国产精品一区二区| 五月婷婷亚洲| jizzjizz国产精品喷水| 日韩在线一区二区| 精品人妻无码中文字幕18禁| 成人教育av在线| 国产精品成人在线视频| 亚洲伦理在线精品| 黄色在线视频网址| 欧美日韩国产不卡| 少妇精品高潮欲妇又嫩中文字幕 | 成人羞羞网站| 久久婷婷人人澡人人喊人人爽| 亚洲精品播放| 经典三级在线视频| 日韩一区二区免费看| 凹凸日日摸日日碰夜夜爽1| 国内国产精品久久| 精品少妇一区二区三区免费观| 久久久久久久久久久电影| 国产大屁股喷水视频在线观看| 一区二区三区在线看| 国产免费观看av| 欧美顶级少妇做爰| 深夜视频在线免费| 色综合色综合久久综合频道88| 欧美男男tv网站在线播放| 国产精品久久婷婷六月丁香| 国产伦理久久久久久妇女| 亚洲国产一区二区精品视频| 欧美另类女人| 91制片厂毛片| 99久久精品免费看| 国产成人无码aa精品一区| 在线一区二区观看| 亚洲精品一区二区三区不卡| 最近中文字幕日韩精品| 中文字幕乱码中文乱码51精品| 国产精品丝袜视频| 亚欧日韩另类中文欧美| 免费cad大片在线观看| 毛片基地黄久久久久久天堂| 中文字幕一区二区人妻电影丶| 国产欧美一区二区精品性| 日韩手机在线观看| 日韩欧美不卡在线观看视频| 亚洲av片在线观看| 最近2019中文字幕一页二页| 免费电影日韩网站| 国产区二精品视| 亚洲成人直播| 伦伦影院午夜理论片| 久久久精品日韩欧美| 日韩欧美中文字幕一区二区| 欧美一区二区三区不卡| 美女羞羞视频在线观看| 国产极品jizzhd欧美| 久久久久九九精品影院| 中文字幕中文字幕一区三区| 久久国产日韩| 动漫精品一区二区三区| 亚洲va国产天堂va久久en| www.五月婷| 欧美精品久久一区二区 | 欧美午夜一区二区三区免费大片| 天堂中文在线资| 97超碰蝌蚪网人人做人人爽| 99re91这里只有精品| 阿v天堂2018| 成人免费高清在线| 丰满少妇乱子伦精品看片| 精品卡一卡二卡三卡四在线| a毛片在线看免费观看| 99re热精品| 一本色道久久综合亚洲精品高清| 国产精品麻豆入口| 午夜视频一区二区| 黄色av一区二区三区| 久久青草精品视频免费观看| 美女一区2区| 国产极品粉嫩福利姬萌白酱| 久久久久久久久久久黄色| 久久久久久久亚洲| 日韩在线观看成人| 欧美h版在线观看| 美脚丝袜脚交一区二区| 久久久久久久综合| 国产黄色免费视频| 欧美成人在线免费视频| 中文一区二区三区四区| 熟妇熟女乱妇乱女网站| 国产suv精品一区二区883| 日韩高清精品免费观看| 国产亚洲精品久久久久久| 成人在线视频观看| 91传媒免费视频| 91一区在线观看| 日韩不卡高清视频| 欧美情侣性视频| 欧美绝顶高潮抽搐喷水合集| 91香蕉视频污版| 中文字幕一区二区三区在线播放| 亚洲精品一区二区三区不卡| 91超碰中文字幕久久精品| 精品国产一区一区二区三亚瑟| 免费精品99久久国产综合精品应用| 亚洲欧美国产77777| 毛片在线播放网址| 成人女保姆的销魂服务| 欧美日韩免费| 日本一级免费视频| 5月丁香婷婷综合| 黄色综合网址| 一级一片免费播放| 久久天堂av综合合色蜜桃网| 国产精品乱码一区二区| 欧美有码在线视频|