日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python3.6.2用pyinstaller3.4报错_OceanBase 2.2 版本体验:用 BenchmarkSQL 跑 TPC-C

發布時間:2025/3/8 python 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python3.6.2用pyinstaller3.4报错_OceanBase 2.2 版本体验:用 BenchmarkSQL 跑 TPC-C 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

OB君:好消息!「 OceanBase 2.2 版本 」正式上線官網啦!(點擊閱讀原文即可直接下載)OceanBase 2.2版本是成功支撐2019年天貓雙11大促的穩定版本,同時也是用于TPC-C測試且榮登TPC-C性能榜首的版本。我們將在接下來的時間里為大家持續推出 “OceanBase 2.2 手把手系列” ,將手把手帶大家一起體驗OceanBase 2.2的強大功能。歡迎持續關注!

引言

OceanBase 2.2版本近期已通過官網提供下載(https://oceanbase.alipay.com/download/resource),2.2支持Oracle租戶。OceanBase在2019年10月2日榮膺國際事務委員會(TPC)審計發布的TPC-C基準測試榜首,用的就是Oracle租戶。TPC-C測試使用了207多臺阿里云高配ECS服務器,是因為TPC-C標準對應用、數據庫等規范非常細致嚴格。一般來說普通企業或個人很難有那樣的條件去測試。

BenchmarkSQL是開源的TPC-C測試程序,它弱化了TPC-C的關鍵標準(數據分布和應用執行行為方面),使得用幾臺服務器就可以跑TPC-C成為可能。當然這個結果不能跟官方TPC-C的結果相比較。不過,使用BenchmarkSQL來比較不同的數據庫的事務處理能力還是有一定參考意義的,尤其是相比Sysbench而言。

OceanBase測試租戶準備

1.sys租戶參數修改

BenchmarkSQL會加載大量數據,短時間內對OceanBase內存消耗速度會很快,因此需要針對內存凍結合并和限流參數做一些調優。在sys租戶執行:

ALTER SYSTEM SET enable_merge_by_turn=FALSE; ALTER SYSTEM set minor_freeze_times=100; ALTER SYSTEM set freeze_trigger_percentage=70; ALTER SYSTEM set writing_throttling_trigger_percentage=70 tenant='obbmsql'; ALTER SYSTEM set writing_throttling_maximum_duration='10m' tenant='obbmsql'; show parameters where name in ('minor_freeze_times','freeze_trigger_percentage');

注意:業務租戶限流參數的修改是在sys租戶里,需要指定相應的租戶名。然后查看確認需要到業務租戶里。
在業務租戶執行:

SHOW parameters WHERE name IN ('writing_throttling_trigger_percentage','writing_throttling_maximum_duration');

2. 業務租戶參數修改

OceanBase跟Oracle/MySQL相比,會有個默認SQL超時和事務超時機制。這個可能會導致后面查看修改數據的SQL報錯。所以先修改一下這些參數。

set global recyclebin=off; set global ob_query_timeout=1000000000; set global ob_trx_idle_timeout=1200000000; set global ob_trx_timeout=1000000000;

此外,需要為bmsql準備一個單獨的schema(即用戶)。

drop user tpcc cascade;create user tpcc identified by 123456; grant all privileges on tpcc.* to tpcc with grant option ; grant create, drop on *.* to tpcc;

3. OBProxy配置修改

OBProxy是OceanBase的訪問代理,其內部一些參數也可能影響性能。如下面的壓縮參數對CPU有一定消耗,測試時可以關閉。

$ obclient -h127.1 -uroot@sys#obdemo -P2883 -p123456 -c -A oceanbasealter proxyconfig set enable_compression_protocol=False; show proxyconfig like 'enable_compression_protocol';

該參數修改后,需要重啟obproxy進程

[admin@xxx /home/admin] $kill -9 `pidof obproxy`[admin@h07d17167.sqa.eu95 /home/admin] $cd /opt/taobao/install/obproxy[admin@xxx /opt/taobao/install/obproxy] $bin/obproxy bin/obproxy

BenchmarkSQL準備

BenchmarkSQL 官方下載地址是: https://sourceforge.net/projects/benchmarksql/ ,下載后請參考 HOW-TO-RUN.txt 中說明先編譯安裝BenchmarkSQL。然后按下面建議修改部分腳本增加對OceanBase支持。也可以直接下載我編譯修改好的BenchmarkSQL,地址是:https://github.com/obpilot/benchmarksql-5.0 。

1. 準備OceanBase驅動文件

BenchmarkSQL是通過jdbc連接各個數據庫的。此次OceanBase的測試租戶是Oracle類型,所以需要借用 lib/oracle 目錄,然后把相關jar包一并放入其中。其中 oceanbase-client-*.jar 是OceanBase提供的,其他jar包可以從互聯網獲取。

[admin@xxx /home/admin/benchmarksql-5.0]$ll lib/oracle/ total 3728 -rwxr-xr-x 1 admin admin 52988 Jul 12 2019 commons-cli-1.3.1.jar -rwxr-xr-x 1 admin admin 245274 Jul 12 2019 commons-lang-2.3.jar -rwxr-xr-x 1 admin admin 2256213 Jul 12 2019 guava-18.0.jar -rwxr-xr-x 1 admin admin 54495 Jul 12 2019 json-20160810.jar -rwxr-xr-x 1 admin admin 1121698 Dec 3 15:04 oceanbase-client-1.0.8.jar -rwxr-xr-x 1 admin admin 174 Jul 12 2019 README.txt -rwxr-xr-x 1 admin admin 76997 Jul 12 2019 toolkit-common-logging-1.10.jar

2. 準備OB配置文件

$cat props.ob db=oracle driver=com.alipay.oceanbase.obproxy.mysql.jdbc.Driver conn=jdbc:oceanbase://127.0.0.1:2883/tpcc?useUnicode=true&characterEncoding=utf-8 user=tpcc@obbmsql#obdemo password=123456warehouses=10 loadWorkers=10 //fileLocation=/home/t4/tmpterminals=10 //To run specified transactions per terminal- runMins must equal zero runTxnsPerTerminal=0 //To run for specified minutes- runTxnsPerTerminal must equal zero runMins=10 //Number of total transactions per minute limitTxnsPerMin=0//Set to true to run in 4.x compatible mode. Set to false to use the //entire configured database evenly. terminalWarehouseFixed=true//The following five values must add up to 100 newOrderWeight=45 paymentWeight=43 orderStatusWeight=4 deliveryWeight=4 stockLevelWeight=4// Directory name to create for collecting detailed result data. // Comment this out to suppress. resultDirectory=my_result_%tY-%tm-%td_%tH%tM%tS osCollectorScript=./misc/os_collector_linux.py osCollectorInterval=1 //osCollectorSSHAddr=user@dbhost //osCollectorDevices=net_eth0 blk_sda

注意:a. 倉庫數(warehouses)決定了數據量。正式的壓測倉庫數一般在10000以上。b. loadworkers數決定了數據加載的性能。如果OceanBase租戶資源很小(尤其是內存資源),那加載速度也不要太快;否則容易把租戶內存打爆。c. 并發數(terminals)是后期做TPC-C測試的客戶端并發數。這個每次測試都可以調整,以方便觀察不同壓力下的性能。

d. 壓測時間(runMin)是每次測試時間,越長測試結果越好且穩定。因為有時候數據訪問有個預熱過程,效果會體現在內存命中率上。

3. 創建BenchmarkSQL相關表

1)建表腳本

該SQL腳本不需要直接執行。

