Advanced: Secrets with binary data¶
Nais Console only supports secrets with string values. You can work around this by Base64-encoding the binary data and store the resulting string, though it also requires that your application does the equivalent decoding.
If you instead want to manage binary data directly, you can use the command line interface (CLI) to create and manage secrets with binary data.
This how-to guides you through creating and managing a secret with binary data using the command line.
Prerequisites¶
- You're part of a Nais team
- You have configured command line access for your machine
Create the secret¶
Create a secret containing binary files using the kubectl command-line tool.
For a secret named cool-cat, the command should look like this:
kubectl create secret generic cool-cat \
  --from-file=cool-cat.jks=/path/to/cool-cat.jks \
  --context $NAIS_ENVIRONMENT \
  --namespace $NAIS_TEAM
- The secret contains a single key, namely cool-cat.jks.
- The value of the key is path to file, namely /path/to/cool-cat.jks.
- The $NAIS_ENVIRONMENTvariable is a placeholder for the environment you're targeting.
- The $NAIS_TEAMvariable is a placeholder for your team.
Update the secret¶
To update the secret, you will need to delete and recreate it with the new files.
For a secret named cool-cat, delete the secret with the following command:
and then recreate the secret with the updated files:
kubectl create secret generic cool-cat \
  --from-file=cool-cat.jks=/path/to/cool-cat.jks \
  --context $NAIS_ENVIRONMENT \
  --namespace $NAIS_TEAM
Any workloads that use the secret must be manually restarted to pick up the changes.
Related pages¶
 Learn how to use a secret in your workload