限制来自虚拟机的 SSH 密钥


本文档介绍如何通过移除和屏蔽来自虚拟机的 SSH 密钥来阻止用户访问虚拟机 (VM) 实例。

准备工作

  • 设置身份验证(如果尚未设置)。身份验证是通过其进行身份验证以访问 Google Cloud 服务和 API 的过程。如需从本地开发环境运行代码或示例,您可以按如下方式向 Compute Engine 进行身份验证。

    选择标签页以了解您打算如何使用本页面上的示例:

    控制台

    当您使用 Google Cloud 控制台访问 Google Cloud 服务和 API 时,无需设置身份验证。

    gcloud

    1. 安装 Google Cloud CLI,然后通过运行以下命令初始化 Google Cloud CLI:

      gcloud init
    2. 设置默认区域和可用区

    REST

    如需在本地开发环境中使用本页面上的 REST API 示例,请使用您提供给 gcloud CLI 的凭据。

      安装 Google Cloud CLI,然后通过运行以下命令初始化 Google Cloud CLI:

      gcloud init

移除 SSH 密钥

您可以从使用 OS Login 的虚拟机使用基于元数据的 SSH 密钥的虚拟机中移除 SSH 密钥。

从使用 OS Login 的虚拟机中移除 SSH 密钥

使用 OS Login 的虚拟机接受与您的 Google 账号关联的 SSH 密钥。您可以使用 Google Cloud CLI 或 OS Login API 从用户账号中移除 SSH 公钥。如果您是组织的管理员,则可以使用 Directory API 将 SSH 密钥从用户账号中移除。Compute Engine 会自动从您的 Google 账号中移除过期的密钥。

gcloud

如需从您的账号中移除 SSH 公钥,请执行以下操作:

  1. 如果您不确定要移除的密钥,请运行 gcloud compute os-login describe-profile 命令以查看与您的账号关联的所有密钥:

    gcloud compute os-login describe-profile
    
  2. 复制要删除的密钥的 fingerprint 值。

  3. 使用 gcloud compute os-login ssh-keys remove 命令从账号中移除密钥:

    gcloud compute os-login ssh-keys remove --key=KEY
    

    KEY 替换为您要移除的 SSH 公钥或您要移除的密钥的 OS Login 指纹。

REST

如需从您的账号中移除 SSH 公钥,请执行以下操作:

  1. 如果您不确定要移除的密钥,请使用 users.getLoginProfile 方法查看与账号关联的所有密钥:

    GET https://oslogin.googleapis.com/v1/users/ACCOUNT_EMAIL/loginProfile
    

    ACCOUNT_EMAIL 替换为与您的账号关联的电子邮件地址。

  2. 复制要删除的密钥的 fingerprint 值。

  3. 使用 users.sshPublicKeys.delete 方法从账号中移除密钥:

    DELETE https://oslogin.googleapis.com/v1/users/ACCOUNT_EMAIL/sshPublicKeys/FINGERPRINT
    

    替换以下内容:

    • ACCOUNT_EMAIL:与您的账号关联的电子邮件地址
    • FINGERPRINT:要移除的密钥的 SHA-256 指纹

从使用基于元数据的密钥的虚拟机中移除 SSH 密钥

您可以使用 Google Cloud Console、gcloud CLI 或 Compute Engine API 从项目或实例元数据中移除 SSH 公钥。

从特定用户的元数据中移除最后一个键或者特定用户的元数据中的最后一个键过期后,Compute Engine 会删除该用户的虚拟机上的 ~/.ssh/authorized_keys 文件。

注意:如果您管理元数据中的 SSH 密钥,可能会导致项目成员无法连接到虚拟机。此外,您可能面临向用户(包括项目外部的用户)授予意外访问虚拟机的权限的风险。如需了解详情,请参阅手动管理密钥的风险

从项目元数据中移除公钥

从项目元数据中移除 SSH 公钥,以移除对项目中所有虚拟机的访问权限。

使用 gcloud CLI 和 Compute Engine API 从元数据中移除密钥时,您必须检索现有密钥列表,修改密钥列表以移除不需要的密钥,并使用您要保留的密钥列表覆盖旧密钥,如以下部分所述。

控制台

如需使用 Google Cloud 控制台从项目元数据中移除 SSH 公钥,请执行以下操作:

  1. 在 Google Cloud Console 中,转到元数据页面。

    转到元数据

  2. SSH 密钥 (SSH Keys) 下,点击修改

  3. 点击 SSH 密钥旁边的移除按钮。

    PuTTYgen 公钥。

  4. 点击保存

gcloud

