2020-11-27 15:46:52 +00:00
#!/usr/bin/env bash
2022-03-18 16:30:05 +00:00
# Tags: no-parallel, no-fasttest
2020-11-27 15:46:52 +00:00
CURDIR = $( cd " $( dirname " ${ BASH_SOURCE [0] } " ) " && pwd )
2020-12-28 11:46:53 +00:00
# shellcheck source=../shell_config.sh
2020-11-27 15:46:52 +00:00
. " $CURDIR " /../shell_config.sh
2022-11-10 12:14:04 +00:00
$CLICKHOUSE_CLIENT --query "DROP TABLE IF EXISTS concurrent_mutate_kill SYNC"
2020-11-27 15:46:52 +00:00
2021-03-15 04:51:28 +00:00
$CLICKHOUSE_CLIENT --query " CREATE TABLE concurrent_mutate_kill (key UInt64, value String) ENGINE = ReplicatedMergeTree('/clickhouse/tables/ $CLICKHOUSE_TEST_ZOOKEEPER_PREFIX /concurrent_mutate_kill', '1') ORDER BY key PARTITION BY key % 100 SETTINGS max_replicated_mutations_in_queue=1000, number_of_free_entries_in_pool_to_execute_mutation=0,max_replicated_merges_in_queue=1000 "
2020-11-27 15:46:52 +00:00
2022-11-10 12:14:04 +00:00
$CLICKHOUSE_CLIENT --insert_keeper_fault_injection_probability= 0 --query "INSERT INTO concurrent_mutate_kill SELECT number, toString(number) FROM numbers(1000000)"
2020-11-27 15:46:52 +00:00
function alter_thread
{
2022-05-28 17:20:32 +00:00
while true; do
TYPE = $( $CLICKHOUSE_CLIENT --query " SELECT type FROM system.columns WHERE table='concurrent_mutate_kill' and database=' ${ CLICKHOUSE_DATABASE } ' and name='value' " )
if [ " $TYPE " = = "String" ] ; then
$CLICKHOUSE_CLIENT --query "ALTER TABLE concurrent_mutate_kill MODIFY COLUMN value UInt64 SETTINGS replication_alter_partitions_sync=2"
else
$CLICKHOUSE_CLIENT --query "ALTER TABLE concurrent_mutate_kill MODIFY COLUMN value String SETTINGS replication_alter_partitions_sync=2"
fi
done
2020-11-27 15:46:52 +00:00
}
function kill_mutation_thread
{
2022-05-28 17:20:32 +00:00
while true; do
# find any mutation and kill it
mutation_id = $( $CLICKHOUSE_CLIENT --query " SELECT mutation_id FROM system.mutations WHERE is_done=0 and database=' ${ CLICKHOUSE_DATABASE } ' and table='concurrent_mutate_kill' LIMIT 1 " )
if [ ! -z " $mutation_id " ] ; then
$CLICKHOUSE_CLIENT --query " KILL MUTATION WHERE mutation_id=' $mutation_id ' and table='concurrent_mutate_kill' and database=' ${ CLICKHOUSE_DATABASE } ' " 1> /dev/null
sleep 1
fi
done
2020-11-27 15:46:52 +00:00
}
2022-05-28 17:20:32 +00:00
export -f alter_thread;
export -f kill_mutation_thread;
2020-11-27 15:46:52 +00:00
TIMEOUT = 30
2022-05-28 17:20:32 +00:00
timeout $TIMEOUT bash -c alter_thread 2> /dev/null &
timeout $TIMEOUT bash -c kill_mutation_thread 2> /dev/null &
2020-11-27 15:46:52 +00:00
wait
$CLICKHOUSE_CLIENT --query "SYSTEM SYNC REPLICA concurrent_mutate_kill"
2020-12-28 11:46:22 +00:00
# with timeout alter query can be not finished yet, so to execute new alter
# we use retries
counter = 0
while true; do
if $CLICKHOUSE_CLIENT --query "ALTER TABLE concurrent_mutate_kill MODIFY COLUMN value Int64 SETTINGS replication_alter_partitions_sync=2" 2> /dev/null ; then
break
fi
if [ " $counter " -gt 120 ]
then
break
fi
sleep 0.5
counter = $(( $counter + 1 ))
done
2020-11-27 15:46:52 +00:00
$CLICKHOUSE_CLIENT --query "SHOW CREATE TABLE concurrent_mutate_kill"
$CLICKHOUSE_CLIENT --query "OPTIMIZE TABLE concurrent_mutate_kill FINAL"
$CLICKHOUSE_CLIENT --query "SELECT sum(value) FROM concurrent_mutate_kill"
2022-11-10 12:14:04 +00:00
$CLICKHOUSE_CLIENT --query "DROP TABLE IF EXISTS concurrent_mutate_kill SYNC"