mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-25 09:02:00 +00:00
3e627e2861
The following new provile events had been added: - FileSync - Number of times the F_FULLFSYNC/fsync/fdatasync function was called for files. - DirectorySync - Number of times the F_FULLFSYNC/fsync/fdatasync function was called for directories. - FileSyncElapsedMicroseconds - Total time spent waiting for F_FULLFSYNC/fsync/fdatasync syscall for files. - DirectorySyncElapsedMicroseconds - Total time spent waiting for F_FULLFSYNC/fsync/fdatasync syscall for directories. v2: rewrite test to sh with retries Signed-off-by: Azat Khuzhin <a.khuzhin@semrush.com>
74 lines
1.9 KiB
Bash
Executable File
74 lines
1.9 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# Tags: no-s3-storage
|
|
# Tag no-s3-storage: s3 does not have fsync
|
|
|
|
CUR_DIR=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
|
|
# shellcheck source=../shell_config.sh
|
|
. "$CUR_DIR"/../shell_config.sh
|
|
|
|
$CLICKHOUSE_CLIENT -nm -q "
|
|
drop table if exists data_fsync_pe;
|
|
|
|
create table data_fsync_pe (key Int) engine=MergeTree()
|
|
order by key
|
|
settings
|
|
min_rows_for_wide_part=2,
|
|
fsync_after_insert=1,
|
|
fsync_part_directory=1;
|
|
"
|
|
|
|
ret=1
|
|
# Retry in case of fsync/fdatasync was too fast
|
|
# (FileSyncElapsedMicroseconds/DirectorySyncElapsedMicroseconds was 0)
|
|
for i in {1..100}; do
|
|
query_id="insert-$i-$CLICKHOUSE_DATABASE"
|
|
|
|
$CLICKHOUSE_CLIENT --query_id "$query_id" -q "insert into data_fsync_pe values (1)"
|
|
|
|
read -r FileSync FileOpen DirectorySync FileSyncElapsedMicroseconds DirectorySyncElapsedMicroseconds <<<"$(
|
|
$CLICKHOUSE_CLIENT -nm --param_query_id "$query_id" -q "
|
|
system flush logs;
|
|
|
|
select
|
|
ProfileEvents['FileSync'],
|
|
ProfileEvents['FileOpen'],
|
|
ProfileEvents['DirectorySync'],
|
|
ProfileEvents['FileSyncElapsedMicroseconds']>0,
|
|
ProfileEvents['DirectorySyncElapsedMicroseconds']>0
|
|
from system.query_log
|
|
where
|
|
event_date >= yesterday() and
|
|
current_database = currentDatabase() and
|
|
query_id = {query_id:String} and
|
|
type = 'QueryFinish';
|
|
")"
|
|
|
|
# Non retriable errors
|
|
if [[ $FileSync -ne 7 ]]; then
|
|
exit 2
|
|
fi
|
|
# Check that all files was synced
|
|
if [[ $FileSync -ne $FileOpen ]]; then
|
|
exit 3
|
|
fi
|
|
if [[ $DirectorySync -ne 2 ]]; then
|
|
exit 4
|
|
fi
|
|
|
|
# Retriable errors
|
|
if [[ $FileSyncElapsedMicroseconds -eq 0 ]]; then
|
|
continue
|
|
fi
|
|
if [[ $DirectorySyncElapsedMicroseconds -eq 0 ]]; then
|
|
continue
|
|
fi
|
|
|
|
# Everything is OK
|
|
ret=0
|
|
break
|
|
done
|
|
|
|
$CLICKHOUSE_CLIENT -q "drop table data_fsync_pe"
|
|
|
|
exit $ret
|