PDiskWriteLoad
Tests the performance of writes to the PDisk. The load is generated on behalf of a VDisk. The actor creates chunks on the specified PDisk and writes random data to them. After the load stops, the data written by the actor is deleted.
You can generate two types of load:
- Continuous: The actor ensures the specified number of requests are run concurrently. To generate a continuous load, set a zero interval between requests, e.g.,
IntervalMsMin: 0
andIntervalMsMax: 0
, while keeping theInFlightWrites
parameter different from zero. - Interval: The actor runs requests at preset intervals. To generate interval load, set a non-zero interval between requests, e.g.,
IntervalMsMin: 10
andIntervalMsMax: 100
. You can set the maximum number of in-flight requests using theInFlightWrites
parameter. If its value is0
, their number is unlimited.
Actor parameters
The basic actor parameters are described below. For the full list of parameters, see the load_test.proto file in the YDB Git repository.
Parameter | Description |
---|---|
PDiskId |
ID of the Pdisk being loaded on the node. |
PDiskGuid |
Globally unique ID of the PDisk being loaded. |
VDiskId |
The load is generated on behalf of a VDisk with the following parameters:
|
Chunks |
Chunk parameters.Slots : Number of slots per chunk, determines the write size.You can specify multiple Chunks , in which case a specific chunk to write data to is selected based on its Weight . |
DurationSeconds |
Load duration in seconds. |
IntervalMsMin ,IntervalMsMax |
Minimum and maximum intervals between requests under interval load, in milliseconds. The interval value is selected randomly from the specified range. |
InFlightWrites |
Number of simultaneously processed write requests. |
LogMode |
Logging mode. In LOG_SEQUENTIAL mode, data is first written to a chunk and then, once the write is committed, to a log. |
Sequential |
Type of writes.
|
IsWardenlessTest |
Set it to False in case the PDiskReadLoad actor is run on the cluster; otherwise, e.g. when it is run during unit tests, set it to True . |
Examples
The following actor writes data blocks of 32
MB during 120
seconds with 64
in-flight requests (continuous load):
PDiskWriteLoad: {
PDiskId: 1000
PDiskGuid: 2258451612736857634
VDiskId: {
GroupID: 11234
GroupGeneration: 5
Ring: 1
Domain: 1
VDisk: 3
}
Chunks: { Slots: 4096 Weight: 1 }
Chunks: { Slots: 4096 Weight: 1 }
Chunks: { Slots: 4096 Weight: 1 }
Chunks: { Slots: 4096 Weight: 1 }
Chunks: { Slots: 4096 Weight: 1 }
Chunks: { Slots: 4096 Weight: 1 }
Chunks: { Slots: 4096 Weight: 1 }
Chunks: { Slots: 4096 Weight: 1 }
DurationSeconds: 120
IntervalMsMin: 0
IntervalMsMax: 0
InFlightWrites: 64
LogMode: LOG_SEQUENTIAL
Sequential: false
IsWardenlessTest: false
}
When viewing test results, the following value should be of most interest to you:
Average speed since start
: Average write speed since start, in MB/s, e.g.,615.484013
.