Gitlab部署及使用

1. 简介

GitLab 是一个用于仓库管理系统的开源项目,使用 Git 作为代码管理工具,并在此基础上搭建起来的Web服务。
Gitlab是目前被广泛使用的基于 git 的开源代码管理平台,基于Ruby on Rails构建,主要针对软件开发过程中产生的代码和文档进行管理。
Gitlab主要针对 group 和 project 两个维度进行代码和文档管理,其中 group 是群组,project 是工程项目,一个 group 可以管理多个project,可以理解为一个群组中有多项软件开发任务,而一个 project 中可能包含多个 branch,意为每个项目中有多个分支,分支间相互独立,不同分支可以进行归并。

2. 安装方法

  • Linux 安装包
  • 云原生 Helm chart
  • Docker

3. Linux安装包部署

linux安装包的部署有两种方式,一种是 apt 直接进行安装,一种是使用 dpkg 指令进行安装。
服务器配置最好是:2核4G起步,低于这个配置安装和启动 GitLab 会非常吃力,内存和CPU消耗几乎占满。

官方文档:
https://docs.gitlab.cn/jh/administration/

3.1 apt 安装

3.1.1 安装并配置必要的依赖项

sudo apt-get update
sudo apt-get install -y curl openssh-server ca-certificates

3.1.2 安装邮箱服务(可跳过)

sudo apt-get install -y postfix

3.1.3 添加 Gitlab 软件包到存储库并安装

curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | sudo bash
sudo apt-get install gitlab-ce
GitLab安装包大约有1G,安装需要耐心等待几分钟(视服务器配置而定);
001.jpg
安装成功
002.jpg

3.1.4 修改配置文件

vim /etc/gitlab/gitlab.rb

#修改内容
external_url 'http://10.66.55.132:6001/'

部署 gitlab 后发现机器的cpu和内存占用非常大,而且 gitlab 启动了非常多的bundle。我们需要对他的相关配置进行优化,关闭不必要的进程,尽量减少cpu及内存的占用,编辑配置文件gitlab.rb。如果没有找到以下字段也可以跳过此步。

#修改以下内容:

puma['worker_timeout'] = 30   #设置最大请求持续时间
gitlab_rails['time_zone'] = 'Asia/Shanghai'
puma['worker_processes'] = 2
sidekiq['max_concurrency'] = 8   #减少sidekiq并发数
postgresql['shared_buffers'] = "128MB"   #减少数据库缓存(默认为256MB 改为128MB)
postgresql['max_worker_processes'] = 3   #减少数据库并发数
puma['per_worker_max_memory_mb'] = 600   #更改内存限制设置
prometheus_monitoring['enable'] = false   #普罗米修斯监控关闭启用
sidekiq['min_concurrency'] = 8

参考文档:
https://docs.gitlab.cn/jh/administration/operations/puma.html#%E6%9B%B4%E6%94%B9%E5%86%85%E5%AD%98%E9%99%90%E5%88%B6%E8%AE%BE%E7%BD%AE
https://blog.csdn.net/m0_46542378/article/details/125344764

3.1.5 开放端口

iptables -I INPUT -p tcp --dport 6001 -j ACCEPT;开放指定的6001端口
iptables-save;生效,保存规则
apt-get install iptables-persistent;安装工具
sudo netfilter-persistent save;端口持续化规则,确保重启后有效
sudo netfilter-persistent reload

3.1.6 重新载入配置文件

sudo gitlab-ctl reconfigure;需要等待几分钟时间
1664261963092.jpg
sudo gitlab-ctl restart;重启GitLab

3.1.7 查看 Gitlab 状态

sudo gitlab-ctl status
image.png

3.1.8 访问 GitLab

浏览器访问 http://10.66.55.132:6001
image.png

3.1.9 更改密码并登录

Gitlab root的默认密码在 /etc/gitlab/initial_root_password 文件中,此文件在第一次更新配置后24小时内会删除。
1664265120281.jpg
可以使用默认密码登录,然后在web界面更改密码。
也可以在部署界面直接更改。
修改root默认密码
gitlab-rails console -e production;需要等一会

user = User.where(username:"root").first   #查询用户
user.password = "pwd_gitlab"   #修改密码
user.save!   #保存
exit   #退出

1664262463029.jpg
账号:root 密码:pwd_gitlab
1664262519329.png

3.2 dpkg 指令安装

3.2.1 安装依赖包

