Skip to content

Latest commit

 

History

History

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

README.md

Stagehand + Browserbase: Basic Caching

AT A GLANCE

  • Goal: Demonstrate how Stagehand's caching feature dramatically reduces cost and latency by reusing previously computed actions instead of calling the LLM every time.
  • Shows side-by-side comparison of workflows with and without caching enabled.
  • Demonstrates massive cost savings for repeated workflows (99.9% reduction in LLM calls).
  • Docs → https://docs.stagehand.dev/v3/best-practices/caching#caching-actions

GLOSSARY

QUICKSTART

  1. pnpm install
  2. cp .env.example .env
  3. Add your Browserbase API key to .env
  4. pnpm start (run twice to see cache benefits!)

EXPECTED OUTPUT

  • First run: Executes workflow without cache, then with cache enabled (populates cache)
  • Subsequent runs: Uses cached actions for instant execution with zero LLM calls
  • Displays timing comparison, cost savings, and cache statistics
  • Shows cache location and file structure

HOW CACHING WORKS

Cache Key Generation:

  • Based on instruction text
  • Based on page context
  • Automatically computed

When Cache is Used:

  • ✅ Same instruction
  • ✅ Same page structure
  • ✅ Cache file exists
  • ❌ Different instruction
  • ❌ Page structure changed significantly

Cache Storage:

  • Location: .cache/stagehand-demo
  • Format: JSON files (one per cached action)
  • Persistent across runs

BENEFITS FOR REPEATED WORKFLOWS

Example Scenario: 1,000 customers × 10 portals = 10,000 payment flows

Without caching:

  • 10,000 workflows × 5 actions = 50,000 LLM calls
  • Cost: ~$500-2,500
  • Latency: 2-3s per action × 5 = 10-15s per payment

With caching:

  • First payment per portal: 5 LLM calls (populate cache)
  • Next 999 payments: 0 LLM calls (use cache)
  • Total: 10 portals × 5 actions = 50 LLM calls
  • Cost: ~$0.50-2.50 (99.9% savings!)
  • Latency: <100ms per action × 5 = <0.5s per payment

Key Insight: Payment portals rarely change → Cache actions once → Reuse for thousands of payments → Massive cost + latency reduction

COMMON PITFALLS

  • Missing credentials: verify .env contains BROWSERBASE_API_KEY
  • Cache not working: ensure cacheDir path is writable and check that instruction text matches exactly
  • First run slower: expected behavior - cache is populated on first run, subsequent runs will be instant
  • Find more information on your Browserbase dashboard -> https://www.browserbase.com/sign-in

USE CASES

• Payment processing: Cache form-filling actions for payment portals that don't change frequently, processing thousands of payments with minimal LLM calls. • Data entry automation: Reuse actions for repetitive data entry tasks across similar forms or interfaces. • Testing workflows: Cache test actions to speed up regression testing and reduce API costs during development.

BEST PRACTICES

  • ✅ Enable caching in production for repeated workflows
  • ✅ One cache per portal/interface type
  • ✅ Invalidate cache when page structure changes significantly
  • ✅ Monitor cache hit rate to optimize cache effectiveness
  • ✅ Warm cache with test runs before production deployment

NEXT STEPS

• Customize cache directory: Modify cacheDir to organize caches by workflow type or environment. • Add cache invalidation: Implement logic to clear cache when page structure changes or after a certain time period. • Monitor cache performance: Track cache hit rates and cost savings to measure effectiveness.

TRY IT YOURSELF

  1. Run this script again: pnpm start → Second run will be MUCH faster (cache hits)

  2. Clear cache and run again: rm -rf .cache/stagehand-demo && pnpm start → Back to first-run behavior

  3. Check cache contents: ls -la .cache/stagehand-demo → See cached action files

HELPFUL RESOURCES

📚 Stagehand Docs: https://docs.stagehand.dev/v3/first-steps/introduction 🎮 Browserbase: https://www.browserbase.com 💡 Try it out: https://www.browserbase.com/playground 🔧 Templates: https://www.browserbase.com/templates 📧 Need help? support@browserbase.com 💬 Discord: http://stagehand.dev/discord