Skip to main content
Glama
yincongcyincong

VictoriaMetrics-mcp-server

vm_query_range

Query time series data over a specified time range using PromQL expressions to analyze historical metrics and performance trends.

Instructions

Query time series over a time range

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
queryYesPromQL expression
startNoStart timestamp in Unix seconds
endNoEnd timestamp in Unix seconds
stepNoQuery resolution step width

Implementation Reference

  • Switch case handler for vm_query_range tool call, extracts arguments and invokes the query range function.
    case "vm_query_range": { const {query, start, end, step} = request.params.arguments; return await vmDataRangeQuery(query, start, end, step);
  • Core helper function that performs the HTTP range query to VictoriaMetrics API, handles response and formats output.
    async function vmDataRangeQuery(query, start, end, step) { let urlStr = VM_URL if (urlStr === "") { urlStr = VM_SELECT_URL } const url = new URL(urlStr + "/api/v1/query_range"); url.searchParams.append("query", query); url.searchParams.append("start", start ?? ""); url.searchParams.append("end", end ?? ""); url.searchParams.append("step", step ?? ""); const response = await fetch(url.toString()); const data = await response.json(); if (data.status === "success") { return { content: [{ type: "text", text: JSON.stringify(data.data), }], isError: false }; } else { return { content: [{ type: "text", text: "range query fail:" + await response.text(), }], isError: true }; } }
  • Tool schema definition specifying name, description, and input schema for vm_query_range.
    const VM_QUERY_RANGE_TOOL = { name: "vm_query_range", description: "Query time series over a time range", inputSchema: { type: "object", properties: { query: { type: "string", description: "PromQL expression", }, start: { type: "number", description: "Start timestamp in Unix seconds", }, end: { type: "number", description: "End timestamp in Unix seconds", }, step: { type: "string", description: "Query resolution step width", } }, required: ["query"], } };
  • src/index.js:127-134 (registration)
    Registration of vm_query_range tool (as VM_QUERY_RANGE_TOOL) in the list of available tools returned by ListToolsRequestHandler.
    const VM_TOOLS = [ VM_DATA_WRITE_TOOL, VM_QUERY_RANGE_TOOL, VM_QUERY_TOOL, VM_LABELS_TOOL, VM_LABEL_VALUES_TOOL, VM_PROMETHEUS_WRITE_TOOL ];

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/yincongcyincong/VictoriaMetrics-mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server