개요
SELECT 쿼리에만 적용되며, 분산
쿼리 처리에서는 제한이 각 서버에 개별적으로 적용됩니다.
ClickHouse는 일반적으로 각 행마다 제한을 확인하지 않고, 데이터 파트가
완전히 처리된 후에만 제한을 확인합니다. 따라서 파트가 처리되는 동안
제한이 위반되는 상황이 발생할 수 있습니다.
overflow_mode 설정
overflow_mode 설정도 있으며, 이 설정은 한도를 초과했을 때
어떻게 동작할지를 정의합니다. 값으로는 다음 두 가지 중 하나를 사용할 수 있습니다:
throw: 예외를 발생시킵니다(기본값).break: 쿼리 실행을 중지하고 부분 결과를 반환합니다. 이는 소스 데이터가 소진된 것처럼 처리합니다.
group_by_overflow_mode 설정
group_by_overflow_mode 설정에는
any 값도 있습니다:
any: 집합에 이미 들어간 키에 대해서는 집계를 계속하지만, 집합에 새 키는 추가하지 않습니다.
설정 목록
“어떤 항목의 최대값”에 대한 제한은
0으로 설정할 수 있으며,
이는 “제한 없음”을 의미합니다.| 설정 | 간단한 설명 |
|---|---|
max_memory_usage | 단일 서버에서 쿼리를 실행할 때 사용할 수 있는 RAM의 최대량입니다. |
max_memory_usage_for_user | 단일 서버에서 사용자의 쿼리를 실행할 때 사용할 수 있는 RAM의 최대량입니다. |
max_rows_to_read | 쿼리를 실행할 때 테이블에서 읽을 수 있는 행 수의 최댓값입니다. |
max_bytes_to_read | 쿼리를 실행할 때 테이블에서 읽을 수 있는 바이트 수(압축되지 않은 데이터 기준)의 최댓값입니다. |
read_overflow_mode_leaf | 읽은 데이터 양이 리프 제한 중 하나를 초과할 때 어떻게 처리할지 설정합니다. |
max_rows_to_read_leaf | 분산 쿼리를 실행할 때 리프 노드의 로컬 테이블에서 읽을 수 있는 행 수의 최댓값입니다. |
max_bytes_to_read_leaf | 분산 쿼리를 실행할 때 리프 노드의 로컬 테이블에서 읽을 수 있는 바이트 수(압축되지 않은 데이터 기준)의 최댓값입니다. |
read_overflow_mode_leaf | 읽은 데이터 양이 리프 제한 중 하나를 초과할 때 어떻게 처리할지 설정합니다. |
max_rows_to_group_by | 집계 결과로 생성되는 고유 키 수의 최댓값입니다. |
group_by_overflow_mode | 집계를 위한 고유 키 수가 제한을 초과할 때 어떻게 처리할지 설정합니다. |
max_bytes_before_external_group_by | 외부 메모리에서 GROUP BY 절을 실행할지 여부를 설정합니다. |
max_bytes_ratio_before_external_group_by | GROUP BY에 사용할 수 있는 가용 메모리 비율입니다. 이 값에 도달하면 집계에 외부 메모리를 사용합니다. |
max_bytes_before_external_sort | 외부 메모리에서 ORDER BY 절을 실행할지 여부를 설정합니다. |
max_bytes_ratio_before_external_sort | ORDER BY에 사용할 수 있는 가용 메모리 비율입니다. 이 값에 도달하면 외부 정렬을 사용합니다. |
max_rows_to_sort | 정렬 전에 허용되는 행 수의 최댓값입니다. 정렬 시 메모리 사용량을 제한할 수 있습니다. |
max_bytes_to_sort | 정렬 전에 허용되는 바이트 수의 최댓값입니다. |
sort_overflow_mode | 정렬 전에 수신한 행 수가 제한 중 하나를 초과할 경우 어떻게 처리할지 설정합니다. |
max_result_rows | 결과의 행 수를 제한합니다. |
max_result_bytes | 결과 크기를 바이트 단위(압축되지 않은 기준)로 제한합니다. |
result_overflow_mode | 결과 크기가 제한 중 하나를 초과할 경우 어떻게 처리할지 설정합니다. |
max_execution_time | 쿼리의 최대 실행 시간(초)입니다. |
timeout_overflow_mode | 쿼리 실행 시간이 max_execution_time을 초과하거나 예상 실행 시간이 max_estimated_execution_time을 초과할 경우 어떻게 처리할지 설정합니다. |
max_execution_time_leaf | 의미상 max_execution_time과 유사하지만 분산 또는 원격 쿼리의 리프 노드에만 적용됩니다. |
timeout_overflow_mode_leaf | 리프 노드에서 쿼리 실행 시간이 max_execution_time_leaf를 초과할 때 어떻게 처리할지 설정합니다. |
min_execution_speed | 초당 행 수 기준의 최소 실행 속도입니다. |
min_execution_speed_bytes | 초당 실행 바이트 수의 최솟값입니다. |
max_execution_speed | 초당 실행 행 수의 최댓값입니다. |
max_execution_speed_bytes | 초당 실행 바이트 수의 최댓값입니다. |
timeout_before_checking_execution_speed | 지정한 시간(초)이 지난 후 실행 속도가 너무 느리지 않은지(min_execution_speed 이상인지) 확인합니다. |
max_estimated_execution_time | 쿼리의 최대 예상 실행 시간(초)입니다. |
max_columns_to_read | 단일 쿼리에서 테이블에서 읽을 수 있는 최대 컬럼 수입니다. |
max_temporary_columns | 상수 컬럼을 포함해, 쿼리 실행 시 동시에 RAM에 유지해야 하는 임시 컬럼의 최대 개수입니다. |
max_temporary_non_const_columns | 쿼리 실행 시 동시에 RAM에 유지해야 하는 임시 컬럼의 최대 개수이며, 상수 컬럼은 제외합니다. |
max_subquery_depth | 쿼리에 지정된 개수를 초과하는 중첩 서브쿼리가 있을 때의 동작을 설정합니다. |
max_ast_depth | 쿼리 구문 트리의 최대 중첩 깊이입니다. |
max_ast_elements | 쿼리 구문 트리의 최대 요소 수입니다. |
max_rows_in_set | 서브쿼리에서 생성된 IN 절의 데이터 집합에 허용되는 최대 행 수입니다. |
max_bytes_in_set | 서브쿼리에서 생성된 IN 절의 집합이 사용하는 최대 바이트 수(비압축 데이터 기준)입니다. |
set_overflow_mode | 데이터 양이 제한값 중 하나를 초과할 때의 동작을 설정합니다. |
max_rows_in_distinct | DISTINCT 사용 시 서로 다른 행의 최대 개수입니다. |
max_bytes_in_distinct | DISTINCT 사용 시 해시 테이블이 사용하는 메모리 내 상태의 최대 바이트 수(비압축 바이트 기준)입니다. |
distinct_overflow_mode | 데이터 양이 제한값 중 하나를 초과할 때의 동작을 설정합니다. |
max_rows_to_transfer | GLOBAL IN/JOIN 절이 실행될 때 원격 서버로 전달하거나 임시 테이블에 저장할 수 있는 최대 크기(행 수 기준)입니다. |
max_bytes_to_transfer | GLOBAL IN/JOIN 절이 실행될 때 원격 서버로 전달하거나 임시 테이블에 저장할 수 있는 최대 바이트 수(비압축 데이터 기준)입니다. |
transfer_overflow_mode | 데이터 양이 제한값 중 하나를 초과할 때의 동작을 설정합니다. |
max_rows_in_join | 테이블 JOIN 시 사용되는 해시 테이블의 최대 행 수를 제한합니다. |
max_bytes_in_join | 테이블 JOIN 시 사용되는 해시 테이블의 최대 크기(바이트 수 기준)입니다. |
join_overflow_mode | 아래 JOIN 제한 중 하나에 도달했을 때 ClickHouse가 수행할 동작을 정의합니다. |
max_partitions_per_insert_block | 단일 삽입 블록의 최대 파티션 수를 제한하며, 블록에 파티션이 너무 많이 포함되면 예외가 발생합니다. |
throw_on_max_partitions_per_insert_block | max_partitions_per_insert_block에 도달했을 때의 동작을 제어할 수 있습니다. |
max_temporary_data_on_disk_size_for_user | 동시에 실행 중인 해당 사용자의 모든 쿼리에서 디스크의 임시 파일이 사용할 수 있는 최대 데이터 양(바이트 기준)입니다. |
max_temporary_data_on_disk_size_for_query | 동시에 실행 중인 모든 쿼리에서 디스크의 임시 파일이 사용할 수 있는 최대 데이터 양(바이트 기준)입니다. |
max_sessions_for_user | 인증된 사용자당 ClickHouse 서버의 최대 동시 세션 수입니다. |
max_partitions_to_read | 단일 쿼리에서 읽을 수 있는 최대 파티션 수를 제한합니다. |
더 이상 사용되지 않는 설정
다음 설정은 더 이상 사용되지 않습니다.