Gemini Image Gen MCP Server
Provides AI image generation, editing (inpainting/outpainting), and upscaling through Google Gemini and Imagen models, with support for both AI Studio (free) and Vertex AI (GCP) providers.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Gemini Image Gen MCP ServerGenerate an image of a serene lake at sunset."
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Gemini Image Gen MCP Server
Features
3 tools —
generate_image,edit_image(inpainting/outpainting),upscale_image(2x/4x)Dual provider — AI Studio (free) or Vertex AI (GCP credits)
Multi-model — Gemini 2.0 Flash + Imagen 3.0 + Imagen 4 (Fast & Ultra)
Dynamic model switching — choose model per request via
modelparameter, no restart neededBuilt-in guides — MCP Resources with model selection tips and provider docs
Smart error recovery — auto-suggests alternative models on quota errors
Auto-save generated images to disk
SOCKS proxy support out of the box
Demo
Architecture
User Prompt → AI Assistant (Claude / Cursor) → MCP Server → Gemini API / Vertex AI
↓
Save to disk + DisplayHow It Works
The server handles two distinct Google APIs under one unified interface:
API | Models | Endpoint | Request Format |
Predict API |
| Vertex AI only |
|
GenerateContent API |
| AI Studio + Vertex AI |
|
Capability API |
| Vertex AI only |
|
Upscale API |
| Vertex AI only |
|
The server automatically selects the correct API based on the model name prefix — imagen* routes to Predict, everything else to GenerateContent. You don't need to worry about this distinction.
Quick Start
Option A: AI Studio (Free, Recommended for Getting Started)
1. Get API Key — visit https://aistudio.google.com/apikey → Create API Key → copy it
2. Configure MCP
claude mcp add --transport stdio mcp-image \
--env GEMINI_API_KEY=your_api_key \
-- uv --directory /path/to/mcp-image-gen run image-gen{
"mcpServers": {
"mcp-image": {
"command": "uv",
"args": ["--directory", "/path/to/mcp-image-gen", "run", "image-gen"],
"env": {
"GEMINI_API_KEY": "your_api_key"
}
}
}
}3. Use it — just ask your AI assistant:
"Generate an image of a dragon flying over mountains at dawn"The image will be displayed inline and automatically saved to the output/ directory.
Option B: Vertex AI (Higher Quality, GCP Credits)
Use GCP billing with Imagen 4 / 3.0 for higher quality results, plus image editing and upscaling.
1. Prerequisites
A GCP project with billing enabled (create one)
Vertex AI API enabled (enable it)
A GCP API key (create one)
2. Install with Vertex AI support
git clone https://github.com/kevinten-ai/mcp-image-gen.git
cd mcp-image-gen
uv sync --extra vertex3. Configure MCP
claude mcp add --transport stdio mcp-image \
--env GEMINI_PROVIDER=vertex-ai \
--env GEMINI_API_KEY=your_gcp_api_key \
--env GCP_PROJECT_ID=your-project-id \
--env GCP_REGION=us-central1 \
--env GEMINI_MODEL=imagen-3.0-fast-generate-001 \
-- uv --directory /path/to/mcp-image-gen --extra vertex run image-gen{
"mcpServers": {
"mcp-image": {
"command": "uv",
"args": ["--directory", "/path/to/mcp-image-gen", "--extra", "vertex", "run", "image-gen"],
"env": {
"GEMINI_PROVIDER": "vertex-ai",
"GEMINI_API_KEY": "your_gcp_api_key",
"GCP_PROJECT_ID": "your-project-id",
"GCP_REGION": "us-central1",
"GEMINI_MODEL": "imagen-3.0-fast-generate-001"
}
}
}
}Auth options: Vertex AI supports two authentication methods:
GCP API Key (recommended) — set
GEMINI_API_KEY. Simple, no extra deps.OAuth2 / ADC — run
gcloud auth application-default login. The server auto-detects ADC when no API key is set. Requires--extra vertexforgoogle-authdependency.
Tools
generate_image — Text to Image
Generate images from text prompts.
"A cozy cafe in Paris at sunset"edit_image — Image Editing (Vertex AI only)
Edit existing images with text instructions. Supports inpainting, outpainting, and background swap.
edit_image(prompt="Add a red hat", image_path="/path/to/photo.png")
edit_image(prompt="Replace background with beach", image_path="photo.png", edit_mode="product-image")
edit_image(prompt="Expand the sky", image_path="photo.png", mask_path="mask.png", edit_mode="outpainting")upscale_image — Super Resolution (Vertex AI only)
Upscale images to 2x or 4x resolution.
upscale_image(image_path="/path/to/photo.png", upscale_factor="x4")Usage Guide
Tips for Better Results
Be specific: "A golden retriever puppy playing in autumn leaves, soft natural lighting" works better than "a dog"
Mention style: Add terms like "digital art", "photorealistic", "watercolor", "oil painting", "anime style"
Describe lighting: "golden hour", "dramatic lighting", "soft diffused light"
Specify composition: "close-up portrait", "wide-angle landscape", "bird's eye view"
No text: Image models generally struggle with rendering text. Use "No text" in prompts for cleaner results.
Choosing a Model
Per-request switching (recommended)
Pass the model parameter when calling the tool:
generate_image(prompt="a sunset landscape", model="imagen-3.0-fast-generate-001")AI assistants can dynamically pick the best model per request. If one model hits a quota limit, the error response automatically suggests an alternative.
Decision flowchart
Need an image?
├─ Free / no GCP account?
│ └─ AI Studio: gemini-2.0-flash-exp-image-generation ✅
│
└─ Have GCP billing?
├─ Need highest quality?
│ └─ imagen-4.0-ultra-generate-001 (~$0.06/img)
│
├─ Best value (recommended)?
│ └─ imagen-4.0-generate-001 (~$0.02/img) ✅
│
├─ Need to edit an image?
│ └─ edit_image tool (uses imagen-3.0-capability-001)
│
├─ Need to upscale?
│ └─ upscale_image tool (uses imagen-4.0-upscale-preview)
│
└─ Hit quota on one model?
└─ Switch to another — each model has independent quotaDefault via environment variable
Set GEMINI_MODEL to configure the default model used when no model parameter is passed:
# AI Studio (Gemini models)
GEMINI_MODEL=gemini-2.0-flash-exp-image-generation # free, experimental (default)
GEMINI_MODEL=gemini-2.0-flash-preview-image-generation # preview
# Vertex AI (Imagen models)
GEMINI_MODEL=imagen-3.0-generate-002 # high quality
GEMINI_MODEL=imagen-3.0-fast-generate-001 # faster, lower cost — recommended for Vertex AIMCP Resources
The server exposes built-in documentation that AI assistants can automatically read:
Resource URI | Description |
| Model comparison, pricing, quota tips, and selection guide |
| Provider setup, authentication, and troubleshooting |
AI assistants (Claude, etc.) can read these resources to make informed model choices without human intervention.
Custom Output Directory
--env IMAGE_OUTPUT_DIR=/absolute/path/to/your/imagesImages are saved with timestamps: imagen_20260321_234225.png or gemini_20260321_234225.png.
Environment Variables
Variable | Required | Default | Description |
| No |
|
|
| Yes* | — | API key (AI Studio or GCP). *Not required if using ADC. |
| No |
| Default model (can be overridden per request via |
| No |
| Directory to save generated images |
| Vertex AI only | — | GCP project ID |
| No |
| GCP region for Vertex AI |
Supported Models
AI Studio (Gemini) — Free
Model ID | Quality | Speed | Pricing | Best for |
| Good | Fast | Free | Getting started, experimentation |
| Good | Fast | Free | Preview features |
Vertex AI (Imagen) — GCP Credits
Model ID | Quality | Speed | Pricing | Best for |
| High | Fast | ~$0.02/image | Best value, recommended |
| Highest | Slower | ~$0.06/image | Premium quality |
| High | Slower | ~$0.04/image | Legacy, stable |
| Good | Fast | ~$0.02/image | Legacy fast |
| Good | Fast | Pay-per-use | Multimodal text+image |
Vertex AI — Specialized Models
Model ID | Tool | Pricing | Notes |
|
| ~$0.04/edit | Inpainting, outpainting, bg swap |
|
| Preview | 2x/4x super resolution |
Key insight: Each model has its own independent API quota. If one model hits a 429, switching to another will work because they use separate rate limits.
Troubleshooting
Error Reference
Error | Root Cause | Solution |
| Missing API key in env config | Set |
| Using Vertex AI without project ID | Set |
Quota & Billing Errors (429)
These are the most common errors. There are two distinct 429 errors with different causes:
429: Quota exceeded for online_prediction_requests_per_base_model
What it means: You've hit the per-minute API call rate limit for a specific model.
Quick fix: Switch to a different model via the model parameter — each model has independent quota:
generate_image(prompt="...", model="imagen-3.0-fast-generate-001")Long-term fix: Request a quota increase:
Filter by
online_prediction_requests_per_base_modelFind your model (e.g.,
imagen-3.0-generate)Click Edit Quotas → request a higher limit (default is often just 5 QPM)
429: Quota exceeded ... spending cap
What it means: You've hit a self-imposed billing spending limit, NOT an API rate limit.
Fix:
Find the budget with a spending cap
Increase or remove the cap
Tip:
imagen-3.0-fast-generate-001costs ~$0.02/image vs $0.04 for the high-quality version. Setting it as default halves your spending.
Authentication Errors
Error | Root Cause | Solution |
| Model doesn't accept API key auth | Use ADC: run |
| API key lacks Vertex AI permissions | Enable Vertex AI API in GCP Console, or check API key restrictions |
| No valid credentials found | Set |
Model Errors
Error | Root Cause | Solution |
| Wrong model ID for provider | AI Studio uses |
| Regional restriction on model | Try a different region ( |
| Model declined or returned empty | Try a more descriptive prompt, avoid ambiguous or restricted content |
Connection Errors
Error | Root Cause | Solution |
| Network issue or proxy needed | If behind a firewall, configure SOCKS proxy via |
| Unexpected API response | Check model ID is correct, API may be temporarily down |
Prerequisites
Python 3.10+
uv — install with
curl -LsSf https://astral.sh/uv/install.sh | sh
Local Development
git clone https://github.com/kevinten-ai/mcp-image-gen.git
cd mcp-image-gen
# Install dependencies (add --extra vertex for Vertex AI support)
uv sync
# Copy and configure environment variables
cp .env.example .env
# Edit .env with your API key
# Run the server directly
uv run image-genDebug with MCP Inspector
npx @modelcontextprotocol/inspector uv --directory /path/to/mcp-image-gen run image-genRelated Projects
mcp-video-gen — Multi-provider AI video generation MCP server
mcp-3d-gen — AI 3D model generation MCP server
License
MIT — see LICENSE for details.
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/kevinten-ai/mcp-image-gen'
If you have feedback or need assistance with the MCP directory API, please join our Discord server