GitLab服务器搭建

前述

一般的公司都不希望将自己的代码托管到公共的代码托管网站,如:github,gitee等,而是自己搭建一个代码托管的服务器来管理代码,所以我们就看看怎么搭建一个自己的代码托管服务器吧

  • 官方网站:https://about.gitlab.com/
  • 官方安装文档:https://gitlab.cn/install?version=ce(你也可以参考这个官方文档搭建)
    在这里插入图片描述

本人使用的是centos7操作系统,使用xshell连接上你的服务器就可以开始安装了,注意,服务器内存大小要在6G-8G左右,因为gitlab服务比较大,服务器内存太小可能会启动失败。

方式一:非容器安装

搭建GitLab服务器

首先使用xshell连接上你的服务器

使用free -m 命令可以查看虚拟机的内存大小,单位是MB(看看内存大小是否够用1GB=1024MB):
在这里插入图片描述

使用su root命令切换到root权限:
在这里插入图片描述

使用命令安装perl包: yum install -y curl policycoreutils-python openssh-server perl

使用命令打开sshd:systemctl enable sshd

使用命令启动sshd:systemctl start sshd

配置镜像源:curl -fsSL https://packages.gitlab.cn/repository/raw/scripts/setup.sh | /bin/bash
在这里插入图片描述
开始安装:EXTERNAL_URL="http://192.168.1.103:8081" yum install -y gitlab-jh

  • http://192.168.0.103:该地址为服务器的地址或者域名,如果不知道可以使用ifconfig命令查询,端口号为你的gitlab服务端口号
  • 如果配置错了,也没关系,这个我们后面还可以通过gitlab的配置文件修改
  • 安装完成后会随机生成一个密码(初始密码只有二十四小时的有效期)存储在/etc/gitlab/initial_root_password文件中,安装成功后建议立即修改初始密码,使用修改后的密码和用户名root登录。

注意:配置gitlab服务的端口号的时候要先检查该端口号是否被占用,以及服务器是否开放此端口号,如果没开放该端口号,外面是访问不了你的gitlab服务的。

查看开放的端口号:firewall-cmd --list-all

设置开放端口号:sudo firewall-cmd --add-port=8081/tcp --permanent

重启防火墙(设置完一定要重启防火墙):firewall-cmd --reload

现在外部就可以访问8081端口了

查看gitlab用户的初始密码:

账号为:root

cat /etc/gitlab/initial_root_password|grep password

可以使用账户和密码登录,然后再页面修改初始密码,也可以使用下面的命令行修改密码。

修改初始密码

我们使用命令行的方式:

进入gitlab控制台:
gitlab-rails console

切换用户,看到root用户又返回值(返回nil代表空),证明该用户存在:
user = User.where(username: 'admin').first
user = User.where(username: 'root').first

修改root用户的密码为123456:
user.password = "123456ldd"

保存密码,返回true表示修改成功:
user.save! 

退出控制台:
ctrl+z保存并退出控制台

然后就可以使用root+123456ldd登录了

gitlab配置文件

gitlab服务的配置文件:/etc/gitlab/gitlab.rb

修改服务的端口号

修改gitlab服务端口号:vim /etc/gitlab/gitlab.rb
在这里插入图片描述

按 i 开始编辑
编辑完成,按esc退出编辑
按冒号,输入wq保存退出

使用命令进行更新配置:gitlab-ctl reconfigure

注: 这个位置也可以查看配置gitlab服务的ip和端口号:/opt/gitlab/embedded/service/gitlab-rails/config/gitlab.yml
在这里插入图片描述

启动并访问服务

使用命令查看linux中正在运行的服务:netstat -lntp

如果gitlab服务没有启动我们可以通过下面的命令启动或者关闭:

  • 停止gitlab服务:gitlab-ctl stop
  • 启动gitlab服务:gitlab-ctl start

服务启动成功后即可通过http://192.168.1.103:8081访问

在这里插入图片描述

方式二:容器下安装基于Docker

官网教程:https://docs.gitlab.cn/jh/install/docker.html

安装Docker

更新yum源:yum install

安装依赖:yum install -y yum-utils device-mapper-persistent-data 1vm2

添加镜像源:

  • 国外镜像源:yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
  • 阿里镜像源:yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/decker-ce.repo

查看源中可用的docker版本:yum list docker-ce --showduplicates|sort -r

安装docker:

  • 安装最新版本(默认):yum install docker-ce
  • 安装指定版本:yum install docker-ce-20.10.9-3.el7

配置开机启动:

  • 启动docker:systemctl start docker
  • 配置开机启动:systemctl enable docker
  • 查看docker版本:docker version

在容器中安装gitlab服务

在设置其他所有内容之前,请配置一个新的环境变量 $GITLAB_HOME,指向配置、日志和数据文件所在的目录, 确保该目录存在并且已授予适当的权限。

  • docker中的gitlab文件会映射到本机的/srv/gitlab目录
