skills/render-keyvalue/SKILL.md
Provisions and configures Render Key Value (Redis-compatible Valkey 8) instances for caching, session storage, and job queues. Use when the user needs Redis, Key Value, Valkey, a cache, session store, job queue backend, or needs to configure maxmemory policy, ipAllowList, connection strings, or internal vs external access. Trigger terms: Key Value, Redis, Valkey, cache, session store, REDIS_URL, maxmemory, ipAllowList, allkeys-lru, noeviction.
npx skillsauth add render-oss/skills render-keyvalueInstall 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.
Render Key Value provides low-latency, Redis-compatible in-memory storage running Valkey 8. Use it as a shared cache, session store, or job queue backend. Compatible with virtually all Redis client libraries.
For background worker setup and queue framework patterns, see render-background-workers. For Blueprint authoring, see render-blueprints.
New instances run Valkey 8, an open-source Redis fork. It is a drop-in replacement for Redis—existing Redis client libraries work without changes. Legacy instances (created before Feb 2025) run Redis 6.
Every instance has two URLs:
| URL type | When to use | Auth required |
|----------|-------------|---------------|
| Internal (redis://red-xxx:6379) | From Render services in the same region | No (by default) |
| External (rediss://red-xxx:6379) | From outside Render (local dev, CI) | Always |
Always prefer the internal URL for production services—lower latency, no TLS overhead, communicates over the private network.
External connections are disabled by default. Enable them by adding IP ranges to the access control list in the Dashboard.
By default, internal connections are unauthenticated. You can require auth for internal connections in the Dashboard for compliance or extra security. This changes the internal URL to include credentials:
redis://default:PASSWORD@red-xxx:6379
Warning: Enabling internal auth breaks existing unauthenticated connections. Migrate clients to the authenticated URL first.
Critical decision. Choose based on your use case:
| Use case | Policy | Why |
|----------|--------|-----|
| Cache (can lose data) | allkeys-lru | Evicts least-recently-used keys to free space |
| Job queue (cannot lose data) | noeviction | Returns error on writes when full; never drops keys |
| Session store | allkeys-lru or volatile-lru | Sessions can be regenerated; LRU is safe |
All available policies:
| Policy | Behavior | Memory fills up? |
|--------|----------|-----------------|
| allkeys-lru | Evict any key by LRU | No |
| noeviction | Error on writes when full | Yes |
| volatile-lru | Evict keys with TTL by LRU | Yes |
| volatile-lfu | Evict keys with TTL by LFU | Yes |
| allkeys-lfu | Evict any key by LFU | No |
| volatile-random | Evict random keys with TTL | Yes |
| allkeys-random | Evict any random key | No |
| volatile-ttl | Evict keys nearest to expiry | Yes |
services:
- type: keyvalue
name: cache
plan: starter
region: oregon
maxmemoryPolicy: allkeys-lru
ipAllowList: []
ipAllowList is requiredBlueprints must include ipAllowList on Key Value services. Common patterns:
| Value | Meaning |
|-------|---------|
| [] | No external access (internal only—recommended for most apps) |
| [{source: "0.0.0.0/0", description: "everywhere"}] | Open external access (use sparingly) |
| [{source: "203.0.113.0/24", description: "office"}] | Specific IP ranges |
Use fromService with type: keyvalue and property: connectionString:
envVars:
- key: REDIS_URL
fromService:
name: cache
type: keyvalue
property: connectionString
Available fromService properties for Key Value:
| Property | Value |
|----------|-------|
| connectionString | Full internal URL (redis://red-xxx:6379) |
| host | Hostname only |
| port | Port only (typically 6379) |
appendfsync everysec. You may lose up to 1 second of writes on interruption.See references/connection-examples.md for client code in Node.js (ioredis, node-redis), Python (redis-py), Ruby (redis-rb, Sidekiq), and Go.
| Mistake | Fix |
|---------|-----|
| Missing ipAllowList in Blueprint | Add ipAllowList: [] for internal-only access |
| Using allkeys-lru for job queues | Switch to noeviction—LRU eviction drops queued jobs |
| Connecting with external URL from a Render service | Use the internal URL for lower latency and no auth requirement |
| Forgetting type: keyvalue in fromService | type is required; without it the wiring fails |
| Using deprecated redis type alias | Prefer keyvalue in new Blueprints (redis still works but is deprecated) |
| Document | Contents |
|----------|----------|
| references/connection-examples.md | Client code for Node.js, Python, Ruby, Go |
| references/troubleshooting.md | Auth errors, connection refused, memory full, migration from Redis 6 |
render.yaml schema, fromService patternsREDIS_URL and other connection varsdevelopment
Configures Render web services—port binding, TLS, health checks, custom domains, auto-deploy, PR previews, persistent disks, and deploy lifecycle. Use when the user needs to set up a web service, fix health check failures, add a custom domain, configure zero-downtime deploys, or troubleshoot port binding issues.
development
Deploys and configures static sites on Render's global CDN—build commands, publish paths, SPA routing, redirects, custom headers, and PR previews. Use when the user needs to deploy a static site, set up a React/Vue/Hugo/Gatsby frontend, configure SPA fallback routing, add redirect rules, customize response headers, or choose between a static site and a web service for their frontend. Trigger terms: static site, CDN, SPA, single-page app, React deploy, Vue deploy, Hugo, Gatsby, Docusaurus, Jekyll, staticPublishPath.
tools
Scales Render services—configures autoscaling targets, chooses instance types, sets manual instance counts, and optimizes cost. Use when the user needs to handle more traffic, set up autoscaling, pick the right instance type, reduce costs, or troubleshoot scaling behavior like slow scale-down or stuck instances.
development
Configures Render private services—internal-only apps that accept traffic exclusively from other Render services over the private network. Use when the user needs an internal API, microservice, gRPC server, sidecar, or any service that should not be publicly accessible. Also use when choosing between a private service and a background worker. Trigger terms: private service, pserv, internal service, internal API, microservice, gRPC, not public, private network service.