create table bmsql_config (cfg_name varchar2(30) primary key,cfg_value varchar2(50) );create tablegroup tpcc_group partition by hash partitions 12;create table bmsql_warehouse (w_id integer not null,w_ytd decimal(12,2),w_tax decimal(4,4),w_name varchar2(10),w_street_1 varchar2(20),w_street_2 varchar2(20),w_city varchar2(20),w_state char(2),w_zip char(9),primary key(w_id) )tablegroup='tpcc_group' partition by hash(w_id) partitions 12;create table bmsql_district (d_w_id integer not null,d_id integer not null,d_ytd decimal(12,2),d_tax decimal(4,4),d_next_o_id integer,d_name varchar2(10),d_street_1 varchar2(20),d_street_2 varchar2(20),d_city varchar2(20),d_state char(2),d_zip char(9),PRIMARY KEY (d_w_id, d_id) )tablegroup='tpcc_group' partition by hash(d_w_id) partitions 12;create table bmsql_customer (c_w_id integer not null,c_d_id integer not null,c_id integer not null,c_discount decimal(4,4),c_credit char(2),c_last varchar2(16),c_first varchar2(16),c_credit_lim decimal(12,2),c_balance decimal(12,2),c_ytd_payment decimal(12,2),c_payment_cnt integer,c_delivery_cnt integer,c_street_1 varchar2(20),c_street_2 varchar2(20),c_city varchar2(20),c_state char(2),c_zip char(9),c_phone char(16),c_since timestamp,c_middle char(2),c_data varchar2(500),PRIMARY KEY (c_w_id, c_d_id, c_id) )tablegroup='tpcc_group' use_bloom_filter=true compress partition by hash(c_w_id) partitions 12;create sequence bmsql_hist_id_seq;create table bmsql_history (hist_id integer,h_c_id integer,h_c_d_id integer,h_c_w_id integer,h_d_id integer,h_w_id integer,h_date timestamp,h_amount decimal(6,2),h_data varchar2(24) )tablegroup='tpcc_group' use_bloom_filter=true compress partition by hash(h_w_id) partitions 12;create table bmsql_new_order (no_w_id integer not null ,no_d_id integer not null,no_o_id integer not null,PRIMARY KEY (no_w_id, no_d_id, no_o_id) )tablegroup='tpcc_group' use_bloom_filter=true compress partition by hash(no_w_id) partitions 12;create table bmsql_oorder (o_w_id integer not null,o_d_id integer not null,o_id integer not null,o_c_id integer,o_carrier_id integer,o_ol_cnt integer,o_all_local integer,o_entry_d timestamp,PRIMARY KEY (o_w_id, o_d_id, o_id) )tablegroup='tpcc_group' use_bloom_filter=true compress partition by hash(o_w_id) partitions 12;create table bmsql_order_line (ol_w_id integer not null,ol_d_id integer not null,ol_o_id integer not null,ol_number integer not null,ol_i_id integer not null,ol_delivery_d timestamp,ol_amount decimal(6,2),ol_supply_w_id integer,ol_quantity integer,ol_dist_info char(24),PRIMARY KEY (ol_w_id, ol_d_id, ol_o_id, ol_number) )tablegroup='tpcc_group' use_bloom_filter=true compress partition by hash(ol_w_id) partitions 12;create table bmsql_item (i_id integer not null,i_name varchar2(24),i_price decimal(5,2),i_data varchar2(50),i_im_id integer,PRIMARY KEY (i_id) )use_bloom_filter=true compress locality='F,R{all_server}@zone1, F,R{all_server}@zone2, F,R{all_server}@zone3' primary_zone='zone1' duplicate_scope='cluster';create table bmsql_stock (s_w_id integer not null,s_i_id integer not null,s_quantity integer,s_ytd integer,s_order_cnt integer,s_remote_cnt integer,s_data varchar2(50),s_dist_01 char(24),s_dist_02 char(24),s_dist_03 char(24),s_dist_04 char(24),s_dist_05 char(24),s_dist_06 char(24),s_dist_07 char(24),s_dist_08 char(24),s_dist_09 char(24),s_dist_10 char(24),PRIMARY KEY (s_w_id, s_i_id) )tablegroup='tpcc_group' use_bloom_filter=true compress partition by hash(s_w_id) partitions 12;

注意:

a. 建表語句中的分區數目可以根據實際情況調整,跟集群節點數有關。如果集群是3臺(1-1-1),建議是6個或6的倍數;如果集群是6臺(2-2-2),建議是12個或12的倍數;如果集群是9臺(3-3-3),建議是36個或36的倍數。這樣是方便后期彈性伸縮測試的時候能盡可能保證每個節點上的分區數均衡。

b. 上面bmsql_item使用了【復制表】功能,在租戶的所有節點上都會有一個副本。當然主副本始終只有一個。有關【復制表】功能介紹請參考《OceanBase事務引擎特性和應用實踐分享》。

c. 建表語句不包含非主鍵索引,是為了后面加載數據性能更快。

2)建表

./runSQL.sh props.ob ./sql.oceanbase/tableCreates.sql

建表后,可以查看主副本分布

SELECT t1.tenant_id,t1.tenant_name,t2.database_name,t3.table_id,t3.table_Name,t3.tablegroup_id,t3.part_num,t4.partition_Id,t4.zone,t4.svr_ip,t4.role, round(t4.data_size/1024/1024) data_size_mb from `gv$tenant` t1join `gv$database` t2 on (t1.tenant_id = t2.tenant_id)join gv$table t3 on (t2.tenant_id = t3.tenant_id and t2.database_id = t3.database_id and t3.index_type = 0)left join `__all_virtual_meta_table` t4 on (t2.tenant_id = t4.tenant_id and ( t3.table_id = t4.table_id or t3.tablegroup_id = t4.table_id ) and t4.role in (1)) where t1.tenant_id = 1001 order by t3.tablegroup_id, t4.partition_Id, t3.table_name ;

4. 加載數據

1)開始加載數據

./runLoader.sh props.ob

2)觀察數據加載性能

為了對數據寫入速度進行觀察,可以在sys租戶下反復執行下面SQL,主要是觀察增量內存增速和增量內存總量,以及是否接近總增量內存限制。

SELECT tenant_id, ip, round(active/1024/1024) active_mb, round(total/1024/1024) total_mb, round(freeze_trigger/1024/1024) freeze_trg_mb, round(mem_limit/1024/1024) mem_limit_mb, freeze_cnt , round((active/freeze_trigger),2) freeze_pct, round(total/mem_limit, 2) mem_usage FROM `gv$memstore` WHERE tenant_id IN (1001) ORDER BY tenant_id, ip;

當然,觀察數據加載另外一個方法就是使用監控。OCP的監控或者dooba腳本監控。

python dooba.py -h 127.1 -uroot@sys#obdemo -P2883 -p123456

dooba 進去后,默認是sys租戶。按字母小寫'c',選擇業務租戶。按數字'1'查看幫助,數字'2'查看租戶總覽,數字'3'查看租戶的機器性能信息,按TAB切換當前焦點,按字母小寫'd' 刪除當前TAB,按字母大寫R 恢復所有TAB。總覽里的NET TAB沒有意義可以刪除以節省屏幕空間。

5. 建索引

索引很少,就2條。由于相關表是分區表,可以建全局索引或者本地索引。我們建本地索引。

$cat ./sql.oceanbase/indexCreates.sql create index bmsql_customer_idx1on bmsql_customer (c_w_id, c_d_id, c_last, c_first) local; create index bmsql_oorder_idx1on bmsql_oorder (o_w_id, o_d_id, o_carrier_id, o_id) local;

開始建索引。OceanBase建索引很快就會返回,索引構建是異步的。

./runSQL.sh props.ob ./sql.oceanbase/indexCreates.sql

6. 數據校驗

檢查一下各個表的數據量

obclient> select /*+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_CONFIG; *+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_STOCK;+----------+ | COUNT(*) | +----------+ | 4 | +----------+ 1 row in set (0.06 sec)obclient> select /*+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_WAREHOUSE; +----------+ | COUNT(*) | +----------+ | 10 | +----------+ 1 row in set (0.06 sec) obclient> select /*+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_DISTRICT; +----------+ | COUNT(*) | +----------+ | 100 | +----------+ 1 row in set (0.06 sec)obclient> select /*+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_CUSTOMER; +----------+ | COUNT(*) | +----------+ | 300000 | +----------+ 1 row in set (0.34 sec)obclient> select /*+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_HISTORY; +----------+ | COUNT(*) | +----------+ | 300000 | +----------+ 1 row in set (0.10 sec)obclient> select /*+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_NEW_ORDER; +----------+ | COUNT(*) | +----------+ | 90000 | +----------+ 1 row in set (0.07 sec)obclient> select /*+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_OORDER; +----------+ | COUNT(*) | +----------+ | 300000 | +----------+ 1 row in set (0.11 sec)obclient> select /*+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_ORDER_LINE; +----------+ | COUNT(*) | +----------+ | 3001782 | +----------+ 1 row in set (0.27 sec)obclient> select /*+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_ITEM; +----------+ | COUNT(*) | +----------+ | 100000 | +----------+ 1 row in set (0.08 sec)obclient> select /*+ parallel(16) read_consistency(weak) */ count(*) from TPCC.BMSQL_STOCK; +----------+ | COUNT(*) | +----------+ | 1000000 | +----------+ 1 row in set (0.63 sec)

