基于ubuntu搭建gitlab

原文地址:基于ubuntu搭建gitlab -- 无敌牛

欢迎参观我的网站:无敌牛 -- 技术/著作/典籍/分享等

之前介绍了一个使用 git + openssh-server 搭建一个极简 git 库的方法,感兴趣可以查看往期文章:手搓一个极简远端git库 -- 无敌牛 。git实现了代码管理的核心,gitlab 更有丰富的权限管理、自动测试、系统集成等丰富的功能,而且可视化操作也更友好,更加方便代码管理。本片文章介绍一下 gitlab 服务的搭建方法。

1、添加GitLab软件仓库源

在系统源增加 gitlab 的软件仓库源,直接执行以下代码。(前提:需要有 curl 工具,没有则需要安装: apt install curl)

复制代码
curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | sudo bash

安装成功会添加 /etc/apt/sources.list.d/gitlab_gitlab-ce.list 和 /usr/share/keyrings/gitlab_gitlab-ce-archive-keyring.gpg 文件

2、安装gitlab及相关软件

复制代码
sudo apt install -y gitlab-ce ca-certificates postfix

3、修改相关配置

打开 /etc/gitlab/gitlab.rb 文件,修改以下参数

复制代码
external_url 'https://YourIpOrDomain'
gitlab_rails['time_zone'] = 'Asia/Shanghai'
nginx['enable'] = true
nginx['redirect_http_to_https'] = true
nginx['ssl_certificate'] = "/etc/gitlab/cert/server.crt"
nginx['ssl_certificate_key'] = "/etc/gitlab/cert/server.key"
nginx['ssl_ciphers'] = "ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384"
nginx['ssl_prefer_server_ciphers'] = "off"
nginx['listen_port'] = 443

external_url 设置成对系统的 IP 地址 或者 指定的域名(只要域名指向gitlab主机即可)

nginx打开了 https 访问,所以需要颁布证书。参考往期文章:自签名证书 -- 无敌牛 ,自签名证书 和 Let's Encrypt 颁发证书都有介绍。

4、部署生效并启动服务

部署生效:gitlab-ctl reconfigure

启动系统:gitlab-ctl start

打开浏览器访问,首次登录使用root账号登录即可,root 初始密码会保存在 /etc/gitlab/initial_root_password 文件。也可以注册新账号,不过新账号需要root通过才可以使用。


另外、docker方式安装

1、找一目录,在此创建 gitlab 的工作目录,并进入刚创建的 gitlab 目录

复制代码
mkdir -p gitlab/{config,logs,data}
cd gitlab

2、在此目录创建 compose.yml 文件,内容如下。xx.xx.xx.xx 需要改成自己的 IP 地址或者 域名

复制代码
version: '3.8'
services:
  gitlab:
    image: gitlab/gitlab-ce:latest
    container_name: gitlab
    restart: always
    hostname: 'xx.xx.xx.xx'  # 改为你的域名或IP
    environment:
      GITLAB_OMNIBUS_CONFIG: |
        external_url 'https://xx.xx.xx.xx'
        gitlab_rails['gitlab_shell_ssh_port'] = 2222
    ports:
      - "880:80"
      - "443:443"
      - "2222:22"
    volumes:
      - ./config:/etc/gitlab
      - ./logs:/var/log/gitlab
      - ./data:/var/opt/gitlab
    shm_size: '256m'

3、启动: docker-compose up -d 。root 的初始密码就在 config/initial_root_password

相关推荐
大聪明-PLUS1 小时前
Docker 的底层工作原理
linux·嵌入式·arm·smarc
WDLOVELONGLONG1 小时前
与实验室服务器互相ping
linux·服务器·网络
间彧1 小时前
Linux常用命令速查表,拿走,不谢
linux
BXS_null2 小时前
windows、linux/ubuntu 系统运用.net core使用Selenium WebDriver实现自动化测试
linux·ubuntu·.netcore
ayaya_mana2 小时前
Linux告别搜索卡顿:解决“Argument list too long”与实现文件内容秒搜
linux·运维·list
一念一花一世界2 小时前
Arbess从初级到进阶(4) - 使用Arbess+GitLab实现React.js 项目自动化部署
react.js·ci/cd·gitlab·arbess
lqqjuly3 小时前
Lidar调试记录Ⅰ之Ubuntu22.04虚拟机安装ROS2(无坑版)
linux·ros2·lidar·ubuntu22.04
I · T · LUCKYBOOM3 小时前
构建软RAID磁盘阵列
linux·运维·服务器
IT小白农民工3 小时前
安装SAP Business one for HANA之前的准备
linux·经验分享·sap
一念一花一世界4 小时前
Arbess从初级到进阶(3) - 使用Arbess+GitLab+SonarQube搭建Java项目自动化部署
ci/cd·gitlab·devops·arbess