Application Design Center helps you and your teams streamline the design and deployment of application infrastructure on Google Cloud. Use App Design Center to establish and manage a catalog of approved architectural patterns, so developers can quickly and safely provision applications that align with organizational standards and best practices.
Why use App Design Center
App Design Center helps you achieve goals that are specific to your responsibilities, including the following:
- Platform Administrators and Platform Engineers: Tailor spaces to the needs of each development team. In each space, provide application templates that integrate your company governance rules. 
- Application Developers: Quickly customize and deploy applications. After you deploy, you can connect to your code repository to pull in client code or containers. 
For example, you might use App Design Center to develop and evaluate a concept that addresses a business goal. Administrators can create an initial template, and refine it as they iterate. Developers can use the template to deploy the application to multiple environments.
You can use App Design Center to design and deploy the following application types:
- Serving infrastructure. For example, a three-tier web application that includes multiple isolated backends.
- Containerized cloud-native. For example, a Cloud Run service that handles long-running operations for your database.
- Generative AI. For example, a Retrieval-Augmented Generation (RAG) architecture that provides comprehensive search results.
How to use App Design Center
You can design and deploy applications in App Design Center using the following:
- Design canvas: Add application components to a canvas to create an application diagram. As you add components, get suggestions for additional components and possible connections. 
- Natural language chat: If you have Gemini Cloud Assist, you can chat to do the following: - Provide a business problem and receive a proposed initial design.
- Set up and connect specific Google Cloud products. Gemini responds with a proposed initial design in App Design Center. As you create your application, chat with Gemini to get design suggestions.
 
- APIs: Programmatically create and manage applications. 
The App Design Center workflow
Administrators and application developers work together to design and deploy applications in App Design Center using the following iterative workflow:
- Gather requirements and plan.
- Design, architect, and collaborate.
- Develop templates and guardrails.
- Test, debug, optimize, and deploy.
- Iterate.
App Design Center concepts
The following diagram illustrates App Design Center concepts and connections.
 
 
To understand how these fundamental elements work together, review the following key concepts:
- Space: A dedicated area for a team to collaborate, create templates, and deploy applications.
- Application template: A deployable, opinionated architecture built from components.
- Components: Reusable building blocks designed with Google Cloud best practices.
- Application: An instance created from a template, which you can customize and deploy.
- Catalog: A collection of templates that can be shared between different spaces.
Space: An area for team collaboration
A space is an exclusive area where a team creates templates and deploys applications. Templates and applications that you create in a space are only available in the space. An administrator can share templates with other spaces by adding them to a catalog and sharing the catalog with other spaces.
Administrators create a space and assign it to at least one team, where they have access to templates and applications. You can create a space for each team or for each purpose.
Application template: An opinionated architecture
An application template is a deployable combination of components. You can use the following template types:
- Application template: a template that you create in your space, and collaborate on with other users in your space.
- Catalog template: a template that you add to your space's catalog.
- Shared template: a template that you add to a catalog and share with another space, or a template that was shared with your space through a catalog.
As your business needs change, you can create and distribute template revisions. For example, you might add a memory store for caching to improve performance. When you update and reshare a template, developers can update their deployed application to reflect the latest revision.
Components: Template building blocks
Components are building blocks designed by Google, incorporating Google Cloud best practices and default security configurations. A component can be one of the following:
- Assets: High-level resources that help you control other resources. 
- Services: Network or API interfaces that expose functionality that clients consume over the network. 
- Workloads: A binary deployment, such as a MIG deployment that performs a subset of business functionality. 
Application: Customize and deploy from a template
You create an application draft from a template. You can then configure and deploy using one of the following methods:
- Deploy from the Google Cloud console: Conveniently deploy from the Google Cloud console, track changes, and apply template revisions. 
- Download and deploy Terraform: Use your own deployment tools and workflows. 
Catalog: A sharable collection of templates
A catalog is a collection of application templates that you can share with multiple spaces. You can use the following catalog types:
- Google catalog: A public catalog that contains application templates that Google created using best practices. This catalog is shared with all spaces. 
- Default catalog: Each space has a default catalog, where you can add templates to share with other spaces. 
- Shared catalog: A catalog that you share with another space, or a catalog that was shared with your space from another space.