Oracle Cloud Infrastructure (OCI) MCP Server
A Model Context Protocol server for managing Oracle Cloud Infrastructure services, enabling LLMs to interact with compute instances, storage, identity, and databases through natural language.
README
Oracle Cloud Infrastructure (OCI) MCP Server
A comprehensive, robust, and highly extensible Model Context Protocol (MCP) server for managing Oracle Cloud Infrastructure (OCI) services. This server enables LLMs and MCP-compatible clients to securely interact with your Oracle Cloud account to manage compute instances, storage, identity, and databases.
š Features
- Standardized Authentication: Automatically integrates with your existing OCI CLI configuration (
~/.oci/config). - Identity & Access Management (IAM): Manage compartments and list users across your tenancy.
- Compute & Networking: View Virtual Cloud Networks (VCNs), list instances, fetch details, and execute lifecycle operations (START, STOP, RESET, SOFTRESET).
- Object Storage: Explore your tenancy's namespaces, list storage buckets, and view bucket objects.
- Database: Monitor and list your Autonomous Databases.
- Docker Ready: Fully containerized and optimized for secure isolation.
- Extensible Architecture: Designed with modularity in mind, allowing you to easily plug in any of the hundreds of other OCI services using the official
@oracle/oci-sdk.
š Prerequisites
Before running this MCP server, ensure you have the following set up:
- Oracle Cloud Account: An active OCI account.
- OCI CLI Configuration: You must have the Oracle Cloud CLI installed and configured on your machine.
- The default location is
~/.oci/config(Linux/Mac) orC:\Users\<YourUser>\.oci\config(Windows). - Tip: You can set this up using the
oci setup configcommand if you have the OCI CLI installed.
- The default location is
- Node.js: Node.js 18 or higher (if running locally without Docker).
- Docker: (Optional) If you prefer running the server in an isolated container.
š Installation & Setup
Option A: Running Locally (Node.js)
-
Clone/Navigate to the repository:
cd f:\MCP_Server\Oracle_cloud_MCP_server -
Install dependencies:
npm install -
Build the TypeScript code:
npm run build -
Run the server (for testing):
npm startNote: MCP servers communicate over
stdio, so running it directly in your terminal will make it wait for JSON-RPC inputs.
Option B: Running with Docker
Running with Docker requires mounting your local ~/.oci directory into the container so the server can authenticate using your credentials.
-
Build the Docker Image:
docker build -t oracle-cloud-mcp . -
Run the Docker Container: Replace
~/.ociwith the path to your OCI configuration folder.docker run -i -v ~/.oci:/root/.oci oracle-cloud-mcp
š Connecting to an MCP Client
To use this server, you must configure your MCP client (such as Claude Desktop, Cline, etc.) to spawn this process.
Example: Claude Desktop Configuration
Edit your claude_desktop_config.json:
For Local Node.js Execution:
{
"mcpServers": {
"oracle-cloud": {
"command": "node",
"args": [
"f:/MCP_Server/Oracle_cloud_MCP_server/dist/index.js"
]
}
}
}
For Docker Execution:
{
"mcpServers": {
"oracle-cloud": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-v",
"~/.oci:/root/.oci",
"oracle-cloud-mcp"
]
}
}
}
Note: The -i flag is required for interactive standard input (stdio) communication.
š ļø Available MCP Tools
Once connected, the LLM will have access to the following tools:
Identity Services
oci_list_compartments: List all compartments in the tenancy. If nocompartmentIdis provided, it defaults to the root tenancy.oci_list_users: List all users within the specified compartment or the root tenancy.
Compute & Networking Services
oci_list_instances: List all compute instances inside a specificcompartmentId.oci_get_instance: Get detailed metadata about a specific compute instance using itsinstanceId.oci_instance_action: Execute lifecycle actions on an instance (e.g.,START,STOP,SOFTRESET,RESET,SOFTSTOP).oci_list_vcns: List all Virtual Cloud Networks (VCNs) in a givencompartmentId.
Object Storage Services
oci_get_namespace: Fetch the Object Storage namespace associated with your tenancy.oci_list_buckets: List all storage buckets within a specified namespace and compartment.oci_list_objects: List all objects (files) inside a specific bucket.
Database Services
oci_list_autonomous_databases: List all Autonomous Databases (ADW/ATP) within a specified compartment.
š Project Structure
Oracle_cloud_MCP_server/
āāā src/
ā āāā index.ts # Main MCP server entry point and tool definitions
ā āāā auth/
ā ā āāā auth.ts # OCI Authentication module
ā āāā tool/ # Modular tool implementations
ā āāā compute/index.ts # Compute and VCN APIs
ā āāā database/index.ts # Autonomous Database APIs
ā āāā identity/index.ts # Compartment and User APIs
ā āāā objectstorage/index.ts # Bucket and Object APIs
āāā dist/ # Compiled JavaScript output (generated)
āāā Dockerfile # Docker container definition
āāā .dockerignore # Excluded files for Docker build
āāā .gitignore # Excluded files for Git tracking
āāā package.json # Node.js dependencies and scripts
āāā tsconfig.json # TypeScript compiler configuration
š§© Extending the Server
Because Oracle Cloud has hundreds of services, this server is designed to be easily extensible. To add a new service (e.g., oci-dns):
- Install the SDK package:
npm install oci-dns - Create a new tool module: Create
src/tool/dns/index.ts. - Initialize the client: Import
getAuthProviderfrom../../auth/auth.jsand instantiate the DNS client. - Export your function: Write your async function calling the OCI API.
- Register the tool: In
src/index.ts, import your new module, add a tool definition in theListToolsRequestSchemahandler, and map the tool execution in theCallToolRequestSchemaswitch statement.
ā ļø Troubleshooting
- Authentication Errors: If you see
Failed to initialize OCI Config File Provider, ensure that the OCI CLI is installed and configured. If running via Docker, verify that you correctly mounted the~/.ocifolder using-v. - Permission Errors: If you get a 404 or 401 error from the Oracle Cloud API, ensure the user profile configured in your
~/.oci/configfile has the correct IAM policies to read compartments, instances, etc. - No Compartment ID: Many OCI operations require a
compartmentId. The root compartment OCID is usually the same as your Tenancy OCID, which is defined in your~/.oci/configfile.
Built with Model Context Protocol and the Oracle Cloud Infrastructure Node.js SDK.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.