跳至主要内容

GitHub Codespaces 客户端故障排除

本文提供有关您可能在使用 GitHub Codespaces 客户端时遇到的问题的故障排除信息。

注意

  • 目前,使用 JetBrains IDE 与 GitHub Codespaces 处于公开预览阶段,可能会发生更改。
  • 要在 JetBrains IDE 中处理 Codespace,您必须使用 JetBrains Gateway 的 2023.3.* 或 2024.1.* 版本。

Visual Studio Code 网页客户端故障排除

如果您在使用非基于 Chromium 的浏览器中的 GitHub Codespaces 时遇到问题,请尝试切换到基于 Chromium 的浏览器,例如 Google Chrome 或 Microsoft Edge。或者,通过搜索标有浏览器名称的问题(例如 firefoxsafari),在 microsoft/vscode 仓库中检查您浏览器的已知问题。

如果您在使用基于 Chromium 的浏览器中的 GitHub Codespaces 时遇到问题,您可以检查您是否在 microsoft/vscode 仓库中遇到了 VS Code 的其他已知问题。

与在本地 VS Code 中工作的区别

当您在浏览器中使用 VS Code 网页客户端打开 Codespace 时,您会注意到与在 VS Code 桌面应用程序中的本地工作区工作的一些区别。例如,某些键绑定将有所不同或缺失,并且某些扩展程序的行为可能有所不同。有关摘要,请参阅 VS Code 文档中的“已知限制和调整” 。

您可以在 microsoft/vscode 仓库中检查已知问题并记录有关 VS Code 体验的新问题。

Visual Studio Code 预览版

Visual Studio Code 预览版是 VS Code 最频繁的版本发布。它包含所有最新的功能和错误修复,但也可能偶尔包含导致构建中断的新问题。

如果您使用的是预览版版本并注意到行为异常,我们建议您切换到 Visual Studio Code 稳定版并重试。

点击编辑器左下角的,然后选择**切换到稳定版本...**。如果 VS Code 网页客户端无法加载,或者不可用,您可以通过将?vscodeChannel=stable附加到 Codespace URL 并在此 URL 加载 Codespace 来强制切换到 Visual Studio Code 稳定版。

如果问题在 Visual Studio Code 稳定版中未解决,请检查已知问题,并在需要时在 microsoft/vscode 仓库中记录有关 VS Code 体验的新问题。

简单浏览器疑难解答

在 codespace 中启动 Web 应用程序后,您可以在 VS Code 中嵌入的简单浏览器中预览正在运行的应用程序。在某些项目中,应用程序启动时会在编辑器中自动打开一个简单浏览器选项卡。如果 codespace 的devcontainer.json配置文件中,应用程序运行端口的onAutoForward属性设置为openPreview,则会发生这种情况。

"portsAttributes": {
  "3000": {
    "label": "Application",
    "onAutoForward": "openPreview"
  }
}

如果简单浏览器选项卡没有自动打开,您可以手动打开简单浏览器来查看应用程序。

  1. 在 VS Code 中,单击**端口**选项卡。

  2. 右键单击端口,然后单击**在编辑器中预览**。

    Screenshot of the pop-up menu in the VS Code Ports tab. The menu entry "Preview in Editor" is highlighted with a dark orange outline.

简单浏览器选项卡不会自动打开

如果devcontainer.json配置文件为某个端口指定了"onAutoForward": "openPreview",但应用程序启动时简单浏览器没有自动打开,请检查应用程序是否已在配置文件中指定的端口上启动。如果目标端口繁忙,应用程序可能会在其他端口启动。

为了实现devcontainer.json中指定的端口配置,GitHub Codespaces 在创建 codespace 时会将配置写入 VS Code 的settings.json文件。您可以检查配置是否已正确写入 codespace 中的settings.json文件。

  1. 在 codespace 的终端中,输入以下命令。

    Bash
    cat ~/.vscode-remote/data/Machine/settings.json
    
  2. 验证settings.json文件是否包含以下类似的行。

     "remote.portsAttributes": {
         "3000": {
             "label": "Application",
             "onAutoForward": "openPreview"
         }
     }
    

如果settings.json文件不包含这些设置,请检查您是否启用了 dotfiles,以及您的 dotfiles 中的任何配置是否覆盖了settings.json文件。更多信息,请参见为您的帐户个性化 GitHub Codespaces