如需使用 gcloud CLI 从项目元数据中移除 SSH 公钥,请执行以下操作:

  1. 运行 gcloud compute project-info describe 命令以获取项目的元数据:

    gcloud compute project-info describe
    

    输出内容类似如下:

    ...
    metadata:
      ...
      - key: ssh-keys
        value: |-
          cloudysanfrancisco:ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDAu5kKQCPF
          baklavainthebalkans:ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDQDx3FNVC8 google-ssh {"userName":"baklavainthebalkans","expireOn":"2021-06-14T16:59:03+0000"}
    ...
    
  2. 复制 ssh-keys 元数据值。

  3. 在工作站上创建并打开一个新的文本文件。

  4. 在该文件中,粘贴您刚刚复制的 SSH 密钥列表,然后删除要从项目元数据中移除的所有密钥。

  5. 保存并关闭文件。

  6. 运行 gcloud compute project-info add-metadata 命令以设置项目范围的 ssh-keys 值:

    gcloud compute project-info add-metadata --metadata-from-file=ssh-keys=KEY_FILE
    

    KEY_FILE 替换为以下项之一:

    • 您在上一步中创建的文件的路径(如果项目已有 SSH 密钥)
    • 新建 SSH 公钥文件的路径(如果项目还没有 SSH 密钥)

REST

如需使用 Compute Engine API 从项目元数据中移除 SSH 公钥,请执行以下操作:

  1. 使用 projects.get 方法从元数据中获取 fingerprintssh-keys 值。

    GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID
    

    PROJECT_ID 替换为您的项目 ID。

    响应类似于以下示例:

    ...
    "fingerprint": "utgYE_XWtE8=",
    "items": [
     {
      "key": "ssh-keys",
      "value": "cloudysanfrancisco:ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDAu5kKQCPF\nbaklavainthebalkans:ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDQDx3FNVC8 google-ssh {"userName":"baklavainthebalkans","expireOn":"2021-06-14T16:59:03+0000"}"
     }
    ]
    ...
    
  2. 复制 SSH 密钥值列表并删除要移除的密钥。

  3. 使用 projects.setCommonInstanceMetadata 移除 SSH 密钥。

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/setCommonInstanceMetadata
    
    {
    "items": [
     {
      "key": "ssh-keys",
      "value": "EXISTING_SSH_KEYS"
     }
    ]
    "fingerprint": "FINGERPRINT"
    }
    

    替换以下内容:

    • PROJECT_ID:您的项目 ID
    • EXISTING_SSH_KEYS:您要保留的 SSH 密钥列表
    • FINGERPRINTprojects.get 请求的响应中的 fingerprint 的值

从实例元数据中移除 SSH 公钥

从实例元数据中移除 SSH 公钥,以移除对单个虚拟机的访问权限。

使用 gcloud CLI 和 Compute Engine API 从元数据中移除密钥时,您必须检索现有密钥列表,修改密钥列表以移除不需要的密钥,并使用您要保留的密钥列表覆盖旧密钥,如以下部分所述。

控制台

如需使用 Google Cloud 控制台从实例元数据中移除 SSH 公钥,请执行以下操作:

  1. 在 Google Cloud Console 中,转到元数据页面。

    转到元数据

  2. 点击要为其移除密钥的虚拟机的名称。

  3. 点击修改

  4. 在中央窗格中的 SSH 密钥下,点击显示和修改。该部分随即展开,显示所有实例级 SSH 公钥。

  5. 点击要移除的密钥旁边的移除按钮:

    PuTTYgen 公钥。

  6. 点击保存

gcloud

如需使用 gcloud CLI 从实例元数据中移除 SSH 公钥,请执行以下操作:

  1. 运行 gcloud compute instances describe 命令以获取虚拟机的元数据:

    gcloud compute instances describe VM_NAME
    

    VM_NAME 替换为需要添加或移除 SSH 公钥的虚拟机的名称。

    输出内容类似如下:

    ...
    metadata:
    ...
    - key: ssh-keys
     value: |-
       cloudysanfrancisco:ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDAu5kKQCPF
       baklavainthebalkans:ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDQDx3FNVC8 google-ssh {"userName":"baklavainthebalkans","expireOn":"2021-06-14T16:59:03+0000"}
    ...
    
  2. 复制 ssh-keys 元数据值。

  3. 在本地工作站上创建并打开一个新的文本文件。

  4. 在该文件中,粘贴您刚刚复制的 SSH 密钥列表,然后移除要删除的所有密钥。

  5. 保存并关闭文件。

  6. 运行 gcloud compute project-info add-metadata 命令以设置项目范围的 ssh-keys 值:

    gcloud compute instances add-metadata VM_NAME --metadata-from-file ssh-keys=KEY_FILE
    

    替换以下内容:

    • VM_NAME:您要移除其 SSH 密钥的虚拟机
    • KEY_FILE:包含所有项目 SSH 密钥列表的文件的路径

REST

