Manage ksonnet environments
An environment is a deployment target for your ksonnet app and its constituent
components. You can use ksonnet to deploy a given app to multiple environments,
such as dev
and prod
.
Intuitively, an environment acts as a sort of "named cluster", similar to a
Kubernetes context. (Running ks env add --help
provides more detail
about the fields that you need to create an environment).
All of this environment info is cached in local files. Metadata such as k8s version, API server address, and namespace are found in app.yaml
. Environments are
represented as a hierarchy in the environments/
directory of a ksonnet app, like
'default' and 'us-west/staging' in the example below.
├── environments
│ ├── base.libsonnet
│ ├── default
│ │ ├── globals.libsonnet // Default generated environment ('ks init')
│ │ ├── main.jsonnet
│ │ └── params.libsonnet
│ └── us-west
│ └── staging // Example of user-generated env ('ks env add')
│ ├── globals.libsonnet
│ ├── main.jsonnet // Main file that imports all components (expanded on apply, delete, etc). Add environment-specific logic here.
│ └── params.libsonnet // Customize components *per-environment* here.
ks env [flags]
-h, --help help for env
--dir string Ksonnet application root to use; Defaults to CWD
--tls-skip-verify Skip verification of TLS server certificates
-v, --verbose count Increase verbosity. May be given multiple times.
- ks - Configure your application to deploy to a Kubernetes cluster
- ks env add - Add a new environment to a ksonnet application
- ks env current - Sets the current environment
- ks env describe - Describe an environment
- ks env list - List all environments in a ksonnet application
- ks env rm - Delete an environment from a ksonnet application
- ks env set - Set environment-specific fields (name, namespace, server)
- ks env targets - Set target modules for an environment
- ks env update - Updates the libs for an environment