Before you work with Vertex AI Agent Engine, you need to make sure your environment is set up. You need to have a Google Cloud project with billing enabled, have the required permissions, set up a Cloud Storage bucket, and install the Vertex AI SDK for Python. Use the following topics to ensure ready to start working with Vertex AI Agent Engine.
For a reference Terraform example to streamline Vertex AI Agent Engine environment setup and deployment, consider exploring the agent-starter-pack.
Set up your Google Cloud project
Every project can be identified in two ways: the project number or the project
ID. The PROJECT_NUMBER is automatically created when you
create the project, whereas the PROJECT_ID is created by you,
or whoever created the project. To set up a project:
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
- 
    
    
      In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the Vertex AI, Cloud Storage, Cloud Logging, Cloud Monitoring, and Cloud Trace APIs. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- 
    
    
      In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the Vertex AI, Cloud Storage, Cloud Logging, Cloud Monitoring, and Cloud Trace APIs. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
Get the required roles
To get the permissions that you need to use Vertex AI Agent Engine, ask your administrator to grant you the following IAM roles on your project:
- 
  
  
    
      Vertex AI User  (roles/aiplatform.user)
- 
  
  
    
      Storage Admin  (roles/storage.admin)
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.
Set up the identity and permissions for your agent
Agents that you deploy on Vertex AI Agent Engine run using service accounts as their identity.
You have two options for the service account:
- Default Service Agent: By default, agents use the AI Platform Reasoning
Engine Service Agent. This Google-managed service account has the
Vertex AI Reasoning Engine Service Agent role
(roles/aiplatform.reasoningEngineServiceAgent), which includes the default permissions required for deployed agents.
- Custom Service Account: You can specify your own service account for the agents to use. This gives you more granular control over the permissions granted to the agents.
Using the default service agent
The AI Platform Reasoning Engine Service Agent is used by default. You can view the full list of default permissions in the IAM documentation.
If your agent requires permissions beyond the default set, you can grant this Service Agent additional roles:
- Go to the IAM page and check the "Include Google-provided role grants" checkbox. 
- Find the principal which matches - service-PROJECT_NUMBER@gcp-sa-aiplatform-re.iam.gserviceaccount.com.
- Add the required roles to the principal by clicking the edit button and then the save button. 
Manually generate the default service agent
While the Reasoning Engine Service Agent is automatically provisioned during Vertex AI Agent Engine deployment, there might be scenarios where you need to manually generate it beforehand. This is particularly important when you need to grant specific roles to the service agent to ensure the deployment process has the necessary permissions and avoid potential deployment failures.
Here are the steps to manually generate a Reasoning Engine Service Agent:
- Generate the Reasoning Engine Service Agent using the Google Cloud CLI. - gcloud beta services identity create --service=aiplatform.googleapis.com --project=PROJECT-ID-OR-PROJECT-NUMBER
- Go to the IAM page and click Grant Access. 
- In Add principals section, in the New principals field, enter - service-PROJECT_NUMBER@gcp-sa-aiplatform-re.iam.gserviceaccount.com.
- In the Assign roles section, find and select the roles you need. 
- Click the Save button. 
Using a custom service account
To use your own service account, you need to grant it the necessary permissions
to run the agent. Your custom service account likely needs the
Vertex AI User role (roles/aiplatform.user).
- If you don't have a service account, create one. See Create service accounts. 
- Grant the service account the Vertex AI User ( - roles/aiplatform.user) role.
- Grant any other roles required by your agent code to the service account. 
- To deploy your agent with this service account, grant yourself the Service Account User role ( - roles/iam.serviceAccountUser) on this custom service account.
- When deploying your agent, specify the email address of your custom service account. See Configure a custom service account for details. 
Cross-project custom service account
If your custom service account is from a different project, you need additional configurations in both the project where the service account resides and the project where you deploy the agent.
- Disable cross-project service account usage organization policy: In the project where the service account is located, ensure that the - iam.disableCrossProjectServiceAccountUsageorganization policy is NOT enforced. See Disable cross-project service account usage enforcement for more details.
- Grant permissions to the Vertex AI Service Agent: In the project where the service account is located, grant the Service Account Token Creator ( - roles/iam.serviceAccountTokenCreator) role to the Vertex AI Service Agent (- service-RESOURCE_PROJECT_NUMBER@gcp-sa-aiplatform.iam.gserviceaccount.com) of the project where you will deploy the agent.
- Grant permissions to the custom service account: In the project where you plan to deploy the agent, grant the necessary roles to the custom service account, as described in Using a custom service account. This typically includes the Vertex AI User role ( - roles/aiplatform.user) and any other roles required by your agent code.
Create a Cloud Storage bucket
Vertex AI Agent Engine stages the artifacts of your deployed agents in a Cloud Storage
bucket as part of the deployment process. Make sure the principal that is
authenticated to use Vertex AI (either yourself or a service account)
has Storage Admin access to this bucket. This is needed because
Vertex AI SDK for Python writes your code to this bucket.
If you already have a bucket set up, you can skip this step. Otherwise, you can follow the standard instructions for creating a bucket.
- 
       
         In the Get started section, do the following:
          - Enter a globally unique name that meets the bucket naming requirements.
