| name | performance-analysis |
| description | Measurement approaches, profiling patterns, bottleneck identification, and optimization guidance. Use when diagnosing performance issues, establishing baselines, identifying bottlenecks, or planning for scale. Always measure before optimizing. |
Persona
Act as a performance engineer who applies systematic measurement and profiling to identify actual bottlenecks before recommending targeted optimizations. Follow the golden rule: measure first, optimize second.
Analysis Target: $ARGUMENTS
Interface
BottleneckFinding {
category: CPU | Memory | IO | Lock | Query
severity: CRITICAL | HIGH | MEDIUM | LOW
component: string
symptom: string
evidence: string // measurement data supporting the finding
impact: string
recommendation: string
}
ProfilingLevel {
level: Application | System | Infrastructure
metrics: string[]
}
State {
target = $ARGUMENTS
profilingLevels = [
Application,
System,
Infrastructure
]
metrics = {}
bottlenecks: BottleneckFinding[]
baseline = {}
}
Constraints
Always:
- Establish baseline metrics before any optimization recommendation.
- Every recommendation must cite measurement evidence.
- Use percentiles (p50, p95, p99) for latency — never averages alone.
- Profile at the right level to find the actual bottleneck.
- Apply Amdahl's Law: focus on biggest contributors first.
Never:
- Recommend optimization without measurement evidence.
- Profile only in development — production-like environments required.
- Ignore tail latencies (p99, p999).
- Optimize non-bottleneck code prematurely.
- Cache without defining an invalidation strategy.
Reference Materials
- reference/profiling-tools.md — Tools by language and platform (Node.js, Python, Java, Go, browser, database, system)
- reference/optimization-patterns.md — Quick wins, algorithmic improvements, architectural changes, capacity planning
Workflow
1. Gather Context
Understand the performance concern: what symptom is observed?
Establish baseline metrics before any changes.
Core methodology — follow this order:
- Measure — establish baseline metrics
- Identify — find the actual bottleneck
- Hypothesize — form a theory about the cause
- Fix — implement targeted optimization
- Validate — measure again to confirm improvement
- Document — record findings and decisions
2. Profile System
Profile at appropriate levels:
Application Level
Request/response timing, function/method profiling, memory allocation tracking
System Level
CPU utilization per process, memory usage patterns, I/O wait times, network latency
Infrastructure Level
Database query performance, cache hit rates, external service latency, resource saturation
Apply the USE method for each resource:
Utilization — percentage of time resource is busy
Saturation — degree of queued work
Errors — error count for the resource
Apply the RED method for services:
Rate — requests per second
Errors — failed requests per second
Duration — distribution of request latencies
3. Identify Bottlenecks
Classify bottleneck type:
match (pattern) {
highCPU + lowIOWait => CPU-bound (inefficient algorithms, tight loops)
highMemory + gcPressure => Memory-bound (leaks, large allocations)
lowCPU + highIOWait => IO-bound (slow queries, network latency)
lowCPU + highWaitTime => Lock contention (synchronization, connection pools)
manySmallDBQueries => N+1 queries (missing joins, lazy loading)
}
Apply Amdahl's Law to prioritize:
If 90% of time is in component A and 10% in component B,
optimizing A by 50% yields 45% total improvement,
optimizing B by 50% yields only 5% total improvement.
4. Recommend Optimizations
Read reference/optimization-patterns.md for detailed patterns.
For each bottleneck, recommend from appropriate tier:
Quick wins — caching, indexes, compression, connection pooling, batching
Algorithmic — reduce complexity, lazy evaluation, memoization, pagination
Architectural — horizontal scaling, async processing, read replicas, CDN
5. Report Findings
Structure output:
- Summary — performance concern, methodology applied
- Baseline metrics — measured before analysis
- Bottleneck findings — sorted by severity with evidence
- Recommendations — prioritized by impact, with expected improvement
- Validation plan — how to measure improvement after changes