Types of service accounts  |  IAM Documentation  |  Google Cloud (2024)

Service accounts can be divided into the following categories:

  • User-managed service accounts, which you create and manage yourself
  • Service agents, which Google Cloud creates and manages

This page describes how each type of service account is created and used.

User-managed service accounts

User-managed service accounts are service accounts that you create in yourprojects. You can update, disable, enable, and delete these service accounts atyour discretion. You can also manage other principals' access to these serviceaccounts.

You can create user-managed service accounts in your project using theIAM API, the Google Cloud console, or the Google Cloud CLI.

By default, you can create up to 100 user-managed serviceaccounts in a project. If this quota does not meet your needs, you can use theGoogle Cloud console to request a quota increase. Onlyuser-created service accounts count towards this quota—default serviceaccounts and service agents don't count towardsthe quota.

When you create a user-managed service account in your project, you choose aname for the service account. This name appears in the email address thatidentifies the service account, which uses the following format:

service-account-name@project-id.iam.gserviceaccount.com

To learn how to create a service account, see Create service accounts.

Default service accounts

Default service accounts are user-managed service accounts that are createdautomatically when you enable or use certain Google Cloud services. Theseservice accounts let the service deploy jobs that access otherGoogle Cloud resources. You are responsible for managing default serviceaccounts after they are created.

If your application runs in a Google Cloud environment that hasa default service account, your application can use the credentials for thedefault service account to call Google Cloud APIs. Alternatively, you cancreate your own user-managed service account and use it to authenticate. Fordetails, see Set up Application Default Credentials.

Depending on your organization policy configuration, the default service account might automatically be granted the Editor role on your project. We strongly recommend that you disable the automatic role grant by enforcing the iam.automaticIamGrantsForDefaultServiceAccounts organization policy constraint. If you created your organization after May 3, 2024, this constraint is enforced by default.

If you disable the automatic role grant, you must decide which roles to grant to the default service accounts, and then grant these roles yourself.

If the default service account already has the Editor role, we recommend that you replace the Editor role with less permissive roles. To safely modify the service account's roles, use Policy Simulator to see the impact of the change, and then grant and revoke the appropriate roles.

The following table lists the services that create default service accounts:

Service Service account name Email address
App Engine, and any Google Cloud service that uses App Engine App Engine default service account project-id@appspot.gserviceaccount.com
Compute Engine, and any Google Cloud service that uses Compute Engine Compute Engine default service account project-number[email protected]

Service agents

Some Google Cloud services need access to your resources so that they canact on your behalf. For example, when you use Cloud Run to run acontainer, the service needs access to any Pub/Sub topics that cantrigger the container.

To meet this need, Google Cloud creates and manages service accounts formany Google Cloud services. These service accounts are known as serviceagents. You might see service agents in your project's allow policy, in auditlogs, or on the IAM page in the Google Cloud console.

Service agents aren't created in your projects, so you won't see them whenviewing your projects' service accounts. You can't access them directly.

By default, service agents aren't listed in the IAM page in theGoogle Cloud console, even if they've been granted a role on your project. Toview role grants for service agents, select the Include Google-provided rolegrants checkbox.

Types of service accounts | IAM Documentation | Google Cloud (1)

Types of service accounts | IAM Documentation | Google Cloud (2)

Google Cloud has the following types of service agents:

  • Service-specific service agents
  • Google APIs Service Agent
  • Role manager for service agents

Service-specific service agents

Most service agents are service-specific—they act on behalf ofindividual services. In many cases, these service agents are required forservices to function properly. For example, service agents are what allowCloud Logging sinks to write logs to Cloud Storage buckets.

Each service agent is associated with a resource. This resource is typically aproject, folder, or organization, though it can also be a service-specificresource—for example, a Cloud SQL instance. This resource defines thescope of the service agent's actions. For example, if a service agent isassociated with a project, it will act on behalf of a service for the projectand its descendant resources.

You can determine which type of resource a service agent is associated with bylooking at its email address:

  • If the service agent is associated with a project, folder, or organization,its email address contains the numeric ID for that project, folder, ororganization.
  • If the service agent is associated with a service-specific resource, its emailaddress contains a numeric project ID and a unique identifier. The numericproject ID indicates which project owns the resource that the service agent isassociated with. The unique identifier distinguishes the service agent fromother similar service agents in the same project.

Google APIs Service Agent

Your project's allow policy is likely to refer to a service account named theGoogle APIs Service Agent, with an email address that uses the following format:project-number@cloudservices.gserviceaccount.com.

This service account runs internal Google Cloud processes on your behalf.It is automatically granted the Editor role (roles/editor) on the project.

Role manager for service agents

Your audit logs for IAM might refer to the serviceaccount [email protected].

This service account manages the roles that are granted to other service agents.It is visible only in audit logs.

For example, if you use a new API, Google Cloud might automatically createa new service agent and grant it roles on your project. Granting these rolesgenerates an audit log entry, which shows that [email protected] set theallow policy for the project.

Service agent creation

The exact time that a service agent is created depends on what type of resourceit's associated with.

Service agents that are associated with a service-specific resource are createdwhen you create the resource. For more information on how to identify andconfigure these service agents, review the documentation for the associatedresource.

Service agents that are associated with projects, folders, and organizations arecreated as you need them, usually when you first use a service. If necessary,you can also ask Google Cloud to create service agents for a servicebefore you use the service. For more information, see Create and grant roles toservice agents.

Service agent roles

Some actions in Google Cloud require service agents to create and accessresources on your behalf. For example, when you create a Dataproccluster, the Dataproc service agent needs permission to createCompute Engine instances in your project in order to create the cluster.

To get this access, service agents need specific IAM roles. Manyproject-level service agents are automatically granted the roles that they need.The names of these automatically granted roles typically end in serviceAgentor ServiceAgent. For other service agents, you need to grant them roles sothat the service works correctly. To find out which service agents are grantedroles automatically, see the service agent reference.

If you ask Google Cloud to create service agents before you use a service,you must grant the service agents the roles that they are typically grantedautomatically. This is because service agents that are created at a user'srequest aren't automatically granted roles. If you don't grant the serviceagents these roles, some services might not function properly. To learn how togrant these roles to service agents, see Create and grant roles to serviceagents.

Primary service agents

In the service agent reference, some service agents areidentified as primary service agents. Primary service agents are serviceagents whose email address is returned when you trigger service agentcreation for a service.

Audit logging

Sometimes, when a principal initiates an operation, a service agent executes an action on the principal's behalf. However, when you're reviewing audit logs for a service agent, it can be hard to tell who the service agent was acting on behalf of, and why.

To help you understand the context for a service agent's actions, some service agents include additional details in their audit logs, like the job the action is associated with and the principal that created the job.

The following service agents include these additional details in their audit logs:

  • BigQuery Connection Service Agent
  • BigQuery Connection Delegation Service Agent

These additional details are in the serviceDelegationHistory field of the audit log, which is nested in the authenticationInfo field. This field contains the following information:

  • The original principal who created the job
  • The service agent that executed the action
  • The service that the service agent belongs to
  • The job ID

For example, suppose [email protected] creates a job using the BigQuery Connection API. This job requires one of the BigQuery Connection API's service agents to execute an action. In this case, the audit log for the service agent's action would contain a serviceDelegationHistory field similar to the following:

{ "protoPayload": { "@type": "type.googleapis.com/google.cloud.audit.AuditLog", "authenticationInfo": { "principalEmail": "bqcx-442188550395-jujw@gcp-sa-bigquery-condel.iam.gserviceaccount.com", "serviceDelegationHistory": { "originalPrincipal": "user:[email protected]", "serviceMetadata": [ { "principalSubject": "serviceAccount:bqcx-442188550395-jujw@gcp-sa-bigquery-condel.iam.gserviceaccount.com", "serviceDomain": "bigquery.googleapis.com", } ] } } }}

What's next

  • Find out how to create and manage service accounts.
  • Learn how to create and manage service account keys.
  • Get best practices for working with service accounts.
  • Review best practices for managing service account keys.

Try it for yourself

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.

Get started for free

Types of service accounts  |  IAM Documentation  |  Google Cloud (2024)
Top Articles
Market Price of CDS - CFA, FRM, and Actuarial Exams Study Notes
Top 18 BlackRock Competitors & Alternatives in 2024
Scheelzien, volwassenen - Alrijne Ziekenhuis
Evil Dead Movies In Order & Timeline
Toa Guide Osrs
Regal Amc Near Me
Trabestis En Beaumont
Air Canada bullish about its prospects as recovery gains steam
What happens if I deposit a bounced check?
Ashlyn Peaks Bio
Craigslist/Phx
Why Is Stemtox So Expensive
Items/Tm/Hm cheats for Pokemon FireRed on GBA
Hssn Broadcasts
Nj Scratch Off Remaining Prizes
Washington Poe en Tilly Bradshaw 1 - Brandoffer, M.W. Craven | 9789024594917 | Boeken | bol
Craigslist Pets Longview Tx
Dc Gas Login
ᐅ Bosch Aero Twin A 863 S Scheibenwischer
CANNABIS ONLINE DISPENSARY Promo Code — $100 Off 2024
Bank Of America Financial Center Irvington Photos
Forum Phun Extra
Rugged Gentleman Barber Shop Martinsburg Wv
Program Logistics and Property Manager - Baghdad, Iraq
Best Transmission Service Margate
Parc Soleil Drowning
Low Tide In Twilight Ch 52
Aspenx2 Newburyport
Myql Loan Login
Motorcycle Blue Book Value Honda
Bfsfcu Truecar
Ice Dodo Unblocked 76
Halsted Bus Tracker
Myra's Floral Princeton Wv
Boondock Eddie's Menu
Sun Haven Pufferfish
Dallas City Council Agenda
Whitehall Preparatory And Fitness Academy Calendar
Mytime Maple Grove Hospital
Gfs Ordering Online
Powerspec G512
How I Passed the AZ-900 Microsoft Azure Fundamentals Exam
8776725837
Silicone Spray Advance Auto
Does Target Have Slime Lickers
Martha's Vineyard – Travel guide at Wikivoyage
Portal Pacjenta LUX MED
Borat: An Iconic Character Who Became More than Just a Film
Scott Surratt Salary
UNC Charlotte Admission Requirements
Jasgotgass2
Haunted Mansion Showtimes Near The Grand 14 - Ambassador
Latest Posts
Article information

Author: Lidia Grady

Last Updated:

Views: 5553

Rating: 4.4 / 5 (65 voted)

Reviews: 88% of readers found this page helpful

Author information

Name: Lidia Grady

Birthday: 1992-01-22

Address: Suite 493 356 Dale Fall, New Wanda, RI 52485

Phone: +29914464387516

Job: Customer Engineer

Hobby: Cryptography, Writing, Dowsing, Stand-up comedy, Calligraphy, Web surfing, Ghost hunting

Introduction: My name is Lidia Grady, I am a thankful, fine, glamorous, lucky, lively, pleasant, shiny person who loves writing and wants to share my knowledge and understanding with you.