跳至主要内容
版本:1.23.6

常見問題

此頁面包含一些常見問題和答案。

如需更多幫助資源,請查看所有支援選項

1.x 和 1.x.x 下載之間的區別,如何獲取最新的穩定版本並修復錯誤?

以版本 1.20.x 為例。

在我們的下載頁面上,您將看到 1.20 目錄以及 1.20.0、1.20.1 目錄。

1.20 目錄是每次合併提交到 release/v1.20 分支時構建的夜間構建。

1.20.0 目錄是當 v1.20.0 標籤創建時創建的發布構建。

夜間構建(1.x)下載將隨著提交合併到各自的分支而變化,它們包含在標籤發布之前的最新更改/修復。

如果錯誤修復針對 1.20.1,但 1.20.1 尚未發布,您可以獲取 "1.20-nightly" 構建以獲取錯誤修復。

如何找到配置文件 "app.ini"

這取決於您如何安裝 Gitea。如果您沒有手動設置自定義路徑或配置文件的路徑,那麼配置文件 (app.ini) 應該存在於 Gitea 工作路徑的 "custom/conf" 目錄中。一些軟件包供應商可能會使用 "/etc/gitea" 來存儲配置文件,而其他供應商則不會。

您可以通過檢查 Gitea 的啟動日誌或閱讀 Gitea 網站管理員 -> 配置摘要來手動查找配置文件 (app.ini)。

如果您使用的是一些隔離環境(如容器 docker),您看到的路徑通常不是主機文件系統中的實際路徑。在這種情況下,您需要檢查容器的文件系統卷映射並找出主機上配置文件的實際路徑。

Gitea 存儲文件的位置

  • AppWorkPath
    • app.ini 中的 WORK_PATH 選項
    • 否則 --work-path 標誌
    • 否則環境變量 GITEA_WORK_DIR
    • 否則在構建時設置的內置值
    • 否則包含 Gitea 二進制文件的目錄
  • AppDataPath(默認為數據庫、索引器等)
    • app.ini 中的 APP_DATA_PATH
    • 否則 AppWorkPath/data
  • CustomPath(自定義模板)
    • --custom-path 標誌
    • 否則環境變量 GITEA_CUSTOM
    • 否則在構建時設置的內置值
    • 否則 AppWorkPath/custom
  • HomeDir
    • Unix:環境變量 HOME
    • Windows:環境變量 USERPROFILE,否則環境變量 HOMEDRIVE+HOMEPATH
  • RepoRootPath
    • app.ini 中 [repository] 部分的 ROOT(如果是絕對路徑)
    • 否則 AppWorkPath/ROOT(如果 app.ini 中 [repository] 部分的 ROOT 是相對路徑)
    • 默認 %(APP_DATA_PATH)/gitea-repositories
  • INI(配置文件)
    • --config 標誌
    • 構建時設置的可能內置值
    • 否則 CustomPath/conf/app.ini
  • SQLite 數據庫
    • app.inidatabase 部分的 PATH
    • 否則 %(APP_DATA_PATH)/gitea.db

看不到克隆 URL 或克隆 URL 不正確

有幾個地方可能會導致顯示不正確。

  1. 如果使用反向代理,請確保您已按照反向代理指南中的正確指示進行操作
  2. 確保您已正確設置 app.iniserver 部分的 ROOT_URL

如果某些克隆選項未顯示(HTTP/S 或 SSH),可以在 app.ini 中檢查以下選項

  • DISABLE_HTTP_GIT:如果設置為 true,則不會有 HTTP/HTTPS 連接
  • DISABLE_SSH:如果設置為 true,則不會有 SSH 連接
  • SSH_EXPOSE_ANONYMOUS:如果設置為 false,則匿名用戶將隱藏 SSH 連接

文件上傳失敗:413 Request Entity Too Large

當反向代理限制文件上傳大小時,會出現此錯誤。

請參閱反向代理指南以獲取 nginx 的解決方案。

自定義模板未加載或工作不正確

Gitea 的自定義模板必須添加到正確的位置,否則 Gitea 將無法找到並使用它們。

模板的正確路徑將相對於 CustomPath

  1. 要查找 CustomPath,請在網站管理 -> 配置中查找自定義文件根路徑
  2. 如果您仍然無法找到路徑,可以在上面計算默認值
  3. 一旦您找到了正確的自定義路徑,您可以參考自定義 Gitea頁面將模板添加到正確的位置。