应用程序无法加载

有时,您可能会发现简单浏览器选项卡已打开,但显示错误页面图标或空白页,而不是正在运行的应用程序。如果要加载的 Web 应用程序包含限制网站页面允许嵌入的域的内容安全策略 (CSP),则可能会发生这种情况。更多信息,请参见mdn 网站上的CSP: frame-ancestors

您可以尝试在本地更改应用程序的frame-ancestors安全策略,以使应用程序显示在简单浏览器中。或者,如果frame-ancestors策略导致此问题,您可以通过在常规浏览器选项卡中打开应用程序(而不是简单浏览器)来查看应用程序。为此,请单击 VS Code 中的**端口**选项卡,右键单击端口,然后单击**在浏览器中打开**。

VS Code 疑难解答

在 VS Code 桌面应用程序中打开 codespace 时,您可能会注意到与在本地工作区中工作相比有一些差异,但体验应该相似。

如果遇到问题,您可以检查已知问题并使用 VS Code 体验在microsoft/vscode存储库中记录新问题。

Visual Studio Code 预览版

Visual Studio Code 预览版是 VS Code 最频繁的版本发布。它包含所有最新的功能和错误修复,但也可能偶尔包含导致构建中断的新问题。

如果您使用的是预览版版本并注意到行为异常,我们建议您切换到 Visual Studio Code 稳定版并重试。

要切换到 Visual Studio Code Stable,请关闭 Visual Studio Code Insiders 应用程序,打开 Visual Studio Code Stable 应用程序,然后重新打开您的 codespace。

如果问题在 Visual Studio Code 稳定版中未解决,请检查已知问题,并在需要时在 microsoft/vscode 仓库中记录有关 VS Code 体验的新问题。

简单浏览器疑难解答

在 codespace 中启动 Web 应用程序后,您可以在 VS Code 中嵌入的简单浏览器中预览正在运行的应用程序。在某些项目中,应用程序启动时会在编辑器中自动打开一个简单浏览器选项卡。如果 codespace 的devcontainer.json配置文件中,应用程序运行端口的onAutoForward属性设置为openPreview,则会发生这种情况。

"portsAttributes": {
  "3000": {
    "label": "Application",
    "onAutoForward": "openPreview"
  }
}

如果简单浏览器选项卡没有自动打开,您可以手动打开简单浏览器来查看应用程序。

  1. 在 VS Code 中,单击**端口**选项卡。

  2. 右键单击端口,然后单击**在编辑器中预览**。

    Screenshot of the pop-up menu in the VS Code Ports tab. The menu entry "Preview in Editor" is highlighted with a dark orange outline.

简单浏览器选项卡不会自动打开

如果devcontainer.json配置文件为某个端口指定了"onAutoForward": "openPreview",但应用程序启动时简单浏览器没有自动打开,请检查应用程序是否已在配置文件中指定的端口上启动。如果目标端口繁忙,应用程序可能会在其他端口启动。

为了实现devcontainer.json中指定的端口配置,GitHub Codespaces 在创建 codespace 时会将配置写入 VS Code 的settings.json文件。您可以检查配置是否已正确写入 codespace 中的settings.json文件。

  1. 在 codespace 的终端中,输入以下命令。

    Bash
    cat ~/.vscode-remote/data/Machine/settings.json
    
  2. 验证settings.json文件是否包含以下类似的行。

     "remote.portsAttributes": {
         "3000": {
             "label": "Application",
             "onAutoForward": "openPreview"
         }
     }
    

如果settings.json文件不包含这些设置,请检查您是否启用了 dotfiles,以及您的 dotfiles 中的任何配置是否覆盖了settings.json文件。更多信息,请参见为您的帐户个性化 GitHub Codespaces

应用程序无法加载

有时,您可能会发现简单浏览器选项卡已打开,但显示错误页面图标或空白页,而不是正在运行的应用程序。如果要加载的 Web 应用程序包含限制网站页面允许嵌入的域的内容安全策略 (CSP),则可能会发生这种情况。更多信息,请参见mdn 网站上的CSP: frame-ancestors

您可以尝试在本地更改应用程序的frame-ancestors安全策略,以使应用程序显示在简单浏览器中。或者,如果frame-ancestors策略导致此问题,您可以通过在常规浏览器选项卡中打开应用程序(而不是简单浏览器)来查看应用程序。为此,请单击 VS Code 中的**端口**选项卡,右键单击端口,然后单击**在浏览器中打开**。

