This repository contains the Gemini CLI, a command-line AI workflow tool that connects to your tools, understands your code and accelerates your workflows.
With the Gemini CLI you can:
- Query and edit large codebases in and beyond Gemini's 1M token context window.
- Generate new apps from PDFs or sketches, using Gemini's multimodal capabilities.
- Automate operational tasks, like querying pull requests or handling complex rebases.
- Integrate with GitHub: Use the Gemini CLI GitHub Action for automated PR reviews, issue triage, and on-demand AI assistance directly in your repositories.
- Use tools and MCP servers to connect new capabilities, including media generation with Imagen, Veo or Lyria
- Ground your queries with the Google Search tool, built into Gemini.
You have two options to install Gemini CLI.
- 
Prerequisites: Ensure you have Node.js version 20 or higher installed. 
- 
Run the CLI: Execute the following command in your terminal: npx https://github.com/google-gemini/gemini-cli Or install it with: npm install -g @google/gemini-cli Then, run the CLI from anywhere: gemini 
- 
Prerequisites: Ensure you have Homebrew installed. 
- 
Install the CLI: Execute the following command in your terminal: brew install gemini-cli Then, run the CLI from anywhere: gemini 
- Pick a color theme
- Authenticate: When prompted, sign in with your personal Google account. This will grant you up to 60 model requests per minute and 1,000 model requests per day using Gemini.
You are now ready to use the Gemini CLI!
The Gemini API provides a free tier with 100 requests per day using Gemini 2.5 Pro, control over which model you use, and access to higher rate limits (with a paid plan):
- 
Generate a key from Google AI Studio. 
- 
Set it as an environment variable in your terminal. Replace YOUR_API_KEYwith your generated key.export GEMINI_API_KEY="YOUR_API_KEY" 
- 
(Optionally) Upgrade your Gemini API project to a paid plan on the API key page (will automatically unlock Tier 1 rate limits) 
The Vertex AI API provides a free tier using express mode for Gemini 2.5 Pro, control over which model you use, and access to higher rate limits with a billing account:
- 
Generate a key from Google Cloud. 
- 
Set it as an environment variable in your terminal. Replace YOUR_API_KEYwith your generated key and set GOOGLE_GENAI_USE_VERTEXAI to trueexport GOOGLE_API_KEY="YOUR_API_KEY" export GOOGLE_GENAI_USE_VERTEXAI=true 
- 
(Optionally) Add a billing account on your project to get access to higher usage limits 
For other authentication methods, including Google Workspace accounts, see the authentication guide.
Once the CLI is running, you can start interacting with Gemini from your shell.
You can start a project from a new directory:
cd new-project/
gemini
> Write me a Gemini Discord bot that answers questions using a FAQ.md file I will provideOr work with an existing project:
git clone https://github.com/google-gemini/gemini-cli
cd gemini-cli
gemini
> Give me a summary of all of the changes that went in yesterday- Learn how to contribute to or build from the source.
- Explore the available CLI Commands.
- If you encounter any issues, review the troubleshooting guide.
- For more comprehensive documentation, see the full documentation.
- Take a look at some popular tasks for more inspiration.
- Check out our Official Roadmap
Head over to the troubleshooting guide if you're having issues.
Integrate Gemini CLI directly into your GitHub workflows with the Gemini CLI GitHub Action. Key features include:
- Pull Request Reviews: Automatically review pull requests when they're opened.
- Issue Triage: Automatically triage and label GitHub issues.
- On-demand Collaboration: Mention @gemini-cliin issues and pull requests for assistance and task delegation.
- Custom Workflows: Set up your own scheduled tasks and event-driven automations.
Start by cding into an existing or newly-cloned repository and running gemini.
> Describe the main pieces of this system's architecture.
> What security mechanisms are in place?
> Provide a step-by-step dev onboarding doc for developers new to the codebase.
> Summarize this codebase and highlight the most interesting patterns or techniques I could learn from.
> Identify potential areas for improvement or refactoring in this codebase, highlighting parts that appear fragile, complex, or hard to maintain.
> Which parts of this codebase might be challenging to scale or debug?
> Generate a README section for the [module name] module explaining what it does and how to use it.
> What kind of error handling and logging strategies does the project use?
> Which tools, libraries, and dependencies are used in this project?
> Implement a first draft for GitHub issue #123.
> Help me migrate this codebase to the latest version of Java. Start with a plan.
Use MCP servers to integrate your local system tools with your enterprise collaboration suite.
> Make me a slide deck showing the git history from the last 7 days, grouped by feature and team member.
> Make a full-screen web app for a wall display to show our most interacted-with GitHub issues.
> Convert all the images in this directory to png, and rename them to use dates from the exif data.
> Organize my PDF invoices by month of expenditure.
Head over to the Uninstall guide for uninstallation instructions.
For details on the terms of service and privacy notice applicable to your use of Gemini CLI, see the Terms of Service and Privacy Notice.
Please see our security disclosure process. All security advisories are managed on Github.
