三十分钟完成 Gitlab 搭建安装指南(支持 HTTPS 访问)

2024-09-06 14:18

本文主要是介绍三十分钟完成 Gitlab 搭建安装指南(支持 HTTPS 访问),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景
由于我们早期使用 phabricator 进行代码管理,但是在使用的过程当中发现和社区的 github 使用方式有些不同,所以为了让大伙都习惯 github 社区相同的使用风格,所以我们换成了 gitlab 作为公司内部的代码管理系统;并且其强大的 CI/CD 的方式为后续的持续集成工作打下基础。

注意
Gitlab 分为 社区版 (gitlab-ce) 与 企业版 (gitlab-ee),社区版免费,企业版收费,两个版本的区别参考官方文档:gitlab-ce VS gitlab-ee;官方网站安装文档默认是针对 gitlab-ee 进行说明的,为了避免不必要的麻烦请直接安装 gitlab-ce 版本。

新版本方式 : 此文档针对大于 Gitlab 10.5 版本进行说明的,小于此版本的参考其它文档。

开始安装
由于官方的方式下载软件包太慢,并且我们是专门购买的一台机器安装 gitlab 使用,再加上本人觉得直接下载软件包 *.deb 手动安装方便一些,所以我直接在清华大学开源软件源下载的包进行安装的。

注意:我这里的操作系统版本是 Ubuntu 16.04 ,最后的那位博客使用的是 Centos 方式安装的,最好对照自己的操作系统方式进行博客参考。

下载安装
以下通过手动方式安装的,如果希望通过添加软件源的方式添加方便后续的自动更新,可以参考: 清华大学开源文档如何添加 gitlab-ce 软件源。

下载包文件
wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/ubuntu/pool/xenial/main/g/gitlab-ce/gitlab-ce_10.7.2-ce.0_amd64.deb
1
开始安装
dpkg -i gitlab-ce_10.7.2-ce.0_amd64.deb
1
基础配置
打开 /etc/gitlab/gitlab.rb 文件进行基础设置,所有的核心设置均在这个文件中。

设置外部地址
## GitLab URL
##! URL on which GitLab will be reachable.
##! For more details on configuring external_url see:
##! https://docs.gitlab.com/omnibus/settings/configuration.html#configuring-the-external-url-for-gitlab
external_url 'https://gitlab.xxx.com'
1
2
3
4
5
注意:如果没有设置以下 https 方式,则需要把地址前面换成 http。

设置 HTTPS 方式
如果想要以上的 https 方式正常生效使用,则需要把 letsencrypt 自动生成证书的配置打开,这样在执行重新让配置生效命令 (gitlab-ctl reconfigure) 的时候会自动给域名生成免费的证书并自动在 gitlab 自带的 nginx 中加上相关的跳转配置,都是全自动的,非常方便。

注意:进行生成证书的时候请预先把域名解析设置完毕,否则会执行配置生效命令失败。

################################################################################
# Let's Encrypt integration
################################################################################
 letsencrypt['enable'] = true
 letsencrypt['contact_emails'] = ['caryyu@qq.com'] # This should be an array of email addresses to add as contacts
1
2
3
4
5
邮件配置
很多博客及大多数的情况都推荐使用 postfix 模块进行邮件通知处理;但是我们公司已有邮箱服务器,所以 postfix 并非必须的;所以我这里采用 SMTP 的方式配置邮件服务器来实现通知效果;具体配置参考如下: 


打开 /etc/gitlab/gitlab.rb 配置 SMTP 服务的具体内容如下,我这里采用的邮箱安全端口,点击打开更多配置参考。

### Email Settings
 gitlab_rails['gitlab_email_enabled'] = true
 gitlab_rails['gitlab_email_from'] = 'system.notice@qq.com'
 gitlab_rails['gitlab_email_display_name'] = 'gitlab.notice'
 gitlab_rails['gitlab_email_reply_to'] = 'system.notice@qq.com'
 gitlab_rails['gitlab_email_subject_suffix'] = 'gitlab'

