Skip to main content

database trace-command

[์—ฐ๊ฒฐ] ์ถ”์ ๋œ ๋นŒ๋“œ์˜ ์ผ๋ถ€๋กœ ๋‹จ์ผ ๋ช…๋ น์„ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค.

๋ˆ„๊ฐ€ ์ด ๊ธฐ๋Šฅ์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‚˜์š”?

CodeQL์€(๋Š”) ๋‹ค์Œ ๋ฆฌํฌ์ง€ํ† ๋ฆฌ ์œ ํ˜•์— ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

  • GitHub Code Security๋ฅผ ์ง€์›ํ•˜๋Š” ์กฐ์ง ์†Œ์œ  ๋ฆฌํฌ์ง€ํ† ๋ฆฌ

์ด ๋ฌธ์„œ์˜ ๋‚ด์šฉ

์ฐธ๊ณ  ํ•ญ๋ชฉ

์ด ์ฝ˜ํ…์ธ ๋Š” CodeQL CLI์˜ ์ตœ์‹  ๋ฆด๋ฆฌ์Šค์— ๋Œ€ํ•ด ์„ค๋ช…ํ•ฉ๋‹ˆ๋‹ค. ์ด ์š”์†Œ์— ๋Œ€ํ•œ ์ž์„ธํ•œ ๋‚ด์šฉ์€ https://github.com/github/codeql-cli-binaries/releases์„(๋ฅผ) ์ฐธ์กฐํ•˜์„ธ์š”.

์ด์ „ ๋ฆด๋ฆฌ์Šค์—์„œ ์ด ๋ช…๋ น์— ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋Š” ์˜ต์…˜์˜ ์„ธ๋ถ€ ์ •๋ณด๋ฅผ ๋ณด๋ ค๋ฉด ํ„ฐ๋ฏธ๋„์—์„œ ์˜ต์…˜์„ ์‚ฌ์šฉํ•˜์—ฌ --help ๋ช…๋ น์„ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค.

๊ฐœ์š”

Shell
codeql database trace-command [--threads=<num>] [--ram=<MB>] [--extractor-option=<extractor-option-name=value>] <options>... -- <database> <command>...

์„ค๋ช…

[์—ฐ๊ฒฐ] ์ถ”์ ๋œ ๋นŒ๋“œ์˜ ์ผ๋ถ€๋กœ ๋‹จ์ผ ๋ช…๋ น์„ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค.

์ด๋ ‡๊ฒŒ ํ•˜๋ฉด ์ถ”์ ๊ธฐ์—์„œ ์ง€์ •๋œ ๋‹จ์ผ ๋ช…๋ น์ค„์„ ์‹คํ–‰ํ•˜๋ฏ€๋กœ ์ผ๋ถ€ ์ถ”์ถœ์„ ์ˆ˜ํ–‰ํ•  ์ˆ˜ ์žˆ์ง€๋งŒ ๊ฒฐ๊ณผ๋กœ ๋‚˜ํƒ€๋‚œ CodeQL ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๋Š” ์™„๋ฃŒ๋˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค.

์˜ต์…˜

๊ธฐ๋ณธ ์˜ต์…˜

<database>

[ํ•„์ˆ˜] ์ƒ์„ฑ ์ค‘์ธ CodeQL ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค์˜ ๊ฒฝ๋กœ์ž…๋‹ˆ๋‹ค. codeql ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค init์„ ์‚ฌ์šฉํ•˜์—ฌ ์ถ”์ถœํ•  ์ค€๋น„๊ฐ€ ๋˜์–ด ์žˆ์–ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

--db-cluster ์˜ต์…˜์ด ์ง€์ •๋œ ๊ฒฝ์šฐ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ์ž์ฒด๊ฐ€ ์•„๋‹ˆ๋ผ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๋ฅผ _ํฌํ•จ_ํ•˜๋Š” ๋””๋ ‰ํ„ฐ๋ฆฌ์ด๋ฉฐ ์ด๋Ÿฌํ•œ ๋ชจ๋“  ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๊ฐ€ ํ•จ๊ป˜ ์ฒ˜๋ฆฌ๋ฉ๋‹ˆ๋‹ค.

<command>...

์‹คํ–‰ํ•  ๋ช…๋ น์ž…๋‹ˆ๋‹ค. ํ”„๋กœ์„ธ์Šค๋ฅผ ๋งŒ๋“œ๋Š” ๋ฐ ์‚ฌ์šฉ๋˜๋Š” ํ•˜๋‚˜ ์ด์ƒ์˜ ์ธ์ˆ˜๋กœ ๊ตฌ์„ฑ๋ฉ๋‹ˆ๋‹ค. ์ธ์ˆ˜์™€ ์ธ์ˆ˜ ๊ฐ„์˜ ํ˜ผ๋™์„ ๋ฐฉ์ง€ํ•˜๊ธฐ ์œ„ํ•ด ๋ช…๋ น ์ธ์ˆ˜๋ฅผ ๋‚˜์—ดํ•˜๊ธฐ ์ „์— '--' ์ธ์ˆ˜๋ฅผ ์ „๋‹ฌํ•˜๋Š” ๊ฒƒ์ด ์ข‹์Šต๋‹ˆ๋‹ค.

์ด ๋ช…๋ น์€ ์ƒํƒœ ์ฝ”๋“œ 0์œผ๋กœ ์ข…๋ฃŒ๋˜์–ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. ๋‹ค๋ฅธ ๋ชจ๋“  ์ข…๋ฃŒ ์ฝ”๋“œ๋Š” ์˜ค๋ฅ˜๋กœ ํ•ด์„๋ฉ๋‹ˆ๋‹ค.

--index-traceless-dbs๊ฐ€ ์ง€์ •๋œ ๊ฒฝ์šฐ ๋ช…๋ น์„ ์ƒ๋žตํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

-j, --threads=<num>

์ถ”์ถœ๊ธฐ์—์„œ ํ•ด๋‹น ์Šค๋ ˆ๋“œ ์ˆ˜๋ฅผ ์‚ฌ์šฉํ•˜๋„๋ก ์š”์ฒญํ•ฉ๋‹ˆ๋‹ค. ์ด ์˜ต์…˜์€ ์ œ์•ˆ์œผ๋กœ์จ ์ถ”์ถœ๊ธฐ๋กœ ์ „๋‹ฌ๋ฉ๋‹ˆ๋‹ค. CODEQL_THREADS ํ™˜๊ฒฝ ๋ณ€์ˆ˜๊ฐ€ ์„ค์ •๋˜๋ฉด ํ™˜๊ฒฝ ๋ณ€์ˆ˜ ๊ฐ’์ด ์ด ์˜ต์…˜๋ณด๋‹ค ์šฐ์„ ํ•ฉ๋‹ˆ๋‹ค.

0์„ ์ „๋‹ฌํ•˜์—ฌ ์ปดํ“จํ„ฐ์˜ ์ฝ”์–ด๋‹น ํ•˜๋‚˜์˜ ์Šค๋ ˆ๋“œ๋ฅผ ์‚ฌ์šฉํ•˜๊ฑฐ๋‚˜ -_N_์„ ์ „๋‹ฌํ•˜์—ฌ _N_๊ฐœ์˜ ์ฝ”์–ด๋ฅผ ์‚ฌ์šฉํ•˜์ง€ ์•Š์€ ์ƒํƒœ๋กœ ๋‘˜ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค(ํ•˜๋‚˜ ์ด์ƒ์˜ ์Šค๋ ˆ๋“œ๋ฅผ ๊ณ„์† ์‚ฌ์šฉํ•˜๋Š” ๊ฒฝ์šฐ ์ œ์™ธ).

-M, --ram=<MB>

์ถ”์ถœ๊ธฐ์—์„œ ํ•ด๋‹น ๋ฉ”๋ชจ๋ฆฌ๋ฅผ ์‚ฌ์šฉํ•˜๋„๋ก ์š”์ฒญํ•ฉ๋‹ˆ๋‹ค. ์ด ์˜ต์…˜์€ ์ œ์•ˆ์œผ๋กœ์จ ์ถ”์ถœ๊ธฐ๋กœ ์ „๋‹ฌ๋ฉ๋‹ˆ๋‹ค. CODEQL_RAM ํ™˜๊ฒฝ ๋ณ€์ˆ˜๊ฐ€ ์„ค์ •๋˜๋ฉด ํ™˜๊ฒฝ ๋ณ€์ˆ˜ ๊ฐ’์ด ์ด ์˜ต์…˜๋ณด๋‹ค ์šฐ์„ ํ•ฉ๋‹ˆ๋‹ค.