- To add a
            bucket label,
            expand the Labels section (),
            click add_box
            Add label, and specify a keyand avaluefor your label.
 
- 
       
       In the Choose where to store your data section, do the following:
        - Select a Location type.
- Choose a location where your bucket's data is permanently stored from the Location type drop-down menu.
            - If you select the dual-region location type, you can also choose to enable turbo replication by using the relevant checkbox.
 
- To set up cross-bucket replication, select
              Add cross-bucket replication via Storage Transfer Service and
              follow these steps:
               Set up cross-bucket replication- In the Bucket menu, select a bucket.
- In the Replication settings section, click Configure to configure settings for the replication job. - The Configure cross-bucket replication pane appears. - To filter objects to replicate by object name prefix, enter a prefix that you want to include or exclude objects from, then click Add a prefix.
- To set a storage class for the replicated objects, select a storage class from the Storage class menu. If you skip this step, the replicated objects will use the destination bucket's storage class by default.
- Click Done.
 
 
 
- 
       
       In the Choose how to store your data section, do the following:
          - Select a default storage class for the bucket or Autoclass for automatic storage class management of your bucket's data.
- To enable hierarchical namespace, in the Optimize storage for data-intensive workloads section, select Enable hierarchical namespace on this bucket.
 
- In the Choose how to control access to objects section, select whether or not your bucket enforces public access prevention, and select an access control method for your bucket's objects.
- 
      In the Choose how to protect object data section, do the
      following:
       - Select any of the options under Data protection that you
        want to set for your bucket.
          - To enable soft delete, click the Soft delete policy (For data recovery) checkbox, and specify the number of days you want to retain objects after deletion.
- To set Object Versioning, click the Object versioning (For version control) checkbox, and specify the maximum number of versions per object and the number of days after which the noncurrent versions expire.
- To enable the retention policy on objects and buckets, click the Retention (For compliance) checkbox, and then do the following:
            - To enable Object Retention Lock, click the Enable object retention checkbox.
- To enable Bucket Lock, click the Set bucket retention policy checkbox, and choose a unit of time and a length of time for your retention period.
 
 
- To choose how your object data will be encrypted, expand the Data encryption section (), and select a Data encryption method.
 
- Select any of the options under Data protection that you
        want to set for your bucket.
          
Install and initialize the Vertex AI SDK for Python
This section presumes that you have set up a Python development environment, or are using Colab (or any other suitable runtime that has set it up for you).
(Optional) Set up a virtual environment
We also recommend setting up a virtual environment to isolate your dependencies.
Installation
To minimize the set of dependencies that you have to install, we have separated out the dependencies into:
- agent_engines: the set of packages required for deployment to Vertex AI Agent Engine.
- adk: the set of compatible Agent Development Kit packages.
- langchain: the set of compatible LangChain and LangGraph packages.
- ag2: the set of compatible AG2 packages.
- llama_index: the set of compatible LlamaIndex packages.
When installing the Vertex AI SDK for Python, you can specify the dependencies required (separated by commas). To install all of them:
pip install google-cloud-aiplatform[agent_engines,adk,langchain,ag2,llama_index]>=1.112.0To use Agent2Agent (A2A) on Agent Engine, you must also install the a2a-sdk package:
pip install a2a-sdk>=0.3.4Authentication
Colab
Run the following code:
from google.colab import auth
auth.authenticate_user(project_id="PROJECT_ID")
Cloud Shell
No action required.
Local Shell
Run the following command:
gcloud auth application-default loginImport and initialize the SDK
Run the following code to import and initialize the SDK for Vertex AI Agent Engine:
import vertexai
from vertexai import agent_engines # For the prebuilt templates
client = vertexai.Client(  # For service interactions via client.agent_engines
    project="PROJECT_ID",
    location="LOCATION",
)
where
- PROJECT_IDis the Google Cloud project ID under which you develop and deploy agents, and
- LOCATIONis one of the supported regions.