為了避免產生的數據不符合規范(如中間報錯導致有事務失敗),運行下面校驗腳本

#!/usr/bin/shcc1=" SELECT /*+ no_use_px parallel(8) */ * FROM(SELECT w.w_id, w.w_ytd, d.sum_d_ytdFROM bmsql_warehouse w,(SELECT /*+ no_use_px parallel(8) */ d_w_id, sum(d_ytd) sum_d_ytd FROM bmsql_district GROUP BY d_w_id) dWHERE w.w_id= d.d_w_id ) x WHERE w_ytd != sum_d_ytd; " cc2=" SELECT /*+ no_use_px parallel(8) */ * FROM(SELECT d.d_w_id, d.d_id, d.d_next_o_id, o.max_o_id, no.max_no_o_idFROM bmsql_district d,(SELECT /*+ no_use_px parallel(8) */ o_w_id, o_d_id, MAX(o_id) max_o_id FROM bmsql_oorder GROUP BY o_w_id, o_d_id) o,(SELECT /*+ no_use_px parallel(8) */ no_w_id, no_d_id, MAX(no_o_id) max_no_o_id FROM bmsql_new_order GROUP BY no_w_id, no_d_id) noWHERE d.d_w_id= o.o_w_id AND d.d_w_id= no.no_w_id AND d.d_id= o.o_d_id AND d.d_id= no.no_d_id ) x WHERE d_next_o_id - 1!= max_o_id OR d_next_o_id - 1!= max_no_o_id; "cc3=" SELECT /*+ no_use_px paratLel(8) */ * FROM(SELECT /*+ no_use_px parallel(8) */ no_w_id, no_d_id, MAX(no_o_id) max_no_o_id, MIN(no_o_id) min_no_o_id, COUNT(*) count_noFROM bmsql_new_orderGROUP BY no_w_id, no_d_Id ) x WHERE max_no_o_id - min_no_o_id+ 1!= count_no; "cc4=" SELECT /*+ no_use_px parallel(8) */ * FROM (SELECT o.o_w_id, o.o_d_id, o.sum_o_ol_cnt, ol.count_olFROM (SELECT /*+ no_use_px parallel(8) */ o_w_id, o_d_id, SUM(o_ol_cnt) sum_o_ol_cnt FROM bmsql_oorder GROUP BY o_w_id, o_d_id) o,(SELECT /*+ no_use_px parallel(8) */ ol_w_id, ol_d_id, COUNT(*) count_ol FROM bmsql_order_line GROUP BY ol_w_id, ol_d_id) olWHERE o.o_w_id = ol.ol_w_id AND o.o_d_id = ol.ol_d_id ) x WHERE sum_o_ol_cnt != count_ol; "cc5=" SELECT /*+ no_use_px parallel(8) */ * FROM (SELECT o.o_w_id, o.o_d_id, o.o_id, o.o_carrier_id, no.count_noFROM bmsql_oorder o,(SELECT /*+ no_use_px parallels) */ no_w_id, no_d_id, no_o_id, COUNT(*) count_no FROM bmsql_new_order GROUP BY no_w_id, no_d_id, no_o_id) noWHERE o.o_w_id = no.no_w_id AND o.o_d_id = no.no_d_id AND o.o_id = no.no_o_id ) x WHERE (o_carrier_id IS NULL AND count_no = 0) OR (o_carrier_id IS NOT NULL AND count_no != 0); "cc6=" SELECT /*+ no_use_px parallel(8) */ * FROM (SELECT o.o_w_id, o.o_d_id, o.o_id, o.o_ol_cnt, ol.count_olFROM bmsql_oorder o,(SELECT /*+ no_use_px parallel(8) */ ol_w_id, ol_d_id, ol_o_id, COUNT(*) count_ol FROM bmsql_order_line GROUP BY ol_w_id, ol_d_id, ol_o_id) olWHERE o.o_w_id = ol.ol_w_id AND o.o_d_id = ol.ol_d_id AND o.o_id = ol.ol_o_id ) x WHERE o_ol_cnt != count_ol; " cc7=" SELECT /*+ no_use_px parallel(8) */ * FROM ( SELECT /*+ no_use_px parallel(8) */ * FROM (SELECT o.o_w_id, o.o_d_id, o.o_id, o.o_ol_cnt, ol.count_olFROM bmsql_oorder o,(SELECT /*+ no_use_px parallel(8) */ ol_w_id, ol_d_id, ol_o_id, COUNT(*) count_ol FROM bmsql_order_line GROUP BY ol_w_id, ol_d_id, ol_o_id) olWHERE o.o_w_id = ol.ol_w_id AND o.o_d_id = ol.ol_d_id AND o.o_id = ol.ol_o_id ) x WHERE o_ol_cnt != count_ol; "cc7=" SELECT /*+ no_use_px parallel(8) */ * FROM (SELECT /*+ no_use_px parallel(8) */ ol.ol_w_id, ol.ol_d_id, ol.ol_o_id, ol.ol_delivery_d, o.o_carrier_idFROM bmsql_order_line ol, bmsql_oorder oWHERE ol.ol_w_id = o.o_w_id ANDol.ol_d_id = o.o_d_id ANDol.ol_o_id = o.o_id ) x WHERE (ol_delivery_d IS NULL AND o_carrier_id IS NOT NULL) OR(ol_delivery_d IS NOT NULL AND o_carrier_id IS NULL); "cc8=" SELECT /*+ no_use_px parallel(8) */ * FROM (SELECT w.w_id, w.w_ytd, h.sum_h_amountFROM bmsql_warehouse w,(SELECT /*+ no_use_px parallel(8) */ h_w_id, SUM(h_amount) sum_h_amount FROM bmsql_history GROUP BY h_w_id) hWHERE w.w_id = h.h_w_id) x WHERE w_ytd != sum_h_amount; "cc9=" SELECT /*+ no_use_px parallel(8) */ * FROM (SELECT d.d_w_id, d.d_id, d.d_ytd, h.sum_h_amountFROM bmsql_district d,(SELECT /*+ no_use_px parallel(8) */ h_w_id, h_d_id, SUM(h_amount) sum_h_amount FROM bmsql_history GROUP BY h_w_id, h_d_id) hWHERE d.d_w_id = h.h_w_id AND d.d_id = h.h_d_id ) x WHERE d_ytd != sum_h_amount; "cc_list="$cc1|$cc2|$cc3|$cc4|$cc5|$cc6|$cc7|$cc8|$cc9" oldIFS=$IFS IFS="|"counter=0 for sql in $cc_list dolet counter++echo `date '+%F %X'`" cc$counter start"obclient -Dtpcc -h127.1 -P2883 -utpcc@obbmsql#obdemo -p123456 -A -c -e "$sql"#echo $?if [[ $? -ne 0 ]];thenIFS=$oldIFSecho `date '+%F %X'`" cc$counter failed"exit 1fiecho `date '+%F %X'`" cc$counter finished" done IFS=$oldIFS

BenchmarkSQL TPC-C場景分析

1. E-R模型

2. 場景SQL

TPC-C 系統需要處理的交易有以下五種:場景名場景描述交易占比New-Order客戶輸入一筆新的訂貨交易45%Payment更新客戶賬戶余額以反應其支付狀況43%Delivery發貨(批處理交易)4%Order-Status查詢客戶最近交易的狀態4%Stock-Level查詢倉庫庫存狀況,以便能夠及時補貨。4%場景的比例是在數據庫配置文件中定義的。這里是默認值。對于前四種類型的交易,要求響應時間在 5 秒以內;對于庫存狀況的查詢交易,要求響應時間在 20 秒以內。這五種交易作用在圖 1 所示的九張表上,事務操作類型包括更新,插入,刪除和取消操作。

下面是我事先通過OceanBase的全量SQL審計抓出的TPCC的事務SQL(做過去重,但可能不全)。

1)場景1:New-Order