--[no-]db-cluster

๋ช…๋ น์ค„์— ์ง€์ •๋œ ๋””๋ ‰ํ„ฐ๋ฆฌ๊ฐ€ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ์ž์ฒด๊ฐ€ ์•„๋‹ˆ๋ผ ์ƒ์„ฑ ์ค‘์ธ ํ•˜๋‚˜ ์ด์ƒ์˜ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๋ฅผ _ํฌํ•จ_ํ•˜๋Š” ๋””๋ ‰ํ„ฐ๋ฆฌ์ž„์„ ๋‚˜ํƒ€๋ƒ…๋‹ˆ๋‹ค. ์ด๋Ÿฌํ•œ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๋Š” ํ•จ๊ป˜ ์ฒ˜๋ฆฌ๋ฉ๋‹ˆ๋‹ค.

--no-tracing

[๊ณ ๊ธ‰] ์ง€์ •๋œ ๋ช…๋ น์„ ์ถ”์ ํ•˜์ง€ ์•Š๊ณ  ๋ช…๋ น์— ์˜์กดํ•˜์—ฌ ํ•„์š”ํ•œ ๋ชจ๋“  ๋ฐ์ดํ„ฐ๋ฅผ ์ง์ ‘ ์ƒ์„ฑํ•ฉ๋‹ˆ๋‹ค.

--extra-tracing-config=<tracing-config.lua>

[๊ณ ๊ธ‰] ์ถ”์ ๊ธฐ ๊ตฌ์„ฑ ํŒŒ์ผ์˜ ๊ฒฝ๋กœ์ž…๋‹ˆ๋‹ค. ๋นŒ๋“œ ์ถ”์ ๊ธฐ์˜ ๋™์ž‘์„ ์ˆ˜์ •ํ•˜๋Š” ๋ฐ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ๋นŒ๋“œ ๋ช…๋ น์˜ ์ผ๋ถ€๋กœ ์‹คํ–‰๋˜๋Š” ์ปดํŒŒ์ผ๋Ÿฌ ํ”„๋กœ์„ธ์Šค๋ฅผ ์„ ํƒํ•˜๊ณ  ๋‹ค๋ฅธ ๋„๊ตฌ์˜ ์‹คํ–‰์„ ํŠธ๋ฆฌ๊ฑฐํ•˜๋Š” ๋ฐ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์ถ”์ถœ๊ธฐ๋Š” ๋Œ€๋ถ€๋ถ„์˜ ์ƒํ™ฉ์—์„œ ์ž‘๋™ํ•ด์•ผ ํ•˜๋Š” ๊ธฐ๋ณธ ์ถ”์ ๊ธฐ ๊ตฌ์„ฑ ํŒŒ์ผ์„ ์ œ๊ณตํ•ฉ๋‹ˆ๋‹ค.

--[no-]index-traceless-dbs

์ง€์ •๋œ ๋ช…๋ น ์™ธ์—๋„ ๋นŒ๋“œ ํ”„๋กœ์„ธ์Šค ์ถ”์ ์— ์˜์กดํ•˜์ง€ ์•Š๋Š” ์ถ”์ถœ๊ธฐ์— ๋Œ€ํ•ด ๊ธฐ๋ณธ ์Šคํฌ๋ฆฝํŠธ๋ฅผ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค. --db-cluster๋กœ ์—ฌ๋Ÿฌ ์–ธ์–ด์— ๋Œ€ํ•œ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๋ฅผ ์ƒ์„ฑํ•˜๋Š” ๊ฒฝ์šฐ ์ด ์˜ต์…˜์€ codeql database trace-command์„ ์ •ํ™•ํžˆ ํ•œ ๋ฒˆ ํ˜ธ์ถœํ•  ๋•Œ ์ง€์ •ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

--[no-]use-build-mode

๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค์˜ ๋นŒ๋“œ ๋ชจ๋“œ์— ๋”ฐ๋ผ ๋ฌด์—‡์„ ์‹คํ–‰ํ• ์ง€ ๊ฒฐ์ •ํ•ฉ๋‹ˆ๋‹ค. ์ด ์˜ต์…˜์€ --index-traceless-dbs๊ณผ(์™€) ํ•จ๊ป˜ ์‚ฌ์šฉํ•  ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค.

--working-dir=<dir>

