当前位置: 首页 > news >正文

GitLab 安装指南

目录

  • 一、概述
  • 二、 安装方式
  • 三、系统要求
  • 四、 具体安装步骤
    • 1. Ubuntu 系统安装(原生包方式)
      • 1.1 安装依赖包
      • 1.2 添加 GitLab 官方仓库
      • 1.3 安装 GitLab
      • 1.4 配置防火墙(如启用)
    • 2. Docker 安装方式
      • 2.1 创建 `docker-compose.yml` 文件
      • 2.2 启动 GitLab 容器
      • 2.3 等待启动完成
    • 3. Mac 系统安装(M1 芯片支持)
      • 3.1 创建 `docker-compose.yml`
      • 3.2 进入容器修改配置
  • 五、安装后初始设置
    • 1. 访问 GitLab 并获取初始密码
      • 原生安装获取密码:
      • Docker 安装获取密码:
    • 2. 基本配置修改
      • 2.1 修改管理员密码
      • 2.2 配置 SMTP 邮件服务器(可选但推荐)
  • 六、 GitLab 基本使用
    • 1. 管理区域设置
    • 2. 项目管理
      • 2.1 创建项目
      • 2.2 项目基本操作
    • 3. 用户和权限管理
    • 4. CI/CD 流水线配置
      • 4.1 在项目中创建 `.gitlab-ci.yml` 文件
      • 4.2 配置 GitLab Runner
  • 七、常用管理命令
    • 1. GitLab 服务管理
    • 2.备份和恢复
  • 八、 常见问题解决
    • 1. 502 错误
    • 2. 服务无法启动
    • 3. 邮件无法发送
    • 4. HTTPS 配置

一、概述

GitLab 是一个功能强大的开源 DevOps 平台,集代码托管、CI/CD、项目管理和团队协作于一体。本文将为你梳理如何在主流操作系统上安装 GitLab,以及安装后的基本使用和常见问题处理。

二、 安装方式

GitLab 主要有三种安装方式,你可以根据自己的需求和环境选择合适的方法:

安装方式适用平台优点缺点
原生包安装Ubuntu, CentOS, Debian 等 Linux 系统官方推荐,性能最佳,功能完整对系统资源要求较高
Docker 安装所有支持 Docker 的平台(Windows, Mac, Linux)环境隔离,快速部署,易于维护配置稍复杂,性能略有损耗
Windows 安装Windows 系统适合 Windows 环境开发者官方不支持直接安装,需通过 Docker 或虚拟机

三、系统要求

在开始安装前,请确保你的系统满足以下最低要求:

  • 内存:至少 4GB(推荐 8GB 或更多)
  • CPU:至少 2 核心(推荐 4 核或更多)
  • 磁盘空间:至少 10GB(推荐 20GB 或更多)
  • 网络:固定的 IP 地址或域名,开放 80 和 443 端口

四、 具体安装步骤

1. Ubuntu 系统安装(原生包方式)

以下是官方推荐的 Omnibus 包安装方法:

1.1 安装依赖包

sudo apt update
sudo apt upgrade -y
sudo apt install -y curl openssh-server ca-certificates postfix tzdata perl

在 Postfix 安装过程中,选择 “Internet Site” 并输入服务器主机名。

1.2 添加 GitLab 官方仓库

curl -sS https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | sudo bash

1.3 安装 GitLab

sudo EXTERNAL_URL="http://你的域名或IP" apt install gitlab-ce

EXTERNAL_URL 替换为你实际的域名或 IP 地址。

1.4 配置防火墙(如启用)

sudo ufw allow http
sudo ufw allow https
sudo ufw allow OpenSSH

2. Docker 安装方式

如果你更喜欢使用 Docker,以下是安装步骤:

2.1 创建 docker-compose.yml 文件

version: '3.8'
services:gitlab:image: gitlab/gitlab-ce:latestcontainer_name: gitlab-dockerhostname: 'gitlab.example.com'restart: alwaysenvironment:GITLAB_OMNIBUS_CONFIG: |external_url 'http://192.168.11.111:8807'letsencrypt['enable'] = falsevolumes:- './config:/etc/gitlab'- './logs:/var/log/gitlab'- './data:/var/opt/gitlab'ports:- '8807:8807'- '8808:22'

