skills/performance_engineering/SKILL.md
When validating system performance under load, identifying bottlenecks through profiling, or optimizing application responsiveness. Covers load testing (k6, Locust), profiling (CPU, memory, I/O), and optimization strategies (caching, query optimization, Core Web Vitals). Use for capacity planning, regression detection, and establishing performance SLOs.
npx skillsauth add vuralserhat86/antigravity-agentic-skills performance_engineeringInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Performance engineering encompasses load testing, profiling, and optimization to deliver reliable, scalable systems. This skill provides frameworks for choosing the right performance testing approach (load, stress, soak, spike), profiling techniques to identify bottlenecks (CPU, memory, I/O), and optimization strategies for backend APIs, databases, and frontend applications.
Use this skill to validate system capacity before launch, detect performance regressions in CI/CD pipelines, identify and resolve bottlenecks through profiling, and optimize application responsiveness across the stack.
Common Triggers:
Use Cases:
Validate system behavior under expected traffic levels.
When to use: Pre-launch capacity planning, regression testing after refactors, validating auto-scaling.
Find system capacity limits and failure modes.
When to use: Capacity planning, understanding failure behavior, infrastructure sizing decisions.
Identify memory leaks, resource exhaustion, and degradation over time.
When to use: Detecting memory leaks, validating connection pool cleanup, testing long-running batch jobs.
Validate system response to sudden traffic spikes.
When to use: Validating auto-scaling, testing event-driven systems (product launches), ensuring rate limiting works.
Which test type to use?
What am I trying to learn?
├─ Can my system handle expected traffic? → LOAD TEST
├─ What's the maximum capacity? → STRESS TEST
├─ Will it stay stable over time? → SOAK TEST
└─ Can it handle traffic spikes? → SPIKE TEST
For detailed testing patterns, load scenarios, and interpreting results, see references/testing-types.md.
Installation:
brew install k6 # macOS
sudo apt-get install k6 # Linux
Basic Load Test:
import http from 'k6/http';
import { check, sleep } from 'k6';
export const options = {
stages: [
{ duration: '30s', target: 20 },
{ duration: '1m', target: 20 },
{ duration: '30s', target: 0 },
],
thresholds: {
http_req_duration: ['p(95)<500'],
http_req_failed: ['rate<0.01'],
},
};
export default function () {
const res = http.get('https://api.example.com/products');
check(res, {
'status is 200': (r) => r.status === 200,
});
sleep(1);
}
Run: k6 run script.js
For stress, soak, and spike testing examples, see examples/k6/.
Installation:
pip install locust
Basic Load Test:
from locust import HttpUser, task, between
class WebsiteUser(HttpUser):
wait_time = between(1, 3)
host = "https://api.example.com"
@task(3)
def view_products(self):
self.client.get("/products")
@task(1)
def view_product_detail(self):
self.client.get("/products/123")
Run: locust -f locustfile.py --headless -u 100 -r 10 --run-time 10m
For REST API testing and data-driven testing, see examples/locust/.
| Symptom | Profiling Type | Tool | |---------|----------------|------| | High CPU (>70%) | CPU Profiling | py-spy, pprof, DevTools | | Memory growing | Memory Profiling | memory_profiler, pprof heap | | Slow response, low CPU | I/O Profiling | Query logs, pprof block |
py-spy (Production-Safe):
pip install py-spy
# Profile running process
py-spy record -o profile.svg --pid <PID> --duration 30
# Top-like view
py-spy top --pid <PID>
Memory Profiling:
from memory_profiler import profile
@profile
def my_function():
a = [1] * (10 ** 6)
return a
# Run: python -m memory_profiler script.py
pprof (Built-in):
import (
"net/http"
_ "net/http/pprof"
)
func main() {
go func() {
http.ListenAndServe("localhost:6060", nil)
}()
startApp()
}
Capture profile:
# CPU profile (30 seconds)
go tool pprof http://localhost:6060/debug/pprof/profile?seconds=30
# Interactive analysis
(pprof) top
(pprof) web
Chrome DevTools (Browser/Node.js):
Node.js:
node --inspect app.js
# Open chrome://inspect
# Performance tab → Record
clinic.js (Node.js):
npm install -g clinic
clinic doctor -- node app.js
For detailed profiling workflows and analysis, see references/profiling-guide.md and examples/profiling/.
When to cache:
Redis example:
import redis
r = redis.Redis()
def get_cached_data(key, fn, ttl=300):
cached = r.get(key)
if cached:
return json.loads(cached)
data = fn()
r.setex(key, ttl, json.dumps(data))
return data
N+1 prevention:
# Bad: N+1 queries
users = User.query.all()
for user in users:
print(user.orders) # Separate query per user
# Good: Eager loading
users = User.query.options(joinedload(User.orders)).all()
Indexing:
CREATE INDEX idx_users_email ON users(email);
Cursor-based pagination:
app.get('/api/products', async (req, res) => {
const { cursor, limit = 20 } = req.query;
const products = await db.query(
'SELECT * FROM products WHERE id > ? ORDER BY id LIMIT ?',
[cursor || 0, limit]
);
res.json({
data: products,
next_cursor: products[products.length - 1]?.id,
});
});
Key metrics:
Optimization techniques:
For detailed optimization strategies, see references/optimization-strategies.md and references/frontend-performance.md.
| Service Type | p95 Latency | p99 Latency | Availability | |--------------|-------------|-------------|--------------| | User-Facing API | < 200ms | < 500ms | 99.9% | | Internal API | < 100ms | < 300ms | 99.5% | | Database Query | < 50ms | < 100ms | 99.99% | | Background Job | < 5s | < 10s | 99% | | Real-time API | < 50ms | < 100ms | 99.95% |
For detailed SLO framework and performance budgets, see references/slo-framework.md.
GitHub Actions example:
name: performance_engineering
on:
pull_request:
branches: [main]
jobs:
load-test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Install k6
run: |
curl https://github.com/grafana/k6/releases/download/v0.48.0/k6-v0.48.0-linux-amd64.tar.gz -L | tar xvz
sudo mv k6-v0.48.0-linux-amd64/k6 /usr/local/bin/
- name: Run load test
run: k6 run tests/load/api-test.js
Performance budgets:
// k6 test with thresholds (fail build if violated)
export const options = {
thresholds: {
http_req_duration: ['p(95)<500'],
http_req_failed: ['rate<0.01'],
},
};
Standard process:
Best practices:
Primary: k6 (JavaScript-based, Grafana-backed)
When to use: Modern APIs, microservices, CI/CD integration.
Alternative: Locust (Python-based)
When to use: Python-heavy teams, complex user flows.
Python:
Go:
TypeScript/JavaScript:
For detailed tool comparisons, see references/testing-types.md and references/profiling-guide.md.
Detailed Guides:
references/testing-types.md - Load, stress, soak, spike testing patternsreferences/profiling-guide.md - CPU, memory, I/O profiling across languagesreferences/optimization-strategies.md - Caching, database, API optimizationreferences/frontend-performance.md - Core Web Vitals, bundle optimizationreferences/slo-framework.md - Setting SLOs, performance budgetsreferences/benchmarking.md - Benchmarking best practicesExamples:
examples/k6/ - Load, stress, soak, spike testsexamples/locust/ - Python-based load testingexamples/profiling/ - Profiling examples (Python, Go, TypeScript)examples/optimization/ - Caching, query, API optimizationFor comprehensive testing strategies, see the testing-strategies skill.
For CI/CD integration patterns, see the building-ci-pipelines skill.
For infrastructure sizing based on load tests, see the infrastructure-as-code skill.
Performance Engineering v1.1 - Enhanced
Kaynak: k6 Methodology & The Art of Capacity Planning
| Aşama | Doğrulama | |-------|-----------| | 1 | Test verisi (Database seed) yeterli hacimde mi? | | 2 | Load Generator (Test makinesi) CPU darboğazına girdi mi? (False negative riski). | | 3 | 3rd party API'lar (Stripe, Twilio) mock'landı mı? (Masraf ve ban riski). |
tools
Production-tested setup for Zustand state management in React. Includes patterns for persistence, devtools, and TypeScript patterns. Prevents hydration mismatches and render loops.
development
Comprehensive spreadsheet creation, editing, and analysis with support for formulas, formatting, data analysis, and visualization. When Claude needs to work with spreadsheets (.xlsx, .xlsm, .csv, .tsv, etc) for: (1) Creating new spreadsheets with formulas and formatting, (2) Reading or analyzing data, (3) Modify existing spreadsheets while preserving formulas, (4) Data analysis and visualization in spreadsheets, or (5) Recalculating formulas
development
--- name: websocket_engineer router_kit: FullStackKit description: WebSocket specialist for real-time communication systems. Invoke for Socket.IO, WebSocket servers, bidirectional messaging, presence systems. Keywords: WebSocket, Socket.IO, real-time, pub/sub, Redis. triggers: - WebSocket - Socket.IO - real-time communication - bidirectional messaging - pub/sub - server push - live updates - chat systems - presence tracking role: specialist scope: implementation output-format:
tools
Toolkit for interacting with and testing local web applications using Playwright. Supports verifying frontend functionality, debugging UI behavior, capturing browser screenshots, and viewing browser logs.