### GitLab email server settings
###! Docs: https://docs.gitlab.com/omnibus/settings/smtp.html
###! **Use smtp instead of sendmail/postfix.**

 gitlab_rails['smtp_enable'] = true
 gitlab_rails['smtp_address'] = "smtp.qq.com"
 gitlab_rails['smtp_port'] = 465
 gitlab_rails['smtp_user_name'] = "system.notice@qq.com"
 gitlab_rails['smtp_password'] = "xxxxx"
 gitlab_rails['smtp_domain'] = "qq.com"
 gitlab_rails['smtp_authentication'] = "login"
 gitlab_rails['smtp_enable_starttls_auto'] = true
 gitlab_rails['smtp_tls'] = true
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20


利用以下命令进行测试邮箱配置是否正确,测试使用方式更多参考:如何测试

gitlab-ctl console
irb(main):002:0>Notify.test_email('xx@qq.com', '邮件标题', '邮件正题').deliver_now
1
2
配置生效
当 /etc/gitlab/gitlab.rb 配置发生改变的时候想要生效必须执行以下命令:

gitlab-ctl reconfigure
1
以上的操作执行完毕并且成功之后,这个时候就可以直接在浏览器中打开了。

注意:如果依然无法访问的话,请检查主机防火墙或云服务安全组中的 80 或 443 端口是否正常开放,切记!切记!切记!

最后
此篇主要只涉及安装与基础配置的部分,如果需要查看更多包括:忘记 root 密码重置、备份与恢复等;可以点击这篇博客(如何安装与使用 Gitlab)进行查看,此篇主要参考了这位作者的博客内容,并根据自己的操作进行整理,感谢这位作者的付出!

其它参考
针对小于 Gitlab 10.5 的旧版本配置 HTTPS 证书
 

这篇关于三十分钟完成 Gitlab 搭建安装指南(支持 HTTPS 访问)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142244

相关文章

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根

华为鸿蒙HarmonyOS 5.1官宣7月开启升级! 首批支持名单公布

《华为鸿蒙HarmonyOS5.1官宣7月开启升级!首批支持名单公布》在刚刚结束的华为Pura80系列及全场景新品发布会上,除了众多新品的发布,还有一个消息也点燃了所有鸿蒙用户的期待,那就是Ha... 在今日的华为 Pura 80 系列及全场景新品发布会上,华为宣布鸿蒙 HarmonyOS 5.1 将于 7

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

Java SWT库详解与安装指南(最新推荐)

《JavaSWT库详解与安装指南(最新推荐)》:本文主要介绍JavaSWT库详解与安装指南,在本章中,我们介绍了如何下载、安装SWTJAR包,并详述了在Eclipse以及命令行环境中配置Java... 目录1. Java SWT类库概述2. SWT与AWT和Swing的区别2.1 历史背景与设计理念2.1.

Redis过期删除机制与内存淘汰策略的解析指南

《Redis过期删除机制与内存淘汰策略的解析指南》在使用Redis构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下... 目录1、简述2、Redis http://www.chinasem.cn的过期删除策略(Key Expir

SpringBoot整合Apache Flink的详细指南

《SpringBoot整合ApacheFlink的详细指南》这篇文章主要为大家详细介绍了SpringBoot整合ApacheFlink的详细过程,涵盖环境准备,依赖配置,代码实现及运行步骤,感兴趣的... 目录1. 背景与目标2. 环境准备2.1 开发工具2.2 技术版本3. 创建 Spring Boot

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Python远程控制MySQL的完整指南

《Python远程控制MySQL的完整指南》MySQL是最流行的关系型数据库之一,Python通过多种方式可以与MySQL进行交互,下面小编就为大家详细介绍一下Python操作MySQL的常用方法和最... 目录1. 准备工作2. 连接mysql数据库使用mysql-connector使用PyMySQL3.