【gitlab安装】基于docker容器安装gitlab代码仓库

第一步 下载相关资源

如果是离线版安装则需要下载docker和gitlab:
docker下载地址:[docker官网](https://download.docker.com/linux/static/stable/x86_64/)
gitlab容器的话建议找一台有网的服务器安装完docker之后执行:
docker pull gitlab/gitlab-ce

#查看镜像
docker images

#保存镜像成tar包到本地
docker save -o /xxxx/gitlab.tar gitlab/gitlab-ce:latest
#然后下载到电脑上保存
如果是线上安装,那么直接通过yum,wget,rpm等方式都可以。

第二步 安装docker

将准备好的压缩包解压到服务器上,然后执行以下命令:
#解压
tar -zxvf xxxx.tar.gz /xxx/docker

#将docker复制到系统目录
sudo cp /xxx/docker/* /usr/bin/
准备service文件,想要将docker注册成服务实现开机自启已经通过服务的方式管理则添加以下文件
到/usr/lib/systemd/system/下面,service文件示例:
[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network-online.target firewalld.service
Wants=network-online.target

[Service]
Type=notify
# the default is not to use systemd for cgroups because the delegate issues still
# exists and systemd currently does not support the cgroup feature set required
# for containers run by docker
ExecStart=/usr/bin/dockerd --selinux-enabled=false
ExecReload=/bin/kill -s HUP $MAINPID
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
# Uncomment TasksMax if your systemd version supports it.
# Only systemd 226 and above support this version.
#TasksMax=infinity
TimeoutStartSec=0
# set delegate yes so that systemd does not reset the cgroups of docker containers
Delegate=yes
# kill only the docker process, not all processes in the cgroup
KillMode=process
# restart the docker process if it exits prematurely
Restart=on-failure
StartLimitBurst=3
StartLimitInterval=60s

[Install]
WantedBy=multi-user.target
然后执行以下命令:
#重新加载服务文件
systemctl daemon-reload

#开机自启
systemctl enable docker

#启动docker
systmectl start docker

#检查docker状态
docker ps

第三步 上传gitlab镜像

直接拉取:docker pull gitlab/gitlab-ce
上传镜像到服务器,执行命令:
docker load -i gitlab.tar

#查看镜像
docker images

第四步 创建docker 子网

创建一个docker子网用来给容器使用,避免使用默认子网导致环境问题
# 创建100.0.0.0/16 的网段给容器使用,网络名是nat
docker network create --subnet=100.0.0.0/16 nat

#查看子网
docker network ls

#查看nat子网详细信息以及容器
docker network inspect nat

在这里插入图片描述

第五步 运行gitlab容器

执行docker run脚本,指定对外暴露端口,以及映射数据文件夹到外部实现持久化:
docker run --restart=always  -d -p 8001:80 -p 8002:443 -p 8003:22 
--name gitlab --net nat --privileged=true  -v /xxx/gitlab/etc:/etc/gitlab 
-v /xxx/gitlab/log:/var/log/gitlab -v /xxx/gitlab/data:/var/opt/gitlab 
gitlab/gitlab-ce:latest

#执行之后等待一会,然后执行docker ps命令查看
docker ps -a 

#使用命令查看容器详细信息
docker inspect gitlab

在这里插入图片描述

第六步 进入容器执行命令

进入容器进行一些配置的修改,由于gitlab的特殊性,有些配置无法通过环境变量或者映射修改
# 进入容器内部
docker exec -it gitlab /bin/bash

#修改/etc/gitlab/gitlab.rb文件
vi /etc/gitlab/gitlab.rb

#gitlab访问地址,可以写域名。如果端口不写的话默认为80端口
external_url 'http://192.168.2.102'    【注意:写你自己机器的IP】
#ssh主机ip
gitlab_rails['gitlab_ssh_host'] = '192.168.2.102'
#ssh连接端口
gitlab_rails['gitlab_shell_ssh_port'] = 8003,

文件修改保存之后,执行gitlab-ctl reconfigure实现gitlab配置重写
容器内部修改启动配置:

vi 	/var/opt/gitlab/gitlab-rails/etc/gitlab.yml

在这里插入图片描述
修改启动文件之后,直接容器内部执行gitlab-ctl restart重启即可,不用重启容器

第七步 查看初始化密码

第一次创建服务时会有个初始化root账号的密码,密码直接在宿主机上看即可,处于gitlab的安装文件夹下面的etc/initial_root_password中,查看之后直接访问gitlab登录即可。
这个安装文件夹是映射出来的外部路径,到这一步,gitlab基本安装完成。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值