Gitea 是否有 "GitHub/GitLab pages" 功能?

Gitea 沒有內置的 Pages 服務器。您需要一個專用域來提供靜態頁面以避免 CSRF 安全風險。

對於簡單的使用,您可以使用反向代理來重寫並從 Gitea 的原始文件 URL 提供靜態內容。

已經有可用的第三方服務,如獨立的pages 服務器caddy 插件,可以提供所需的功能。

活躍用戶與禁止登錄用戶

在 Gitea 中,“活躍”用戶是指通過電子郵件激活其帳戶的用戶。

“禁止登錄”用戶是指不再允許登錄 Gitea 的用戶

什麼是 Swagger?

Swagger 是 Gitea 用於其 API 文檔的工具。

所有 Gitea 實例都有內置的 API,無法完全禁用它。 但是,您可以通過在 app.iniapi 部分中設置 ENABLE_SWAGGERfalse 來禁用顯示其文檔。 有關更多信息,請參閱 Gitea 的 API 文檔

您可以在 https://gitea.com/api/swagger 上查看最新的 API(例如)

您還可以在 https://gitea.com/swagger.v1.json 上查看 swagger.json 文件的示例

調整您的服務器以供公用/私用

防止垃圾郵件

有多種方法可以結合使用來防止垃圾郵件。

  1. 通過白名單或黑名單某些電子郵件域
  2. 通過僅白名單某些域與 OpenID(見下文)
  3. app.ini 中設置 ENABLE_CAPTCHAtrue 並正確配置 RECAPTCHA_SECRETRECAPTCHA_SITEKEY
  4. 設置 DISABLE_REGISTRATIONtrue 並通過 CLIAPI 或 Gitea 的管理 UI 創建新用戶

只允許/阻止某些電子郵件域

您可以在 app.ini[service] 部分中配置 EMAIL_DOMAIN_WHITELISTEMAIL_DOMAIN_BLOCKLIST

只允許/阻止某些 OpenID 提供商

您可以在 app.ini[openid] 部分中配置 WHITELISTED_URISBLACKLISTED_URIS

備註

白名單優先,如果它不是空白的,則忽略黑名單。

僅限問題用戶

目前的實現方式是創建/修改用戶,將其最大倉庫創建限制設置為 0。

受限用戶

受限用戶僅限於根據其組織/團隊成員資格和協作關係訪問部分內容,忽略組織/倉庫等的公共標誌。

示例用例:一家公司運行一個需要登錄的 Gitea 實例。大多數倉庫是公共的(所有同事都可以訪問/瀏覽)。

某個時候,客戶或第三方需要訪問特定倉庫並且僅限於該倉庫。將此類客戶帳戶設置為受限並使用團隊成員資格和/或協作關係授予所需的訪問權限是一種簡單的方法,無需將所有內容設置為私有。

啟用 Fail2ban

使用 Fail2Ban 監控並阻止基於日誌模式的自動登錄嘗試或其他惡意行為

SSHD 與內置 SSH

SSHD 是大多數 Unix 系統上的內置 SSH 服務器。

Gitea 也提供了自己的 SSH 服務器,用於 SSHD 不可用時使用。

翻譯不正確/如何添加更多翻譯

我們的翻譯目前在我們的 Crowdin 項目 上進行群眾外包

無論您是想更改翻譯還是添加新翻譯,都需要在那裡進行,因為所有翻譯都會在我們的 CI 中通過 Crowdin 集成進行覆蓋。

推送 Hook / Webhook / Actions 未運行

如果您可以推送但在主頁面板上看不到推送活動,或者推送未觸發 webhook 和 Actions 工作流,這可能是 git hooks 未正常工作。

有幾種可能性:

  1. git hooks 不同步:在網站管理面板上運行“重新同步所有倉庫的 pre-receive、update 和 post-receive hooks”
  2. git 倉庫(和 hooks)存儲在某些文件系統上(例如由 NAS 掛載)不支持腳本執行,確保文件系統支持 chmod a+x any-script
  3. 如果您使用 docker,確保 Docker 服務器(不是客戶端)>= 20.10.6

SSH 問題

如果您無法通過 ssh 訪問倉庫,但 https 正常工作,請考慮查看以下內容。