如需使用 Compute Engine API 从实例元数据中移除 SSH 公钥,请执行以下操作:

  1. 使用 instances.get 方法从元数据中获取 fingerprintssh-keys 值。

    GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME
    

    替换以下内容:

    • PROJECT_ID:您的项目 ID
    • ZONE:您要为其添加 SSH 密钥的虚拟机的可用区
    • VM_NAME:您要为其添加 SSH 密钥的虚拟机

    响应类似于以下示例:

    ...
    "fingerprint": "utgYE_XWtE8=",
    "items": [
    {
     "key": "ssh-keys",
     "value": "cloudysanfrancisco:ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDAu5kKQCPF\nbaklavainthebalkans:ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDQDx3FNVC8 google-ssh {"userName":"baklavainthebalkans","expireOn":"2021-06-14T16:59:03+0000"}"
    }
    ]
    ...
    
  2. 复制 SSH 密钥值列表并删除要移除的密钥。

  3. 使用 instances.setMetadata 移除 SSH 密钥。

    
    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME/setMetadata
    
    {
    "items": [
     {
      "key": "ssh-keys",
      "value": "EXISTING_SSH_KEYS
     }
    ]
    "fingerprint": "FINGERPRINT"
    }
    

    替换以下内容:

    • PROJECT_ID:您的项目 ID
    • EXISTING_SSH_KEYSprojects.get 请求的响应中的 ssh-keys 键的值
    • FINGERPRINTinstances.get 请求的响应中的 fingerprint 的值

屏蔽使用基于元数据的 SSH 密钥的虚拟机的项目 SSH 密钥

您可以通过阻止来自虚拟机的项目 SSH 密钥,阻止虚拟机接受存储在项目元数据中的 SSH 密钥。 您可以在创建虚拟机时或者创建虚拟机后屏蔽来自虚拟机的项目 SSH 密钥。

在虚拟机创建的过程中阻止来自虚拟机的项目 SSH 密钥

您可以在创建虚拟机的过程中使用 Google Cloud 控制台、gcloud CLI 或 Compute Engine API 阻止来自虚拟机的项目 SSH 密钥。

控制台

如需使用 Google Cloud 控制台创建虚拟机并阻止其接受存储在项目元数据中的 SSH 密钥,请执行以下操作:

  1. 在 Google Cloud Console 中,转到创建实例页面。

    转到“创建实例”

  2. 指定虚拟机详情。

  3. 展开高级选项部分,然后执行以下操作:

    1. 展开安全部分。

    2. 选中屏蔽项目范围的 SSH 密钥

  4. 要创建并启动该虚拟机,请点击创建

gcloud

如需使用 gcloud CLI 创建虚拟机并阻止其接受存储在项目元数据中的 SSH 密钥,请使用 gcloud compute instances create 命令

gcloud compute instances create VM_NAME \
    --metadata block-project-ssh-keys=TRUE

VM_NAME 替换为新虚拟机的名称。

REST

如需使用 Compute Engine 创建虚拟机并阻止其接受存储在项目元数据中的 SSH 密钥,请构建一个向 instances.insert 方法发出的 POST 请求:

POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances

替换以下内容:

  • PROJECT_ID:项目 ID
  • ZONE:虚拟机所在的区域

在请求正文中,在 items 属性中提供用户名和 SSH 公钥:

...
{
 "items": [
    {
     "key": "block-project-ssh-keys",
     "value": TRUE
    }
   ]
}
...

在虚拟机创建之后阻止来自虚拟机的项目 SSH 密钥

您可以在创建虚拟机后使用 Google Cloud 控制台、gcloud CLI 或 Compute Engine API 阻止来自虚拟机的项目 SSH 密钥。

控制台

如需使用 Google Cloud 控制台阻止虚拟机接受存储在项目元数据中的 SSH 密钥的连接,请执行以下操作:

  1. 在 Google Cloud Console 中,转到元数据页面。

    转到元数据

  2. 点击要为其屏蔽项目 SSH 密钥的虚拟机的名称。

  3. 点击修改

  4. SSH 密钥下,选中屏蔽项目范围的 SSH 密钥复选框。

  5. 修改完 SSH 密钥的连接设置后,点击保存

gcloud

如需使用 gcloud CLI 阻止虚拟机接受存储在项目元数据中的 SSH 密钥的连接,请执行以下操作:

运行 gcloud compute instances add-metadata 命令

gcloud compute instances add-metadata VM_NAME --metadata block-project-ssh-keys=TRUE

VM_NAME 替换为要针对其屏蔽项目范围的 SSH 公钥的虚拟机名称。

REST

如需使用 Compute Engine API 阻止虚拟机接受存储在项目元数据中的 SSH 密钥的连接,请执行以下操作:

  1. 使用 instances.get 方法从元数据中获取 fingerprint

    GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME
    

    替换以下内容:

    • PROJECT_ID:您的项目 ID
    • ZONE:您要为其添加 SSH 密钥的虚拟机的可用区
    • VM_NAME:您要为其添加 SSH 密钥的虚拟机

    响应类似于以下示例:

    ...
    "fingerprint": "utgYE_XWtE8="
    ...
    
  2. 使用 instances.setMetadata 方法block-project-ssh-keys 设置为 TRUE

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME/setMetadata
    
    {
    "items": [
     {
      "key": "block-project-ssh-keys",
      "value": TRUE
     }
    ]
    "fingerprint": "FINGERPRINT"
    }
    

    替换以下内容:

    • PROJECT_ID 是项目 ID
    • ZONE 是实例所在的可用区
    • INSTANCE_NAME 是您要屏蔽的项目范围的密钥实例。
    • FINGERPRINTinstances.get 请求的响应中的 fingerprint 的值。

后续步骤