copyright | lastupdated | keywords | subcollection | ||
---|---|---|---|---|---|
|
2024-07-18 |
onboard, catalog management, private catalog, stack definition, software, automation, metadata |
secure-enterprise |
{{site.data.keyword.attribute-definition-list}}
{: #stack-definition}
The stack definition file defines the member deployable architectures that are grouped together in the deployable architecture stack. It specifies information about how those deployable architctures are supposed to relate to each other, like input references that connect architectures together within the stack. If you plan to share the stack with others through a private catalog, a stack definition is required to ensure the stack can be deployed successfully. {: shortdesc}
The stack definition contains stack variables. These variables are inputs that users can configure and outputs from deployable architectures within the stack that display at the stack level. Those input values are referenced in the member deployable architectures within the stack, as illustrated in the following image. The stack definition also includes inputs from member deployable architectures within the stack. These inputs can be references that link the member deployable architectures together. Inputs that require a specific value or reference to deploy the stack successfully need to be included in the stack definition. For an example, see Creating the stack definition by using the CLI.
{: caption="Figure 1. Visualizing the stack definition" caption-side="bottom"}
{: #project-create-stack-definition}
In a project, your stack definition is created automatically when you stack deployable architectures together and define stack variables. Using the console to stack deployable architectures and define stack variables provides the following benefits:
- You can use the reference picker in the console to create references between deployable architectures in the stack, as opposed to writing the references from scratch.
- Deploying the stack from a project helps verify the stack works as designed before others configure and deploy it.
- Since the stack definition is created automatically based on the selections in the console, information like version locator IDs of member deployable architectures is accurate and updated automatically.
In the project, you can select which inputs you want included at the stack level. These inputs are included in the inputs
section of the stack definition and are configured as references in the member deployable architecture in your project. In the following image, the prefix
input is highlighted within the Custom Apache
member deployable architecture. If this input is selected, the Default value
changes to a reference to the stack level input. When a user adds the stack to a project from a catalog, they can configure the prefix
input and the Custom Apache
member architecture will reference that value. The fp_vsi_floating_ip_address
input references an output from another member deployable architecture. That input shouldn't be selected, as that reference links the member architectures together within the stack. Such inputs from member architectures are included in the members
section of the stack definition file.
{: caption="Figure 2. Defining stack variables in a project" caption-side="bottom"}
{: #edit-stack-definition}
To edit your stack definition locally, complete the following steps:
-
Complete the steps to stack the deployable architectures, define stack variables, and onboard the stack to a private catalog.
Configure and deploy the stack to verify that it works as designed before adding the stack to a private catalog. {: important}
-
After the deployable architecture stack is added to your private catalog, you are taken to the Configure version page in the catalog. From there, click the Actions menu > Export as code.
You can also use the projects API Get a stack definition method or the projects CLI
ibmcloud project stack-definition
command to export the stack definition. {: tip} -
Open the
stack_definition.json
file. -
Using the example definition as a guide, edit the input and output variables.
-
Add the file into the root folder of your source code repository.
The next time that you add a new version of your stacked deployable architecture to the catalog, your updates will be included.
{: #example-definition}
Though it's recommended to use a project to create the stack definition to help ensure accuracy, the following code snippet can be used as a template to create the stack definition from scratch.
{
"inputs": [
{
"name": "Stack input 1",
"type": "string",
"hidden": false,
"required": true,
"default" : "Default value"
},
{
"name": "Stack input 2",
"type": "string",
"hidden": false,
"required": true
}
],
"outputs": [
{
"name": "Output 1 name",
"value": "The reference to this output value"
},
{
"name": "Output 2 name",
"value": "The reference to this output value"
}
],
"members": [
{
"Name": "Deployable architecture 1 name",
"Version_locator": "",
"inputs": [
{
"name": "Input 1 name",
"value": "reference"
},
{
"name": "Input 2 name",
"value": "reference"
}
]
},
{
"Name": "Deployable architecture 2 name",
"Version_locator": "",
"inputs": [
{
"name": "Input 1 name",
"value": "reference"
},
{
"name": "Input 2 name",
"value": "reference"
}
]
}
]
}
{: codeblock}
{: #value-stack-inputs}
The inputs
value indicates an array of the input variables that are required for the stack to successfully deploy. When a user adds the deployable architecture stack to a project from a catalog, they must configure these inputs before they deploy. The following values can be included at the inputs
level.
"inputs": [
{
"name": "Stack input 1",
"type": "string",
"hidden": false,
"required": true,
"default" : "Default value"
},
{
"name": "Stack input 2",
"type": "string",
"hidden": false,
"required": true
}
]
{: codeblock}
name
: The name of your input variable.
type
: The Terraform primitive data type of the variable. For example, boolean
or string
.
hidden
: A boolean that indicates whether the parameter should be hidden from users during installation.
required
: A boolean that indicates whether users are required to specify the parameter during installation.
default
: The default value that should be set in the catalog.
{: #value-stack-inputs}
The outputs
value indicates an array of the output variables that are created when the stack is deployed. The following values can be included at the outputs
level.
"outputs": [
{
"name": "Output 1 name",
"value": "The reference to this output value"
},
{
"name": "Output 2 name",
"value": "The reference to this output value"
}
]
{: codeblock}
name
: The name of your output variable.
value
: The reference to where the value can be found. For more information about references, see Referencing values.
{: #value-stack-inputs}
The members
value indicates an array of the inputs and outputs for each deployable architecture in the stack. The following values can be included at the members
level.
"members": [
{
"Name": "Deployable architecture 1 name",
"Version_locator": "",
"inputs": [
{
"name": "Input 1 name",
"value": "reference"
},
{
"name": "Input 2 name",
"value": "reference"
}
]
}
]
{: codeblock}
name
: The programmatic name of the deployable architecture included in the stack.
version_locator
: Identifies the version of the member deployable architecture within the stack. To find the version locator, select the product in the catalog to open the catalog details page. Make sure that the correct version is selected. Then, click View details.
inputs
: Inputs to the member deployable architectures within the stack. Include inputs with specific values that are required for the deployable architecture stack to deploy. If the member architectures within the stack depend on one another, then include those values here as references. For more information, see Referencing values. For example, if one of your architectures requires an output from another architecture within the stack, add a reference to the output as the value.
name
: The name of your input variable. Don't edit the name as it must match the input that is used in the member deployable architecture.
value
: The value of your input variable. A default value or a reference needs to be provided.