SELECT d_tax, d_next_o_id FROM bmsql_district WHERE d_w_id = 778 AND d_id = 5 FOR UPDATE; SELECT c_discount, c_last, c_credit, w_tax FROM bmsql_customer JOIN bmsql_warehouse ON (w_id = c_w_id) WHERE c_w_id = 778 AND c_d_id = 5 AND c_id = 2699; UPDATE bmsql_district SET d_next_o_id = d_next_o_id + 1 WHERE d_w_id = 778 AND d_id = 5 ; INSERT INTO bmsql_oorder ( o_id, o_d_id, o_w_id, o_c_id, o_entry_d, o_ol_cnt, o_all_local) VALUES (5686, 5, 778, 2699, timestamp '2020-01-04 13:49:34.137', 8, 1); INSERT INTO bmsql_new_order ( no_o_id, no_d_id, no_w_id) VALUES (5686, 5, 778); SELECT i_price, i_name, i_data FROM bmsql_item WHERE i_id = 7752 ; -- 循環8次 SELECT s_quantity, s_data, s_dist_01, s_dist_02, s_dist_03, s_dist_04, s_dist_05, s_dist_06, s_dist_07, s_dist_08, s_dist_09, s_dist_10 FROM bmsql_stock WHERE s_w_id = 778 AND s_i_id = 7752 FOR UPDATE; -- 循環8次 SHOW VARIABLES WHERE Variable_name = 'tx_read_only'; UPDATE bmsql_stock SET s_quantity = 47, s_ytd = s_ytd + 8, s_order_cnt = s_order_cnt + 1, s_remote_cnt = s_remote_cnt + 0 WHERE s_w_id = 778 AND s_i_id = 7752; -- 循環8次 SHOW VARIABLES WHERE Variable_name = 'tx_read_only'; INSERT INTO bmsql_order_line ( ol_o_id, ol_d_id, ol_w_id, ol_number, ol_i_id, ol_supply_w_id, ol_quantity, ol_amount, ol_dist_info) VALUES (5686, 5, 778, 1, 7752, 778, 8, 589.36, 'lYvcNHkOvt3iNoBb5W29umGO'); -- 循環8次 COMMIT;

2)場景2:New-Order

SELECT c_id FROM bmsql_customer WHERE c_w_id = 778 AND c_d_id = 2 AND c_last = 'PRICALLYPRES' ORDER BY c_first; SELECT c_first, c_middle, c_last, c_balance FROM bmsql_customer WHERE c_w_id = 778 AND c_d_id = 2 AND c_id = 2694; SELECT o_id, o_entry_d, o_carrier_id FROM bmsql_oorder WHERE o_w_id = 778 AND o_d_id = 2 AND o_c_id = 2694 AND o_id = ( SELECT max(o_id) FROM bmsql_oorder WHERE o_w_id = 778 AND o_d_id = 2 AND o_c_id = 2694 ); SELECT ol_i_id, ol_supply_w_id, ol_quantity, ol_amount, ol_delivery_d FROM bmsql_order_line WHERE ol_w_id = 778 AND ol_d_id = 2 AND ol_o_id = 4494 ORDER BY ol_w_id, ol_d_id, ol_o_id, ol_number; ROLLBACK;

3)場景3:Payment

UPDATE bmsql_district SET d_ytd = d_ytd + 4806.11 WHERE d_w_id = 778 AND d_id = 10; SELECT d_name, d_street_1, d_street_2, d_city, d_state, d_zip FROM bmsql_district WHERE d_w_id = 778 AND d_id = 10; UPDATE bmsql_warehouse SET w_ytd = w_ytd + 4806.11 WHERE w_id = 778; SELECT w_name, w_street_1, w_street_2, w_city, w_state, w_zip FROM bmsql_warehouse WHERE w_id = 778 ; SELECT c_id FROM bmsql_customer WHERE c_w_id = 778 AND c_d_id = 10 AND c_last = 'ESEBAROUGHT' ORDER BY c_first; SELECT c_first, c_middle, c_last, c_street_1, c_street_2, c_city, c_state, c_zip, c_phone, c_since, c_credit, c_credit_lim, c_discount, c_balance FROM bmsql_customer WHERE c_w_id = 778 AND c_d_id = 10 AND c_id = 502 FOR UPDATE; UPDATE bmsql_customer SET c_balance = c_balance - 4806.11, c_ytd_payment = c_ytd_payment + 4806.11, c_payment_cnt = c_payment_cnt + 1 WHERE c_w_id = 778 AND c_d_id = 10 AND c_id = 502; INSERT INTO bmsql_history ( h_c_id, h_c_d_id, h_c_w_id, h_d_id, h_w_id, h_date, h_amount, h_data) VALUES (502, 10, 778, 10, 778, timestamp '2020-01-04 13:49:34.148', 4806.11, 'HfYovpM6 b6aJtf2Xk6'); COMMIT;

4)場景4:

SELECT count(*) AS low_stock FROM ( SELECT s_w_id, s_i_id, s_quantity FROM bmsql_stock WHERE s_w_id = 778 AND s_quantity < 10 AND s_i_id IN ( SELECT ol_i_id FROM bmsql_district JOIN bmsql_order_line ON ol_w_id = d_w_id AND ol_d_id = d_id AND ol_o_id >= d_next_o_id - 20 AND ol_o_id < d_next_o_id WHERE d_w_id = 778 AND d_id = 1 ) ); ROLLBACK;

5)場景5:

SELECT no_o_id FROM bmsql_new_order WHERE no_w_id = 778 AND no_d_id = 1 ORDER BY no_o_id ASC; DELETE FROM bmsql_new_order WHERE no_w_id = 778 AND no_d_id = 1 AND no_o_id = 4488; UPDATE bmsql_oorder SET o_carrier_id = 2 WHERE o_w_id = 778 AND o_d_id = 1 AND o_id = 4488; SELECT o_c_id FROM bmsql_oorder WHERE o_w_id = 778 AND o_d_id = 1 AND o_id = 4488; UPDATE bmsql_order_line SET ol_delivery_d = timestamp '2020-01-04 13:49:34.181' WHERE ol_w_id = 778 AND ol_d_id = 1 AND ol_o_id = 4488; SELECT sum(ol_amount) AS sum_ol_amount FROM bmsql_order_line WHERE ol_w_id = 778 AND ol_d_id = 1 AND ol_o_id = 4488; UPDATE bmsql_customer SET c_balance = c_balance + 3733.14, c_delivery_cnt = c_delivery_cnt + 1 WHERE c_w_id = 778 AND c_d_id = 1 AND c_id = 1260; <---循環8次---> commit

注意:可能還有事務SQL沒有找到。

3. TPC-C輸出指標

TPC-C 的測試結果主要有兩個指標:

  • 流量指標(tpmC):描述了系統在執行 Payment,Order-Status,Delivery,Stock-level 這四種交易的同時,每分鐘可以處理的 New-Order交易的數量。流量指標值越大越好。
    tpm 是 transactions per minute 的簡稱;C 指 TPC 中的 C 基準程序。它的定義是每分鐘內系統處理的新訂單個數。要注意的是,在處理新訂單的同時,系統還要按圖 1 的要求處理其 它 4 類事務 請求。從圖 1 可以看出,新訂單請求不可能超出全部事務請求的 45%,因此,當一個系統的性能為 1000tpmC 時,它每分鐘實際處理的請求數是 2000 多個。
  • 性價比(Price/tpmC):測試系統價格與流量指標的比值。性價比越小越好。

運行BenchmarkSQL TPC-C測試

1. OceanBase內存凍結與合并

前面加載了大量數據,OceanBase的增量都在內存中,需要做一次major freeze以釋放增量內存。這個事件分兩步。一是凍結操作,這個很快。二是合并操作,這個跟增量數據量有關,通常要幾分鐘或者幾十分鐘。每次重復測試的時候都建議做一次major freeze事件以釋放內存,弊端就是隨后測試中內存數據訪問又需要一個預熱過程。

1)觀察內存增量使用情況

select tenant_id, ip, round(active/1024/1024) active_mb, round(total/1024/1024) total_mb, round(freeze_trigger/1024/1024) freeze_trg_mb, round(mem_limit/1024/1024) mem_limit_mb, freeze_cnt, round(total/mem_limit,2) total_pct from `gv$memstore` where tenant_id>1001 order by tenant_id;

