home / skills / julianobarbosa / claude-code-skills / k8s-timezone-config
This skill helps configure Kubernetes pod timezone to America/Sao_Paulo by injecting TZ env vars across containers and pods for accurate local timestamps.
npx playbooks add skill julianobarbosa/claude-code-skills --skill k8s-timezone-configReview the files below or copy the command above to add this skill to your agents.
---
name: k8s-timezone-config
description: Configure timezone for Kubernetes pods using TZ environment variable. Use when deploying workloads that need Brazil/São Paulo timezone or when logs show UTC (+0000) instead of local time.
---
# Kubernetes Pod Timezone Configuration
**Standard timezone for Hypera infrastructure:** `America/Sao_Paulo`
## Problem
Kubernetes pods run in UTC by default. Logs and application timestamps show `+0000` offset instead of local Brazil time (`-0300`).
## Solution
Add the `TZ` environment variable to container specifications.
## Implementation Patterns
### 1. Helm Values (extraEnv pattern)
For Helm charts that support `extraEnv`:
```yaml
# In values.yaml
extraEnv:
- name: TZ
value: America/Sao_Paulo
```
### 2. Multiple Containers
When a deployment has multiple containers (e.g., API server + frontend), add `TZ` to **ALL** containers:
```yaml
apiServer:
extraEnv:
- name: TZ
value: America/Sao_Paulo
frontend:
extraEnv:
- name: TZ
value: America/Sao_Paulo
```
### 3. Raw Kubernetes Deployment
```yaml
apiVersion: apps/v1
kind: Deployment
spec:
template:
spec:
containers:
- name: app
env:
- name: TZ
value: America/Sao_Paulo
```
### 4. StatefulSet
```yaml
apiVersion: apps/v1
kind: StatefulSet
spec:
template:
spec:
containers:
- name: app
env:
- name: TZ
value: America/Sao_Paulo
```
## Verification
After deployment, verify timezone is set correctly:
```bash
# Check pod logs for timestamp offset
# Before: 2026-01-13T11:37:06 +0000
# After: 2026-01-13T08:37:06 -0300
# Or exec into pod
kubectl exec -it <pod-name> -n <namespace> -- date
# Should show: Mon Jan 13 08:37:06 -03 2026
```
## Common Applications Requiring Timezone
| Application | Config Location | Notes |
|-------------|-----------------|-------|
| Dependency-Track | `apiServer.extraEnv` + `frontend.extraEnv` | Both containers need TZ |
| Grafana | `env` or `extraEnvVars` | Single container |
| Loki | `extraEnv` | Affects log timestamps |
| Prometheus | `server.env` | Affects alert timestamps |
| DefectDojo | `extraEnv` | Django app |
| PostgreSQL | `primary.extraEnvVars` | Database timestamps |
## Important Notes
1. **Restart required**: Pods must restart for TZ changes to take effect
2. **All containers**: Set TZ on ALL containers in a pod, including sidecars
3. **Init containers**: Also set TZ on init containers if they log timestamps
4. **Cron jobs**: Kubernetes CronJob schedules are always UTC - TZ only affects container-level time
## Hypera GitOps Workflow
1. Edit values.yaml in `argo-cd-helm-values/kube-addons/<service>/<cluster>/values.yaml`
2. Add TZ environment variable to all containers
3. Commit and push (ArgoCD auto-syncs)
4. Verify pods restart with new timezone
## Reference
- IANA Timezone Database: `America/Sao_Paulo` = UTC-3 (no DST since 2019)
- Linux TZ variable: Uses `/usr/share/zoneinfo/America/Sao_Paulo`
This skill configures the timezone for Kubernetes pods by injecting the TZ environment variable set to America/Sao_Paulo. It provides patterns for Helm values, raw manifests, StatefulSets, CronJobs, and multi-container pods so logs and application timestamps reflect Brazil time instead of UTC. The guidance covers verification and common pitfalls to ensure consistent application behavior.
The skill adds an env entry named TZ with value America/Sao_Paulo to container specs so the process inside the container uses the correct timezone file. It shows where to add TZ for Helm charts (extraEnv/extraEnvVars), raw Deployment/StatefulSet manifests, init containers, sidecars, and CronJob containers. It also explains verification commands and restart requirements.
Will setting TZ change Kubernetes CronJob schedule?
No. Kubernetes CronJob schedules are evaluated in UTC. TZ only affects time inside the container, not the CronJob controller schedule.
Do pods need to be restarted after adding TZ?
Yes. Updating environment variables requires pod restart or pod recreation for the new TZ to take effect.