Ubuntu部署gitlab频繁出现502的问题

Ubuntu部署gitlab频繁出现502的问题

问题描述

在ubuntu中基于docker部署了gitlab,但是发现网页频繁出现502错误,而且长时间卡死无法正常恢复,只能通过docker restart gitlab才能短暂恢复正常使用。

bash 复制代码
HTTP 502: Waiting for GitLab to boot

It can take up to a few minutes for GitLab to boot completely.

This page will automatically reload every 5 seconds.

创建docker容器时使用的命令:

bash 复制代码
sudo docker run -d \
--hostname localhost \
--shm-size 512m \
--memory 16g \
--memory-swap 24g \
-p 8090:80 -p 10022:22 -p 443:443 \
--name gitlab \
--restart unless-stopped \
-v /.../config:/etc/gitlab \
-v /.../log:/var/log/gitlab \
-v /.../data:/var/opt/gitlab \
gitlab/gitlab-ce:latest

分配的shm-sizememory都非常大,理论上根本不应该不够gitlab使用,而且实际使用频率也很低。

分析问题

运行命令:

bash 复制代码
docker inspect gitlab --format='{{.State.OOMKilled}}'

返回:

bash 复制代码
true

这意味着GitLab容器确实是因为触碰了16GB的内存上限,被 Docker 引擎无情地触发了 OOM (Out Of Memory) 机制并强制杀死了核心进程。这正是导致页面卡在 502 并且不断循环重启的直接原因。

但是为什么连16G内存都无法满足gitlab的需求呢?

定位原因

GitLab 的核心 Web 服务是 Puma。默认情况下,Puma 会根据宿主机的 CPU 核心数来自动生成对应数量的 Worker 进程。

每个 Puma Worker 大约会消耗 800MB 到 1GB 的内存。

如果物理机性能很好(比如是一台 16 核或 32 核的服务器),GitLab 就会启动 16 到 32 个 Worker。

单单是 Puma 这一项就会瞬间吃掉 16GB 以上的内存,再加上 PostgreSQL、Redis、Sidekiq 和监控组件,16GB 的 Docker 限制立刻就会被撑爆。

解决方法

gitlab.rb文件中修改

限制 Puma Worker 数量

bash 复制代码
puma['worker_processes'] = 2

限制并发数:

bash 复制代码
puma['min_threads'] = 4
puma['max_threads'] = 4

刷新配置读取:

bash 复制代码
# 重启容器
docker restart gitlab

# 进入容器内部重新编译配置
docker exec -it gitlab gitlab-ctl reconfigure

# 重启所有 GitLab 服务
docker exec -it gitlab gitlab-ctl restart

修改完成之后,gitlab工作恢复正常,再也没有出现过一段时间后自己卡死无响应的问题。

相关推荐
zhangfeng11332 小时前
ps aux讲解,结合国家超算中心 hpc apptainer
linux·服务器·网络
夜月yeyue2 小时前
STM32 DMA 双缓冲采样
linux·stm32·单片机·嵌入式硬件·系统架构
ScilogyHunter2 小时前
Buildroot完全指南:从入门到实战
linux·嵌入式·buildroot
毕竟是shy哥2 小时前
Claude Code 接入 DeepSeek 保姆级教程,WSL/Linux 通用
linux·安装教程·codex·deepseek·claude code·openclaw
无限进步_2 小时前
从零实现一个迷你Shell——深入理解Linux命令行解释器
linux·运维·服务器·开发语言·c++·chrome
__Witheart__2 小时前
rk3568 交叉编译链
ubuntu·rockchip
happymaker06263 小时前
Linux常见命令总结
linux·运维·服务器
lbb 小魔仙3 小时前
【Linux】DevOps 工程师必备:Linux 自动化脚本与高效工具链整合
linux·自动化·devops
开源量化GO3 小时前
期货 K 线算信号 tick 级止损:天勤双序列 wait_update 触发规则
linux·运维·服务器·python