2)發起內存major freeze事件

ALTER SYSTEM major freeze;

3) 觀察合并進度

觀察合并事件

SELECT DATE_FORMAT(gmt_create, '%b%d %H:%i:%s') gmt_create_ , module, event, name1, value1, name2, value2, rs_svr_ip FROM __all_rootservice_event_history WHERE 1 = 1 AND module IN ('daily_merge') ORDER BY gmt_create DESC LIMIT 100;

觀察合并進度

select ZONE,svr_ip,major_version,ss_store_count ss_sc, merged_ss_store_count merged_ss_sc, modified_ss_store_count modified_ss_sc, date_format(merge_start_time, "%h:%i:%s") merge_st, date_format(merge_finish_time,"%h:%i:%s") merge_ft, merge_process from `__all_virtual_partition_sstable_image_info` s order by major_version, zone, svr_ip ;

2. 跑TPC-C測試

1)運行測試程序

$./runBenchmark.sh props.ob

2)性能監控

注意:這個監控界面重點關注QPS/TPS、以及相應的RT、增量內存的增量和總量占比等。此外還能看出測試過程中還是有不少物理讀IO。

注意:

這個監控界面里的重點看各個節點的QPS和TPS分布,以及遠程SQL的數量占總QPS的比例(SRC/SLC)。TPC-C業務定義會有約1%的遠程倉庫交易事務,在OceanBase里這個交易又有一定概率是分布式事務。

3)TPC-C報告

運行結束后會生成結果。

從圖上看,tpmC結果是48204。這個業務租戶總資源是20C25G*3。倉庫數只有10倉太少了,如果機器好一點,并做10000倉,這個結果應該會更高。

運行同時還生成了一個文件夾

$ll my_result_2020-01-13_175531/ total 16 drwxrwxr-x 2 admin admin 4096 Jan 13 17:55 data -rw-rw-r-- 1 admin admin 5130 Jan 13 18:10 report.html -rwxr-xr-x 1 admin admin 1050 Jan 13 17:55 run.properties

以上就是通過BenchmarkSQL跑TPC-C測試程序的完整過程,感興趣的同學也可以按照上述步驟體驗。有更多反饋歡迎在文章評論區留言。

總結

以上是生活随笔為你收集整理的python3.6.2用pyinstaller3.4报错_OceanBase 2.2 版本体验:用 BenchmarkSQL 跑 TPC-C的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

