본문으로 바로가기
본문으로 바로가기

실행 파일 딕셔너리 소스

실행 파일을 사용하는 방식은 딕셔너리가 메모리에 저장되는 방법에 따라 달라집니다. 딕셔너리가 cachecomplex_key_cache를 사용해 저장되는 경우 ClickHouse는 실행 파일의 STDIN으로 요청을 전송해 필요한 키를 조회합니다. 그렇지 않은 경우 ClickHouse는 실행 파일을 시작하고 그 출력을 딕셔너리 데이터로 처리합니다.

설정 예시:

SOURCE(EXECUTABLE(
    command 'cat /opt/dictionaries/os.tsv'
    format 'TabSeparated'
    implicit_key false
))

설정 필드:

SettingDescription
command실행 파일의 절대 경로이거나, (명령의 디렉터리가 PATH에 있는 경우) 파일 이름입니다.
format파일 형식입니다. Formats에 설명된 모든 형식을 지원합니다.
command_termination_timeout실행 스크립트에는 기본 읽기/쓰기 루프가 포함되어야 합니다. 딕셔너리가 파괴된 후 파이프가 닫히며, 실행 파일은 ClickHouse가 자식 프로세스에 SIGTERM 신호를 보내기 전에 종료할 수 있도록 command_termination_timeout 초가 주어집니다. 초 단위로 지정합니다. 기본값은 10입니다. 선택 사항입니다.
command_read_timeout명령 stdout에서 데이터를 읽는 타임아웃(밀리초)입니다. 기본값은 10000입니다. 선택 사항입니다.
command_write_timeout명령 stdin에 데이터를 쓰는 타임아웃(밀리초)입니다. 기본값은 10000입니다. 선택 사항입니다.
implicit_key실행 소스 파일은 값만 반환할 수 있으며, 요청된 키와의 대응은 결과의 행 순서에 따라 암묵적으로 결정됩니다. 기본값은 false입니다.
execute_directexecute_direct = 1인 경우 commanduser_scripts_path에 지정된 user_scripts 폴더 내에서 검색됩니다. 공백 구분자를 사용해 추가 스크립트 인자를 지정할 수 있습니다. 예: script_name arg1 arg2. execute_direct = 0인 경우 commandbin/sh -c의 인자로 전달됩니다. 기본값은 0입니다. 선택 사항입니다.
send_chunk_header프로세스로 데이터 청크를 전송하기 전에, 먼저 해당 청크의 행 수를 보낼지 여부를 제어합니다. 기본값은 false입니다. 선택 사항입니다.

이 딕셔너리 소스는 XML 설정을 통해서만 구성할 수 있습니다. DDL을 통해 실행 가능한 소스를 사용하는 딕셔너리를 생성하는 기능은 비활성화되어 있으며, 그렇지 않으면 DB 사용자가 ClickHouse 노드에서 임의의 바이너리를 실행할 수 있게 되기 때문입니다.