`/etc/gitlab/gitlab-secrets.json`文件丢失时Gitlab恢复办法

2023-12-14 06:01

本文主要是介绍`/etc/gitlab/gitlab-secrets.json`文件丢失时Gitlab恢复办法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/etc/gitlab/gitlab-secrets.json文件丢失时

如果您没有备份secrets文件,则必须完成几个步骤才能使GitLab重新正常工作。

secrets文件负责存储包含必需的敏感信息的列的加密密钥。如果密钥丢失,GitLab将无法解密这些列,从而阻止对以下项目的访问:

  • CI/CD变量
  • Kubernetes / GCP集成
  • 自定义页面域
  • 项目错误跟踪
  • Runner认证
  • 项目镜像
  • 集成
  • webhooks

在CI/CD变量和runner认证等情况下,您可能遭遇未曾预料到的结果,例如:

  • 工作卡住了
  • 访问页面报500错误。

在这种情况下,您必须重置CI/CD变量和runner身份验证的所有令牌,这将在以下部分中详细描述。重置令牌后,您应该能够访问项目,作业开始再次运行。

本节中的步骤可能会导致上述项目的数据丢失。如果您是Premium或Ultimate客户,请考虑技术支持请求。

验证是否可以解密所有值

您可以确定数据库是否包含无法使用Rake任务解密的值。

sudo gitlab-rake gitlab:doctor:secrets

![[Pasted image 20231213164644.png]]

进行备份

您必须直接修改GitLab数据以解决丢失的secrets文件。

请确保在尝试任何更改之前创建完整的数据库备份。

禁用用户双因素身份验证(2FA)

启用2FA的用户无法登录GitLab。在这种情况下,您必须为每个人禁用2FA,之后用户必须重新激活2FA。

重置CI/CD变量
  1. 进入数据库控制台:

    对于Linux包(Omnibus)GitLab 14.1及更早版本:

    sudo gitlab-rails dbconsole
    

    对于Linux包(Omnibus)GitLab 14.2及更高版本:

    sudo gitlab-rails dbconsole --database main
    
  2. 检查 ci_group_variablesci_variables 表:

    SELECT * FROM public."ci_group_variables";
    SELECT * FROM public."ci_variables";
    

    这些是你需要删除的变量。

  3. 删除所有变量:

    DELETE FROM ci_group_variables;
    DELETE FROM ci_variables;
    
  4. 如果您知道要从中删除变量的特定组或项目,则可以在 DELETE 中包含一个 WHERE 语句来指定:

    DELETE FROM ci_group_variables WHERE group_id = <GROUPID>;
    DELETE FROM ci_variables WHERE project_id = <PROJECTID>;
    

您可能需要重新配置或重新启动GitLab以使更改生效。

重置跑步者注册令牌
  1. 进入数据库控制台:

    对于Linux包(Omnibus)GitLab 14.1及更早版本:

    sudo gitlab-rails dbconsole
    

    对于Linux包(Omnibus)GitLab 14.2及更高版本:

    sudo gitlab-rails dbconsole --database main
    
  2. 清除项目、组和整个实例的所有令牌:

    最后的 UPDATE 操作会阻止跑步者获得新的作业。你必须注册新的跑步者。

    -- Clear project tokens
    UPDATE projects SET runners_token = null, runners_token_encrypted = null;
    -- Clear group tokens
    UPDATE namespaces SET runners_token = null, runners_token_encrypted = null;
    -- Clear instance tokens
    UPDATE application_settings SET runners_registration_token_encrypted = null;
    -- Clear key used for JWT authentication
    -- This may break the $CI_JWT_TOKEN job variable:
    -- https://gitlab.com/gitlab-org/gitlab/-/issues/325965
    UPDATE application_settings SET encrypted_ci_jwt_signing_key = null;
    -- Clear runner tokens
    UPDATE ci_runners SET token = null, token_encrypted = null;
    
