百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

从0到1,Docker安装中文版Gitlab服务端

wptr33 2024-11-20 22:38 20 浏览

1.pull中文版镜像:

docker pull beginor/gitlab-ce:11.3.0-ce.0


2.创建目录:

通常会将 GitLab 的配置 (etc) 、 日志 (log) 、数据 (data) 放到容器之外, 便于日后升级, 因此请先准备这三个目录。

mkdir -p /mydata/gitlab/etc

mkdir -p /mydata/gitlab/log

mkdir -p /mydata/gitlab/data


3.修改目录权限:

chmod 777 /mydata/gitlab/etc

chmod 777 /mydata/gitlab/log

chmod 777 /mydata/gitlab/data


4.运行:

准备好这三个目录之后, 就可以开始运行 Docker 镜像了:

docker run --detach \

--publish 5443:443 \

--publish 82:82 \

--publish 2222:22 \

--name gitlab \

--volume /mydata/gitlab/etc:/etc/gitlab \

--volume /mydata/gitlab/logs:/var/log/gitlab \

--volume /mydata/gitlab/data:/var/opt/gitlab \

--privileged=true \

beginor/gitlab-ce:11.3.0-ce.0

--publish 5443:443:将http:443映射到外部端口5443

--publish 82:82:将web:82映射到外部端口82

--publish 2222:22:将ssh:22映射到外部端口2222

--name gitlab 运行容器名

--restart unless-stopped 重启策略

--volume /mydata/gitlab/etc:/etc/gitlab 挂载目录,配置文件目录

--volume /mydata/gitlab/log:/var/log/gitlab 挂载目录,日志目录

--volume /mydata/gitlab/data:/var/opt/gitlab 挂载目录,数据目录(可用于数据恢复)

--privileged=true 使得容器内的root拥有真正的root权限。否则,container内的root只是外部的一个普通用户权限


5. 配置gitlab服务器的访问地址

5.1、gitlab容器运行起来是没有问题的,但是当gitlab上创建项目的时候,生成项目的URL访问地址是容器的id(如上图)。作为gitlab服务器,当然是需要一个固定的URL访问地址,于是需要配置gitlab.rb(宿主机上的路径为:/mydata/gitlab/etc/gitlab.rb)配置文件里面的参数。

vi /mydata/gitlab/etc/gitlab.rb

# 配置http协议所使用的访问地址,推荐配置成域名或不变的ip

external_url 'http://192.168.85.135:82'

# https需要下面这句

# nginx['redirect_http_to_https_port'] = 82

nginx['listen_port'] = 82

# 配置2222端口

gitlab_rails['gitlab_shell_ssh_port'] = 2222


首行加入即可:

保存退出后重启gitlab,再查看项目地址是否正确

docker restart gitlab

重启完成(可能需要30秒)后,可以看到地址已经变成ip+端口号了

如果地址未变,则可尝试执行5.2,5.3进行重启,再查看项目地址是否正确


5.2、进入gitlab容器初始化配置

docker exec -it gitlab /bin/bash 进去gitlab容器的命令

gitlab-ctl reconfigure 重置gitlab客户端的命令

备注:如上信息如果出现了,然后等了将近一分钟的话,恭喜你在docker安装Gitlab成功通过了


5.3、重启:gitlab-ctl restart

重启成功后发现原来的容器ID已经变成了IP地址

注:如果容器运行启动的不是80端口,则这里git地址要加上对应的端口。如上面启动的端口是82映射到82端口此时git地址应使用:git clone http://192.168.85.136:82/root/test.git


6.访问:

