如果openKylin 2.0 SP2主机的IPv4地址改变,如何让GitLab正常运行

作者:沈传越

明德融创工作室(Minter Fusion Studio, MFS) 出品

本文介绍的所有步骤均经过测试复现。


本文针对GitLab管理员使用。如果对于相关的专业词汇不太清楚。可以参考以下文章:

如何在openKylin下安装并配置GitLab(v0.1.1)

何谓磐石架构

openKylin 2.0 SP桌面操作系统的mm-cli命令详解(v01.0)

如果公司运行GitLab的服务器,因为某些原因变更了IPv4地址,那么,就需要重新配置GitLab,本文介绍相关的操作步骤。

一、术语

【操作系统】

计算机系统中的一种软件。是具有特定功能的程序模块的集合,能有效管理软硬件资源,合理组织工作流程,向用户提供服务,使用户方便地使用计算机,使整个计算机系统能高效运行。

【指令】

用户通过终端(Terminal)直接输入,用来操控操作系统的命令。

【执行指令】

用户在终端中输入指令,然后按回车键,运行指令对应的程序,完成相应的功能。

二、操作步骤

  1. Ctrl+Alt+T(同时按下Ctrl、Alt、T三个键),打开命令终端(Terminal)。

  2. 在命令终端中,执行以下指令,将openKylin 2.0 SP2桌面系统切换到维护模式(Maintain Mode):

sudo mm-cli -o

sudo reboot

  1. 在重新启动系统后,按Ctrl+Alt+T(同时按下Ctrl、Alt、T三个键),打开命令终端。

  2. 在命令终端中,执行以下指令:

ifconfig

查询当前主机的IP地址。具体方法,参考 《如何在Linux下查看当前主机的IP地址(v0.1.0)》。

记录查询到的IPv4地址。

  1. 执行以下指令,修改gitlab的配置文件gitlab.rb:

sudo vim /etc/gitlab/gitlab.rb

该指令会打开gitlab的配置文件gitlab.rb。然后按下面步骤操作。

1)按Esc键,输入/external_url。

2)使用↓键,将光标向下移动到

external_url='https://gitlab.example.com'

这一行。

按"a"键进入新增编辑状态。将两个单引号''之间的http://gitlab.example.com,更换为第4步中刚刚查到的IPv4,或者是GitLab服务器的IP地址,如:http://192.168.0.++++7++++

3)按Esc键,然后输入

:wq

完成存盘退出。

  1. 执行以下指令,让配置生效:

sudo gitlab-ctl reconfigure

这一步需要等待一段时间。当看到以下内容时,配置成功。

Running handlers:

2026-04-24T09:56:29+08:00 INFO: Running report handlers

Running handlers complete

2026-04-24T09:56:29+08:00 INFO: Report handlers complete

Infra Phase complete, 6/892 resources updated in 46 seconds

gitlab Reconfigured!

  1. 在浏览器地址栏中输入:http://192.168.1.87/users/sign_in,其中"192.168.1.87"是第5步,在gitlab.rb文件中输入的那个IPv4地址。如果正常显示如图1所示的登录页面,则说明GitLab正常运行。

图1 GitLab登录页面

  1. 如果GitLab没有正常运行,执行以下指令,启动GitLab

sudo gitlab-ctl start

  1. 执行以下指令,将openKylin 2.0 SP2桌面系统切换回普通模式(Normal Mode):

sudo mm-cli -c -a

$ sudo reboot

三、可能遇到的问题及解决方案

如果遇到以下问题:

|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Running handlers: 2026-04-23T20:35:06+08:00 ERROR: Running exception handlers There was an error running gitlab-ctl reconfigure: directory/usr/lib/systemd/system (package::runit_systemd line 22) had an error: Chef::Exceptions::InsufficientPermissions: Cannot create directory/usr/lib/systemd/system at /usr/lib/systemd/system due to insufficient permissions Running handlers complete 2026-04-23T20:35:06+08:00 ERROR: Exception handlers complete Infra Phase failed. 4 resources updated in 01 minutes 30 seconds 2026-04-23T20:35:06+08:00 FATAL: Stacktrace dumped to /opt/gitlab/embedded/cookbooks/cache/cinc-stacktrace.out 2026-04-23T20:35:06+08:00 FATAL: --------------------------------------------------------------------------------------- 2026-04-23T20:35:06+08:00 FATAL: PLEASE PROVIDE THE CONTENTS OF THE stacktrace.out FILE (above) IF YOU FILE A BUG REPORT 2026-04-23T20:35:06+08:00 FATAL: --------------------------------------------------------------------------------------- 2026-04-23T20:35:06+08:00 FATAL: Chef::Exceptions::InsufficientPermissions: directory/usr/lib/systemd/system (package::runit_systemd line 22) had an error: Chef::Exceptions::InsufficientPermissions: Cannot create directory/usr/lib/systemd/system at /usr/lib/systemd/system due to insufficient permissions |

原因是openKylin 2.0 SP2是因为系统处于正常模式(Normal Mode),磐石架构的保护开启,无法写入系统核心区域。

解决方案:

  1. Ctrl+Alt+T(同时按下Ctrl、Alt、T三个键),打开命令终端。

  2. 在命令终端中,执行下面两条指令,将系统切换到维护模式(Maintain Mode):

sudo mm-cli -o

sudo reboot

  1. 在重新启动系统后,按Ctrl+Alt+T(同时按下Ctrl、Alt、T三个键),打开命令终端。

  2. 在命令终端中,执行以下指令:

sudo gitlab-ctl reconfigure

重新配置GitLab。


【创作团队】

策 划:沈传越

文字创作:沈传越

技术支持:樊瑞平

图片采集:沈传越

制 图:樊瑞平

技术验证:沈传越

编 辑:沈传越

版式设计:沈传越

相关推荐
荣--2 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森2 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜3 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
SelectDB4 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
XIAOHEZIcode5 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220706 天前
如何搭建本地yum源(上)
运维
大树889 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠9 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质9 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
Inhand陈工9 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信