You can restage apps on a new stack. Here you will find a description of stacks and lists of stacks that are supported on .

To restage a Windows app on a new Windows stack, see Changing Windows Stacks.

You can also use the Stack Auditor plugin for the Cloud Foundry Command Line Interface (cf CLI) when changing stacks. See Using the Stack Auditor Plugin.

Overview

A stack is a prebuilt root file system (rootfs) that supports a specific operating system. For example, Linux-based systems need /usr and /bin directories at their root. The stack works in tandem with a buildpack to support apps running in compartments. Under Diego architecture, cell VMs can support multiple stacks.

Important Docker apps do not use stacks.

Available stacks

TAS for VMs includes support for cflinuxfs3. The Linux cflinuxfs3 stack is derived from Ubuntu Bionic 18.04. For more information about supported libraries, see the GitHub stacks page.

Restaging apps on a new stack

For security, stacks receive regular updates to address Common Vulnerabilities and Exposures (CVEs). Apps pick up on these stack changes through new releases of TAS for VMs. However, if your app links statically to a library provided in the rootfs, you may have to manually restage it to pick up the changes.

It can be difficult to know what libraries an app statically links to, and it depends on the languages you are using. One example is an app that uses a Ruby or Python binary, and links out to part of the C standard library. If the C library requires an update, you may need to recompile the app and restage it.

To restage an app on a new stack, do the following:

  1. Use the cf stacks command to list the stacks available in a deployment.

    $ cf stacks
    Getting stacks in org MY-ORG / space development as developer@example.com...
    OK
    
    name            description
    cflinuxfs2      Cloud Foundry Linux-based filesystem - Ubuntu Trusty 14.04 LTS
    cflinuxfs3      Cloud Foundry Linux-based filesystem - Ubuntu Bionic 18.04 LTS
    
  2. To change your stack and restage your app, run the following command:

    cf push MY-APP -s STACK-NAME
    

    Where: - MY-APP is the name of the app. - STACK-NAME is the name of the new stack.

    For example, to restage your app on the stack cflinuxfs3, run cf push MY-APP -s cflinuxfs3:

     $ cf push MY-APP -s cflinuxfs3 Using stack cflinuxfs3… OK Creating app MY-APP in org MY-ORG / space development as developer@example.com… OK … requested state: started instances: 1/1 usage: 1G x 1 instances urls: MY-APP.cfapps.io last uploaded: Wed 17 Jul 22:57:04 UTC 2024 state     since                  cpu    memory        disk           logging         cpu entitlement   details #0  running   2024-07-17T22:57:22Z   0.3%   49.5M of 1G   130.2M of 1G   0B/s of 16K/s   2.4% 

Stacks API

For API information, see the Stacks section of the Cloud Foundry API Documentation.

check-circle-line exclamation-circle-line close-line
Scroll to top icon