copyright | lastupdated | keywords | subcollection | ||
---|---|---|---|---|---|
|
2021-09-16 |
environment variables with code engine, environment variables, creating environment variables, working with environment variables, key-value pair |
codeengine |
{:DomainName: data-hd-keyref="APPDomain"} {:DomainName: data-hd-keyref="DomainName"} {:android: data-hd-operatingsystem="android"} {:api: .ph data-hd-interface='api'} {:apikey: data-credential-placeholder='apikey'} {:app_key: data-hd-keyref="app_key"} {:app_name: data-hd-keyref="app_name"} {:app_secret: data-hd-keyref="app_secret"} {:app_url: data-hd-keyref="app_url"} {:audio: .audio} {:authenticated-content: .authenticated-content} {:beta: .beta} {:c#: .ph data-hd-programlang='c#'} {:c#: data-hd-programlang="c#"} {:cli: .ph data-hd-interface='cli'} {:codeblock: .codeblock} {:curl: #curl .ph data-hd-programlang='curl'} {:curl: .ph data-hd-programlang='curl'} {:deprecated: .deprecated} {:dotnet-standard: .ph data-hd-programlang='dotnet-standard'} {:download: .download} {:external: .external target="_blank"} {:external: target="_blank" .external} {:faq: data-hd-content-type='faq'} {:fuzzybunny: .ph data-hd-programlang='fuzzybunny'} {:generic: data-hd-operatingsystem="generic"} {:generic: data-hd-programlang="generic"} {:gif: data-image-type='gif'} {:go: .ph data-hd-programlang='go'} {:help: data-hd-content-type='help'} {:hide-dashboard: .hide-dashboard} {:hide-in-docs: .hide-in-docs} {:important: .important} {:ios: data-hd-operatingsystem="ios"} {:java: #java .ph data-hd-programlang='java'} {:java: .ph data-hd-programlang='java'} {:java: data-hd-programlang="java"} {:javascript: .ph data-hd-programlang='javascript'} {:javascript: data-hd-programlang="javascript"} {:middle: .ph data-hd-position='middle'} {:navgroup: .navgroup} {:new_window: target="_blank"} {:node: .ph data-hd-programlang='node'} {:note: .note} {:objectc: .ph data-hd-programlang='Objective C'} {:objectc: data-hd-programlang="objectc"} {:org_name: data-hd-keyref="org_name"} {:php: .ph data-hd-programlang='PHP'} {:php: data-hd-programlang="php"} {:pre: .pre} {:preview: .preview} {:python: .ph data-hd-programlang='python'} {:python: data-hd-programlang="python"} {:release-note: data-hd-content-type='release-note'} {:right: .ph data-hd-position='right'} {:route: data-hd-keyref="route"} {:row-headers: .row-headers} {:ruby: .ph data-hd-programlang='ruby'} {:ruby: data-hd-programlang="ruby"} {:runtime: architecture="runtime"} {:runtimeIcon: .runtimeIcon} {:runtimeIconList: .runtimeIconList} {:runtimeLink: .runtimeLink} {:runtimeTitle: .runtimeTitle} {:screen: .screen} {:script: data-hd-video='script'} {:service: architecture="service"} {:service_instance_name: data-hd-keyref="service_instance_name"} {:service_name: data-hd-keyref="service_name"} {:shortdesc: .shortdesc} {:space_name: data-hd-keyref="space_name"} {:step: data-tutorial-type='step'} {:step: data-tutorial-type='step'} {:subsection: outputclass="subsection"} {:support: data-reuse='support'} {:swift: #swift .ph data-hd-programlang='swift'} {:swift: .ph data-hd-programlang='swift'} {:swift: data-hd-programlang="swift"} {:table: .aria-labeledby="caption"} {:term: .term} {:terraform: .ph data-hd-interface='terraform'} {:tip: .tip} {:tooling-url: data-tooling-url-placeholder='tooling-url'} {:topicgroup: .topicgroup} {:troubleshoot: data-hd-content-type='troubleshoot'} {:tsCauses: .tsCauses} {:tsResolve: .tsResolve} {:tsSymptoms: .tsSymptoms} {:tutorial: data-hd-content-type='tutorial'} {:ui: .ph data-hd-interface='ui'} {:unity: .ph data-hd-programlang='unity'} {:url: data-credential-placeholder='url'} {:user_ID: data-hd-keyref="user_ID"} {:vbnet: .ph data-hd-programlang='vb.net'} {:video: .video}
{: #envvar}
Learn how to work with environment variables in {{site.data.keyword.codeengineshort}}. You can set environment variables as key-value pairs that can be used by your application or job. {: shortdesc}
{: #envvar-create}
Create and manage environment variables with {{site.data.keyword.codeengineshort}}. {: shortdesc}
You can define environment variables as literal values or you can reference an existing secret or configmap. {{site.data.keyword.codeengineshort}} uses environment variables to enable secrets and configmaps to be used by your job or application.
{: #envvar-create-ui}
Create and update environment variables with the {{site.data.keyword.codeengineshort}} console. {: shortdesc}
You can define environment variables when you create your app or job, or when you update an existing app or job from the console.
Before you begin
- You must create your project and the project{: external} must be in
active
status. - Determine whether you want to create a literal environment variable or create an environment variable that references an existing secret or configmap. If you want your environment variable to fully reference an existing secret or configmap or reference individual keys in an existing secret or configmap, the secret or configmap must exist. See create a secret or create a configmap to define your secret or configmap before proceeding.
-
To open the dialog to define your environment variable on the Add environment variable page, complete one of the following choices.
- If you are creating an app, from the Create application page, expand the Environment variables (optional) section. You can add one or more environment variables to the app that you are creating. Click Add to open the Add environment variable page.
- If you are creating a job, from the Create job page, expand the Environment variables (optional) section. Click Add to open the Add environment variable page.
- If you are updating an existing app or job to add environment variables, go to the existing app or job and click the Environment variables tab. Click Add to open the Add environment variable page.
-
From the Add environment variable page, create an environment variable in one of the following ways,
- To create a literal environment variable, choose
Literal value
, specify the name for the literal environment variable, and provide a value. Notice that theResulting definition
section displays the name of the environment variable and its value. - To create an environment variable that fully references a configmap, choose
Reference full configmap
, and then select the existing configmap. For this case, all keys of the selected configmap are referenced as part of the environment variable. Notice that theResulting definition
section displays the name of the keys in the configmap, but does not display the actual values of the keys that are referenced within the configmap. - To create an environment variable that references an individual key of a defined configmap, choose
Reference key in configmap
, select the existing configmap that you want, and then select the key to reference as part of the environment variable. After you select the individual key in the configmap that you want to reference, notice that theResulting definition
section displays the name of the selected key in the configmap, but does not display the actual value of the key that is referenced within the configmap. - To create an environment variable that fully references a secret, choose
Reference full secret
, and then select the existing secret. For this case, all keys of the selected secret are referenced as part of the environment variable. Notice that theResulting definition
section displays the name of the keys in the secret, but does not display the actual values of the keys that are referenced within the secret. - To create an environment variable that references an individual key of a defined secret, choose
Reference key in secret
, select the existing secret that you want, and then select the key to reference as part of the environment variable. After you select the individual key in the secret that you want to reference, notice that theResulting definition
section displays the name of the selected key in the secret, but does not display the actual value of the key that is referenced within the secret.
From the console, you can reference only one individual key of a defined configmap or secret per environment variable. If you need to reference more than one key of a configmap or secret, then repeat the steps to define another environment variable that references a different key. {: note}
- To create a literal environment variable, choose
-
Click Done to save your changes. This action adds your environment variable to the table on the Environment variables tab. To continue adding environment variables, click Add.
-
Complete the create or update for your app or job with the defined environment variable.
- If you are creating an app or job, when you click Create, the app or job is deployed with your environment variables.
- If you are updating an existing app or job to add an environment variable, click Save and deploy to update the app or click Save to update your job with the new environment variables.
-
When your app or job is in
Ready
state, your app or job is updated with your environment variables.
The following table describes information about your environment variables.
Heading | Description |
---|---|
Name |
The name of your environment variable. |
Defined by |
Specifies whether the environment variable is of type literal , or whether the environment variable is a fully referenced configmap or secret, or whether specific keys of a secret or configmap are referenced. |
Value or reference |
Displays the literal value, the fully referenced configmap or secret, or the referenced keys of a configmap or secret. |
{: caption="Table of environment variables"} |
For example, let's create an app and set environment variables for the app.
- Create an app that is named
myapp
, which uses thedocker.io/ibmcom/codeengine
image. Thishello-world
app includes theTARGET
environment variable, and the app printsHello ${TARGET} from {{site.data.keyword.codeengineshort}}
and prints a listing of environment variables. If theTARGET
environment variable is empty,Hello World from {{site.data.keyword.codeengineshort}}
is returned. - Go to this app in the console.
- When the app is in
Ready
state, click Send request to review the app output. Themyapp
app returns aHello World from {{site.data.keyword.codeengineshort}}
response and prints the environment variables that are included in this app. - Click the Environment variables tab.
- Create the following environment variables.
- Click Add to open the Add environment variable page and create a literal environment variable. For example, create a literal environment variable with the name
literalenvvar
and with the value ofThis is my literal
. Click Done to save your changes. - Click Add to open the Add environment variable page and create an environment variable that fully references a configmap. Before you can reference a configmap, it must exist. For this example, a configmap with the name
mycolorconfigmap
exists and contains the following key-value pairs:key1=blue
,key2=green
, andkey3=yellow
. Create an environment variable that fully references themycolorconfigmap
configmap, including all of its key-value pairs. Notice that theResulting definition
section displays the name of the keys in the configmap, but does not display the actual values of the keys that are referenced within the configmap. Click Done to save your changes. - Click Add to open the Add environment variable page and create another environment variable that references an individual key of a defined secret. Before you can reference a secret, it must exist. For this example, a secret with the name
mynewsecret
exists and contains the following key-value pairs:newsec1=mynewsecret1
,newsec2=mynewsecret2
, andnewsec3=mynewsecret3
. Create an environment variable that references thenewsec2
key of themynewsecret
secret. Notice theResulting definition
section displays the name of the selected key in the secret, but does not display the actual value of the key that is referenced within the secret. Click Done to save your changes.
- Click Add to open the Add environment variable page and create a literal environment variable. For example, create a literal environment variable with the name
- Click Save and deploy to update the app with the new environment variables.
- When the app is in
Ready
state, your app is updated with your environment variables. - Click Send request or Open application URL to display the application result. With this app revision, this app outputs
Hello World from {{site.data.keyword.codeengineshort}}
and the output includes the names of the environment variables, which were added in the previous steps.
When you set environment variables in your app or job, this action adds a new environment variable or overrides an existing environment variable. If you have an environment variable with the same Name, and specify a different value than the previously defined environment variable, then the updated environment variable overrides the existing value. For example, if you have a defined environment variable that is named envvar1
and its value is myenvar1
, and you define another environment variable that is also named envvar1
and specify its value as mynewenvvar1
, then after you save and deploy your updated app or you save your updated job, your running app, or job uses the envvar1
environment variable with value mynewenvvar1
.
{: note}
{: #envvar-update-ui}
- To update an existing environment variable, go to your app or job that includes the environment variable that you want to change and click the Environment variables tab to display your table of environment variables.
- From the table of environment variables, click the environment variable that you want to update.
- From the Edit environment variable page, make your update and click Done to save your changes. When you edit your environment variable, you can change the Defined by value and its corresponding required fields.
- Click Save and deploy to deploy your application with your changes or click Save to run your job with your changes. When your app or job is in
Ready
state, your app or job is updated with your environment variables.
{: #envvar-create-cli}
Create and manage environment variables with the {{site.data.keyword.codeengineshort}} CLI. {: shortdesc}
You can define environment variables when you create your app or job, or when you update an existing app or job with the CLI.
When you create an environment variable with the CLI, you can reference configmaps or secrets, or you can create a literal environment variable. These instructions describe creating and updating literal environment variables with the CLI.
For detailed scenarios about referencing full secrets and configmaps as environment variables, overriding references, and removing references in the CLI, see Referencing secrets and configmaps.
Before you begin
- Set up your {{site.data.keyword.codeengineshort}} CLI environment.
- Create and work with a project.
{: #envvar-create-cli-app}
Create and update environment variables for your app as follows,
-
To create and set an environment variable for your app, use the
--env
option with theapp create
orapp update
command. The following example creates themyapp
application that uses theibmcom/codeengine
image, and defines theenvA
andenvB
environment variables.ibmcloud ce application create --name myapp --image ibmcom/codeengine --env envA=A --env envB=B
{: pre}
-
To update environment variables for an existing application, use the
--env
option with theapp update
command. The following example updates themyapp
application to overwrite the value ofenvA
and adds theenvC
environment variable.ibmcloud ce application update --name myapp --env envA=AA --env envC=C
{: pre}
{: #envvar-create-cli-job}
Set and update environment variables for your job as follows,
-
To create and set an environment variable for your job, use the
--env
option with thejob create
,job update
,jobrun submit
, orjobrun resubmit
command. The following example creates themyjob
job that uses theibmcom/codeengine
image, and defines theenvA
environment variable.ibmcloud ce job create --name myjob --image ibmcom/codeengine --env envA=A
{: pre}
-
To update environment variables for an existing job, use the
--env
option with thejob update
,jobrun submit
, orjobrun resubmit
command.
Example 1
The following example updates the myjob
job to overwrite the value of envA
and adds the envB
environment variable.
ibmcloud ce job update --name myjob --env envA=AA --env envB=B
{: pre}
Run the job get
command to display details of the job, including its environment variables.
ibmcloud ce job get --name myjob
{: pre}
Example output
Getting job 'myjob'...
OK
Name: myjob
[...]
Environment Variables:
Type Name Value
Literal envA AA
Literal envB B
Image: ibmcom/codeengine
[...]
{: screen}
Example 2
The following example runs the myjob
job, overwrites the value of envA
, and adds the envD
environment variable for this job run.
ibmcloud ce jobrun submit --job myjob --name myjobrun1 --env envB=BB --env envC=C
{: pre}
Run the jobrun get
command to display details of the job run, including its environment variables.
ibmcloud ce jobrun get --name myjobrun1
{: pre}
Example output
[...]
Name: myjobrun1
[...]
Job Ref: myjob
Environment Variables:
Type Name Value
Literal envA AA
Literal envB BB
Literal envC C
Image: ibmcom/codeengine
[...]
Instances:
Name Running Status Restarts Age
myjobrun1-0-0 0/1 Succeeded 0 17s
{: screen}
{: #envvar-upd-consider}
Consider the following information when you update an app or job that has an environment variable that references configmaps or secrets.
- When you update an app or job that has an environment variable that fully references a configmap (or secret) to fully reference a different configmap (or secret), full references override other full references in the order in which they are set (the last referenced set overrides the first set).
- When you update an app or job that has an environment variable that references a key in one configmap (or secret) to reference the same key in a different configmap (or secret), then the last referenced key is used.
- When you update an app or job that has an environment variable that fully references a configmap (or secret) to add a reference to a specific key, then the specific key reference overrides the full configmap (or secret) reference. {: note}
{: #envvar-delete}
When you no longer need an environment variable, you can delete it. {: shortdesc}
{: #envvar-delete-ui}
- From the console, go to the app or job that has the environment variable that you want to delete. Click the Environment variables tab.
- From the table of environment variables, delete the environment variable that you want to remove from the app or job.
- Click Save and deploy to update the app or click Save to update your job with the new environment variables. When your app or job is in
Ready
state, your app or job is updated with your current environment variables.
{: #envvar-delete-cli}
When you work with environment variables with the CLI, you can reference existing configmaps or secrets, or you can work with literal environment variables. These instructions describe deleting literal environment variables with the CLI.
For detailed scenarios about removing references to full secrets and configmaps in the CLI, see Referencing secrets and configmaps.
{: #envvar-delete-cli-app}
-
To remove an environment variable for your app, use the
--env-rm
option with theapp update
command. The following example updates themyapp
application to delete theenvA
environment variable.ibmcloud ce application update --name myapp --env-rm envA
{: pre}
{: #envvar-delete-cli-job}
To remove an environment variable for your job, use the --env-rm
option with the job update
or jobrun resubmit
command.
Use the --env-rm
option with the job update
command to remove environment variables set on the job. Use the --env-rm
option with the jobrun resubmit
command to remove environment variables set on a specified job run.
{: note}
-
The following example updates the
myjob
job to delete theenvA
environment variable.ibmcloud ce job update --name myjob --env-rm envA
{: pre}
Use the
job get
command to display details of the job, including its environment variables. -
The following example resubmits the
myjobrun1
job run and deletes theenvC
environment variable.ibmcloud ce jobrun resubmit --jobrun myjobrun1 --name jobrun2resuba--env-rm envC
{: pre}
Run the
jobrun get
command to display details of the job run, including its environment variables.ibmcloud ce jobrun get --name jobrun2resuba
{: pre}
Example output
Getting jobrun 'jobrun2resuba'... Getting instances of jobrun 'jobrun2resuba'... Getting events of jobrun 'jobrun2resuba'... [...] Name: jobrun2resuba [...] Job Ref: myjob Environment Variables: Type Name Value Literal envB BB Image: ibmcom/codeengine [...] Instances: Name Running Status Restarts Age jobrun2resuba-0-0 0/1 Succeeded 0 21s
{: screen}