.secrets Guide

# docker-compose.yml (Swarm mode) secrets: db_password: external: true services: app: secrets: - db_password Even if you use a vault, the .secrets file has three insidious ways of leaking data. 1. The Log File Your application code might have a debug statement: console.log(process.env) . If the .secrets file is loaded into environment variables, that log line dumps all your passwords to Datadog or Splunk. Always scrub your logs. 2. The Dump File When a Node.js or Python app crashes, it often creates a core dump or a heap snapshot. These memory dumps contain the exact string values of your .secrets file. If a crash report is sent to a third-party service (Sentry, Bugsnag), your secrets go with it. 3. The Backup You set up a nightly backup script for your home directory. It captures /home/user/projects/ . It captures the .secrets file. The backup goes to an unencrypted S3 bucket. The bucket gets misconfigured. You lose everything. Best Practices: How to Tame the .secrets Beast To use .secrets files safely, implement these five ironclad rules: Rule 1: Never Store Production Secrets on a Laptop Your local .secrets file should only contain development credentials (localhost database, mock API keys). Production secrets should require a VPN or a vault token to access. Rule 2: Rotate Secrets Aggressively If a .secrets file is ever exposed—even for a second—rotate every secret inside it. Your CI/CD should support automatic rotation. Manual rotation is boring; automatic rotation is secure. Rule 3: Use Pre-Commit Hooks Install a tool like detect-secrets (Yelp) or truffleHog . These run a scan every time you type git commit . If they detect a string that looks like an API key or a high-entropy password (like sk_live_... ), they block the commit.

# .secrets.template DATABASE_PASSWORD=<your-local-password> API_KEY=<get-from-vault> The developer copies .secrets.template to .secrets and fills in the blanks. The template contains no real secrets, so it is safe in Git. The .secrets file is a bridge technology. It is human-readable, easy to debug, and works everywhere. But the industry is moving toward ephemeral secrets and OIDC (OpenID Connect) . .secrets

Your future self—and your security team—will thank you. Have a story about a .secrets leak that almost ruined your weekend? Share it in the comments below. Let's learn from our collective scars. # docker-compose