记得将 external_url 中的 IP 和端口改为你自己的。

2.2 启动 GitLab 容器

docker-compose up -d

2.3 等待启动完成

容器启动后需要几分钟时间 GitLab 才能完全就绪。


3. Mac 系统安装(M1 芯片支持)

对于 Mac 用户(特别是 M1 芯片),可以使用专门的 ARM 镜像:

3.1 创建 docker-compose.yml

version: "3.8"
services:gitlab-ce:image: yrzr/gitlab-ce-arm64v8:latestcontainer_name: gitlab-ceprivileged: truerestart: alwaysports:- "9922:22"- "9980:9980"volumes:- /your/path/gitlab/etc:/etc/gitlab:z- /your/path/gitlab/log:/var/log/gitlab:z- /your/path/gitlab/opt:/var/opt/gitlab:zdeploy:resources:limits:memory: 4096M

3.2 进入容器修改配置

docker exec -it gitlab-ce /bin/bash
vi /etc/gitlab/gitlab.rb

添加以下配置:

external_url 'http://127.0.0.1:9980'
gitlab_rails['gitlab_ssh_host'] = '127.0.0.1'
gitlab_rails['gitlab_shell_ssh_port'] = 9922

五、安装后初始设置

1. 访问 GitLab 并获取初始密码

  1. 打开浏览器,访问你配置的 EXTERNAL_URL
  2. 使用以下凭据登录:
    • 用户名root
    • 密码:从以下文件获取

原生安装获取密码:

sudo cat /etc/gitlab/initial_root_password

Docker 安装获取密码:

docker exec -it gitlab-docker grep 'Password:' /etc/gitlab/initial_root_password

⚠️ 注意:此密码文件会在 24 小时后自动删除,请及时修改密码。


2. 基本配置修改

登录后建议立即进行以下配置:

2.1 修改管理员密码

  • 点击右上角头像 → Settings → 左侧菜单 “Password

2.2 配置 SMTP 邮件服务器(可选但推荐)

编辑 /etc/gitlab/gitlab.rb

gitlab_rails['smtp_enable'] = true
gitlab_rails['smtp_address'] = "smtp.your-email.com"
gitlab_rails['smtp_port'] = 587
gitlab_rails['smtp_user_name'] = "your-username"
gitlab_rails['smtp_password'] = "your-password"
gitlab_rails['smtp_domain'] = "your-domain.com"
gitlab_rails['smtp_authentication'] = "login"
gitlab_rails['smtp_enable_starttls_auto'] = true
gitlab_rails['gitlab_email_from'] = "gitlab@your-domain.com"

然后重新配置:

sudo gitlab-ctl reconfigure

六、 GitLab 基本使用

1. 管理区域设置

以管理员身份登录后,你可以通过点击顶部导航栏的 “Admin Area”(扳手图标)进入管理区域,进行以下重要设置:

  • 关闭 Gravatar(国内访问不了):Settings → Preferences → Gravatar
  • 关闭公开注册(内部使用):Settings → General → Sign-up restrictions
  • 配置外部认证(如 LDAP、OAuth 等)

2. 项目管理

2.1 创建项目

  • 点击导航栏 “+” 号 → “New project”
  • 选择创建空白项目、从模板创建或导入项目

2.2 项目基本操作

  • 文件管理:在项目内创建、上传文件
  • 分支管理:查看和管理代码分支
  • 合并请求:创建和审查代码合并
  • 议题跟踪:管理任务和 bug 报告

3. 用户和权限管理

  • 创建用户Admin Area → Users → New user
  • 分配权限:将用户添加到项目并设置相应角色
    • Guest
    • Reporter
    • Developer
    • Maintainer
    • Owner

4. CI/CD 流水线配置

GitLab 内置了强大的 CI/CD 功能:

4.1 在项目中创建 .gitlab-ci.yml 文件

