前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >GitLab搭建并接入自建Nginx

GitLab搭建并接入自建Nginx

作者头像
CrazyCodes
发布2019-11-07 10:07:16
2.5K0
发布2019-11-07 10:07:16
举报
文章被收录于专栏:Grace developmentGrace development

前言

我一生的文章都会放在这里,我的博客,我希望每一行代码,每一段文字都能帮助你。https://github.com/CrazyCodes/Blog

大家好,我是CrazyCodes,这篇文章的标题有些严肃了,算是非常单纯的教学文,愿可以帮助到有需要的人。

GitLab

GitLab与GitHub和码云一样,都是以web形式存在的在线管理Git仓库并且都拥有优雅的可视化操作页面。当然这篇文章咱们不介绍这没用的。

因为GitLab/Hub或者码云对免费用户不是够友好,无论是在库的容量或者协作人员都有些许限制,GitHub的提交速度对中国程序员更是慢如蜗牛。

网络上关于GitLab安装的文章并不少,因为GitLab在安装过程中会默认再安装一个Nginx,这必然会与已有Nginx冲突,写这篇文章主要的目的还是对已存在Nginx服务的服务器如何配置GitLab做一个指导。

安装

服务器版本:(阿里云) CentOS Linux release 7.6.1810 GitLab版本:12.4.0-ee Nginx版本:nginx/1.17.0

基本都算是比较新的版本了,废话不多说,我们开始吧!

第一步:进入GitLab官网

https://about.gitlab.com/install/

第二步: 执行一大堆牛逼的命令

代码语言:javascript
复制
sudo yum install -y curl policycoreutils-python openssh-server
sudo systemctl enable sshd
sudo systemctl start sshd
sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo systemctl reload firewalld

第三步:下载GitLab安装文件

代码语言:javascript
复制
curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.rpm.sh | sudo bash

第四步:安装

代码语言:javascript
复制
sudo EXTERNAL_URL="https://gitlab.example.com" yum install -y gitlab-ee

EXTERNAL_URL 这个配置就默认好了,毕竟咱们也不用GitLab自带的Nginx

第五步:完成

就是这么简单,安装完成了。第一次访问的时候会要求重新设置密码。用户名默认为 root

配置

安装完成后,需要对现有的GitLab做一些配置更改。

官方文档:https://docs.gitlab.com/12.4/omnibus/settings/nginx.html#using-a-non-bundled-web-server

禁用NGINX

在文件

代码语言:javascript
复制
/etc/gitlab/gitlab.rb

下,将配置设置为false

代码语言:javascript
复制
nginx['enable'] = false

设置所属用户

需要将自建Nginx的所属用户加入到配置内 在文件

代码语言:javascript
复制
/etc/gitlab/gitlab.rb

下,将配置设置为 www-data

对于Debian/Ubuntu,默认用户是www-data 对于RHEL/CentOS,NGINX用户是nginx

当然如果安装nginx未指定所属用户,也有可能会是root。当然可以通过命令

代码语言:javascript
复制
cat /usr/local/nginx/conf/nginx.conf | grep user

查看所属用户,实际就在配置文件里写着

代码语言:javascript
复制
user  root;
    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

回到正题,修改配置为root(刚刚讲过了,为啥是root)

代码语言:javascript
复制
web_server['external_users'] = ['root']

这个设置是一个数组,可以添加多个用户。设置好后运行命令

代码语言:javascript
复制
sudo gitlab-ctl reconfigure

配置已生效

添加虚拟主机

GitLab已经为开发者准备好相应的vhost文件。可以通过访问下方链接获取 https://gitlab.com/gitlab-org/gitlab-recipes/tree/master/web-server 配置完成后执行

代码语言:javascript
复制
nginx -s reload

既完成,原理很简单,其他配置我也不是太明白,大概则是使用反向代理转发了一下请求这样子。

问题

在最新版本中,如果按照上述方式配置,可能会在提交过程中出现422错误,具体原因不清楚,我遇到这个问题后配置了ssl,解决了这个问题。

致谢

大多都是官方的文字,可能只是不太好找,所以网络上经常出现这个问题,但都无解,所以写这么个水文,帮助需要的人,当然,提倡还是去看官网的文档。

感谢你看到这里,希望本篇文章可以帮到你。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • GitLab
  • 安装
    • 第一步:进入GitLab官网
      • 第二步: 执行一大堆牛逼的命令
        • 第三步:下载GitLab安装文件
          • 第四步:安装
            • 第五步:完成
            • 配置
              • 禁用NGINX
                • 设置所属用户
                  • 添加虚拟主机
                  • 问题
                  • 致谢
                  相关产品与服务
                  轻量应用服务器
                  轻量应用服务器(TencentCloud Lighthouse)是新一代开箱即用、面向轻量应用场景的云服务器产品,助力中小企业和开发者便捷高效的在云端构建网站、Web应用、小程序/小游戏、游戏服、电商应用、云盘/图床和开发测试环境,相比普通云服务器更加简单易用且更贴近应用,以套餐形式整体售卖云资源并提供高带宽流量包,将热门软件打包实现一键构建应用,提供极简上云体验。
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档