基于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

相关推荐
石像鬼₧魂石2 小时前
内网渗透靶场实操清单(基于 Vulhub+Metasploitable 2)
linux·windows·学习·ubuntu
橘子真甜~4 小时前
C/C++ Linux网络编程15 - 网络层IP协议
linux·网络·c++·网络协议·tcp/ip·计算机网络·网络层
拾贰_C4 小时前
【Linux | Windows | Terminal Command】 Linux---grep | Windows--- findstr
linux·运维·服务器
pblh1235 小时前
本地局域网部署的gitlab使用教程
gitlab
阿华hhh5 小时前
Linux系统编程(标准io)
linux·开发语言·c++
石像鬼₧魂石6 小时前
Kali Linux 网络端口深度扫描
linux·运维·网络
alengan6 小时前
linux上面写python3日志服务器
linux·运维·服务器
Rose sait7 小时前
【环境配置】Linux配置虚拟环境pytorch
linux·人工智能·python
叶之香8 小时前
CentOS/RHEL 7、8安装exfat和ntfs文件系统
linux·运维·centos