亚洲视频电影在线 | 国产麻豆精品一区 | 久久国产精品免费视频 | 香蕉视频免费看 | 日韩a级黄色| 久久这里有 | 久久歪歪| 国产91免费在线 | 亚av在线| 亚洲一区 影院 | www.天天色.com | 成人中文字幕+乱码+中文字幕 | 久久夜色精品国产亚洲aⅴ 91chinesexxx | 三上悠亚一区二区在线观看 | 亚洲欧洲精品一区 | 999久久久久久 | 久草青青在线观看 | 高清有码中文字幕 | 免费观看性生活大片3 | 日韩亚洲在线 | 黄色.com| 国产综合片 | 91精品国自产在线偷拍蜜桃 | 手机在线中文字幕 | 丁香5月婷婷久久 | 最新国产一区二区三区 | 日韩一区二区三区免费电影 | 国产精品久久久久久一二三四五 | 久久国产精品色av免费看 | 国产精品成人在线观看 | 久久尤物电影视频在线观看 | 一本一道久久a久久综合蜜桃 | 亚洲激情在线 | 亚洲精品在线观看不卡 | 精品视频在线免费 | 狠狠干综合网 | 久草在线资源观看 | 国内久久久 | 色婷婷欧美| 99热这里是精品 | 欧美色图狠狠干 | 欧美成年网站 | 免费黄色看片 | 免费精品在线 | 久久九九视频 | 国产午夜三级一区二区三 | 亚洲三级影院 | 五月婷婷婷婷婷 | 久久久精品综合 | 349k.cc看片app | 国产精品久久久久一区二区三区 | 国产高清视频免费最新在线 | 国产精品久久久久av福利动漫 | 亚洲成人精品国产 | 美女国产在线 | av成人在线网站 | 国产精品嫩草在线 | 天天操天天色天天 | 亚洲精品在线网站 | 五月婷婷丁香六月 | 黄网站app在线观看免费视频 | 少妇bbb好爽 | 日韩免费在线一区 | 色综合婷婷久久 | 日韩在线观看一区 | 成人av片免费观看app下载 | 欧美日本中文字幕 | 亚洲精品视| 国产成人精品一区二 | www..com毛片| 久久精选 | 欧美日本在线视频 | 91桃色免费观看 | 在线中文字幕av观看 | 国产成人一区二区三区久久精品 | 国产精品久久久久久久久久久久午 | 久久免费视频网站 | 亚洲自拍偷拍色图 | 99精品在线视频观看 | 成人av在线直播 | 欧美色插 | 日本中文字幕在线免费观看 | 狠狠操狠狠干天天操 | 久久免费美女视频 | 在线国产视频一区 | 免费av免费观看 | 国产精品国产三级国产aⅴ入口 | 国内精品免费久久影院 | 97在线观看免费高清完整版在线观看 | 69视频网站| 国产一二三精品 | 亚洲视频在线观看免费 | 免费av在 | 精品久久久久久久 | 久久婷亚洲五月一区天天躁 | 国产精品久久伊人 | 黄色av电影在线观看 | v片在线看| 综合网在线视频 | 亚洲精品一区二区久 | a国产精品 | 在线天堂中文在线资源网 | 国产又粗又猛又爽又黄的视频先 | 97成人免费视频 | 人人干人人超 | 免费在线黄网 | 日韩动漫免费观看高清完整版在线观看 | 欧美视屏一区二区 | 99精品视频免费在线观看 | 日本护士撒尿xxxx18 | 日韩欧美综合在线视频 | 久久成人精品电影 | 久草在线91| 国产a视频免费观看 | 久久精品女人毛片国产 | 91九色porny蝌蚪视频 | 在线观看国产www | 亚洲www天堂com| 国产成人精品av久久 | 欧美一进一出抽搐大尺度视频 | 国产在线观看地址 | 99在线国产 | 久久久麻豆视频 | 99精品免费久久久久久日本 | 免费大片黄在线 | 蜜臀av夜夜澡人人爽人人桃色 | 国产综合香蕉五月婷在线 | 国内精品在线看 | 国模视频一区二区三区 | 一区二区三区观看 | 日韩成人精品一区二区三区 | 天天se天天cao天天干 | 尤物一区二区三区 | 91视频在线 | 国产破处精品 | 日韩精品在线观看av | 国产精品 日韩 | 精品黄色片 | 99精品毛片 | 日韩av在线看 | 久久av免费电影 | 色婷婷伊人 | 国产精品99页 | 国产一级黄色免费看 | 日韩免费视频一区二区 | 在线免费视 | 久久精品—区二区三区 | 天天色综合三 | 成年人免费看 | 精品亚洲va在线va天堂资源站 | 国产成a人亚洲精v品在线观看 | 91亚洲精品国偷拍自产在线观看 | 日韩av快播电影网 | av片免费播放 | 日韩视频在线播放 | 国产美女被啪进深处喷白浆视频 | 精品免费视频. | 美女视频黄免费的久久 | 免费国产一区二区 | 国产精品日韩在线 | 在线精品在线 | 91桃色视频 | 成年人电影免费在线观看 | 国产成人777777 | 亚洲视频456| 西西444www大胆高清视频 | 天天操天天干天天综合网 | 欧美日韩超碰 | 精品亚洲视频在线 | 日韩视频在线观看免费 | 欧美一级片免费在线观看 | 精品网站999www| 超碰97在线看 | 午夜色场| jizz18欧美18 | 日韩免费中文字幕 | 在线视频 成人 | 色婷丁香 | 青青河边草免费观看 | 日本在线视频一区二区三区 | 亚洲欧洲精品久久 | 日韩高清 一区 | 成人黄色电影免费观看 | 日日干天天 | 国产亚洲精品久久久久久久久久 | 国产综合小视频 | 在线免费黄色毛片 | 九九视频在线观看视频6 | 国产女人40精品一区毛片视频 | 成人免费在线播放视频 | 日韩精品免费在线 | 91精品国自产在线观看欧美 | 特级毛片在线观看 | 超级碰碰碰碰 | 午夜精品成人一区二区三区 | 六月丁香六月婷婷 | 国产激情小视频在线观看 | 超碰免费97 | 99精品国产一区二区三区不卡 | 国产拍在线 | 久久久久久久久久影院 | 欧美一级日韩三级 | 在线观看黄色大片 | 精品久久一区二区三区 | www.69xx| 黄网在线免费观看 | www麻豆视频 | 午夜免费在线观看 | 四虎成人免费影院 | 黄色在线观看污 | 成人精品国产 | 免费涩涩网站 | 在线中文字幕av观看 | 日韩中文幕 | 国产一线二线三线在线观看 | 国产一级特黄毛片在线毛片 | 中文字幕在线资源 | 国产一区二区久久久久 | 深夜免费福利在线 | 国产午夜精品久久久久久久久久 | av短片在线 | 亚洲精品美女久久 | 永久免费精品视频网站 | 久久精品国产精品 | 成年人在线观看 | 日韩欧美一区二区三区在线 | 成人av网址大全 | 手机看片中文字幕 | 成 人 黄 色 视频免费播放 | av中文天堂在线 | 国产91精品欧美 | 蜜桃av人人夜夜澡人人爽 | 色悠悠久久综合 | 99热最新精品 | 99精品视频免费 | 国产成人精品国内自产拍免费看 | 国产精品美女视频 | 久久手机在线视频 | 国产中文视 | av电影在线免费观看 | 中文字幕有码在线播放 | 国产精品一区二区久久精品 | 国产精品久久久亚洲 | 精品国产一区二区三区日日嗨 | 国产精品美女久久久免费 | 亚洲成人精品在线 | 亚洲无在线 | 欧美一级性视频 | 久久精品国产免费看久久精品 | 99热最新地址 | 久久99精品久久久久婷婷 | 天天射天天色天天干 | 又黄又爽又刺激视频 | 六月丁香婷婷久久 | 国产一二区视频 | 久久久激情视频 | 久久久久一区二区三区四区 | 久久不射网站 | 欧美一区二区在线刺激视频 | 在线亚洲观看 | 精品91视频| 丁香久久 | 免费看成年人 | 中文字幕乱码电影 | 97香蕉久久国产在线观看 | 在线黄色av | 国产欧美综合在线观看 | 手机av电影在线观看 | 国产精久久久 | 免费在线观看日韩视频 | 亚洲aaa毛片 | 日韩免费一区二区三区 | 狠狠操综合 | 日韩欧美视频在线观看免费 | 久久社区视频 | 亚洲精品在线免费观看视频 | 69av在线播放| 最新国产在线观看 | 欧美中文字幕第一页 | 精品一区二区三区电影 | 欧美一区,二区 | av福利资源| 欧美一区二区三区在线观看 | 日韩av片无码一区二区不卡电影 | 欧美va天堂在线电影 | 欧美日韩aaaa | 成人在线黄色 | 丰满少妇在线观看网站 | 在线观看国产成人av片 | 午夜 在线 | 狠狠夜夜| 国产手机视频在线观看 | 六月激情网 | 国产精品久久久久久久婷婷 | 国产精品日韩在线播放 | 国产精品xxxx18a99 | 欧美日比视频 | 在线视频观看你懂的 | 久草在线免 | 国产成人av电影在线 | 亚洲精品在线观看不卡 | 精品日韩在线一区 | 五月婷婷在线视频 | 中文字幕av免费在线观看 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 亚洲黄色在线免费观看 | 欧美日韩免费观看一区=区三区 | 成人精品视频久久久久 | 91在线免费播放 | 91av在线视频播放 | 免费在线观看av不卡 | 91视频在线国产 | av黄色成人 | 99久久激情视频 | 欧美一区二区三区免费观看 | av电影不卡在线 | 天天天色综合 | 在线观看日韩精品视频 | 日韩精品一区二区三区高清免费 | 91av在线播放视频 | 亚洲精品啊啊啊 | 久久久久久久久福利 | 一本一本久久a久久精品综合小说 | 中文字幕一区二区三区四区视频 | 天天综合狠狠精品 | 亚洲精品福利在线 | 久久精品99 | 天天综合色网 | 91在线看视频免费 | 欧美一区日韩精品 | 91人人爱 | 天天操夜夜拍 | 国产精品久久久久久妇 | 成人精品在线 | 天天操天天操天天操 | 亚洲精品国产精品乱码在线观看 | 在线 精品 国产 | 正在播放五月婷婷狠狠干 | 久久国产99| 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 日韩一区二区三区高清免费看看 | 亚洲 欧美日韩 国产 中文 | 久久夜视频| 国内精品视频一区二区三区八戒 | 天天操天天干天天玩 | 国产精品24小时在线观看 | 久久草网| 日韩精品视频免费专区在线播放 | 97超碰香蕉| 久久蜜臀一区二区三区av | 成年人免费看的视频 | 欧美一级黄色视屏 | www亚洲视频 | 免费日韩视 | 成人91av| 中文字幕一区二区三 | 在线观看亚洲国产 | 深爱婷婷 | 男女免费视频观看 | 国产伦精品一区二区三区免费 | 久久久国产精品久久久 | 日韩欧美国产成人 | 日韩高清www | 久久 地址 | 国产午夜激情视频 | av丁香| 午夜婷婷在线播放 | 天天干天天色2020 | 国产精品video爽爽爽爽 | 日韩免费在线视频 | 日韩美视频 | 国产视频一区在线播放 | www.伊人网| 韩国av免费在线 | 欧美美女激情18p | 免费在线观看午夜视频 | 天天干天天干天天干天天干天天干天天干 | 免费男女羞羞的视频网站中文字幕 | www日日夜夜 | 天天色综合三 | 亚州免费视频 | 在线播放一区二区三区 | 99视频国产精品 | 欧美大码xxxx | 亚洲免费av一区二区 | 免费日韩av片 | 国产正在播放 | 色噜噜在线观看 | 久久精品看片 | 九九视频免费观看视频精品 | 欧美地下肉体性派对 | 国产剧在线观看片 | 欧美在线你懂的 | 狠狠躁18三区二区一区ai明星 | 综合中文字幕 | 在线观看视频中文字幕 | 男女全黄一级一级高潮免费看 | 国产午夜精品久久久久久久久久 | 精品视频久久 | 九九视频精品在线 | 99爱视频在线观看 | 国产成人精品亚洲a | 国产最新视频在线 | 成人蜜桃 | 在线а√天堂中文官网 | 久久久午夜视频 | 涩涩资源网 | 欧美日韩aa | 肉色欧美久久久久久久免费看 | av在线一二三区 | 一区二区精品视频 | 久久久久久久看片 | 在线天堂8√ | 国内精品久久久久久久 | 日韩免费看视频 | 久久avav | 国产伦精品一区二区三区无广告 | 91在线播放综合 | 亚洲精品综合一二三区在线观看 | 国产精品高清免费在线观看 | 97超碰网| 青草视频在线播放 | 97国产一区 | 国产精品久久久久久久久久久免费看 | 国产亚洲婷婷 | 亚洲www天堂com| 亚洲资源网 | 国内精品久久久久久久影视麻豆 | 国产精品久久久久久久免费 | 亚洲激情一区二区三区 | 99理论片| 国产精品video爽爽爽爽 | 久久午夜网 | 欧美最新另类人妖 | 亚洲最快最全在线视频 | 天天色天天操综合 | 在线观看精品黄av片免费 | 国产在线观看a | 国产电影一区二区三区四区 | 成人免费在线观看入口 | 日本中文不卡 | 久久这里只有精品久久 | 欧美视频99 | 亚洲欧美激情插 | 亚洲激情网站免费观看 | 免费av在 | 欧美精品天堂 | 韩国视频一区二区三区 | 在线一二三四区 | 久久久国产精品网站 | 国产精品一区二区免费视频 | 天天做天天爱夜夜爽 | 日韩av电影中文字幕在线观看 | 手机在线视频福利 | 欧美一级欧美一级 | 国产h在线播放 | 91视频在线国产 | 91精品国产综合久久婷婷香蕉 | 国产一区二三区好的 | 日本高清xxxx | 波多野结衣精品 | 在线观看免费一级片 | 免费在线观看av的网站 | 99热精品在线观看 | 亚洲午夜剧场 | 国产精品成人av电影 | 免费黄色av. | 97在线观看 | 免费网站v | 色综合天天综合网国产成人网 | 美女在线观看网站 | 久久99久久99久久 | 欧美精品二区 | 国产手机免费视频 | 国产精品美女久久久久久免费 | 亚洲另类视频在线 | 日韩av在线免费播放 | 四虎永久视频 | 在线观看黄色 | 亚洲国产精品女人久久久 | 成人羞羞免费 | 在线亚洲天堂网 | 精品一区在线 | 久色婷婷 | 国产免费亚洲 | 午夜精品视频免费在线观看 | 亚洲国产日韩精品 | 在线观看国产91 | 欧美性护士 | 久久另类小说 | 粉嫩av一区二区三区四区五区 | 中文字幕在线视频免费播放 | 91丨九色丨国产在线观看 | 日韩欧美视频在线观看免费 | 精品久久久久久电影 | 日韩av免费一区 | 手机在线看a | 一本一本久久a久久精品综合 | 免费久久久久久 | 久久99国产一区二区三区 | 97超视频免费观看 | 亚洲成人资源在线观看 | 久草在线电影网 | a色网站 | 一区二区激情视频 | 蜜臀aⅴ国产精品久久久国产 | 日本深夜福利视频 | 亚洲欧美视频在线播放 | 免费看国产一级片 | 九九电影在线 | 一本—道久久a久久精品蜜桃 | 激情深爱.com | 青草视频在线播放 | 天天色欧美 | 九九热免费视频在线观看 | 热热热热热色 | 国产精品免费高清 | 日韩在线视 | a级片韩国| 日韩视频中文字幕在线观看 | www.久久成人| 天天操福利视频 | 天天操天天干天天综合网 | 成年人黄色免费网站 | 成人免费在线网 | 天天干天天操天天射 | 婷婷六月综合网 | 97超碰在线久草超碰在线观看 | 国产精选在线 | 亚洲日本在线一区 | 国产精品精品国产色婷婷 | 在线视频电影 | 国内精品视频久久 | 一级黄毛片 | 麻豆影视在线免费观看 | 国产成人精品一区二区三区在线 | 天堂黄色片 | 精品你懂的 | 亚洲 欧洲av | 97福利在线 | 在线观看亚洲免费视频 | 欧美久草视频 | 久久国产精品一区二区三区四区 | 丝袜美腿在线视频 | 欧美精品做受xxx性少妇 | 国产精品专区在线观看 | 亚洲精品18p | 91精品久久久久 | 在线电影 一区 | 午夜精品一区二区三区免费视频 | 天天狠狠干 | 最近中文字幕高清字幕免费mv | 亚洲综合成人婷婷小说 | 福利av影院| 国产精品成人av电影 | 97看片吧 | a电影免费看 | 九九热精品视频在线观看 | 射九九 | www.天天射.com| 91色国产| 亚洲国产精品一区二区久久hs | 久久久久97国产 | 天天操,夜夜操 | 欧美婷婷综合 | 国产一级片网站 | 婷婷六月丁 | 91麻豆精品国产91久久久更新时间 | 精品一区二区三区在线播放 | 91亚洲精品久久久久图片蜜桃 | 久久婷婷五月综合色丁香 | 国产 日韩 欧美 中文 在线播放 | 69国产精品视频免费观看 | 一区二区三区四区在线 | 不卡中文字幕在线 | 免费欧美 | 国产在线观看免费观看 | 久久国产精品影片 | 在线免费试看 | 天天碰天天操视频 | 免费视频久久久久久久 | 黄色成年网站 | 亚洲综合国产精品 | 亚洲国产精品一区二区久久hs | 中文字幕在线观看不卡 | 欧美性脚交 | 久久伊人爱 | 免费电影播放 | 精品免费国产一区二区三区四区 | 欧美精品日韩 | 天天干干 | 日韩天天操 | 91av在线不卡| 日韩动漫免费观看高清完整版在线观看 | 2023亚洲精品国偷拍自产在线 | 久草在线在线精品观看 | 成人性生活大片 | 久久男人中文字幕资源站 | 色狠狠操 | 一区二区三区视频在线 | 色婷婷婷 | 青青河边草免费视频 | 久插视频 | 久久人人爽人人爽人人 | 色婷婷av在线 | 日韩欧美一区二区三区视频 | 天天透天天插 | 又黄又爽又刺激 | av电影在线免费观看 | 91成品人影院 | 久久一视频 | 午夜影院一区 | 国产麻豆精品95视频 | 久久精国产 | 人人舔人人舔 | 蜜臀av性久久久久av蜜臀妖精 | 国产97在线视频 | 十八岁以下禁止观看的1000个网站 | 狠狠撸电影| 在线国产一区二区三区 | 欧美精品一区二区在线观看 | 久久人人爽人人片 | 日韩精品一区二区免费视频 | 久久国产精品一国产精品 | 免费视频91蜜桃 | 久久精品艹 | 欧美性超爽 | 国产日韩在线视频 | 欧美在线观看视频一区二区 | 91福利视频免费 | 狠狠88综合久久久久综合网 | 狠狠躁日日躁夜夜躁av | 国产精品婷婷午夜在线观看 | av丝袜在线 | 久草电影网 | 西西444www | 成人在线观看资源 | 国产精品色婷婷视频 | 亚洲精品九九 | 日韩在线不卡视频 | 日韩综合一区二区三区 | 亚洲a资源 | 在线精品一区二区 | 在线日本看片免费人成视久网 | 五月天视频网 | 国产日韩精品一区二区三区在线 | 又污又黄网站 | 91高清在线看 | 成人在线播放视频 | 看全黄大色黄大片 | 久久精品国产v日韩v亚洲 | 日韩精品一区二区三区中文字幕 | 欧美做受xxx | 美女久久99 | 一区二精品 | 久久久久久久久爱 | 久久av观看 | 99精品在线免费视频 | 狠狠色丁香婷婷综合最新地址 | 久久伊人精品天天 | 999视频网| 精品视频在线播放 | 九九欧美视频 | 成人免费网视频 | 99久久久久久久久 | 6699私人影院 | 欧美激情综合色综合啪啪五月 | 国产剧情一区二区 | 欧洲亚洲激情 | 国产精品成人av在线 | 狠狠躁夜夜躁人人爽超碰91 | 日韩精品一区二区三区免费观看视频 | 美女视频一区二区 | 综合久久婷婷 | 久久综合中文字幕 | 免费看黄网站在线 | 九九在线高清精品视频 | 91免费在线视频 | 国产区精品视频 | 夜夜骑天天操 | 欧美成人tv| 国产精品九九久久99视频 | 久久国产品 | 日本丰满少妇免费一区 | 色在线网站 | 麻豆精品视频 | 九色视频网站 | 五月婷婷丁香色 | 黄色av一区二区 | 日韩免费网址 | 久久综合九色综合久久久精品综合 | 国产色爽 | 久久精品视频观看 | 麻花豆传媒mv在线观看 | 国产一区 在线播放 | 亚洲天堂网在线观看视频 | 日韩99热| 欧美在线视频一区二区 | 欧美 日韩 性 | 免费a一级 | 天天干,天天干 | 黄色av网站在线免费观看 | 999电影免费在线观看 | 久久夜夜夜 | 久久色中文字幕 | 色网站在线看 | 97人人添人澡人人爽超碰动图 | www.五月婷婷.com | 国产福利a| 精品国产乱码久久久久久浪潮 | 日韩av在线不卡 | 国产一区黄色 | 又湿又紧又大又爽a视频国产 | 久久免费成人网 | 99热手机在线 | 欧美一级片在线 | 国产又粗又猛又色又黄网站 | 午夜国产在线观看 | 色综合久久88色综合天天 | 欧美一区免费观看 | 欧美日韩国产成人 | 91成人国产 | www最近高清中文国语在线观看 | 久久免费a | 久久嗨 | 亚洲一级二级 | 91精品天码美女少妇 | 国产色拍拍拍拍在线精品 | 国产一区二区在线精品 | 国产黄色大片免费看 | 日韩一区精品 | 99在线免费观看 | 日韩精品1区2区 | 久久久久久久久久电影 | 日本久久综合网 | 国产粉嫩在线观看 | 日韩91在线| 黄色av大片| 成人免费网站视频 | 天天激情综合网 | 中文在线a在线 | 五月综合网 | 碰天天操天天 | 日本丰满少妇免费一区 | 中文字幕日本特黄aa毛片 | 天天躁日日躁狠狠躁av中文 | 丁香六月婷婷开心婷婷网 | 亚洲成av| 国产精品理论视频 | www久久国产 | 欧美夫妻生活视频 | 91在线看视频 | av中文在线观看 | 久久国产精品99久久久久久老狼 | 国产综合91| 成人在线网站观看 | 在线免费视频a | 人人看人人| 男女精品久久 | 在线直播av | 欧美日韩高清在线一区 | 国产精品久久久久一区二区国产 | 免费成人av在线 | 九九热re| 4hu视频| 色视频网址 | 久久高清免费视频 | 99草视频在线观看 | 黄色大片视频网站 | 精品国产伦一区二区三区观看方式 | 蜜臀久久99静品久久久久久 | 91精品国产高清自在线观看 | 欧美一级免费在线 | 亚洲美女久久 | 国产精品专区h在线观看 | 中文字幕免费高清 | 日韩免费一区二区在线观看 | 亚洲另类在线视频 | 九9热这里真品2 | 国产一区二区免费看 | 黄色三级免费片 | 亚洲日b视频 | 精品在线观看视频 | 亚洲精品综合一二三区在线观看 | 国产成人精品久久亚洲高清不卡 | 国产美女在线精品免费观看 | 天天干天天摸 | 婷婷中文字幕在线观看 | 国产麻豆剧传媒免费观看 | av888.com| 成 人 黄 色 视频播放1 | 欧美一区二区精美视频 | 狠狠综合 | 亚洲精品在线网站 | 天天综合成人 | 狠狠色噜噜狠狠狠狠2021天天 | 欧美了一区在线观看 | 午夜91在线 | 国产精品1区2区3区在线观看 | 中文字幕第一页在线播放 | 日本久久综合网 | 九色视频网址 | 99草在线视频 | 在线免费观看亚洲视频 | 91.dizhi永久地址最新 | 97成人啪啪网 | 在线精品在线 | 亚洲色视频 | 日日干网址 | 日日操网站 | av免费福利| 麻豆av一区二区三区在线观看 | 午夜视频一区二区 | 精品夜夜嗨av一区二区三区 | 精品久久久久一区二区国产 | 91精品在线免费视频 | 91精品视频一区 | 精品极品在线 | 免费开视频 | 日本韩国在线不卡 | 成人羞羞视频在线观看免费 | 欧美精品做受xxx性少妇 | 一级性视频 | 国产精品一区二区你懂的 | 色网站视频| 国产一线二线三线在线观看 | 91资源在线| 国产精品美女 | 亚洲国产中文字幕在线观看 | 久久午夜精品 | 99久热在线精品视频 | 精品欧美一区二区三区久久久 | 成年人在线免费看视频 | 精品亚洲一区二区三区 | 夜色资源站wwwcom | 天堂av色婷婷一区二区三区 | 97电影手机版 | 在线精品亚洲一区二区 | 久久久久国产精品免费免费搜索 | 在线三级中文 | 天堂av在线免费观看 | 在线观看视频国产一区 | 亚洲在线视频网站 | a√天堂资源 | 国产一区二区三区高清播放 | 一本一本久久a久久精品综合小说 | 亚洲成人欧美 | 伊人色综合久久天天网 | 亚洲精品中文字幕在线观看 | av观看网站 | 91成人精品一区在线播放 | 亚洲精品视频在线观看网站 | 伊人狠狠色| 在线激情电影 | 西西大胆啪啪 | 91亚洲精品久久久蜜桃 | 在线观看91av | 激情中文字幕 | av手机版 | 在线观看亚洲成人 | 黄色av电影在线 | aa一级片 | 免费三级影片 | 岛国大片免费视频 | 成人在线免费看 | 国产成人久久精品亚洲 | 午夜aaaa| 国产三级久久久 | 欧美性色xo影院 | 婷婷网五月天 | 丁香六月国产 | 久爱精品在线 | 亚洲欧美日韩在线看 | 久久av在线播放 | 在线观看aa| 亚洲区精品| 国产女人免费看a级丨片 | 国产精品久久久久婷婷二区次 | 婷婷久久一区 | 六月色婷婷 | 天堂av在线免费观看 | 亚洲日本精品视频 | av黄在线播放 | 波多野结衣在线观看视频 | 在线日本看片免费人成视久网 | www.亚洲视频.com | 亚洲国产一区二区精品专区 | 亚洲精品成人网 | 欧美色图p | 中文理论片 | 国产五月色婷婷六月丁香视频 | 国产主播99 | 亚洲国产欧美一区二区三区丁香婷 | 精品久久久久久久久久久院品网 | 天天色天天草天天射 | 国产成人一级电影 | 国产男女免费完整视频 | 韩国av免费看 | 国产亚洲精品xxoo | 成人免费在线视频 | 在线中文字幕电影 | 久久免费视频播放 | 国产在线p | 在线精品视频免费播放 | 蜜臀精品久久久久久蜜臀 | 国产精品成久久久久三级 | 午夜精品一区二区三区免费视频 | 日日日操操 | 成人动漫一区二区三区 | 国产人成看黄久久久久久久久 | 日韩免费电影网站 | 日韩激情精品 | 三日本三级少妇三级99 | 激情网站免费观看 | 精品国产一区二区三区av性色 | 黄在线免费观看 | 狠狠色伊人亚洲综合网站色 | 久久精品成人欧美大片古装 | 久久国产精品一区二区三区四区 | 五月婷婷视频在线观看 | 日韩在线免费小视频 | 狠狠干在线 | 在线电影日韩 | 天天综合色网 | 国产日韩精品视频 | av中文字幕网站 | 亚洲免费婷婷 | 国产一二三区在线观看 | av三级在线播放 | 国产中文字幕视频在线观看 | 国产国产人免费人成免费视频 | 91视频免费观看 | 欧美疯狂性受xxxxx另类 | 免费看的视频 | 久久一区二 | 久久免费激情视频 | 国产麻豆果冻传媒在线观看 | 在线观看91 | 一二三精品视频 | 欧美日韩高清一区二区 | 国产视频手机在线 | 亚洲黄色精品 | 欧美激情精品久久 | 日本中文字幕在线看 | 国产精品美女久久久久久久久久久 | 日韩国产精品久久 | 日韩精品一区二区三区水蜜桃 | 久久久九九 | 日韩在线网 | www.av免费观看 | 91麻豆精品国产91久久久久久久久 | 国产高清在线不卡 | 精品国产免费一区二区三区五区 | 国产精品高潮呻吟久久av无 | 国产视频99| 最新影院 | 99久久日韩精品视频免费在线观看 | 国产精品专区在线 | 性色av免费观看 | 五月婷婷导航 | 九色琪琪久久综合网天天 | 亚洲激情在线观看 | av色影院| 亚洲精品久久久蜜臀下载官网 | 99国产精品 | 91九色国产在线 | 欧美日韩xxxxx| 久久久精品国产一区二区 | 啪啪精品| 在线观看黄色小视频 | 我爱av激情网 | 国产美女搞久久 | 久久久午夜电影 | 国产在线播放一区 | 国内视频在线观看 | 激情五月综合 | 91视频久久久久 | 欧美韩国日本在线观看 | 国偷自产中文字幕亚洲手机在线 | 国产亚洲午夜高清国产拍精品 | 高清免费在线视频 | 日韩毛片在线一区二区毛片 | 久久黄色小说视频 | 91九色视频在线 | 国产在线免费观看 | 在线观看国产 | 在线色亚洲 | 国产精品va在线观看入 | aaa日本高清在线播放免费观看 | 色播五月激情综合网 | 日韩中字在线 | av中文天堂在线 | 久久久香蕉视频 | 国产日韩中文字幕在线 | 超碰在线日本 | 成人黄色小说视频 | 超碰免费97 | 激情五月婷婷激情 |