Skip to content

Latest commit

 

History

History
70 lines (51 loc) · 6.54 KB

envvar-autoinject.md

File metadata and controls

70 lines (51 loc) · 6.54 KB
copyright lastupdated keywords subcollection
years
2020, 2022
2022-12-12
applications in code engine, apps in code engine, http requests in code engine, deploy apps in code engine, app workloads in code engine, deploying workloads in code engine, application, app, memory, cpu, environment variables
codeengine

{{site.data.keyword.attribute-definition-list}}

Automatically injected environment variables

{: #inside-env-vars}

When you deploy an application or run a job, {{site.data.keyword.codeengineshort}} automatically injects certain environment variables into the app or the job. {: shortdesc}

Automatically injected environment variables for apps

{: #inside-env-vars-app}

When you deploy an application, {{site.data.keyword.codeengineshort}} automatically injects certain environment variables into the app. The following table lists automatically injected environment variables into each instance of your deployed app. The following examples of automatically injected environment variables are based on an app that is named myapp, which references the {{site.data.keyword.codeengineshort}} sample image, icr.io/codeengine/codeengine.

The first 3 environment variables, CE_APP, CE_DOMAIN, and CE_SUBDOMAIN are used to construct the URL of an application, https://CE_APP.CE_SUBDOMAIN.CE_DOMAIN. For example, if CE_APP=myapp, CE_SUBDOMAIN=01234567-abcd and CE_DOMAIN=us-south.codeengine.dev.appdomain.cloud, your application external URL is https://myapp.01234567-abcd.us-south.codeengine.dev.appdomain.cloud. The private URL of your application is appName.CE_SUBDOMAIN, or myapp.01234567-abcd.

Environment variable Description Example
CE_APP The name of the application. CE_APP=myapp
CE_DOMAIN The domain name portion of the URL of the application (and project). CE_DOMAIN=us-south.codeengine.dev.appdomain.cloud
CE_SUBDOMAIN The subdomain portion of the URL associated with the application (and project). If you are familiar with Kubernetes, CE_SUBDOMAIN maps to the Kubernetes namespace associated with your project. CE_SUBDOMAIN=01234567-abcd
HOME Your home directory that is running the app. HOME=/root
HOSTNAME The name of instance that your app is deployed to. HOSTNAME=myapp-00001-deployment-65684cffd-xng7z
K_CONFIGURATION The name of your app. K_CONFIGURATION=myapp
K_REVISION The name of the current revision of your deployed app. K_REVISION=myapp-00001
K_SERVICE The name of your app. K_SERVICE=myapp
PATH The list of directories in which the system looks for executables. PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
PORT The port that your app listens to receive HTTP requests. PORT=8080
PWD The current working directory. PWD=/
{: caption="Automatically injected environment variables when deploying {{site.data.keyword.codeengineshort}} apps"}

Note that you can override the PORT variable by deploying your app from the console and specifying the Listening port value or by using the CLI and setting the --port option.

Automatically injected environment variables for jobs

{: #inside-env-vars-jobs}

When you run a job, {{site.data.keyword.codeengineshort}} automatically injects certain environment variables into the job run instance. The following table lists automatically injected environment variables into each instance of your running job. The following examples of automatically injected environment variables are based on a job that is named myjob, which references the {{site.data.keyword.codeengineshort}} sample image, icr.io/codeengine/codeengine.

Environment variable Description Example
CE_DOMAIN The domain name of the project. CE_DOMAIN=us-south.codeengine.appdomain.cloud
CE_JOB The name of the defined job configuration that was used for the job run. CE_JOB=myjobdef
CE_JOBRUN The name of the job run. CE_JOBRUN=myjob-jobrun-f5kxz
CE_SUBDOMAIN The subdomain associated with the project in which your job is running. If you are familiar with Kubernetes, CE_SUBDOMAIN maps to the Kubernetes namespace that is associated with your project. CE_SUBDOMAIN=01234567-abcd
HOME Your home directory that is running the job. HOME=/root
HOSTNAME The name of instance that your app is deployed to. HOSTNAME=myjob-jobrun-6bgmg-0-0
JOB_INDEX The index of a specific job run instance. JOB_INDEX=1
JOB_INDEX_RETRY_COUNT The current retry count of the job instance. JOB_INDEX_RETRY_COUNT=0
JOB_MODE The mode for runs of a job. In task mode, jobs run for a maximum time and failed instances are retried per the job retries limit. In daemon mode, jobs run without a maximum time and failed instances are restarted indefinitely. JOB_MODE=task
JOB_RETRY_LIMIT The configured retry limit of the jobrun. JOB_RETRY_LIMIT=3
PATH The list of directories in which the system looks for executables. PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
PWD The current working directory. PWD=/
{: caption="Automatically injected environment variables when deploying {{site.data.keyword.codeengineshort}} jobs"}

Note that each job run instance gets its own index from the array of indices that were specified when the job was created. The JOB_INDEX environment variable contains the index value.

While the job itself doesn't have a URL associated with it, the CE_DOMAIN and CE_SUBDOMAIN values might be useful if you need to reference an application that is running in the same project. The full external URL of this application is appName.CE_SUBDOMAIN.CE_DOMAIN. To reference the private URL of an application, use appName.CE_SUBDOMAIN.