首先,確保您可以通過 SSH 訪問 Gitea。

ssh git@myremote.example

如果連接成功,您應該會收到如下錯誤消息:

Hi there, You've successfully authenticated, but Gitea does not provide shell access.
If this is unexpected, please log in with password and setup Gitea under another user.

如果您沒有收到上述消息但仍然連接,這意味著您的 SSH 密鑰由 Gitea 管理。這意味著 hooks 不會運行,還有其他潛在問題。

如果您無法連接,您的 SSH 密鑰可能在本地配置不正確。 這是特定於 SSH 而不是 Gitea 的問題,因此不在此處涵蓋。

SSH 常見錯誤

Permission denied (publickey).
fatal: Could not read from remote repository.

此錯誤表示服務器拒絕了登錄嘗試,請檢查以下內容:

  • 在客戶端:

    • 確保公鑰和私鑰已添加到正確的 Gitea 用戶。
    • 確保遠程 URL 中沒有問題。特別是,確保 Git 用戶名(在 @ 之前)拼寫正確。
    • 確保客戶端機器上的公鑰和私鑰正確。
  • 在服務器上:

    • 確保倉庫存在並且名稱正確。

    • 檢查系統用戶主目錄中 .ssh 目錄的權限。

    • 驗證正確的公鑰已添加到 .ssh/authorized_keys

      嘗試在 Gitea 管理面板上運行“重寫 '.ssh/authorized_keys' 文件(用於 Gitea SSH 密鑰)”。

    • 閱讀 Gitea 日誌。

    • 閱讀 /var/log/auth(或類似)。

    • 檢查倉庫的權限。

以下是缺少公鑰的示例,其中身份驗證成功,但某些其他設置阻止 SSH 訪問正確的倉庫。

fatal: Could not read from remote repository.

Please make sure you have the correct access rights
and the repository exists.

在這種情況下,請查看以下設置:

  • 在服務器上:
    • 確保 git 系統用戶設置了可用的 shell
      • 使用 getent passwd git | cut -d: -f7 驗證
      • 可以使用 usermodchsh 進行修改。
    • 確保 .ssh/authorized_keys 中的 gitea serv 命令使用正確的配置文件。

遷移帶有標籤的倉庫後缺少發布

要遷移帶有所有標籤的倉庫,您需要做兩件事:

  • 將標籤推送到倉庫:
 git push --tags
  • 在 Gitea 中(重新)同步所有倉庫的標籤:
gitea admin repo-sync-releases

如何在啟動 Gitea 之前創建用戶

Gitea 提供了一個子命令 gitea migrate 來初始化數據庫,之後您可以使用 admin CLI 命令 像正常一樣添加用戶。

如何啟用密碼重置

沒有密碼重置的設置。當配置了郵件服務時,它會啟用,否則禁用。

如何更改用戶的密碼

  • 作為管理員,您可以更改任何用戶的密碼(並可選擇強制他們在下次登錄時更改)...

    • 通過導航到您的 網站管理 -> 用戶帳戶 頁面並編輯用戶。

    • 通過使用 admin CLI 命令

      請記住,大多數命令還需要一個全局標誌來指向正確的配置。

  • 作為用戶,您可以更改它...

    • 在您的帳戶 設置 -> 帳戶 頁面(此方法需要您知道當前密碼)。

    • 通過使用 忘記密碼 連結。

      如果 忘記密碼/帳戶恢復 頁面被禁用,請聯繫您的管理員配置郵件服務

數據庫啟動期間有關結構默認值的警告

有時在進行遷移時,舊列和默認值可能會保留在數據庫模式中。這可能會導致如下警告:

2020/08/02 11:32:29 ...rm/session_schema.go:360:Sync() [W] Table user Column keep_activity_private db default is , struct default is 0

這些警告可以安全地忽略,但您可以通過讓 Gitea 重新創建這些表來停止這些警告:

gitea doctor recreate-table user

這將使 Gitea 重新創建用戶表並將舊數據複製到新表中,並適當設置默認值。

您可以讓 Gitea 重新創建多個表:

gitea doctor recreate-table table1 table2 ...

如果您希望 Gitea 重新創建所有表,只需調用:

gitea doctor recreate-table

強烈建議在運行這些命令之前備份您的