export GITLAB_HOME=/srv/gitlab
本地位置容器位置使用
$GITLAB_HOME/data/var/opt/gitlab用于存储应用程序数据。
$GITLAB_HOME/logs/var/log/gitlab用于存储日志。
$GITLAB_HOME/config/etc/gitlab用于存储极狐GitLab 配置文件。

添加gitlab容器:

sudo docker run --detach \
  --hostname 192.168.1.103 \
  --publish 8443:443 --publish 8082:8082 --publish 222:22 \
  --name gitlab \
  --restart always \
  --volume $GITLAB_HOME/config:/etc/gitlab \
  --volume $GITLAB_HOME/logs:/var/log/gitlab \
  --volume $GITLAB_HOME/data:/var/opt/gitlab \
  --shm-size 256m \
  registry.gitlab.cn/omnibus/gitlab-jh:latest
  • hostname:你的服务器的ip地址或者域名
  • publish:将容器内部端口向外映射
    • 8443:443:将容器内443端口映射至宿主机8443端口
    • 8082:8082:将容器内8082端口映射至宿主机8082端口,这是访问gitlab的端口(我们等下配置)
    • 222:22:将容器内22端口映射至宿主机222端口,这是访问ssh的端口
  • name:命名容器名称
  • volume:将容器内数据文件夹或者日志、配置等文件夹挂载到宿主机指定目录
  • restart:系统重启后,容器将自动restart

宿主机配置修改

宿主机端口号开放:8443端口,8082端口,222端口

查看开放的端口号
firewall-cmd --list-all

开放指定端口(因为22一般被sshd服务占据,所以这里用222端口)
sudo firewall-cmd --add-port=8443/tcp --permanent
sudo firewall-cmd --add-port=8082/tcp --permanent
sudo firewall-cmd --add-port=222/tcp --permanent

重启防火墙(设置完一定要重启防火墙):
firewall-cmd --reload

现在外部就可以访问这些端口了

容器配置修改

gitlab.rb(宿主机路径:/srv/gitlab/config/gitlab.rb

配置http协议所使用的访问地址,不加端口号默认为80
external_url 'http://192.168.1.103:8082'

配置ssh协议所使用的访问地址和端口
gitlab_rails['gitlab_ssh_host'] = '192.168.199.231'
gitlab_rails['gitlab_shell_ssh_port'] = 222 # 此端口是运行时22端口映射的222端口

启动并访问服务

启动gitlab容器:docker start gitlab

查看已存在的容器:docker ps -a

进入容器(一定要进入容器):docker exec-it gitlab /bin/bash

查看初始密码:cat /etc/gitlab/initial_root_password|grep password

修改初始密码:参考上面的方法

访问:http://192.168.1.103:8082

  • 5
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
为了搭建GitLab服务器,您需要按照以下步骤进行操作: 1. 准备服务器: - 获取一台运行Linux操作系统的服务器,推荐使用Ubuntu或CentOS。 - 确保服务器具有足够的资源(处理器、内存、存储空间)来支持您的项目需求。 2. 安装依赖: - 更新服务器上的软件包列表: `sudo apt update`(对于Ubuntu)或 `sudo yum update`(对于CentOS)。 - 安装必要的依赖项: `sudo apt install curl openssh-server ca-certificates postfix`(对于Ubuntu)或 `sudo yum install curl openssh-server postfix`(对于CentOS)。 - 在安装过程中,您需要配置Postfix来设置邮件转发。选择"Internet Site"选项,并将系统邮件名称设置为域名,比如"yourdomain.com"。 3. 安装GitLab: - 添加GitLab软件仓库并安装: ``` curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.deb.sh | sudo bash sudo EXTERNAL_URL="http://yourdomain.com" apt install gitlab-ee ``` 或者 ``` curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.rpm.sh | sudo bash sudo EXTERNAL_URL="http://yourdomain.com" yum install gitlab-ee ``` 请将"yourdomain.com"替换为您的域名或服务器IP地址。 4. 配置GitLab: - 打开配置文件: `sudo nano /etc/gitlab/gitlab.rb`。 - 根据您的需求,修改配置文件中的参数,如外部URL、SMTP设置、存储设置等。 - 保存并关闭配置文件。 5. 启动GitLab: - 执行命令: `sudo gitlab-ctl reconfigure`。 - 等待一段时间,直到GitLab配置完成。 6. 访问GitLab: - 在浏览器中访问您的服务器IP地址或域名。 - 您将被重定向到GitLab登录页面。 - 创建管理员账户,完成注册。 现在,您已经成功搭建GitLab服务器,并可以开始管理您的项目了!请注意,这只是一个基本的搭建过程,您可能需要进一步配置和定制以满足您的特定需求。参考GitLab官方文档以获取更多信息和帮助:https://docs.gitlab.com/。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

彤彤的小跟班

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值