FAQ
Below you will find answers to our most commonly asked questions about Browser Rendering.
For pricing questions, visit the pricing FAQ. For usage limits questions, visit the limits FAQ. If you cannot find the answer you are looking for, join us on Discord ↗.
Not yet. Local development currently has the following limitation(s):
- Requests larger than 1 MB are not supported.
No, Browser Rendering requests are always identified as bots by Cloudflare and do not bypass Bot Protection.
If you are attempting to scan your own zone and need Browser Rendering to access areas protected by Cloudflare’s Bot Protection, you can create a WAF skip rule to bypass the bot protection using a header or a custom user agent.
No. Browser Rendering requests originate from Cloudflare's global network and you cannot configure per-request IP rotation. All rendering traffic comes from Cloudflare IP ranges and requests include automatic headers, such as cf-biso-request-id and cf-biso-devtools so origin servers can identify them.
There is no fixed limit on the number of requests per browser session. A single browser can handle multiple requests as long as it stays within available compute and memory limits.
If you are hitting concurrency limits, or want to optimize concurrent browser usage with the Workers Binding method, here are a few tips:
- Optimize with tabs or shared browsers: Instead of launching a new browser for each task, consider opening multiple tabs or running multiple actions within the same browser instance.
- Reuse sessions: You can optimize your setup and decrease startup time by reusing sessions instead of launching a new browser every time. If you are concerned about maintaining test isolation (for example, for tests that depend on a clean environment), we recommend using incognito browser contexts ↗, which isolate cookies and cache with other sessions.
If you are still running into concurrency limits you can request a higher limit ↗.
I see Cannot read properties of undefined (reading 'fetch') when using Browser Rendering. How do I fix this?
This error typically occurs because your Puppeteer launch is not receiving the Browser binding. To resolve: Pass your Browser binding into puppeteer.launch.
Currently it is not possible to use Xpath to select elements since this poses a security risk to Workers.
As an alternative, try to use a css selector or page.evaluate. For example:
const innerHtml = await page.evaluate(() => {  return (    // @ts-ignore this runs on browser context    new XPathEvaluator()      .createExpression("/html/body/div/h1")      // @ts-ignore this runs on browser context      .evaluate(document, XPathResult.FIRST_ORDERED_NODE_TYPE).singleNodeValue      .innerHTML  );});It may be because you increased the height and width of the viewport. To fix this, increase the value of the deviceScaleFactor (default is 1).
I see Error processing the request: Unable to create new browser: code: 429: message: Browser time limit exceeded for today. How do I fix it?
This error indicates you have hit the daily browser-instance limit on the Workers Free plan. Free-plan accounts are capped at free plan limit is 10 minutes of browser use a day once you exceed those, further creation attempts return a 429 until the next UTC day.
To resolve: Upgrade to a Workers Paid plan which allows for more than 10 minutes of usage a day and has higher limits. If you recently upgraded but still see this error, try redeploying your Worker to ensure your usage is correctly associated with your new plan.
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
-