[๊ณ ๊ธ‰] ์ง€์ •๋œ ๋ช…๋ น์„ ์‹คํ–‰ํ•ด์•ผ ํ•˜๋Š” ๋””๋ ‰ํ„ฐ๋ฆฌ์ž…๋‹ˆ๋‹ค. ์ด ์ธ์ˆ˜๊ฐ€ ์ œ๊ณต๋˜์ง€ ์•Š์œผ๋ฉด ๋ช…๋ น์ด codeql ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ๋งŒ๋“ค๊ธฐ์— ์ „๋‹ฌ๋œ --source-root ๊ฐ’(์žˆ๋Š” ๊ฒฝ์šฐ)์œผ๋กœ ์‹คํ–‰๋ฉ๋‹ˆ๋‹ค. --source-root ์ธ์ˆ˜๊ฐ€ ์ œ๊ณต๋˜์ง€ ์•Š์œผ๋ฉด ๋ช…๋ น์ด ํ˜„์žฌ ์ž‘์—… ๋””๋ ‰ํ„ฐ๋ฆฌ์—์„œ ์‹คํ–‰๋ฉ๋‹ˆ๋‹ค.

--no-run-unnecessary-builds

[๊ณ ๊ธ‰] ์ƒ์„ฑ ์ค‘์ธ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๊ฐ€ ๋นŒ๋“œ ํ”„๋กœ์„ธ์Šค ์ถ”์ ์— ์˜์กดํ•˜๋Š” ์ถ”์ถœ๊ธฐ๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ๊ฒฝ์šฐ์—๋งŒ ์ง€์ •๋œ ๋นŒ๋“œ ๋ช…๋ น์„ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค. ์ด ์˜ต์…˜์„ ์ง€์ •ํ•˜์ง€ ์•Š์œผ๋ฉด ๋‹ค๋ฅธ ์ด์œ ๋กœ ์ธํ•ด ๋ถ€์ž‘์šฉ์ด ํ•„์š”ํ•˜๋‹ค๋Š” ๊ฐ€์ • ํ•˜์— CodeQL์ด ํ•„์š”ํ•˜์ง€ ์•Š์€ ๊ฒฝ์šฐ์—๋„ ๋ช…๋ น์ด ์‹คํ–‰๋ฉ๋‹ˆ๋‹ค.

์ถ”์ถœ๊ธฐ ๋™์ž‘ ์ œ์–ด ์˜ต์…˜

-O, --extractor-option=<extractor-option-name=value>

CodeQL ์ถ”์ถœ๊ธฐ์— ๋Œ€ํ•œ ์˜ต์…˜์„ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค. extractor-option-name์€(๋Š”) extractor_name.group1.group2.option_name ๋˜๋Š” group1.group2.option_name์˜ ํ˜•์‹์ด์–ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. extractor_option_name์ด(๊ฐ€) ์ถ”์ถœ๊ธฐ ์ด๋ฆ„์œผ๋กœ ์‹œ์ž‘ํ•˜๋Š” ๊ฒฝ์šฐ, ํ‘œ์‹œ๋œ ์ถ”์ถœ๊ธฐ๋Š” group1.group2.option_name ์˜ต์…˜์„ ์„ ์–ธํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. ๊ทธ๋ ‡์ง€ ์•Š์œผ๋ฉด ์˜ต์…˜ group1.group2.option_name์„ ์„ ์–ธํ•˜๋Š” ๋ชจ๋“  ์ถ”์ถœ๊ธฐ์—์„œ ์˜ต์…˜์„ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค. value์€(๋Š”) ์ค„์„ ํฌํ•จํ•˜์ง€ ์•Š๋Š” ๋ชจ๋“  ๋ฌธ์ž์—ด์ผ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

