When you set up App Hub, you create an administrative boundary for your applications. This boundary is either the management project or the collection of host and service projects you configured for application management, depending on your setup model. Services and workloads are registered as applications inside this administrative boundary.
To avoid configuration drift and maintain a clear source of truth, we recommend that you manage your application resources in the environment where they were originally defined:
- For applications deployed from an Application Design Center template: Use Application Design Center to manage and update the application. You can either revise the template for application design changes or create an application revision to update settings such as application and component details. 
- For applications created by registering resources in App Hub: Manage the application, its services, and workloads directly within App Hub. 
This page describes how to manage services and workloads that are discovered or registered directly within App Hub as applications. You can perform these actions using either the Google Cloud console or the Google Cloud CLI. For applications deployed from a template, see Application Design Center documentation.
Before you begin
Before you can view, update, and unregister services and workloads in App Hub, complete the following steps:
- Set up App Hub using one of the supported setup models.
- Register supported resources to an application.
Required roles
To get the permissions that you need to manage services and workloads in App Hub, ask your administrator to grant you the following IAM roles on the application administrative boundary from your setup model (the management project or the host and service projects) :
- 
            Update and unregister services and workloads:
              
  
  
    
      App Hub Editor  (roles/apphub.editor)
- 
            View services and workloads:
              
  
  
    
      App Hub Viewer  (roles/apphub.viewer)
For more information about granting roles, see Manage access to projects, folders, and organizations.
You might also be able to get the required permissions through custom roles or other predefined roles.
For more information about App Hub roles, see App Hub IAM roles and permissions.
View details of services and workloads
Follow these steps to view details of services and workloads, including their location and registration status to an application, within your App Hub administrative boundary:
Console
View details from registered or detached services and workloads from an application:
- In the Welcome page of the Google Cloud console, use the project picker to select your management project or host project: 
- Navigate to the App Hub Applications page: - The page displays a list of your applications. 
- Click the name of the application from which you want to view services or workloads. 
- In the Services and workloads tab, click the name of the service or workload you want to view. 
- On the Details page for the resource, you can look at details such as the display name, location, registration status, and attributes. 
Alternatively, view a list of all services and workloads with a registration status value of discovered or registered:
- Navigate to the App Hub Services and workloads page: - The page displays a list of all discovered and registered services and workloads. 
- Use the Filter field to narrow the results by attributes like Environment or Registration status. 
gcloud
View details from registered or detached services and workloads from an application:
- Find the project ID of your management project or host project. 
- Describe a service or workload from an application to review its details: - Describe a service: - gcloud apphub applications services describe SERVICE \ --project=PROJECT_ID \ --application=APPLICATION \ --location=LOCATION- Replace the following: - SERVICE: the ID of the service.
- PROJECT_ID: the ID of your host project or management project.
- APPLICATION: the ID of the application to which the service is registered.
- LOCATION: the location of the service. Use- globalfor global resources or a specific region, such as- us-east1, for regional resources.
 
- Describe a workload: - gcloud apphub applications workloads describe WORKLOAD \ --project=PROJECT_ID \ --application=APPLICATION \ --location=LOCATION- Replace the following: - WORKLOAD: the ID of the workload.
- PROJECT_ID: the ID of your host project or management project.
- APPLICATION: the ID of the application to which the workload is registered.
- LOCATION: the location of the workload. Use- globalfor global resources or a specific region, such as- us-east1, for regional resources.
 
 
The output displays details from the resource, such as the display name, location, registration status, and attributes.
Alternatively, view a list of all services and workloads with a registration status value of discovered or registered:
Discovered resources
Discovered resources are available to be registered to an application. Follow these steps to list discovered resources:
- List discovered services: - gcloud apphub discovered-services list \ --project=PROJECT_ID \ --location=LOCATION- Replace the following: - PROJECT_ID: the ID of your host project or management project.
- LOCATION: the location where you want to discover resources. Use- globalfor global resources or a specific region, such as- us-east1, for regional resources.
 
- List discovered workloads: - gcloud apphub discovered-workloads list \ --project=PROJECT_ID \ --location=LOCATION
Registered resources
Registered resources are part of an application. Follow these steps
to list registered resources of a particular application. You can
filter the list based on attributes, using the
--filter flag:
- List registered services in an application: - gcloud apphub applications services list \ --application=APPLICATION_NAME \ --project=PROJECT_ID \ --location=LOCATION \ --filter=FILTER_EXPRESSION- Replace the following: - APPLICATION_NAME: the name of your application. You specify this value when you create an application.
- PROJECT_ID: the ID of your host project or management project.
- LOCATION: the resource location. Use- globalfor global resources or a specific region, such as- us-east1, for regional resources.
- Optional: FILTER_EXPRESSION: the filter expression to specify attributes. For example, to list resources with aPRODUCTIONenvironment type, useattributes.environment.type=PRODUCTION.
 
