Playwright MCP
@cloudflare/playwright-mcp ↗ is a Playwright MCP ↗ server fork that provides browser automation capabilities using Playwright and Browser Rendering.
This server enables LLMs to interact with web pages through structured accessibility snapshots, bypassing the need for screenshots or visually-tuned models. Its key features are:
- Fast and lightweight. Uses Playwright's accessibility tree, not pixel-based input.
- LLM-friendly. No vision models needed, operates purely on structured data.
- Deterministic tool application. Avoids ambiguity common with screenshot-based approaches.
If you are already familiar with Cloudflare Workers and you want to get started with Playwright MCP right away, select this button:
This creates a repository in your GitHub account and deploys the application to Cloudflare Workers. Use this option if you are familiar with Cloudflare Workers, and wish to skip the step-by-step guidance.
Check our GitHub page ↗ for more information on how to build and deploy Playwright MCP.
Follow these steps to deploy @cloudflare/playwright-mcp:
- Install the Playwright MCP npm package ↗.
npm i -D @cloudflare/playwright-mcpyarn add -D @cloudflare/playwright-mcppnpm add -D @cloudflare/playwright-mcp- Make sure you have the browser rendering and durable object bindings and migrations in your wrangler configuration file.
{  "name": "playwright-mcp-example",  "main": "src/index.ts",  "compatibility_date": "2025-03-10",  "compatibility_flags": [    "nodejs_compat"  ],  "browser": {    "binding": "BROWSER"  },  "migrations": [    {      "tag": "v1",      "new_sqlite_classes": [        "PlaywrightMCP"      ]    }  ],  "durable_objects": {    "bindings": [      {        "name": "MCP_OBJECT",        "class_name": "PlaywrightMCP"      }    ]  }}name = "playwright-mcp-example"main = "src/index.ts"compatibility_date = "2025-03-10"compatibility_flags = ["nodejs_compat"]
[browser]binding = "BROWSER"
[[migrations]]tag = "v1"new_sqlite_classes = ["PlaywrightMCP"]
[[durable_objects.bindings]]name = "MCP_OBJECT"class_name = "PlaywrightMCP"- Edit the code.
import { env } from 'cloudflare:workers';import { createMcpAgent } from '@cloudflare/playwright-mcp';
export const PlaywrightMCP = createMcpAgent(env.BROWSER);
export default {  fetch(request: Request, env: Env, ctx: ExecutionContext) {    const { pathname } = new URL(request.url);
    switch (pathname) {      case '/sse':      case '/sse/message':        return PlaywrightMCP.serveSSE('/sse').fetch(request, env, ctx);      case '/mcp':        return PlaywrightMCP.serve('/mcp').fetch(request, env, ctx);      default:        return new Response('Not Found', { status: 404 });    }  },};- Deploy the server.
npx wrangler deployThe server is now available at https://[my-mcp-url].workers.dev/sse and you can use it with any MCP client.

Cloudflare AI Playground ↗ is a great way to test MCP servers using LLM models available in Workers AI.
- Navigate to https://playground.ai.cloudflare.com/ ↗
- Ensure that the model is set to llama-3.3-70b-instruct-fp8-fast
- In MCP Servers, set URL to https://[my-mcp-url].workers.dev/sse
- Click Connect
- Status should update to Connected and it should list 23 available tools
You can now start to interact with the model, and it will run necessary the tools to accomplish what was requested.
Try this sequence of instructions to see Playwright MCP in action:
- "Go to demo.playwright.dev/todomvc"
- "Create some todo entry"
- "Nice. Now create a todo in parrot style"
- "And create another todo in Yoda style"
- "Take a screenshot"
You can also use other MCP clients like Claude Desktop ↗.
Check our GitHub page ↗ for more examples and MCP client configuration options and our developer documentation on how to build Agents on Cloudflare.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark