我不想为我想与之共享 bigquery 数据集的外部用户生成服务帐户 - 这会产生什么影响?

2024-04-03

我向用户的 Google 帐户授予了对我的一个数据集的访问权限。他们正在使用这个 Python 脚本:

def query_stackoverflow():
    client = bigquery.Client()
    query_job = client.query(
        """
        SELECT *
        FROM `myproject.mydata.mytable`
        ORDER BY someColumn DESC
        LIMIT 10"""
    )

    results = query_job.result()

它有效,但他们看到了这个警告:

用户警告:您的应用程序已使用最终用户进行身份验证 来自 Google Cloud SDK 的凭证,无需配额项目。你可能会 收到“超出配额”或“API 未启用”错误。我们推荐 你重新运行gcloud auth application-default login并确保 新增配额项目。或者您可以改用服务帐户。为了 有关服务帐户的更多信息,请参阅https://cloud.google.com/docs/authentication/ https://cloud.google.com/docs/authentication/
警告.警告(_CLOUD_SDK_CREDENTIALS_WARNING)

我阅读了一些文档,但我不明白这意味着什么。意思是不是I应该为我的项目设定配额吗?我认识这个人并信任他们,但这是否意味着他们可以用尽所有mybq 配额及其查询?这似乎也可以通过使用服务帐户来“解决”,那么这个配额是否是我无法更改的非服务帐户访问的硬性限制?

授予用户 Google 帐户访问权限比创建服务帐户并为其生成密钥更方便、更安全。


A quota project由客户端库等用于计费目的。您可以使用 CLI 设置配额项目:

命令示例:

cloud auth application-default set-quota-project my-quota-project

gcloud auth 应用程序默认设置配额项目 https://cloud.google.com/sdk/gcloud/reference/auth/application-default/set-quota-project

查看 BigQuery 配额和限制并实施它们。这将提高安全性并最大限度地降低财务风险。

BigQuery 配额和限制 https://cloud.google.com/bigquery/quotas

Google Cloud 中有三种主要的授权方法。由 Google 帐户(Gmail、G Suite 等)、服务帐户和 API 密钥创建的用户凭据。

您收到的警告是由于 Google 更喜欢应用程序使用服务帐户而不是用户凭据进行授权。您可以在代码中禁用此警告,但我不建议这样做。相反,创建一个配额项目,创建一个服务帐户,然后锁定服务帐户以仅提供用户所需的角色。

在您的问题中,您没有描述如何使用用户凭据来获取授予 API 访问权限所需的 OAuth 访问令牌。如果您传递令牌,那就不太安全。可以删除服务帐户、可以轮换服务帐户密钥等,从而提供更好的安全级别。如果你了解 Google Cloud,我写了一篇关于如何使用模拟的文章。您可以使用此方法继续使用用户凭据来模拟服务帐户,而无需分发密钥。

Google Cloud – 通过模拟提高安全性 https://www.jhanley.com/google-cloud-improving-security-with-impersonation/

PowerShell – 模拟 Google 服务帐户 https://www.jhanley.com/powershell-impersonate-google-service-account/

用户帐户凭据的 API 调用配额比服务帐户低得多。这可能会导致使用用户帐户生成的访问令牌的软件失败。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

我不想为我想与之共享 bigquery 数据集的外部用户生成服务帐户 - 这会产生什么影响? 的相关文章

随机推荐

  • 在 Cordova 应用程序中播放音频

    我正在使用 Cordova 媒体插件在我的移动应用程序中播放音频 我尝试了很多代码 但我没有弄清楚我在底部做错了什么 我放了两段我尝试过的代码 第一个代码 js代码在单独的文件中 var app initialize function th
  • Windows 7 上的 XAMPP 无法正常工作

    我刚刚在 Windows 7 上安装了 XAMPP lite 我有两个驱动器 C 用于操作系统和常规文件 以及外部驱动器 E 我在 E 根目录 上安装了 XAMPP lite 但它一直给我带来问题 Apache 工作得很好 但 MySQL
  • Apache Netbeans 10 CVS 插件不可用?

    我最终升级到 Apache Netbeans 10 从 8 2 并想像往常一样使用菜单安装 CVS 插件Tools gt Plugins gt Available Plugins 但是 我似乎无法找到 访问该插件 在 设置 中 我激活了 N
  • JQuery tablesorter pager 插件在 Edge 模式下无法与 IE11 正常工作

    如果您使用带有分页器的 Tablesorter Jquery 插件 则表上的添加将不会显示任何数据 数据就在那里 但它是隐藏的 我怀疑该插件的浏览器功能检测方法无法处理IE11 还有其他人遇到这个吗 看来IE11的userAgent有问题
  • 使用 snmp 代理注册 OID

    我正在尝试使用 snmp4j 模拟 SNMP 代理 我正在尝试向代理注册 MO 下面是代码片段 static final OID mo1 new OID 1 3 6 1 4 1 1234 1 104 static final OID mo2
  • 在 Coq 中,“if then else”允许非布尔第一个参数?

    我读过一些教程if a then b else c代表match a with true gt b false gt c end 然而 很奇怪的是 前者不检查类型a 而后者当然确保a是一个布尔值 例如 Coq lt Check if nil
  • java中的内存文件系统

    我想用Java创建一个简单的内存文件系统 它有一个根目录 并且能够创建新的子目录 在该目录中 我们可以创建新文件 写入文件 读取文件 删除文件以及重命名文件 您能否提供一些从哪里开始的建议 简单的代码或资源 自定义文件系统提供程序必须实现
  • 临时值在此语句结束时被释放[重复]

    这个问题在这里已经有答案了 我正在尝试使用 Select 箱子抓取网页 let document Document from read response unwrap for node in document find Class lia
  • HTML5 视频,如果没有 .ogv 文件,则回退到 Flash

    如果不存在必要的文件类型 如何回退到 Flash 视频播放器 例如这段代码
  • 我可以在为服务器提供 API 的同时提供静态文件吗?

    所以我对网络开发还很陌生 现在我和我更加面向网络的朋友开始了一个项目 他向我扔了各种各样的框架 我们正在做 Vuejs jade stylus 和 jeet 对于新手来说 这当然非常令人困惑 因为没有 Vuejs 示例使用 jade 没有
  • 绘制三角形 iOS

    下面的代码画了一个圆圈 我如何修改现有代码来画一个三角形 colorDotLayer CALayer layer CGFloat width self bounds size width 6 colorDotLayer bounds CGR
  • 为什么我的充电状态接收器总是返回 false?

    我试图检测用户何时插入 或拔出 设备进行充电 在我的接收器中 当我确定它是否已插入时 我总是得到 错误 的状态读数 这是我的代码 在清单中
  • 如何在 shell 中解析长格式参数?

    我所看到的一切都使用getopt或者稍微花哨一点的getopts仅支持单字符选项 例如 h但不是 help 我想做一些花哨的长选择 我做过类似的事情this http blogger ziesemer com 2010 01 dyndns
  • 带有变量的 Swift 闭包导致内存泄漏

    我正在调试我的程序 发现内存泄漏问题 在ViewController中 当它弹出时 应该调用deinit函数 但事实并非如此 所以我尝试通过以下步骤来解决这个问题 通过注释多行 我发现以下几行使得 ViewController 没有释放 v
  • TimeZoneInfo.ConvertTimeToUtc 问题

    我们遇到一个问题 一位开发人员创建了以下代码 并且该代码可以在他的 DEV 环境中运行 但是当它被签入 QA 时 代码会中断并显示以下错误消息 myRecord UTCStartTime TimeZoneInfo ConvertTimeTo
  • 并行下载多个文件,就像 Android 中的 Whats App 一样

    我已经知道使用服务 意图服务我们下载多个文件在背景中 但这个问题还有一个更复杂的问题需要解决 我必须在不同的活动中并行下载多个视频 图像 例如 Whatsapp 我在什么应用程序中看到我们可以开始下载 然后我们可以在不同的屏幕上移动或按主页
  • Sublime Text 如何将包添加到全局存储库

    我为 sublime 创建了一个插件 并将其称为 sublimecastling 主要思想是替换 2 个选定的字段 因此 我很高兴知道是否可以将其添加到您的 Sublime 存储库中 以便用户可以通过包控制安装该插件 下面提供了 githu
  • 无法使用 Angular 服务处理 onbeforeunload 事件

    我有以下回调onbeforeUnload我的一项服务中的事件 在我的app run我有块 window onbeforeunload Services beforeWindowClose 这个方法是在一个服务中 this beforeWin
  • 覆盖 ggplot 中的图例符号大小

    我正在尝试使用我在本论坛和其他地方找到的命令来覆盖我的符号大小 aes 我可以让 Alpha 覆盖起作用 但不能让大小起作用 f1 lt ggplot data d aes x rpos y count group id color id
  • 我不想为我想与之共享 bigquery 数据集的外部用户生成服务帐户 - 这会产生什么影响?

    我向用户的 Google 帐户授予了对我的一个数据集的访问权限 他们正在使用这个 Python 脚本 def query stackoverflow client bigquery Client query job client query