Modifying options to db_stress when it is run with db_crashtest
Summary: These extra options caught some bugs. Will be run via Jenkins now with the crash_test Test Plan: ./make crashtest Reviewers: dhruba, vamsi Reviewed By: dhruba CC: leveldb Differential Revision: https://reviews.facebook.net/D11151
This commit is contained in:
parent
3bb9449906
commit
7a6bd8e975
@ -2,7 +2,7 @@
|
|||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
import time
|
import time
|
||||||
import shlex
|
import random
|
||||||
import getopt
|
import getopt
|
||||||
import logging
|
import logging
|
||||||
import tempfile
|
import tempfile
|
||||||
@ -27,7 +27,7 @@ def main(argv):
|
|||||||
duration = 6000 # total time for this script to test db_stress
|
duration = 6000 # total time for this script to test db_stress
|
||||||
threads = 32
|
threads = 32
|
||||||
# since we will be killing anyway, use large value for ops_per_thread
|
# since we will be killing anyway, use large value for ops_per_thread
|
||||||
ops_per_thread = 10000000
|
ops_per_thread = 100000000
|
||||||
write_buf_size = 4 * 1024 * 1024
|
write_buf_size = 4 * 1024 * 1024
|
||||||
|
|
||||||
for opt, arg in opts:
|
for opt, arg in opts:
|
||||||
@ -64,6 +64,22 @@ def main(argv):
|
|||||||
|
|
||||||
while time.time() < exit_time:
|
while time.time() < exit_time:
|
||||||
run_had_errors = False
|
run_had_errors = False
|
||||||
|
additional_opts = ' --disable_seek_compaction=' + \
|
||||||
|
str(random.randint(0, 1)) + \
|
||||||
|
' --mmap_read=' + str(random.randint(0, 1)) + \
|
||||||
|
' --block_size=16384 ' + \
|
||||||
|
' --cache_size=1048576 ' + \
|
||||||
|
' --open_files=500000 ' + \
|
||||||
|
' --verify_checksum=1 ' + \
|
||||||
|
' --sync=' + str(random.randint(0, 1)) + \
|
||||||
|
' --disable_wal=0 ' + \
|
||||||
|
' --disable_data_sync=' + \
|
||||||
|
str(random.randint(0, 1)) + \
|
||||||
|
' --target_file_size_base=2097152 ' + \
|
||||||
|
' --target_file_size_multiplier=2 ' + \
|
||||||
|
' --max_write_buffer_number=3 ' + \
|
||||||
|
' --max_background_compactions=20 ' + \
|
||||||
|
' --max_bytes_for_level_base=10485760'
|
||||||
killtime = time.time() + interval
|
killtime = time.time() + interval
|
||||||
child = subprocess.Popen(['./db_stress \
|
child = subprocess.Popen(['./db_stress \
|
||||||
--test_batches_snapshots=1 \
|
--test_batches_snapshots=1 \
|
||||||
@ -74,8 +90,10 @@ def main(argv):
|
|||||||
--reopen=0 \
|
--reopen=0 \
|
||||||
--readpercent=50 \
|
--readpercent=50 \
|
||||||
--db=' + dirpath + '\
|
--db=' + dirpath + '\
|
||||||
--max_key=1000'], stderr=subprocess.PIPE, shell=True)
|
--max_key=100000000 ' + additional_opts],
|
||||||
print("Running db_stress with pid=%d\n" % child.pid)
|
stderr=subprocess.PIPE, shell=True)
|
||||||
|
print("Running db_stress with pid=%d and additional options=\n"
|
||||||
|
% child.pid + additional_opts + "\n")
|
||||||
time.sleep(interval)
|
time.sleep(interval)
|
||||||
while True:
|
while True:
|
||||||
if time.time() > killtime:
|
if time.time() > killtime:
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
import time
|
import time
|
||||||
import shlex
|
import random
|
||||||
import getopt
|
import getopt
|
||||||
import logging
|
import logging
|
||||||
import tempfile
|
import tempfile
|
||||||
@ -69,7 +69,24 @@ def main(argv):
|
|||||||
|
|
||||||
while time.time() < exit_time:
|
while time.time() < exit_time:
|
||||||
run_had_errors = False
|
run_had_errors = False
|
||||||
print "Running db_stress \n"
|
additional_opts = ' --disable_seek_compaction=' + \
|
||||||
|
str(random.randint(0, 1)) + \
|
||||||
|
' --mmap_read=' + str(random.randint(0, 1)) + \
|
||||||
|
' --block_size=16384 ' + \
|
||||||
|
' --cache_size=1048576 ' + \
|
||||||
|
' --open_files=500000 ' + \
|
||||||
|
' --verify_checksum=1 ' + \
|
||||||
|
' --sync=' + str(random.randint(0, 1)) + \
|
||||||
|
' --disable_wal=0 ' + \
|
||||||
|
' --disable_data_sync=' + \
|
||||||
|
str(random.randint(0, 1)) + \
|
||||||
|
' --target_file_size_base=2097152 ' + \
|
||||||
|
' --target_file_size_multiplier=2 ' + \
|
||||||
|
' --max_write_buffer_number=3 ' + \
|
||||||
|
' --max_background_compactions=20 ' + \
|
||||||
|
' --max_bytes_for_level_base=10485760'
|
||||||
|
print ("Running db_stress with additional options=\n"
|
||||||
|
+ additional_opts + "\n")
|
||||||
|
|
||||||
if toggle:
|
if toggle:
|
||||||
# since we are going to kill anyway, use more ops per thread
|
# since we are going to kill anyway, use more ops per thread
|
||||||
@ -90,7 +107,7 @@ def main(argv):
|
|||||||
--reopen=0 \
|
--reopen=0 \
|
||||||
--readpercent=50 \
|
--readpercent=50 \
|
||||||
--db=' + dirpath + ' \
|
--db=' + dirpath + ' \
|
||||||
--max_key=10000']
|
--max_key=100000000 ' + additional_opts]
|
||||||
|
|
||||||
popen = subprocess.Popen(cmd, stdout=subprocess.PIPE,
|
popen = subprocess.Popen(cmd, stdout=subprocess.PIPE,
|
||||||
stderr=subprocess.STDOUT,
|
stderr=subprocess.STDOUT,
|
||||||
|
Loading…
Reference in New Issue
Block a user