重置挂起的管道作业
  1. 进入数据库控制台:

    对于Linux包(Omnibus)GitLab 14.1及更早版本:

    sudo gitlab-rails dbconsole
    

    对于Linux包(Omnibus)GitLab 14.2及更高版本:

    sudo gitlab-rails dbconsole --database main
    
  2. 清除挂起作业的所有令牌:

    对于GitLab 15.3及更早版本:

    -- Clear build tokens
    UPDATE ci_builds SET token = null, token_encrypted = null;
    

    对于GitLab 15.4及更高版本:

    -- Clear build tokens
    UPDATE ci_builds SET token_encrypted = null;
    

类似的策略可以用于其余特征。通过删除无法解密的数据,GitLab可以恢复运行,并且可以手动替换丢失的数据。

修复集成和webhooks

如果您丢失了您的secrets,集成设置和webhooks设置页面可能会显示 500 错误消息。当您尝试使用先前配置的集成或webhook访问项目仓库时,丢失secrets也可能产生 500 错误。

修复方法是截断受影响的表(包含加密列的表)。这将删除所有已配置的集成、webhook和相关元数据。在删除任何数据之前,您应该验证secrets是根本原因。

  1. 进入数据库控制台:

    对于Linux包(Omnibus)GitLab 14.1及更早版本:

    sudo gitlab-rails dbconsole
    

    对于Linux包(Omnibus)GitLab 14.2及更高版本:

    sudo gitlab-rails dbconsole --database main
    
  2. 截断以下表格:

    -- truncate web_hooks table
    TRUNCATE integrations, chat_names, issue_tracker_data, jira_tracker_data, sl
    ```**加粗样式**
    

这篇关于`/etc/gitlab/gitlab-secrets.json`文件丢失时Gitlab恢复办法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/491388

相关文章

一文深入详解Python的secrets模块

《一文深入详解Python的secrets模块》在构建涉及用户身份认证、权限管理、加密通信等系统时,开发者最不能忽视的一个问题就是“安全性”,Python在3.6版本中引入了专门面向安全用途的secr... 目录引言一、背景与动机:为什么需要 secrets 模块?二、secrets 模块的核心功能1. 基

qt5cored.dll报错怎么解决? 电脑qt5cored.dll文件丢失修复技巧

《qt5cored.dll报错怎么解决?电脑qt5cored.dll文件丢失修复技巧》在进行软件安装或运行程序时,有时会遇到由于找不到qt5core.dll,无法继续执行代码,这个问题可能是由于该文... 遇到qt5cored.dll文件错误时,可能会导致基于 Qt 开发的应用程序无法正常运行或启动。这种错

电脑提示xlstat4.dll丢失怎么修复? xlstat4.dll文件丢失处理办法

《电脑提示xlstat4.dll丢失怎么修复?xlstat4.dll文件丢失处理办法》长时间使用电脑,大家多少都会遇到类似dll文件丢失的情况,不过,解决这一问题其实并不复杂,下面我们就来看看xls... 在Windows操作系统中,xlstat4.dll是一个重要的动态链接库文件,通常用于支持各种应用程序

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co

MySQL启动报错:InnoDB表空间丢失问题及解决方法

《MySQL启动报错:InnoDB表空间丢失问题及解决方法》在启动MySQL时,遇到了InnoDB:Tablespace5975wasnotfound,该错误表明MySQL在启动过程中无法找到指定的s... 目录mysql 启动报错:InnoDB 表空间丢失问题及解决方法错误分析解决方案1. 启用 inno

GitLab文件的上传与下载方式

《GitLab文件的上传与下载方式》:本文主要介绍GitLab文件的上传与下载方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录GitLab 项目拉取到本地GitLab 项目上传方法方法 1:本地项目未初始化Git方法 2:本地项目已初始化GitGitLab 上

电脑提示Winmm.dll缺失怎么办? Winmm.dll文件丢失的多种修复技巧

《电脑提示Winmm.dll缺失怎么办?Winmm.dll文件丢失的多种修复技巧》有时电脑会出现无法启动程序,因为计算机中丢失winmm.dll的情况,其实,winmm.dll丢失是一个比较常见的问... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包