์ด ๋ช…๋ น์ค„ ์˜ต์…˜์„ ๋ฐ˜๋ณต์ ์œผ๋กœ ์‚ฌ์šฉํ•˜์—ฌ ์—ฌ๋Ÿฌ ์ถ”์ถœ๊ธฐ ์˜ต์…˜์„ ์„ค์ •ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ๋™์ผํ•œ ์ถ”์ถœ๊ธฐ ์˜ต์…˜์— ์—ฌ๋Ÿฌ ๊ฐ’์„ ์ œ๊ณตํ•˜๋Š” ๊ฒฝ์šฐ, ๋™์ž‘์€ ์ถ”์ถœ๊ธฐ ์˜ต์…˜์ด ์˜ˆ์ƒํ•˜๋Š” ํ˜•์‹์— ๋”ฐ๋ผ ๋‹ฌ๋ผ์ง‘๋‹ˆ๋‹ค. ๋ฌธ์ž์—ด ์˜ต์…˜์€ ์ œ๊ณต๋œ ๋งˆ์ง€๋ง‰ ๊ฐ’์„ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. ๋ฐฐ์—ด ์˜ต์…˜์€ ์ œ๊ณต๋œ ๋ชจ๋“  ๊ฐ’์„ ์ˆœ์„œ๋Œ€๋กœ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. ์ด ๋ช…๋ น์ค„ ์˜ต์…˜์„ ์‚ฌ์šฉํ•˜์—ฌ ์ง€์ •๋œ ์ถ”์ถœ๊ธฐ ์˜ต์…˜์€ ์ถ”์ถœ๊ธฐ ์˜ต์…˜์„ ํ†ตํ•ด --extractor-options-file์ด(๊ฐ€) ์ œ๊ณต๋œ ํ›„์— ์ฒ˜๋ฆฌ๋ฉ๋‹ˆ๋‹ค.

codeql ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค init ๋˜๋Š” codeql database begin-tracing์— ์ „๋‹ฌ๋˜๋ฉด ์˜ต์…˜์ด ๊ฐ„์ ‘ ์ถ”์  ํ™˜๊ฒฝ์—๋งŒ ์ ์šฉ๋ฉ๋‹ˆ๋‹ค. ์›Œํฌํ”Œ๋กœ์—์„œ codeql ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ์ถ”์  ๋ช…๋ น์„ ํ˜ธ์ถœํ•˜๋Š” ๊ฒฝ์šฐ, ์›ํ•˜๋Š” ๊ฒฝ์šฐ์˜ ์˜ต์…˜๋„ ์ „๋‹ฌํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

๊ฐ ์ถ”์ถœ๊ธฐ์—์„œ ์„ ์–ธํ•œ ์˜ต์…˜์„ ๋‚˜์—ดํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ํฌํ•จํ•˜์—ฌ CodeQL ์ถ”์ถœ๊ธฐ ์˜ต์…˜์— ๋Œ€ํ•œ ์ž์„ธํ•œ ๋‚ด์šฉ์€ https://codeql.github.com/docs/codeql-cli/extractor-options์„(๋ฅผ) ์ฐธ์กฐํ•˜์„ธ์š”.

--extractor-options-file=<extractor-options-bundle-file>

์ถ”์ถœ๊ธฐ ์˜ต์…˜ ๋ฒˆ๋“ค ํŒŒ์ผ์„ ์ง€์ •ํ•ฉ๋‹ˆ๋‹ค. ์ถ”์ถœ๊ธฐ ์˜ต์…˜ ๋ฒˆ๋“ค ํŒŒ์ผ์€ ์ถ”์ถœ๊ธฐ ์˜ต์…˜์„ ์„ค์ •ํ•˜๋Š” JSON ํŒŒ์ผ(ํ™•์žฅ๋ช… .json) ๋˜๋Š” YAML ํŒŒ์ผ(ํ™•์žฅ๋ช… .yaml ๋˜๋Š” .yml)์ž…๋‹ˆ๋‹ค. ํŒŒ์ผ์—๋Š” ์ตœ์ƒ์œ„ ๋งต ํ‚ค 'extractor'๊ฐ€ ์žˆ์–ด์•ผ ํ•˜๋ฉฐ, ๊ทธ ์•„๋ž˜์—๋Š” ์ถ”์ถœ๊ธฐ ์ด๋ฆ„์ด ๋‘ ๋ฒˆ์งธ ์ˆ˜์ค€ ๋งต ํ‚ค๋กœ ์ง€์ •๋˜์–ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. ์ง€๋„์˜ ์ถ”๊ฐ€ ์ˆ˜์ค€์€ ์ค‘์ฒฉ๋œ ์ถ”์ถœ๊ธฐ ๊ทธ๋ฃน์„ ๋‚˜ํƒ€๋‚ด๋ฉฐ ๋ฌธ์ž์—ด ๋ฐ ๋ฐฐ์—ด ์˜ต์…˜์€ ๋ฌธ์ž์—ด ๋ฐ ๋ฐฐ์—ด ๊ฐ’์ด ์žˆ๋Š” ์ง€๋„ ํ•ญ๋ชฉ์ž…๋‹ˆ๋‹ค.