JetBrains IDE 疑难解答

性能问题

建议使用至少 4 核的 GitHub Codespaces 机器类型来运行任何 JetBrains IDE。更多信息,请参见更改 codespace 的机器类型

如果您使用的是具有 4 个或更多内核的机器,并且在 JetBrains 中体验到的性能有点迟缓,则可能需要增加最大 Java 堆大小。

推荐的堆大小会根据 codespace 的机器类型而有所不同。

机器类型最大堆大小
4 核,16 GB RAM2048 MiB
8 核,32 GB RAM4096 MiB
16 核,64 GB RAM8192 MiB
32 核,128 GB RAM16,384 MiB

如果堆大小低于推荐值,则 codespace 启动时会显示一条消息,建议您增加堆大小。您可以单击消息中的链接来自动增加堆大小。

Screenshot of the message recommending you increase the heap size.

根据代码库的大小以及运行应用程序所需的内存,您可能需要进一步增加堆大小。您应将堆大小设置为上述表格中显示的大小与远程主机 RAM 的 60% 之间的值。如果您的应用程序很大,则不应设置过大的堆大小,以便为应用程序留出足够的内存。

  1. 在应用程序窗口顶部的导航栏左侧,单击 codespace 的名称。

    Screenshot of the JetBrains client. The codespace name "urban meme," labeled "Resources critical," is highlighted with a dark orange outline.

  2. 在“性能”选项卡中,请注意 CPU 负载和内存详细信息。这些将指示机器是否过载。

    Screenshot of the "Performance" tab in the resources dropdown, showing CPU Load at 97.5%, Memory at 60.6%, and Disk at 28.8%.

  3. 单击“设置”选项卡并编辑堆大小,将其增加到不超过 codespace 可用内存的 60%。

    Screenshot of the "Performance" tab. In the "Maximum heap size" field, 3072 is entered and outlined in dark orange. Below this are "Save" and "Save and restart" buttons.

  4. 单击**保存并重新启动**。

客户端无法在 macOS Ventura 中打开

在 macOS Ventura 中,使用 2022.3 之前的 JetBrains Gateway 版本时,第一次尝试从 JetBrains Gateway 连接到 codespace 时,会显示一条消息,告诉您 JetBrains 客户端应用程序“已损坏且无法打开”。

Screenshot of the 'cannot be opened' error message

此问题已在 JetBrains Gateway 2022.3 及更高版本中修复。

为避免此问题,请更新 JetBrains Gateway。

要解决使用旧版 Gateway 的此问题

  1. 单击**取消**以关闭此消息。

  2. 单击屏幕左上角的 Apple 图标,然后单击**系统设置**。

  3. 单击**隐私与安全性**,然后向下滚动到“安全性”部分。

    Screenshot of macOS "Privacy & Security" dialog, with a security message above the JetBrains Client and the "Open Anyway" button.

    您将看到一条消息,告诉您 JetBrains Client 被阻止使用。

  4. 单击**仍然打开**以将 JetBrains 客户端添加到您已识别的应用程序。该消息再次显示,但这次带有**打开**按钮。

    Screenshot of the error message with an 'Open' button
  5. 再次单击**取消**。

  6. 返回 JetBrains Gateway 应用程序并再次连接到所需的 codespace。JetBrains 客户端现在将成功打开。授权客户端应用程序在您的 Mac 上运行后,将来连接到您的 codespaces 时将不会看到此消息。

SSH 连接问题

要通过 codespace 中运行的 SSH 服务器连接,您必须在~/.ssh目录(macOS 和 Linux)或%HOMEPATH%\.ssh目录(Windows)中拥有已添加到 GitHub 帐户的 SSH 密钥。如果此目录中没有任何密钥,GitHub CLI 将为您生成密钥。更多信息,请参见将新的 SSH 密钥添加到您的 GitHub 帐户

如果您遇到密钥验证问题,请尝试升级您的 GitHub CLI 版本。有关信息,请参阅 GitHub CLI 自述文件中的升级说明

JetBrains IDE 问题

有关您正在使用的 JetBrains IDE 或 JetBrains Gateway 应用程序的特定问题的帮助,请参见 JetBrains 网站上的产品支持