- List registered workloads in an application: - gcloud apphub applications workloads list \ --application=APPLICATION_NAME \ --project=PROJECT_ID \ --location=LOCATION \ --filter=FILTER_EXPRESSION
The registration status of services and workloads from an application can change to detached if you modify the organizational structure of your Google Cloud resources or delete the underlying resource. Detached services and workloads remain in the application until you unregister them, but App Hub can no longer manage or monitor them. For more information, see Registration status of services and workloads.
To reattach services or workloads to an application, you must register them again based on the resource hierarchy of your setup model.
Update service and workload attributes
Follow these steps to modify the user-defined attributes of services and workloads that are registered to an application:
Console
- In the Welcome page of the Google Cloud console, use the project picker to select your management project or host project: 
- Navigate to the App Hub Applications page: - The page displays a list of your applications. 
- Click the name the application for which you want to update service or workload attributes. 
- In the Services and workloads tab, find the name of the service or workload you want to update. 
- Click more_vert More, then click Edit service or Edit workload. 
- In the pane that opens, edit the fields as required and click Save. 
gcloud
- Find the project ID of your management project or host project. 
- Update service or workload attributes: - Update service attributes: - gcloud apphub applications services update SERVICE_NAME \ --application=APPLICATION_NAME \ --project=PROJECT_ID \ --location=LOCATION \ --display-name=DISPLAY_NAME \ --criticality-type=CRITICALITY_LEVEL \ --environment-type=ENVIRONMENT \ --developer-owners=display-name=DEV_NAME,email=DEV_EMAIL \ --operator-owners=display-name=OPERATOR_NAME,email=OPERATOR_EMAIL \ --business-owners=display-name=BUSINESS_NAME,email=BUSINESS_EMAIL- Replace - SERVICE_NAMEwith the name of the service you want to update.
- Update workload attributes: - gcloud apphub applications workloads update WORKLOAD_NAME \ --application=APPLICATION_NAME \ --project=PROJECT_ID \ --location=LOCATION \ --display-name=DISPLAY_NAME \ --criticality-type=CRITICALITY_LEVEL \ --environment-type=ENVIRONMENT \ --developer-owners=display-name=DEV_NAME,email=DEV_EMAIL \ --operator-owners=display-name=OPERATOR_NAME,email=OPERATOR_EMAIL \ --business-owners=display-name=BUSINESS_NAME,email=BUSINESS_EMAIL- Replace - WORKLOAD_NAMEwith the name of the workload you want to update.- Replace the following required and optional flags: - Required: APPLICATION_NAME: the name of your application. You specify this value when you create an application.
- Required: PROJECT_ID: the ID of your host project or management project.
- Required: LOCATION: your resource location. Useglobalfor global resources or a specific region, such asus-east1, for regional resources.
- Optional: DISPLAY_NAME: the display name of your resource.
- Optional: - CRITICALITY_LEVEL: the importance level of the resource. Use one of the following values:- MISSION_CRITICAL
- HIGH
- MEDIUM
- LOW
 
- Optional: - ENVIRONMENT: the stage of the software lifecycle. Use one of the following values:- PRODUCTION
- STAGING
- DEVELOPMENT
- TEST
 
- Optional: - DEV_NAMEand- DEV_EMAIL: the display name and email address of the developer owner, respectively.
- Optional: - OPERATOR_NAMEand- OPERATOR_EMAIL: the display name and email address of the operator owner, respectively.
- Optional: - BUSINESS_NAMEand- BUSINESS_EMAIL: the display name and email address of the business owner, respectively.
 
- Required: 
 
Terraform
To update service or workload attributes with Terraform, modify the
arguments within the corresponding
google_apphub_service
or
google_apphub_workload
resource block in your configuration file. When you apply the changes,
Terraform updates the resource to match the new configuration.
The following examples update the criticality and environment attributes of services and workloads of a regional application:
- Update service attributes: - resource "google_apphub_service" "example" { # ... other arguments attributes { criticality { type = "HIGH" # Updated criticality } environment { type = "PRODUCTION" } # ... other attributes } }
- Update workload attributes: - resource "google_apphub_workload" "example" { # ... other arguments attributes { criticality { type = "HIGH" # Updated criticality } environment { type = "PRODUCTION" } # ... other attributes } }
Unregister services and workloads
Unregistering a service or workload removes it from an application. The underlying resource is not deleted and becomes a discovered resource again, available for registration to another application.
Follow these steps to unregister services and workloads:
Console
- In the Welcome page of the Google Cloud console, use the project picker to select your management project or host project: 
- Navigate to the App Hub Applications page: - The page displays a list of your applications. 
- Click the name the application from which you want to unregister services or workloads. 
- In the Services and workloads tab, click the name of the service or workload you want to unregister. 
- On the details page for the resource, click Unregister. 
gcloud
- Find the project ID of your management project or host project. 
- Unregister a service or a workload: - Unregister a service: - gcloud apphub applications services delete SERVICE_NAME \ --application=APPLICATION_NAME \ --project=PROJECT_ID \ --location=LOCATION- Replace the following: - SERVICE_NAME: the name of the service you want to unregister.
- APPLICATION_NAME: the name of your application. You specify this value when you create an application.
- PROJECT_ID: the ID of your host project or management project.
- LOCATION: the resource location. Use- globalfor global resources or a specific region, such as- us-east1, for regional resources.
 
- Unregister a workload: - gcloud apphub applications workloads delete WORKLOAD_NAME \ --application=APPLICATION_NAME \ --project=PROJECT_ID \ --location=LOCATION- Replace - WORKLOAD_NAMEwith the name of the workload you want to unregister.
 
Terraform
To unregister a service or workload managed by Terraform, remove the
corresponding
google_apphub_service
or
google_apphub_workload
resource block from your configuration file and run terraform apply. When
you apply the changes, Terraform removes the registration from
App Hub.
After unregistering all services and workloads, you can delete the application.
What's next
- Manage your applications
- Optimize an application with design recommendations
- Monitor your applications