sudo apt update
sudo apt install ca-certificates curl openssh-server postfix

3.2.2 下载并安装gitlab

wget -P /Downloads [https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/ubuntu/pool/focal/main/g/gitlab-ce/gitlab-ce_15.3.3-ce.0_amd64.deb](https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/ubuntu/pool/focal/main/g/gitlab-ce/gitlab-ce_15.3.3-ce.0_amd64.deb)
下载安装包

dpkg参数说明:
dpkg -L 查看软件的状态,如:dpkg -L gitlab-ce
dpkg -P 卸载软件(软件名,而不是安装包名)
dpkg --remove 删除安装包,不删除配置
dpkg --purge 删除安装包和配置文件

sudo dpkg -i gitlab-ce_15.3.3-ce.0_amd64.deb;安装
gitlab1.png

3.2.3 修改配置文件

以下步骤与3.1.4~3.1.9相同

参考文档:
https://www.jianshu.com/p/e3da4a3b578a
https://blog.csdn.net/nanerxue/article/details/119825292

4. docker-compose部署

提前安装好 docker 及 docker-compose

4.1 创建挂载目录

mkdir /opt/gitlab/{config,data,logs} -p
添加权限:
chmod 777 config
chmod 777 data
chmod 777 logs

4.2 创建 docker-compose.yml文件

在 /opt/gitlab/ 目录下
vim docker-compose.yml;

 version: '2'
 services:
    gitlab:
      image: 'twang2218/gitlab-ce-zh:11.1.4'
      restart: always
      container_name: "gitlab"
      #privileged: true  #特权模式
      hostname: 'gitlab'
      environment:
        TZ: 'Asia/Shanghai'
        GITLAB_OMNIBUS_CONFIG: |
          external_url 'http://47.97.177.130'   #更改为部署gitlab的机器ip或域名
          gitlab_rails['time_zone'] = 'Asia/Shanghai'
          gitlab_rails['gitlab_shell_ssh_port'] = 80
          gitlab_rails['smtp_enable'] = true
          gitlab_rails['smtp_address'] = "smtp.163.com"
          gitlab_rails['smtp_port'] = 465
          gitlab_rails['smtp_user_name'] = "15665229950@163.com"  #用自己的邮箱地址
          gitlab_rails['smtp_password'] = "123456"  #自己的邮箱密码
          gitlab_rails['smtp_domain'] = "163.com"
          gitlab_rails['smtp_authentication'] = "login"
          gitlab_rails['smtp_enable_starttls_auto'] = true
          gitlab_rails['smtp_tls'] = true
          gitlab_rails['gitlab_email_from'] = '15665229950@163.com'
      ports:
        - '80:80'
        - '443:443'
        - '2222:22'
      volumes:
        - /opt/gitlab/config:/etc/gitlab
        - /opt/gitlab/data:/var/opt/gitlab
        - /opt/gitlab/logs:/var/log/gitlab

4.3 拉取gitlab中文版镜像

docker pull twang2218/gitlab-ce-zh:11.1.4

4.4 启动容器

docker-compose up -d
1664345188754.jpg
docker ps发现启动成功

4.5 浏览器查看

登录浏览器查看 http://47.97.177.130:80
1664335741339.jpg
第一次登录需要设置密码。

5. 卸载gitlab

停止gitlab
gitlab-ctl stop
查看gitlab进程,并杀掉第一个进程
ps aux | grep gitlab
kill -9 17313
23bc2113243bda0f9896d1c434cb8a73.png
删除所有包含gitlab文件
find / -name *gitlab*|xargs rm -rf # find / -name gitlab | xargs rm -rf
删除gitlab-ctl uninstall时自动在root下备份的配置文件
ls /root/gitlab*
这样就可以彻底卸载了gitlab。

6. 启动/重启/停止 命令

  • 查看 gitlab 相关命令:gitlab-ctl --help
  • 启动:gitlab-ctl start
  • 重启:gitlab-ctl restart 每次修改配置文件后需要重启服务,从而使得配置生效。
  • 停止:gitlab-ctl stop

7. gitlab基础使用

1664347990765.jpg

1664349152707.jpg

gitlab在部署时可以选择中文版本,对国内比较友好
中文版.jpg

7.1 创建项目

7.1.1 点击 New project

创建项目1.jpg

7.1.2 点击 Create blank project 创建一个新项目

创建项目2.jpg

7.1.3 输入项目名

