Tool: list_instances
Lists Compute Engine virtual machine (VM) instances. Details for each instance include name, ID, status, machine type, creation timestamp, and attached guest accelerators. Use other tools to get more details about each instance. Requires project and zone as input.
The following sample demonstrate how to use curl to invoke the list_instances MCP tool.
| Curl Request |
|---|
curl --location 'https://compute.googleapis.com/mcp' \ --header 'content-type: application/json' \ --header 'accept: application/json, text/event-stream' \ --data '{ "method": "tools/call", "params": { "name": "list_instances", "arguments": { // provide these details according to the tool's MCP specification } }, "jsonrpc": "2.0", "id": 1 }' |
Input Schema
Request message for listing instances basic info.
| JSON representation |
|---|
{ "project": string, "zone": string, "pageSize": integer, "pageToken": string } |
| Fields | |
|---|---|
project |
Required. Project ID for this request. |
zone |
Required. The zone of the instances. |
pageSize |
Optional. The maximum number of instances to return. |
pageToken |
Optional. A page token received from a previous call to list instances. |
Output Schema
Response message for listing instances basic info.
| JSON representation |
|---|
{
"instances": [
{
object ( |
| Fields | |
|---|---|
instances[] |
The list of instances. |
nextPageToken |
A token that can be sent as |
| JSON representation |
|---|
{ "name": string, "id": string, "status": enum ( |
| Fields | |
|---|---|
name |
Name of the instance. |
id |
The unique identifier for the instance. |
status |
The status of the instance. |
machineType |
The machine type of the instance. |
createTime |
Creation timestamp of the instance. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: |
guestAccelerators[] |
Accelerators attached to the instance. |
| JSON representation |
|---|
{ "seconds": string, "nanos": integer } |
| Fields | |
|---|---|
seconds |
Represents seconds of UTC time since Unix epoch 1970-01-01T00:00:00Z. Must be between -62135596800 and 253402300799 inclusive (which corresponds to 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z). |
nanos |
Non-negative fractions of a second at nanosecond resolution. This field is the nanosecond portion of the duration, not an alternative to seconds. Negative second values with fractions must still have non-negative nanos values that count forward in time. Must be between 0 and 999,999,999 inclusive. |
| JSON representation |
|---|
{ "acceleratorType": string, "acceleratorCount": integer, "acceleratorCountAlts": [ integer ] } |
| Fields | |
|---|---|
acceleratorType |
Full or partial URL of the accelerator type resource to attach to this instance. For example: |
acceleratorCount |
The number of the guest accelerator cards exposed to this instance. |
acceleratorCountAlts[] |
|
Tool Annotations
Destructive Hint: ❌ | Idempotent Hint: ✅ | Read Only Hint: ✅ | Open World Hint: ❌