์ถ”์ถœ๊ธฐ ์˜ต์…˜ ๋ฒˆ๋“ค ํŒŒ์ผ์€ ์ง€์ •๋œ ์ˆœ์„œ๋Œ€๋กœ ์ฝ์Šต๋‹ˆ๋‹ค. ๋‹ค๋ฅธ ์ถ”์ถœ๊ธฐ ์˜ต์…˜ ๋ฒˆ๋“ค ํŒŒ์ผ์—์„œ ๋™์ผํ•œ ์ถ”์ถœ๊ธฐ ์˜ต์…˜์„ ์ง€์ •ํ•˜๋Š” ๊ฒฝ์šฐ, ๋™์ž‘์€ ์ถ”์ถœ๊ธฐ ์˜ต์…˜์ด ์˜ˆ์ƒํ•˜๋Š” ํ˜•์‹์— ๋”ฐ๋ผ ๋‹ฌ๋ผ์ง‘๋‹ˆ๋‹ค. ๋ฌธ์ž์—ด ์˜ต์…˜์€ ์ œ๊ณต๋œ ๋งˆ์ง€๋ง‰ ๊ฐ’์„ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. ๋ฐฐ์—ด ์˜ต์…˜์€ ์ œ๊ณต๋œ ๋ชจ๋“  ๊ฐ’์„ ์ˆœ์„œ๋Œ€๋กœ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. ์ด ๋ช…๋ น์ค„ ์˜ต์…˜์„ ์‚ฌ์šฉํ•˜์—ฌ ์ง€์ •๋œ ์ถ”์ถœ๊ธฐ ์˜ต์…˜์€ ์ถ”์ถœ๊ธฐ ์˜ต์…˜์„ ํ†ตํ•ด --extractor-option์ด(๊ฐ€) ์ œ๊ณต๋˜๊ธฐ ์ „์— ์ฒ˜๋ฆฌ๋ฉ๋‹ˆ๋‹ค.

codeql ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค init ๋˜๋Š” codeql database begin-tracing์— ์ „๋‹ฌ๋˜๋ฉด ์˜ต์…˜์ด ๊ฐ„์ ‘ ์ถ”์  ํ™˜๊ฒฝ์—๋งŒ ์ ์šฉ๋ฉ๋‹ˆ๋‹ค. ์›Œํฌํ”Œ๋กœ์—์„œ codeql ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ์ถ”์  ๋ช…๋ น์„ ํ˜ธ์ถœํ•˜๋Š” ๊ฒฝ์šฐ, ์›ํ•˜๋Š” ๊ฒฝ์šฐ์˜ ์˜ต์…˜๋„ ์ „๋‹ฌํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

๊ฐ ์ถ”์ถœ๊ธฐ์—์„œ ์„ ์–ธํ•œ ์˜ต์…˜์„ ๋‚˜์—ดํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ํฌํ•จํ•˜์—ฌ CodeQL ์ถ”์ถœ๊ธฐ ์˜ต์…˜์— ๋Œ€ํ•œ ์ž์„ธํ•œ ๋‚ด์šฉ์€ https://codeql.github.com/docs/codeql-cli/extractor-options์„(๋ฅผ) ์ฐธ์กฐํ•˜์„ธ์š”.

์ผ๋ฐ˜ ์˜ต์…˜

-h, --help

์ด ๋„์›€๋ง ํ…์ŠคํŠธ๋ฅผ ํ‘œ์‹œํ•ฉ๋‹ˆ๋‹ค.

-J=<opt>

[๊ณ ๊ธ‰] ๋ช…๋ น์„ ์‹คํ–‰ํ•˜๋Š” JVM์— ์˜ต์…˜์„ ์ง€์ •ํ•ฉ๋‹ˆ๋‹ค.

(๊ณต๋ฐฑ์„ ํฌํ•จํ•˜๋Š” ์˜ต์…˜์€ ์˜ฌ๋ฐ”๋ฅด๊ฒŒ ์ฒ˜๋ฆฌ๋˜์ง€ ์•Š์„ ์ˆ˜ ์žˆ์œผ๋‹ˆ ์ฃผ์˜ํ•˜์„ธ์š”.)