stages:- build- test- deploybuild_job:stage: buildscript:- echo "Building the project..."- go build -o myappartifacts:paths:- myapptest_job:stage: testscript:- echo "Running tests..."deploy_job:stage: deployscript:- echo "Deploying application..."only:- main

4.2 配置 GitLab Runner

  • 进入项目 → Settings → CI/CD → Runners
  • 按照说明安装和注册 Runner

七、常用管理命令

1. GitLab 服务管理

# 启动所有服务
sudo gitlab-ctl start# 停止所有服务
sudo gitlab-ctl stop# 重启所有服务
sudo gitlab-ctl restart# 查看服务状态
sudo gitlab-ctl status# 重新配置 GitLab(修改配置后必须执行)
sudo gitlab-ctl reconfigure

2.备份和恢复

# 创建备份
sudo gitlab-rake gitlab:backup:create# 恢复备份
sudo gitlab-rake gitlab:backup:restore BACKUP=备份文件名

八、 常见问题解决

1. 502 错误

  • 原因:通常是内存不足导致
  • 解决方案
    • 建议增加系统内存至 4GB 以上
    • 检查端口冲突,确保 80 和 443 端口未被占用

2. 服务无法启动

  • 原因:系统资源不足或配置错误
  • 解决方案
    • 检查系统资源是否充足
    • 查看日志文件:sudo gitlab-ctl tail

3. 邮件无法发送

  • 原因:SMTP 配置错误或防火墙限制
  • 解决方案
    • 确认 SMTP 配置正确
    • 检查防火墙设置

4. HTTPS 配置

如需启用 HTTPS,可配置:

  • 自签名证书
  • Let’s Encrypt 证书

GitLab 功能丰富,安装和配置过程可能会遇到各种问题,但遵循以上步骤应该能帮助你顺利完成安装!

http://www.dtcms.com/a/452882.html

相关文章:

  • 磁共振成像原理(理论)20:K空间采样 (Sampling of k-Space) - 采样定理
  • 安装wslgui
  • 激光+摄像头:打造高精度视觉测量系统
  • ie的常用网站渭南市建设局网站
  • 前端混入与组合实战指南
  • C++ 学习(3) ----设计模式
  • 畜牧业网站模板怎么做自己的网站平台
  • DAY 43 复习日-2025.10.7
  • 大数据毕业设计选题推荐-基于大数据的人体生理指标管理数据可视化分析系统-Hadoop-Spark-数据可视化-BigData
  • Auricore亮相杭州RWA峰会,以黄金RWA重塑Web3新生态
  • 于飞网站开发免费推广软件工具
  • ChainVault闪耀杭州RWA峰会,黄金RWA重塑Web3新生态
  • [论文阅读] AI+软件工程(迁移)| 从JDK8到21:FreshBrew如何为AI代码迁移画上“可信句号”
  • 电信大数据实战:MySQL与Hadoop高效同步
  • 郑州经济技术开发区协同办公系统seo比较好的公司
  • FFmpeg开发笔记(十二):ffmpeg音频处理、采集麦克风音频录音为WAV
  • 金融大模型应用现状及未来趋势研究:国内外对比分析
  • AI 在金融、医疗、教育、制造业等领域都有广泛且深入的应用,以下是这些领域的一些落地案例
  • TensorFlow2 Python深度学习 - TensorFlow2框架入门 - 变量(Variable)的定义与操作
  • AI行业应用:金融、医疗、教育、制造业领域的落地实践
  • 【Git 子模块冲突解析】
  • 软件设计师——09 数据库技术基础
  • Guava Cache 高性能本地缓存库详解与使用案例
  • 开源安全管理平台wazuh-阻止恶意IP访问
  • 蒲城做网站网站定制开发成本
  • 嵌入式开发入门:从 FreeRTOS 任务到通信协议(详细教程)
  • 数据结构(长期更新)第2讲:顺序表(一)
  • 《Flask 的“微”哲学:从轻量内核到请求上下文的深度剖析》
  • 在 Elasticsearch 中改进 Agentic AI 工具的实验
  • Solid Explorer(双窗格文件管理器) 解锁完整版