gitlab 安装、备份与还原及常见设置
gitlab 安装、备份与还原及常见设置
安装
- 安装过程比较简单,跑在 docker 上,执行命令即可
-v
参数后面的值为卷的名称,自动创建数据卷(如果数据卷不存在)- https://docs.gitlab.com/omnibus/docker/
docker run \
--hostname gitlab.example.com \
--restart always \
--name 'gitlab' \
-d \
-p 443:443 \
-p 80:80 \
-p 22:22 \
-v gitlab_config:/etc/gitlab \
-v gitlab_log:/var/log/gitlab \
-v gitlab_data:/var/opt/gitlab \
gitlab/gitlab-ce:latest
配置文件
- 所有设置 https://docs.gitlab.com/omnibus/settings/README.html
- 配置位于文件
/etc/gitlab/gitlab.rb
/var/opt/gitlab/gitlab-rails/etc
文件夹的配置文件则是分开的,清晰明了,可用于查看。database.yml
是数据库配置文件,gitlab.yml
是应用配置- 注意
gitlab.yml
的开头提示此文件由gitlab-ctl管理。手动更改将删除!要更改以下内容,请编辑/etc/gitlab/gitlab.rb,运行“sudo gitlab-ctl reconfigure”。
,所以最好不要直接编辑这个页面 - 如何重启 gitlab,执行
sudo gitlab-ctl restart
重启。只有通过Omnibus packages
安装的,使配置生效命令sudo gitlab-ctl reconfigure
才有效。经过实践,发现修改gitlab.yml
需要重启才能生效,而修改gitlab.rb
则只需要重新配置,并且会覆盖gitlab.yml
的设置 - 更改 gitlab.yml 和 application.yml 设置,这里说明了
gitlab.rb
与gitlab.yml
等配置文件的关系,由gitlab.rb
生成配置文件,执行命令sudo gitlab-ctl reconfigure
使更改生效。 - gitlab.rb 模板
- gitlab.yml 模板
仓库主机地址、服务器地址、wiki 文件上传地址
- 文档见 https://docs.gitlab.com/omnibus/settings/configuration.html#configuring-the-external-url-for-gitlab
- 安装的时候没有指定 host,项目克隆地址使用了默认的 host 地址,需要手动修改设置
- 修改配置文件
/etc/gitlab/gitlab.rb
,设置external_url ‘https://git.example.com’
,执行命令sudo gitlab-ctl reconfigure
重新配置快速生效
访问内部 PostgreSQL
- 参考教程 https://www.cnblogs.com/UniqueColor/p/7767012.html
- 深入 PostgreSQL 身份验证 https://www.tuicool.com/articles/bQfmUr
- 以下按默认情况处理,并做适当解释
- 查看 gitlab 数据库配置文件
cat /var/opt/gitlab/gitlab-rails/etc/database.yml
- 查看数据库验证方式配置文件
cat /var/opt/gitlab/postgresql/data/pg_hba.conf
- 查看用户
cat /etc/passwd
- 切换登录用户
su - gitlab-psql
,由于默认配置是使用 peer 方式认证,认证工作完全交给系统,所以系统用户名必须与登录数据库用户名一致。 - 参数加横杠有两个作用,第一是切换用户后同时切换到工作目录,第二是添加该用户相关环境变量,否则 psql 无法使用
- 根据数据库配置填写数据库登录主机以及登陆的数据库
psql -h /var/opt/gitlab/postgresql -d gitlabhq_production
- 以下是数据库操作命令
- 查看帮助
\h
- 查看数据库列表
\l
- 查看多表
\dt
- 查看单表
\d users
- 查看索引
\di
- 执行查询
select id,encrypted_password,name,username from users;
- 退出
\q
- 退出当前登录用户
exit
备份与还原
备份
- 官方文档:https://docs.gitlab.com/ce/raketasks/backup_restore.html
- 由于使用 docker 部署,所以不用按照官方文档走,只需要备份 docker 容器产生的数据,并且是放在数据卷中的数据
- 备份与还原 docker 数据卷数据,参考 https://docs.docker.com/storage/volumes/#backup-restore-or-migrate-data-volumes
- 只需要备份
/var/opt/gitlab
以及/etc/gitlab
这两个文件夹即可,一个是存放 gitlab 数据,一个存放配置。日志路径位于/var/log/gitlab
。 - 主要命令如下:
# 挂载gitlab容器的所有卷到alpine容器,将容器backup目录映射到当前目录,执行备份命令,依次备份所有数据即可
$ cd /var/opt/gitlab
$ docker run --rm --volumes-from gitlab -v $(pwd):/backup alpine tar cvf /backup/backup.tar .
- 因为要备份多个文件夹,可进入交互命令环境进行操作
还原
- 得到备份数据的压缩文件,创建卷之后还原即可。还原的时候多一步创建卷,类似创建 gitlab 容器时的操作,得到数据卷,再执行类似备份的操作,运行另外的容器挂载新创建容器的卷,只不过压缩变成解压
# 创建一个匿名卷,挂载到alpine容器的`/var/opt/gitlab`目录
$ docker run -v /var/opt/gitlab --name alpine_data alpine /bin/sh
# 挂载容器alpine_data的数据卷,进入命令交互环境
$ docker run -it --rm --volumes-from alpine_data -v $(pwd):/backup alpine sh
# 在容器内执行下面的还原命令
$ cd /var/opt/gitlab && tar xvf /backup/backup.tar"
- 进入容器之后,还原多个压缩包即可,提前创建好对应数据卷
运行
- 运行过程同安装过程,挂载上面的数据卷即可,也可以直接解压到主机目录,进行主机目录映射
- 注意一定要确认解压的文件夹的相对路径是否正确,这是可能会犯的一个错。因为上面的打包过程,很可能把数据打包成带路径
/var/opt/gitlab
的格式,导致容器中的数据位于/var/opt/gitlab/var/opt/gitlab
svn 迁移到 git
- 命令参考文档 https://git-scm.com/docs/git-svn
- 教程参考,强烈推荐 https://git-scm.com/book/zh/v2/Git-与其他系统-迁移到-Git
- 其它参考,过程都大同小异:
- SVN 迁移到 git
- SVN 迁移到 GIT 且保留提交日志
- SVN 迁移到 Git 的过程(+ 一些技巧)
- svn 迁移到 git 仓库并保留 commit 历史记录
- 以下操作在 ubuntu18.04 上执行,其它 linux 未测试,windows 上可以
shift+右键
点击菜单在此处选择linux shell
以打开 wsl 子系统,没装的话wget
改成curl
,该命令只是下载文件而已 - windows 上安装了 git 的话支持
git svn
命令,ubuntu 需要安装apt update && apt install git-svn
- 首先在一个仓库下执行以下命令得到所有提交者信息,等号填写 git 仓库对应的用户名和邮箱
svn log -q | awk -F '|' '/^r/ {sub("^ ", "", $2); sub(" $", "", $2); print $2" = "$2" <"$2">"}' | sort -u > users.txt
user1 = user1 <user1>
user2 = user2 <user2>
user3 = user3 <user3>
- 从 svn clone 到本地
git svn clone http://svn-server:port/project/trunk/path1/path2 --no-metadata --authors-file=users.txt projectname
--authors-file
参数指定提交者信息映射文件,--no-metadata
去掉多余元数据信息- 抓一份
.gitignore
模板下来,mkdir .gitignore && wget -O .gitignore/VisualStudio.gitignore https://raw.githubusercontent.com/github/gitignore/master/VisualStudio.gitignore
- 添加忽略文件
$ cd projectname
$ cat ../.gitignore/VisualStudio.gitignore >> .gitignore && \
git svn show-ignore >> .gitignore
- 添加文件
.gitignore
到版本控制git add .gitignore
- 本地提交
git commit -a -m 'add .gitignore'
- 添加远程仓库地址
git remote add origin http://git-server:port/project.git
- 推送本地 master 分支到远程,
-u
参数会让 master 关联远程分支git push -u origin master
- 其他操作:从 svn 更新
git svn rebase
、提交到 svngit svn dcommit
总结
- gitlab 是个内存大户,因此主机内存最好大于 2G,并做资源限制,否则占用了过高内存,会导致 gitlab 服务 503,甚至整个主机都变卡
- 此系统一开始装在内网的 win7 主机,使用
docker for windows
安装,后因需要迁移到服务器,只需要迁移数据卷中数据即可,十分方便 - 由 svn 迁移到 git,使用 git 自带的
git svn clone url
即可方便分离 svn 中的大项目为一个个单独的项目。因为原来的存法是所有项目在某一类文件夹,各个项目的提交记录混在一起,不方便查看,而且项目多了不方便管理
gitlab 安装、备份与还原及常见设置的更多相关文章
- GitLab - GitLab的备份与还原
1 - GitLab配置文件 GitLab默认的配置文件路径:/etc/gitlab/ /etc/gitlab/gitlab.rb:主配置文件,包含外部URL.仓库目录.备份目录等 /etc/gitl ...
- GitLab 安装,配置及维护
参考: GitLab 官方文档 docker-gitlab,通过 docker-compose 快速安装 GitLab rake,是 Rails 的工具,类似 ruby 中常用的的 make.通过 R ...
- Gitlab安装与备份恢复
GitHub是2008年由Ruby on Rails编写而成,与业界闻名的Github类似;但要将代码上传到GitHub上面,而且将项目设为私有还要收费.GitLab是一个用于仓库管理系统的开源项目, ...
- gitlab备份与还原
1.备份 登录原服务器,执行命令: gitlab-rake gitlab:backup:create 备份后文件在如下目录,下载该文件 /var/opt/gitlab/backups 2.还原 先安装 ...
- windows环境下mysql的解压安装以及备份和还原
系统环境为server2012 1.下载mysql解压版,解压安装包到指定目录 2.在以上目录中,复制一份my-default.ini文件,重命名为my.ini,进行如下修改(按照需要): [mysq ...
- 【linux】【gitlab】gitlab安装、备份、恢复、升级、内存消耗问题
前言 GitLab:GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务.功能:Gitlab 是一个提供代码托管.提交审核和问题跟踪的代码管理平 ...
- mysql的备份与还原,安装(window)
之前一直使用的navicat的自动的备份功能.但是在使用navicat的还原功能时,贼慢. 今天要做的是window服务器上将mysql单个数据库备份.然后还原到我的mac笔记本上. 本来以为很快的, ...
- Gitlab 安装、升级、备份、恢复、汉化等
一.Gitlab安装 1. 基于yum方式安装Gitlab 安装步骤如下 (1)配置yum源 # vim /etc/yum.repos.d/gitlab-ce.repo (2)复制如下内容并保存(注意 ...
- (4.1)mysql备份还原——mysql常见故障
(4.1)mysql备份还原——mysql常见故障 1.常见故障类型 在数据库环境中,常见故障类型: 语句失败,用户进程失败,用户错误 实例失败,介质故障,网络故障 其中最严重的故障主要是用户错误和介 ...
随机推荐
- MintUI引入vue项目以及引入iconfont图标
官网地址:http://mint-ui.github.io/#!/zh-cn 中文文档:http://mint-ui.github.io/docs/#/zh-cn2 示例展示:http://eleme ...
- 忽略 IDEA 文件
IntelliJ IDEA .idea *.iml /WebRoot/WEB-INF/classes
- Handsontable vue如何实现在线编辑excal
官网地址:https://handsontable.com/ 1.实现效果 2.安装 import { HotTable } from '@handsontable/vue' import Hands ...
- vscode插件开发之如何玩转vscode命令
这里以插件开发为例,VsCode之所以那么强大是因为它背后有千千万万的开发者们为其开发大量功能插件,WordPress同理. 那么如何玩转VsCode命令呢(以插件开发为例)? 官方文档必不可少 ht ...
- sql查询最近7天数据(以年-月-日结果展示)
sql代码如下: , 查询结果如下:
- semi-join子查询优化 -- FirstMatch策略
FirstMatch执行semi-join子查询的一种策略. 类似于MySQL 5.x中如何执行in.exists子查询. 让我们以搜索拥有大城市的国家为例: select * from Countr ...
- Maven构建报错问题解决
[ERROR] Failed to execute goal on project zepeto-admin: Could not resolve dependencies -SNAPSHOT: Fa ...
- Program不是内部命令也不是外部命令
在项目中使用java动态生成.bat文件,再调试时执行bat文件失败! 显示:Program不是内部命令也不是外部命令 百度了一下:C:\"Program Files"或progr ...
- iOS UILabel文字自适应高度自适应
第一步:创建UILabel对象,并设置一些基本设置 UILabel *label = [[UILabel alloc] init]; label.text = @"8月29日,在雅加达亚运会 ...
- EasyDSS高性能RTMP、HLS(m3u8)、HTTP-FLV、RTSP流媒体服务器的视频直播录像、检索、回放方案
需求背景: 近期遇到客户反馈对于直播摄像机录像功能是有一定的需求点的,其实EasyDarwin团队早就研发出对应功能,只是用户对于产品没有足够了解,因此本篇将对录像功能来做一次介绍. 首先,录像就是对 ...