稍等片刻,初始化完毕,再打开浏览器:ip地址:端口号 (http://192.168.85.134:82/)

修改密码为:123456789,修改完成:使用 用户名root,密码为123456789进行登陆。

7.创建一个项目

gitlab页面

下面我们就可以新建一个项目了,点击 创建一个项目

创建完成后:


8、gitlab随 docker 自启动

docker update gitlab --restart=always

注意:这里的 gitlab 是容器的名字,不是镜像的名字。

在启动系统后你必须等待1-2分钟才能使用GitLab。GitLab需要一些时间来启动。

docker update gitlab --restart=no,可取消自动重启


9 启动|停止|重启

docker start gitlab

docker stop gitlab

docker restart gitlab

注意:这里的 gitlab 是容器的名字,不是镜像的名字。


10、进入gitlab (optional)

docker exec -it gitlab /bin/bash

按Ctrl+D或输入exit退出。


11、拉取代码

git http://user:pssword@url

git clone ssh://user:pssword@url

注意:如果项目权限是公开则不需要输入用户名密码,要时候用ssh方式获取代码需要

Gitlib添加ssh key之后,才能正常使用

TortoiseGit如何添加ssh key,百度就可以


12、初始化提交项目

新建一文件夹,然后执行如下命令

git clone http://192.168.85.135:82/xxxx.git

推送到master,输入对应用户名密码即可

相关推荐

Python 中 必须掌握的 20 个核心:str()

str()是Python中用于将对象转换为字符串表示的核心函数,它在字符串处理、输出格式化和对象序列化中扮演着关键角色。本文将全面解析str()函数的用法和特性。1.str()函数的基本用法...

python中的函数报错后继续运行而不是停止整个程序

要让main...

如何在身份证号码中提取出生年月日的函数公式

在不同软件中,从身份证号码提取出生年月日的函数公式不同,以下是常见软件的方法:Excelo假设身份证号码在A列,在B列提取出生年月日,在B2单元格输入公式=TEXT(MID(A2,7,8),"...

sql中的一些CTE和开窗函数相关用法

CTE的优势提高可读性:将复杂查询分解为更简单的部分避免重复子查询:同一CTE可以在查询中多次引用递归查询:处理层次结构数据模块化SQL:将复杂查询拆分成逻辑模块...

【SQL】SQL 语法差异大全(PgSQL/MySQL/Oracle/TiDB/OceanBase)

以下是针对不同数据库系统的SQL语法差异总结,按功能分类展示:一、基础查询1.分页查询...

MySQL索引:从原理到实战的终极指南

MySQL索引原理揭秘MySQL索引是数据库高效查询的核心机制,其原理基于特定的数据结构(主要是B+Tree)和数据库引擎(如InnoDB)的实现策略。索引本质上是一种空间换时间的策略,虽然会占...

如何在本地安装开源人工智能Agent——AutoGen Studio的安装

AutoGen是微软出品的一个用于创建可自主行动,或与人类协同工作的多智能体AI应用程序的框架。下面来介绍如何在本地安装AutoGenStudio,AutoGenStudio是一个低代码界...

小巧WinForm库存系统,竟能实现这些功能?

第一次体验真正“握在手里的”库存控制,是在一个微型工厂的仓库运输带旁。顶着仓库里金属味和三十几平米的闷热,老王蹲在地上,一边用笔在账本上划格,一边嘴里嘟囔:“每次都说要数字化管理,数字在哪儿呢?”透过...

有关SQLite数据库的介绍

SQLite,是一种轻型的数据库,它的设计目标是嵌入式的,而且已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/U...

SQLite 数据库Web管理工具

概述SQLite数据库以其轻量级和易于配置的特点,成为了许多项目中的首选数据库。尽管它的便捷性受到了广泛的认可,但对于数据库的管理和维护,尤其是在没有图形界面工具的情况下,开发者往往需要通过复杂的命...

SqlLite数据库注意要点分析

1.验证sqlite是否安装配置好了。执行sqlite3命令。当执行该命令的时候没有传递任何参数表示默认连接到了一个内存数据库,当退出该程序的时候,数据库自动销毁。退出命令:.quit.ex...

python 连接sqlite

在Python中,你可以使用标准库sqlite3来连接SQLite数据库。在Python中,sqlite3模块是内置的,无需使用pip进行安装。sqlite3模块提供了与SQ...

提升数据库搜索效率:探索SQLite的向量搜索扩展

大家好!今天我们要聊一个特别酷炫的东西——sqlite-vec,一个能让SQLite飞起来的向量搜索扩展。如果你对数据库的搜索速度不满意,那你可得好好看看这篇文章了。...

Qt编程进阶(21):Qt操作SQLite数据库及实例

QtSql模块Qt提供的QtSql模块实现了对数据库的访问,同时提供了一套与平台和具体所用数据库均无关的调用接口。此模块为不同层次的用户提供了不同的丰富的数据库操作类。例如,对于习惯使用SQL语法的用...

5分钟快速掌握在Python使用SQLite数据库,

小巧、稳定、快速!我为什么喜欢用SQLite...