下面的选项可以根据需求配置,也可以默认。
配置完成,点击 Create project 即可创建成功。
创建项目3.jpg

可以看到项目的信息。
创建项目4.jpg

7.2 创建用户

7.2.1 在 Admin Area 下,点击 New user

创建用户1.jpg

7.2.2 填写姓名、邮箱等信息

密码先不设置。
创建用户2.jpg

7.2.3 点击 Create user,创建用户

创建用户3.jpg

7.2.4 点击Edit,设置新用户的密码

创建用户4.jpg

7.2.5 设置密码

创建用户5.jpg

7.2.6 点击 Save changes,保存

创建用户6.jpg

7.2.7 在新界面用邮箱和密码登录

第一次登录需要重置密码。
创建用户7.jpg

7.2.8 登录成功

创建用户8.jpg

7.3 创建团队,添加成员

7.3.1 找到 Groups,点击 New group

创建群1.jpg

7.3.2 点击 Create group

创建群2.jpg

7.3.3 填写团队名等信息

填写完成点击下方的 Create group
创建群3.jpg

7.3.4 添加成员

找到 Group information,点击 Members。
创建群4.jpg

7.3.5 点击 Invite members

创建群5.jpg

7.3.6 将成员添加到团队中,赋予权限

创建群6.jpg

7.3.7 添加成功

可以看到已经成功将成员加入到团队中。
创建群7.jpg

7.4 项目中添加成员或团队

7.4.1 找到对应的项目,点击 Members

1664417792785.jpg

7.4.2 添加成员或团队

1664417792810.jpg

7.4.3 添加成功

1664417792828.jpg

7.4.4 团队中的所有成员都可以看到并管理项目了

1664417792850.jpg

7.5 上传代码文件

7.5.1 在 gitlab 中创建项目

在 Clone 选项下可以看到 Http 的克隆地址。
1.jpg

7.5.2 创建目录

在本地创建一个目录 /data/git_code 并 cd 进去
初始化 git init
此时的目录就不在是一个普通的本地目录了,而是一个git可以管理的本地仓库。

扩展:本地仓库中的三个区

工作区:
本地工作目录和gitlab关联后,就成为工作区。
暂存区:
暂存区又称缓存区,所有需要提交的文件都需要先加入到暂存区,用git add 指令把待提交的文件加入暂存区。
本地仓库:
通过git commit将暂存区里的代码提交到地方称为本地仓库(此时还没有push到远程仓库,所以gitlab中还没有本地上传的文件)。

7.5.3 克隆项目

第一次需要进行全局设置。
git config --global user.name "XX"
git config --global user.email "XXX@163.com"
将远程仓库的项目克隆到本地,在本地生成同名目录,并且目录中会有所有的项目文件。
git clone http://10.66.55.132:6001/zhangsan/hello.gitgit clone + http克隆地址
输入用户名密码后即可。
2.jpg

7.5.4 添加提交

添加文件到暂存区,并提交到本地仓库。
将代码文件 cp 到目录中 cp -r ../file-master/ .
添加所以文件到暂存区 git add .
提交到本地仓库 git commit -m "v1.0"
查看暂存区和工作区的状态 git status

# 添加指定文件到暂存区
git add 文件名

# 添加目录中所有文件到暂存区
git add .

# 将暂存区的文件提交到本地仓库,并添加描述,-m 表示只会提交暂存区的文件
git commit -m "提交描述信息"

# 查看暂存区和工作区的状态
git status

7.5.5 提交

将文件同步到 gitLab 服务器上 git push
由于没有设置 ssh 密钥,需要再次输入用户名和密码。
5.jpg

# 向gitLab远程仓库推送代码
git push -u origin master

# 将本地Git仓库和远程仓库关联起来,并设置远程仓库名称
git remote add http地址
例:git remote add origin http://10.66.55.132:6001/gitlab-instance-4ff98bbd/test.git

# 拉取服务器上最新资源
git pull origin master

7.5.6 在 gitlab 查看

image.png

7.5.7 在 gitlab 中修改代码并保存

1670396399657.jpg
1670396581865.jpg
1670396664027.jpg

7.6 gitlab删除仓库

点击进入到要删除的项目仓库
gitlab删除仓库1.jpg

找到 settings 下的 General,点击 Advanced 旁边的 Expand
gitlab删除仓库2.jpg

下拉到最后,找到 Delete project
gitlab删除仓库3.jpg

