확장 참조
이 가이드는 gemini extensions 명령과 gemini-extension.json 구성 파일의 구조를 다룹니다.
확장 관리
gemini extensions 명령을 사용하여 다양한 확장 관리 도구를 제공합니다.
이러한 명령(예: gemini extensions install)은 CLI의 대화형 모드 내에서는 지원되지 않지만, /extensions list 슬래시 명령을 사용하여 설치된 확장을 나열할 수는 있습니다.
이러한 모든 관리 작업(슬래시 명령 업데이트 포함)은 재시작 시 활성 CLI 세션에 반영됩니다.
확장 설치
GitHub URL 또는 로컬 경로를 사용하여 gemini extensions install로 확장을 설치할 수 있습니다.
설치된 확장의 사본을 생성하므로, 로컬에 정의된 확장과 GitHub에 있는 확장의 변경 사항을 가져오려면 gemini extensions update를 실행해야 합니다.
참고: GitHub에서 확장을 설치하는 경우, 컴퓨터에 git이 설치되어 있어야 합니다. 도움이 필요하면 git 설치 지침 (opens in a new tab)을 참조하세요.
gemini extensions install <source> [--ref <ref>] [--auto-update] [--pre-release] [--consent]<source>: 설치할 확장의 GitHub URL 또는 로컬 경로입니다.--ref: 설치할 git 참조(ref)입니다.--auto-update: 이 확장에 대한 자동 업데이트를 활성화합니다.--pre-release: 이 확장에 대한 프리릴리스 버전을 활성화합니다.--consent: 확장의 보안 위험을 인지하고 확인 메시지를 건너뜁니다.
확장 제거
하나 이상의 확장을 제거하려면 gemini extensions uninstall <name...>을 실행하세요:
gemini extensions uninstall gemini-cli-security gemini-cli-another-extension확장 비활성화
확장은 기본적으로 모든 작업 공간에서 활성화됩니다. 확장을 완전히 비활성화하거나 특정 작업 공간에서만 비활성화할 수 있습니다.
gemini extensions disable <name> [--scope <scope>]<name>: 비활성화할 확장의 이름입니다.--scope: 확장을 비활성화할 범위입니다 (user또는workspace).
확장 활성화
gemini extensions enable <name>을 사용하여 확장을 활성화할 수 있습니다. 작업 공간 내에서 gemini extensions enable <name> --scope=workspace를 사용하여 해당 작업 공간에 대해서만 확장을 활성화할 수도 있습니다.
gemini extensions enable <name> [--scope <scope>]<name>: 활성화할 확장의 이름입니다.--scope: 확장을 활성화할 범위입니다 (user또는workspace).
확장 업데이트
로컬 경로 또는 git 저장소에서 설치된 확장의 경우, gemini extensions update <name>을 사용하여 최신 버전(gemini-extension.json의 version 필드에 반영된 대로)으로 명시적으로 업데이트할 수 있습니다.
다음 명령으로 모든 확장을 업데이트할 수 있습니다:
gemini extensions update --all보일러플레이트 확장 만들기
context, custom-commands, exclude-tools, mcp-server와 같은 몇 가지 예제 확장을 제공합니다. 이러한 예제는 여기 (opens in a new tab)에서 볼 수 있습니다.
원하는 유형을 사용하여 이러한 예제 중 하나를 개발 디렉터리로 복사하려면 다음을 실행하세요:
gemini extensions new <path> [template]<path>: 확장을 생성할 경로입니다.[template]: 사용할 보일러플레이트 템플릿입니다.
로컬 확장 연결
gemini extensions link 명령은 확장 설치 디렉터리에서 개발 경로로의 심볼릭 링크를 생성합니다.
테스트하려는 변경 사항을 만들 때마다 gemini extensions update를 실행할 필요가 없어 유용합니다.
gemini extensions link <path><path>: 연결할 확장의 경로입니다.
확장 형식
Gemini CLI는 시작 시 <home>/.gemini/extensions에서 확장을 찾습니다.
확장은 gemini-extension.json 파일을 포함하는 디렉터리로 존재합니다.
예:
<home>/.gemini/extensions/my-extension/gemini-extension.json
gemini-extension.json
gemini-extension.json 파일에는 확장의 구성이 포함되어 있습니다.
파일 구조는 다음과 같습니다:
{
"name": "my-extension",
"version": "1.0.0",
"description": "My awesome extension",
"mcpServers": {
"my-server": {
"command": "node my-server.js"
}
},
"contextFileName": "GEMINI.md",
"excludeTools": ["run_shell_command"]
}name: 확장의 이름입니다. 이는 확장을 고유하게 식별하고, 사용자 또는 프로젝트 명령과 이름이 같을 때 충돌을 해결하는 데 사용됩니다. 이름은 소문자나 숫자여야 하며, 밑줄이나 공백 대신 대시를 사용해야 합니다. 사용자가 CLI에서 확장을 지칭할 때 이 이름을 사용합니다. 이 이름은 확장 디렉터리 이름과 일치해야 합니다.version: 확장의 버전입니다.description: 확장에 대한 짧은 설명입니다. 이는 geminicli.com/extensions (opens in a new tab)에 표시됩니다.mcpServers: MCP 서버와 설정의 맵입니다. 키는 서버의 이름이고 값은 서버 구성입니다. 이 서버들은settings.json파일에 설정된 MCP 서버처럼 시작 시 로드됩니다. 확장과settings.json파일 모두 같은 이름의 MCP 서버를 설정하는 경우,settings.json파일에 정의된 서버가 우선합니다.trust를 제외한 모든 MCP 서버 구성 옵션이 지원됩니다.
contextFileName: 확장의 컨텍스트를 포함하는 파일의 이름입니다. 확장 디렉터리에서 컨텍스트를 로드하는 데 사용됩니다. 이 속성을 사용하지 않더라도GEMINI.md파일이 확장 디렉터리에 있으면 해당 파일이 로드됩니다.excludeTools: 모델에서 제외할 도구 이름의 배열입니다.run_shell_command도구와 같이 이를 지원하는 도구에 대해 명령별 제한을 지정할 수도 있습니다. 예를 들어,"excludeTools": ["run_shell_command(rm -rf)"]는rm -rf명령을 차단합니다. 이는 MCP 서버 구성에 나열할 수 있는 MCP 서버excludeTools기능과 다르다는 점에 유의하세요.
Gemini CLI가 시작되면 모든 확장을 로드하고 구성을 병합합니다. 충돌이 있는 경우 작업 공간 구성이 우선합니다.
설정 (Settings)
참고: 이는 실험적인 기능입니다. 확장 작성자가 핵심 흐름의 일부로 설정을 도입하는 것을 아직 권장하지 않습니다.
확장은 설치 시 사용자에게 입력을 요청할 설정을 정의할 수 있습니다. 이는 API 키, URL 또는 확장이 작동하는 데 필요한 기타 구성에 유용합니다.
설정을 정의하려면 gemini-extension.json 파일에 settings 배열을 추가하세요.
배열의 각 객체는 다음 속성을 가져야 합니다:
name: 설정의 사용자 친화적인 이름입니다.description: 설정에 대한 설명과 용도입니다.envVar: 설정이 저장될 환경 변수의 이름입니다.sensitive: 선택적 불리언 값입니다. true인 경우 사용자가 제공한 입력을 난독화하고 키체인 저장소에 비밀을 저장합니다.
예시
{
"name": "my-api-extension",
"version": "1.0.0",
"settings": [
{
"name": "API Key",
"description": "Your API key for the service.",
"envVar": "MY_API_KEY"
}
]
}사용자가 이 확장을 설치하면 API 키를 입력하라는 메시지가 표시됩니다. 값은 확장의 디렉터리(예: <home>/.gemini/extensions/my-api-extension/.env)에 있는 .env 파일에 저장됩니다.
다음 명령을 실행하여 확장의 설정 목록을 볼 수 있습니다:
gemini extensions list그리고 다음을 사용하여 주어진 설정을 업데이트할 수 있습니다:
gemini extensions config <extension name> [setting name] [--scope <scope>]--scope: 설정을 설정할 범위입니다 (user또는workspace). 선택 사항이며 기본값은user입니다.
사용자 지정 명령
확장은 확장 디렉터리 내의 commands/ 하위 디렉터리에 TOML 파일을 배치하여 사용자 지정 명령을 제공할 수 있습니다. 이러한 명령은 사용자 및 프로젝트 사용자 지정 명령과 동일한 형식을 따르며 표준 명명 규칙을 사용합니다.
예시
다음과 같은 구조를 가진 gcp라는 확장이 있다고 가정해 봅시다:
.gemini/extensions/gcp/
├── gemini-extension.json
└── commands/
├── deploy.toml
└── gcs/
└── sync.toml이 확장은 다음 명령을 제공합니다:
/deploy- 도움말에[gcp] Custom command from deploy.toml로 표시됨/gcs:sync- 도움말에[gcp] Custom command from sync.toml로 표시됨
훅 (Hooks)
확장은 훅(Hooks)을 제공하여 특정 수명 주기 이벤트에서 Gemini CLI 동작을 가로채고 사용자 지정할 수 있습니다. 확장에서 제공하는 훅은 확장 디렉터리 내의 hooks/hooks.json 파일에 정의되어야 합니다.
[!IMPORTANT] 훅은
gemini-extension.json에 직접 정의되지 않습니다. CLI는 구체적으로hooks/hooks.json파일을 찾습니다.
에이전트 기술 (Agent Skills)
확장은 에이전트 기술을 번들로 묶어 전문적인 워크플로를 제공할 수 있습니다. 기술은 확장 내의 skills/ 디렉터리에 배치해야 합니다.
예시
다음과 같은 구조를 가진 확장이 있다고 가정해 봅시다:
.gemini/extensions/my-extension/
├── gemini-extension.json
└── skills/
└── security-audit/
└── SKILL.md이 확장은 모델이 활성화할 수 있는 security-audit 기술을 노출합니다.
서브 에이전트 (Sub-agents)
참고: 서브 에이전트는 현재 실험적인 기능입니다.
확장은 사용자가 작업을 위임할 수 있는 서브 에이전트를 제공할 수 있습니다.
확장에 서브 에이전트를 번들로 묶으려면 확장 루트 폴더에 agents/ 디렉터리를 만들고 에이전트 정의 파일(.md)을 추가하세요.
예시
.gemini/extensions/my-extension/
├── gemini-extension.json
└── agents/
├── security-auditor.md
└── database-expert.mdGemini CLI는 확장이 설치되고 활성화되면 이러한 에이전트를 자동으로 검색하고 로드합니다.
충돌 해결
파생된 확장 명령은 가장 낮은 우선순위를 갖습니다. 사용자 또는 프로젝트 명령과 충돌이 발생할 때:
- 충돌 없음: 확장 명령은 원래 이름(예:
/deploy)을 사용합니다. - 충돌 발생: 확장 명령은 확장 접두사(예:
/gcp.deploy)를 사용하여 이름이 변경됩니다.
예를 들어, 사용자와 gcp 확장이 모두 deploy 명령을 정의하는 경우:
/deploy- 사용자의 deploy 명령을 실행합니다./gcp.deploy- 확장의 deploy 명령을 실행합니다 ([gcp]태그가 표시됨).
변수
Gemini CLI 확장은 gemini-extension.json과 hooks/hooks.json 모두에서 변수 대체(substitution)를 허용합니다. 예를 들어, "args": ["${extensionPath}${/}dist${/}server.js"]와 같은 인수를 사용하여 MCP 서버를 실행하기 위해 현재 디렉터리가 필요한 경우 유용할 수 있습니다.
지원되는 변수:
| 변수 | 설명 |
|---|---|
${extensionPath} | 사용자 파일 시스템에서 확장의 정규화된(fully-qualified) 경로입니다. 예: '/Users/username/.gemini/extensions/example-extension'. 심볼릭 링크를 해제하지 않습니다. |
${workspacePath} | 현재 작업 공간의 정규화된 경로입니다. |
${/} 또는 ${pathSeparator} | 경로 구분자(OS마다 다름)입니다. |