title | summary | toc |
---|---|---|
Run a Sample Workload |
Use cockroach workload to run a load generator against a CockroachDB cluster. |
true |
CockroachDB comes with built-in load generators for simulating different types of client workloads, printing out per-operation statistics every second and totals after a specific duration or max number of operations. To run one of these load generators, use the cockroach workload
command as described below.
{{site.data.alerts.callout_danger}}
The cockroach workload
command is experimental. The interface and output are subject to change.
{{site.data.alerts.end}}
Create the schema for a workload:
$ cockroach workload init <workload> <flags> '<connection string>'
Run a workload:
$ cockroach workload run <workload> <flags> '<connection string>'
View help:
$ cockroach workload --help
$ cockroach workload init --help
$ cockroach workload init <workload> --help
$ cockroach workload run --help
$ cockroach workload run <workload> --help
Command | Usage |
---|---|
init |
Load the schema for the workload. You run this command once for a given schema. |
run |
Run a workload. You can run this command multiple times from different machines to increase concurrency. See Concurrency for more details. |
There are two ways to increase the concurrency of a workload:
- Increase the concurrency of a single workload instance by running
cockroach workload run <workload>
with the--concurrency
flag set to a value higher than the default. - Run multiple instances of a workload in parallel by running
cockroach workload run <workload>
multiple times from different machines.
Workload | Description |
---|---|
bank |
Models a set of accounts with currency balances. For this workload, you run workload init to load the schema and then workload run to generate data. |
intro |
Loads an intro database, with one table, mytable , with a hidden message.For this workload, you run only workload init to load the data. The workload run subcommand is not applicable. |
kv |
Reads and writes to keys spread (by default, uniformly at random) across the cluster. For this workload, you run workload init to load the schema and then workload run to generate data. |
startrek |
Loads a startrek database, with two tables, episodes and quotes .For this workload, you run only workload init to load the data. The workload run subcommand is not applicable. |
tpcc |
Simulates a transaction processing workload using a rich schema of multiple tables. For this workload, you run workload init to load the schema and then workload run to generate data. |
ycsb |
Simulates a high-scale key value workload, either read-heavy, write-heavy, or scan-based, with additional customizations. For this workload, you run workload init to load the schema and then workload run to generate data. |
{{site.data.alerts.callout_info}}
The cockroach workload
command does not support connection or security flags like other cockroach
commands. Instead, you must use a connection string at the end of the command.
{{site.data.alerts.end}}
Flag | Description |
---|---|
--concurrency |
The number of concurrent workers. Applicable commands: init or run Default: 2 * number of CPUs |
--db |
The SQL database to use. Applicable commands: init or run Default: bank |
--drop |
Drop the existing database, if it exists. Applicable commands: init or run . For the run command, this flag must be used in conjunction with --init . |
--duration |
The duration to run, with a required time unit suffix. Valid time units are ns , us , ms , s , m , and h .Applicable commands: init or run Default: 0 , which means run forever. |
--histograms |
The file to write per-op incremental and cumulative histogram data to. Applicable command: run |
--init |
Automatically run the init command.Applicable command: run |
--max-ops |
The maximum number of operations to run. Applicable command: run |
--max-rate |
The maximum frequency of operations (reads/writes). Applicable command: run Default: 0 , which means unlimited. |
--payload-bytes |
The size of the payload field in each initial row. Applicable commands: init or run Default: 100 |
--ramp |
The duration over which to ramp up load. Applicable command: run |
--ranges |
The initial number of ranges in the bank table.Applicable commands: init or run Default: 10 |
--rows |
The initial number of accounts in the bank table.Applicable commands: init or run Default: 1000 |
--seed |
The key hash seed. Applicable commands: init or run Default: 1 |
--tolerate-errors |
Keep running on error. Applicable command: run |
{{site.data.alerts.callout_info}}
These workloads generate data but do not offer the ability to run continuous load. Thus, only the init
subcommand is supported.
{{site.data.alerts.end}}
Flag | Description |
---|---|
--drop |
Drop the existing database, if it exists, before loading the dataset. |
Flag | Description |
---|---|
--batch |
The number of blocks to insert in a single SQL statement. Applicable commands: init or run Default: 1 |
--concurrency |
The number of concurrent workers. Applicable commands: init or run Default: 8 --cycle-length |
--db |
The SQL database to use. Applicable commands: init or run Default: kv |
--drop |
Drop the existing database, if it exists. Applicable commands: init or run |
--duration |
The duration to run, with a required time unit suffix. Valid time units are ns , us , ms , s , m , and h .Applicable command: run Default: 0 , which means run forever. |
--histograms |
The file to write per-op incremental and cumulative histogram data to. Applicable command: run |
--init |
Automatically run the init command.Applicable command: run |
--max-block-bytes |
The maximum amount of raw data written with each insertion. Applicable commands: init or run Default: 2 |
--max-ops |
The maximum number of operations to run. Applicable command: run |
--max-rate |
The maximum frequency of operations (reads/writes). Applicable command: run Default: 0 , which means unlimited. |
--min-block-bytes |
The minimum amount of raw data written with each insertion. Applicable commands: init or run Default: 1 |
--ramp |
The duration over which to ramp up load. Applicable command: run |
--read-percent |
The percent (0-100) of operations that are reads of existing keys. Applicable commands: init or run |
--seed |
The key hash seed. Applicable commands: init or run Default: 1 |
--sequential |
Pick keys sequentially instead of randomly. Applicable commands: init or run |
--splits |
The number of splits to perform before starting normal operations. Applicable commands: init or run |
--tolerate-errors |
Keep running on error. Applicable command: run |
--use-opt |
Use cost-based optimizer. Applicable commands: init or run Default: true |
--write-seq |
Initial write sequence value. Applicable commands: init or run |
Flag | Description |
---|---|
--active-warehouses |
Run the load generator against a specific number of warehouses. Applicable commands: init or run Defaults: Value of --warehouses |
--db |
The SQL database to use. Applicable commands: init or run Default: tpcc |
--drop |
Drop the existing database, if it exists. Applicable commands: init or run . For the run command, this flag must be used in conjunction with --init . |
--duration |
The duration to run, with a required time unit suffix. Valid time units are ns , us , ms , s , m , and h .Applicable command: run Default: 0 , which means run forever. |
--fks |
Add foreign keys. Applicable commands: init or run Default: true |
--histograms |
The file to write per-op incremental and cumulative histogram data to. Applicable command: run |
--init |
Automatically run the init command.Applicable command: run |
--interleaved |
Use interleaved tables. Applicable commands: init or run |
--max-ops |
The maximum number of operations to run. Applicable command: run |
--max-rate |
The maximum frequency of operations (reads/writes). Applicable command: run Default: 0 , which means unlimited. |
--mix |
Weights for the transaction mix. Applicable commands: init or run Default: newOrder=10,payment=10,orderStatus=1,delivery=1,stockLevel=1 , which matches the TPC-C specification. |
--partition-affinity |
Run the load generator against a specific partition. This flag must be used in conjunction with --partitions .Applicable commands: init or run Default: -1 |
--partitions |
Partition tables. This flag must be used in conjunction with --split .Applicable commands: init or run |
--ramp |
The duration over which to ramp up load. Applicable command: run |
--scatter |
Scatter ranges. Applicable commands: init or run |
--seed |
The random number generator seed. Applicable commands: init or run Default: 1 |
--serializable |
Force serializable mode. CockroachDB only supports SERIALIZABLE isolation, so this flag is not necessary.Applicable command: init |
--split |
Split tables. Applicable commands: init or run |
--tolerate-errors |
Keep running on error. Applicable command: run |
--wait |
Run in wait mode, i.e., include think/keying sleeps. Applicable commands: init or run Default: true |
--warehouses |
The number of warehouses for loading initial data, at approximately 200 MB per warehouse. Applicable commands: init or run Default: 1 |
--workers |
The number of concurrent workers. Applicable commands: init or run Default: --warehouses * 10 |
--zones |
The number of replication zones for partitioning. This number should match the number of --partitions and the zones used to start the cluster.Applicable command: init |
Flag | Description |
---|---|
--concurrency |
The number of concurrent workers. Applicable commands: init or run Default: 8 |
--db |
The SQL database to use. Applicable commands: init or run Default: ycsb |
--drop |
Drop the existing database, if it exists. Applicable commands: init or run . For the run command, this flag must be used in conjunction with --init . |
--duration |
The duration to run, with a required time unit suffix. Valid time units are ns , us , ms , s , m , and h .Applicable command: run Default: 0 , which means run forever. |
--families |
Place each column in its own column family. Applicable commands: init or run |
--histograms |
The file to write per-op incremental and cumulative histogram data to. Applicable command: run |
--init |
Automatically run the init command.Applicable command: run |
--initial-rows |
Initial number of rows to sequentially insert before beginning random number generation. Applicable commands: init or run Default: 10000 |
--json |
Use JSONB rather than relational data. Applicable commands: init or run |
--max-ops |
The maximum number of operations to run. Applicable command: run |
--max-rate |
The maximum frequency of operations (reads/writes). Applicable command: run Default: 0 , which means unlimited. |
--method |
The SQL issue method (prepare , noprepare , simple ).Applicable commands: init or run Default: prepare |
--ramp |
The duration over which to ramp up load. Applicable command: run |
--request-distribution |
Distribution for the random number generator (zipfian , uniform ).Applicable commands: init or run .Default: zipfian |
--seed |
The random number generator seed. Applicable commands: init or run Default: 1 |
--splits |
Number of splits to perform before starting normal operations. Applicable commands: init or run |
--tolerate-errors |
Keep running on error. Applicable command: run |
--workload |
The type of workload to run (A , B , C , D , or F ). For details about these workloads, see YCSB Workloads.Applicable commands: init or run Default: B |
By default, the cockroach workload
command logs errors to stderr
.
If you need to troubleshoot this command's behavior, you can change its logging behavior.
These examples assume that you have already started an insecure cluster locally:
{% include copy-clipboard.html %}
$ cockroach start \
--insecure \
--listen-addr=localhost
-
Load the initial schema:
{% include copy-clipboard.html %}
$ cockroach workload init bank \ 'postgresql://root@localhost:26257?sslmode=disable'
-
Run the workload for 1 minute:
{% include copy-clipboard.html %}
$ cockroach workload run bank \ --duration=1m \ 'postgresql://root@localhost:26257?sslmode=disable'
You'll see per-operation statistics print to standard output every second:
_elapsed___errors__ops/sec(inst)___ops/sec(cum)__p50(ms)__p95(ms)__p99(ms)_pMax(ms) 1s 0 1608.6 1702.2 4.5 7.3 12.6 65.0 transfer 2s 0 1725.3 1713.8 4.5 7.9 13.1 19.9 transfer 3s 0 1721.1 1716.2 4.5 7.3 11.5 21.0 transfer 4s 0 1328.7 1619.2 5.5 10.5 17.8 39.8 transfer 5s 0 1389.3 1573.3 5.2 11.5 16.3 23.1 transfer 6s 0 1640.0 1584.4 5.0 7.9 12.1 16.3 transfer 7s 0 1594.0 1585.8 5.0 7.9 10.5 15.7 transfer 8s 0 1652.8 1594.2 4.7 7.9 11.5 29.4 transfer 9s 0 1451.9 1578.4 5.2 10.0 15.2 26.2 transfer 10s 0 1653.3 1585.9 5.0 7.6 10.0 18.9 transfer ...
After the specified duration (1 minute in this case), the workload will stop and you'll see totals printed to standard output:
_elapsed___errors_____ops(total)___ops/sec(cum)__avg(ms)__p50(ms)__p95(ms)__p99(ms)_pMax(ms)__result 60.0s 0 84457 1407.6 5.7 5.5 10.0 15.2 167.8
-
Load the initial schema:
{% include copy-clipboard.html %}
$ cockroach workload init kv \ 'postgresql://root@localhost:26257?sslmode=disable'
-
Run the workload for 1 minute:
{% include copy-clipboard.html %}
$ cockroach workload run kv \ --duration=1m \ 'postgresql://root@localhost:26257?sslmode=disable'
You'll see per-operation statistics print to standard output every second:
_elapsed___errors__ops/sec(inst)___ops/sec(cum)__p50(ms)__p95(ms)__p99(ms)_pMax(ms) 1s 0 5095.8 5123.7 1.5 2.5 3.3 7.3 write 2s 0 4795.4 4959.6 1.6 2.8 3.5 8.9 write 3s 0 3456.5 4458.5 2.0 4.5 7.3 24.1 write 4s 0 2787.9 4040.8 2.4 6.3 12.6 30.4 write 5s 0 3558.7 3944.4 2.0 4.2 6.8 11.5 write 6s 0 3733.8 3909.3 1.9 4.2 6.0 12.6 write 7s 0 3565.6 3860.1 2.0 4.7 7.9 25.2 write 8s 0 3469.3 3811.4 2.0 5.0 6.8 22.0 write 9s 0 3937.6 3825.4 1.8 3.7 7.3 29.4 write 10s 0 3822.9 3825.1 1.8 4.7 8.9 37.7 write ...
After the specified duration (1 minute in this case), the workload will stop and you'll see totals printed to standard output:
_elapsed___errors_____ops(total)___ops/sec(cum)__avg(ms)__p50(ms)__p95(ms)__p99(ms)_pMax(ms)__result 60.0s 0 276067 4601.0 1.7 1.6 3.1 5.2 96.5
-
Load the dataset:
{% include copy-clipboard.html %}
$ cockroach workload init intro \ 'postgresql://root@localhost:26257?sslmode=disable'
-
Launch the built-in SQL client to view it:
{% include copy-clipboard.html %}
$ cockroach sql --insecure
{% include copy-clipboard.html %}
> SHOW TABLES FROM intro;
table_name +------------+ mytable (1 row)
{% include copy-clipboard.html %}
$ SELECT * FROM intro.mytable WHERE (l % 2) = 0;
l | v +----+------------------------------------------------------+ 0 | !__aaawwmqmqmwwwaas,,_ .__aaawwwmqmqmwwaaa,, 2 | !"VT?!"""^~~^"""??T$Wmqaa,_auqmWBT?!"""^~~^^""??YV^ 4 | ! "?##mW##?"- 6 | ! C O N G R A T S _am#Z??A#ma, Y 8 | ! _ummY" "9#ma, A 10 | ! vm#Z( )Xmms Y 12 | ! .j####mmm#####mm#m##6. 14 | ! W O W ! jmm###mm######m#mmm##6 16 | ! ]#me*Xm#m#mm##m#m##SX##c 18 | ! dm#||+*$##m#mm#m#Svvn##m 20 | ! :mmE=|+||S##m##m#1nvnnX##; A 22 | ! :m#h+|+++=Xmm#m#1nvnnvdmm; M 24 | ! Y $#m>+|+|||##m#1nvnnnnmm# A 26 | ! O ]##z+|+|+|3#mEnnnnvnd##f Z 28 | ! U D 4##c|+|+|]m#kvnvnno##P E 30 | ! I 4#ma+|++]mmhvnnvq##P` ! 32 | ! D I ?$#q%+|dmmmvnnm##! 34 | ! T -4##wu#mm#pw##7' 36 | ! -?$##m####Y' 38 | ! !! "Y##Y"- 40 | ! (21 rows)
-
Load the dataset:
{% include copy-clipboard.html %}
$ cockroach workload init startrek \ 'postgresql://root@localhost:26257?sslmode=disable'
-
Launch the built-in SQL client to view it:
{% include copy-clipboard.html %}
$ cockroach sql --insecure
{% include copy-clipboard.html %}
> SHOW TABLES FROM startrek;
table_name +------------+ episodes quotes (2 rows)
{% include copy-clipboard.html %}
> SELECT * FROM startrek.episodes WHERE stardate > 5500;
id | season | num | title | stardate +----+--------+-----+-----------------------------------+----------+ 60 | 3 | 5 | Is There in Truth No Beauty? | 5630.7 62 | 3 | 7 | Day of the Dove | 5630.3 64 | 3 | 9 | The Tholian Web | 5693.2 65 | 3 | 10 | Plato's Stepchildren | 5784.2 66 | 3 | 11 | Wink of an Eye | 5710.5 69 | 3 | 14 | Whom Gods Destroy | 5718.3 70 | 3 | 15 | Let That Be Your Last Battlefield | 5730.2 73 | 3 | 18 | The Lights of Zetar | 5725.3 74 | 3 | 19 | Requiem for Methuselah | 5843.7 75 | 3 | 20 | The Way to Eden | 5832.3 76 | 3 | 21 | The Cloud Minders | 5818.4 77 | 3 | 22 | The Savage Curtain | 5906.4 78 | 3 | 23 | All Our Yesterdays | 5943.7 79 | 3 | 24 | Turnabout Intruder | 5928.5 (14 rows)
-
Load the initial schema and data:
{% include copy-clipboard.html %}
$ cockroach workload init tpcc \ 'postgresql://root@localhost:26257?sslmode=disable'
-
Run the workload for 10 minutes:
{% include copy-clipboard.html %}
$ cockroach workload run tpcc \ --duration=10m \ 'postgresql://root@localhost:26257?sslmode=disable'
You'll see per-operation statistics print to standard output every second:
_elapsed___errors__ops/sec(inst)___ops/sec(cum)__p50(ms)__p95(ms)__p99(ms)_pMax(ms) 1s 0 1443.4 1494.8 4.7 9.4 27.3 67.1 transfer 2s 0 1686.5 1590.9 4.7 8.1 15.2 28.3 transfer 3s 0 1735.7 1639.0 4.7 7.3 11.5 28.3 transfer 4s 0 1542.6 1614.9 5.0 8.9 12.1 21.0 transfer 5s 0 1695.9 1631.1 4.7 7.3 11.5 22.0 transfer 6s 0 1569.2 1620.8 5.0 8.4 11.5 15.7 transfer 7s 0 1614.6 1619.9 4.7 8.1 12.1 16.8 transfer 8s 0 1344.4 1585.6 5.8 10.0 15.2 31.5 transfer 9s 0 1351.9 1559.5 5.8 10.0 16.8 54.5 transfer 10s 0 1514.8 1555.0 5.2 8.1 12.1 16.8 transfer ...
After the specified duration (10 minutes in this case), the workload will stop and you'll see totals printed to standard output:
_elapsed___errors_____ops(total)___ops/sec(cum)__avg(ms)__p50(ms)__p95(ms)__p99(ms)_pMax(ms)__result 600.0s 0 823902 1373.2 5.8 5.5 10.0 15.2 209.7
-
Load the initial schema and data:
{% include copy-clipboard.html %}
$ cockroach workload init ycsb \ 'postgresql://root@localhost:26257?sslmode=disable'
-
Run the workload for 10 minutes:
{% include copy-clipboard.html %}
$ cockroach workload run ycsb \ --duration=10m \ 'postgresql://root@localhost:26257?sslmode=disable'
You'll see per-operation statistics print to standard output every second:
_elapsed___errors__ops/sec(inst)___ops/sec(cum)__p50(ms)__p95(ms)__p99(ms)_pMax(ms) 1s 0 9258.1 9666.6 0.7 1.3 2.0 8.9 read 1s 0 470.1 490.9 1.7 2.9 4.1 5.0 update 2s 0 10244.6 9955.6 0.7 1.2 2.0 6.6 read 2s 0 559.0 525.0 1.6 3.1 6.0 7.3 update 3s 0 9870.8 9927.4 0.7 1.4 2.4 10.0 read 3s 0 500.0 516.6 1.6 4.2 7.9 15.2 update 4s 0 9847.2 9907.3 0.7 1.4 2.4 23.1 read 4s 0 506.8 514.2 1.6 3.7 7.6 17.8 update 5s 0 10084.4 9942.6 0.7 1.3 2.1 7.1 read 5s 0 537.2 518.8 1.5 3.5 10.0 15.2 update ...
After the specified duration (10 minutes in this case), the workload will stop and you'll see totals printed to standard output:
_elapsed___errors_____ops(total)___ops/sec(cum)__avg(ms)__p50(ms)__p95(ms)__p99(ms)_pMax(ms)__result 600.0s 0 4728286 7880.2 1.0 0.9 2.2 5.2 268.4