复制粘贴上面的内容,点击 Yes,Delete project
gitlab删除仓库4.jpg

7.7 其他常用操作

7.7.1 工作台

查看汇总信息
1664418068209.jpg

7.7.2 查看监控

1664418068234.jpg

参考文档:
https://help.aliyun.com/document_detail/52857.html#section-6r1-7kt-txz
https://blog.csdn.net/weixin_43367756/article/details/126048316
https://blog.csdn.net/weixin_39903846/article/details/111216340

8. FAQ

8.1 502报错

**问题:**使用 apt 部署安装,正常启动之后登录浏览器查看发现报错
Whoops, GitLab is taking too much time to respond
出现502报错,通常是由于后端无法正常回复浏览器的请求响应
排查过程及解决:
由于部署的gitlab是nginx代理的,在nginx已经正常启动的情况下,首先查看下nginx的日志
cd /var/opt/gitlab/nginx/logs
cat /var/opt/gitlab/nginx/logs/gitlab_access.log
发现大多数日志都是空的
–> 查看配置
cat /var/opt/gitlab/nginx/conf/gitlab-http.conf
–> 在配置中找到 nginx 反向代理的路径 http://gitlab-workhorse
cd /var/opt/gitlab/gitlab-workhorse/sockets
–> unix:/var/opt/gitlab/gitlab-workhorse/sockets/socket
由于对这一块不太熟悉,直接复制粘贴到百度查询
–> 参考文档,查看端口 8080 是否被占用
netstat -tpln
–> 发现 8080 端口被 jenkins 占用了,将此进程杀掉
kill -9 进程号
–> 重启 gitlab
gitlab-ctl restart
解决
原因:
由于 jenkins 占用了 8080 端口,导致 gitlab-puma-worker 组件没有启动成功,所以出现了502报错。
1669341625641.png

参考文档:
http://t.zoukankan.com/caicaizi-p-14001332.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/460342.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

phpcms头像上传漏洞引发的故事

目录 关键代码 第一次防御 第一次绕过 第二次防御 第二次绕过 第三次防御 第三次绕过 如何构造一个出错的压缩包 第四次防御 第四次绕过 本篇文章是参考某位大佬与开发人员对于文件包含漏洞的较量记录下的故事,因为要学习文件包含漏洞,就将大佬…

鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:GridItem)

网格容器中单项内容容器。 说明: 该组件从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。仅支持作为Grid组件的子组件使用。 子组件 可以包含单个子组件。 接口 GridItem GridItem(value?: GridItemOptions)…

【AI+办公】利用AI软件制作PPT提升工作效率

最近看了很多AI相关信息的输入,很多使用AI软件赚钱的文章或付费课程,思路多多少少自己了解不少,后面有时间分享下。本篇主题是,利用AI软件制作PPT提升工作效率。对于上班族来说,提升工作效率也是一种节省个人时间的方式…

最佳实践:Swagger 自动生成 Api 文档

自动生成 API 文档的好处不言而喻,它可以提供给你的团队或者外部协作者,方便 API 使用者准确地调用到你的 API。为了降低手动编写文档带来的错误,很多 API 开发者会偏向于寻找一些好的方法来自动生成 API 文档。本文将会介绍一些常用的文档生…

express+mysql+vue,从零搭建一个商城管理系统14--快递查询(对接快递鸟)

提示:学习express,搭建管理系统 文章目录 前言一、安装md5,axios,qs二、新建config/logistics.js三、修改routes/order.js四、添加商品到购物车总结 前言 需求:主要学习express,所以先写service部分 快递鸟…

AI人工智能培训讲师ChatGPT讲师叶梓培训简历及提纲ChatGPT等AI技术在医疗领域的应用

叶梓,上海交通大学计算机专业博士毕业,高级工程师。主研方向:数据挖掘、机器学习、人工智能。历任国内知名上市IT企业的AI技术总监、资深技术专家,市级行业大数据平台技术负责人。 长期负责城市信息化智能平台的建设工作&#xff…

鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:ListItemGroup)

该组件用来展示列表item分组,宽度默认充满List组件,必须配合List组件来使用。 说明: 该组件从API Version 9开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。该组件的父组件只能是List。 使用说明 当List…

云与云计算:从传统到云端的IT资源变革