-v, --verbose

์ถœ๋ ฅ๋˜๋Š” ์ง„ํ–‰๋ฅ  ๋ฉ”์‹œ์ง€ ์ˆ˜๋ฅผ ์ ์ง„์ ์œผ๋กœ ๋Š˜๋ฆฝ๋‹ˆ๋‹ค.

-q, --quiet

์ถœ๋ ฅ๋˜๋Š” ์ง„ํ–‰๋ฅ  ๋ฉ”์‹œ์ง€ ์ˆ˜๋ฅผ ์ ์ง„์ ์œผ๋กœ ์ค„์ž…๋‹ˆ๋‹ค.

--verbosity=<level>

[๊ณ ๊ธ‰] ์„ธ๋ถ€ ์ •๋ณด ํ‘œ์‹œ ์ˆ˜์ค€์„ ์˜ค๋ฅ˜, ๊ฒฝ๊ณ , ์ง„ํ–‰๋ฅ , ์ง„ํ–‰๋ฅ +, ์ง„ํ–‰๋ฅ ++, ์ง„ํ–‰๋ฅ +++ ์ค‘ ํ•˜๋‚˜๋กœ ๋ช…์‹œ์ ์œผ๋กœ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค. -v ๋ฐ -q๋ฅผ ์žฌ์ •์˜ํ•ฉ๋‹ˆ๋‹ค.

--logdir=<dir>

[๊ณ ๊ธ‰] ํƒ€์ž„์Šคํƒฌํ”„์™€ ์‹คํ–‰ ์ค‘์ธ ํ•˜์œ„ ๋ช…๋ น์˜ ์ด๋ฆ„์„ ํฌํ•จํ•˜๋Š” ์ƒ์„ฑ๋œ ์ด๋ฆ„์„ ์‚ฌ์šฉํ•˜์—ฌ ์ง€์ •๋œ ๋””๋ ‰ํ„ฐ๋ฆฌ์— ์žˆ๋Š” ํ•˜๋‚˜ ์ด์ƒ์˜ ํŒŒ์ผ์— ์ž์„ธํ•œ ๋กœ๊ทธ๋ฅผ ๊ธฐ๋กํ•ฉ๋‹ˆ๋‹ค.

(๋ชจ๋“  ๊ถŒํ•œ์„ ๊ฐ€์ง„ ์ด๋ฆ„์œผ๋กœ ๋กœ๊ทธ ํŒŒ์ผ์„ ์ž‘์„ฑํ•˜๋ ค๋ฉด --log-to-stderr์„(๋ฅผ) ์ง€์ •ํ•˜๊ณ  stderr๋ฅผ ์›ํ•˜๋Š” ๋Œ€๋กœ ๋ฆฌ๋””๋ ‰์…˜ํ•ฉ๋‹ˆ๋‹ค.)

--common-caches=<dir>

[๊ณ ๊ธ‰] ๋‹ค์šด๋กœ๋“œํ•œ QL ํŒฉ ๋ฐ ์ปดํŒŒ์ผ๋œ ์ฟผ๋ฆฌ ๊ณ„ํš๊ณผ ๊ฐ™์ด ์—ฌ๋Ÿฌ CLI ์‹คํ–‰ ๊ฐ„์— ์œ ์ง€๋˜๋Š” ๋””์Šคํฌ์˜ ์บ์‹œ๋œ ๋ฐ์ดํ„ฐ์˜ ์œ„์น˜๋ฅผ ์ œ์–ดํ•ฉ๋‹ˆ๋‹ค. ๋ช…์‹œ์ ์œผ๋กœ ์„ค์ •ํ•˜์ง€ ์•Š์€ ๊ฒฝ์šฐ ์ด ๊ธฐ๋ณธ๊ฐ’์€ ์‚ฌ์šฉ์ž์˜ ํ™ˆ ๋””๋ ‰ํ„ฐ๋ฆฌ์— ์ด๋ฆ„์ด ์ง€์ •๋œ .codeql ๋””๋ ‰ํ„ฐ๋ฆฌ๋กœ ์„ค์ •๋˜๋ฉฐ, ์•„์ง ์—†๋Š” ๊ฒฝ์šฐ ๋งŒ๋“ค์–ด์ง‘๋‹ˆ๋‹ค.

v2.15.2๋ถ€ํ„ฐ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.