云:从分散到集约,资源服务化的新模式 让我们先通过一个生活化的场景来理解“云”这一概念。几十年前,诸如农村地区的居民需要自给自足,比如在自家院子里打井取水,冬季烧煤取暖,一切满足自己生活需要的都要…

SwiftUI组件 - AsyncImage

SwiftUI组件-AsyncImage import SwiftUIstruct AsyncImageBootcamp: View {let url URL(string: "https://picsum.photos/200")var body: some View {/// Mark - iOS15 以后才有的方法ScrollView {AsyncImage(url: url, content: { returnImage inreturnImage.resiz…

STM32F103 CubeMX 使用USB生成鼠标设备

STM32F103 CubeMX 使用USB生成鼠标设备 1 配置cubeMX1.1配置外部晶振,配置debug口1.2 配置USB1.3 配置芯片的时钟1.4 生成工程 2. 编写代码2.1 添加申明2.2 main函数代码 1 配置cubeMX 1.1配置外部晶振,配置debug口 1.2 配置USB 1.3 配置芯片的时钟 需…

uniapp 开发出现这个 Error in onLoad hook: “SyntaxError: Unexpected end of JSON input“

uniapp 开发出现这个 Error in onLoad hook: “SyntaxError: Unexpected end of JSON input“,这个问题如何解决。 原因: 由于JSON.parse无法识别某些url中的特殊字符比如&等特殊符号造成的。 解决办法: 页面A(JSON.stringify传参&a…

YOLOV5 部署:基于web网页的目标检测(本地、云端均可)

1、前言 YOLOV5推理的代码很复杂,大多数都是要通过命令行传入参数进行推理,不仅麻烦而且小白不便使用。 本章介绍的web推理,仅仅需要十几行代码就能实现本地推理,并且只需要更改单个参数就可以很方便的部署云端,外网也可以随时的使用 之前文章介绍了QT的可视化推理界面,…

Flutter Inspector 视图调试工具突然不能用了

The embedded browser failed to load. Error: JCEF is not supported in this env or failed to initialize 1、在 Android Studio 的 Help 菜单中,找到 Find Action 2、搜索 boot runtime,找到「Choose Boot Java Runtime for the IDE」选项 3、在「…

计算机毕业设计-基于大数据技术下的高校舆情监测与分析

收藏和点赞,您的关注是我创作的动力 文章目录 概要 一、研究背景与意义1.1背景与意义1.2 研究内容 二、舆情监测与分析的关键技术2.1 robot协议对本设计的影响2.2 爬虫2.2.1 工作原理2.2.2 工作流程2.2.3 抓取策略2.3 scrapy架构2.3.1 scrapy:开源爬虫架…

【论文阅读笔记】Attention Is All You Need

1.论文介绍 Attention Is All You Need 2017年 NIPS transformer 开山之作 回顾一下经典,学不明白了 Paper Code 2. 摘要 显性序列转导模型基于包括编码器和解码器的复杂递归或卷积神经网络。性能最好的模型还通过注意力机制连接编码器和解码器。我们提出了一个新…

vacuum各种选项分析

1、vacuum和vacuum analyze和analyze的区别 我们加上verbose打印vacuum过程中的信息,可以发现: vacuum analyze过程中不但会vacuum表,还会收集表的统计信息,同时还会在表的年龄超过vacuum_freeze_table_age时,将表的年…

Tomcat Session集群---会话绑定

实验配置: 7-1安装Nginx 7-2和7-3安装Tomcat 1.配置7-1 1.做负载均衡,反向代理 [rootlocalhost ~]# vim /etc/nginx/nginx.conf17 http {18 upstream tomcat {19 server 192.168.91.102:8080;20 server 192.168.91.103:8080;2…

【iOS ARKit】PhysicsBodyComponent

在学习完 RealityKit 进行物理模拟的相关理论知识后,下面通过使用 PhysicsBodyComponent 组件进行物理模拟演示,主要代码如下所示,稍后对代码进行详细解析。 // // PhysicsBodyView.swift // ARKitDeamo // // Created by zhaoquan du on…

Docker安装蜜罐Hfish

前言 无意中发现公司的一台服务器被爆破,修改了密码,为了确定内网是否安装需要搭建一个蜜罐来看一下是否存在隐患。 如何安装Docker,请查看我另一篇文章 https://blog.csdn.net/l1677516854/article/details/136751211 一、拉取镜像 dock…

vscode创建文件夹跟在后面,怎么解决?

如果你遇到类似问题。 按照以下操作即可。