首页 > 其他分享 >gitlab安装使用,备份和升级

gitlab安装使用,备份和升级

时间:2022-12-05 14:06:56浏览次数:64  
标签:-- 备份 gitlab smtp rails 升级 ctl

安装依赖

yum install -y curl openssh-server postfix wget

 安装gitlab组件

gitlab安装使用,备份和升级_git

 

yum localinstall -y xxx自动帮忙解决依赖

 最新版本

1) 下载
wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/gitlab-ce-14.10.5-ce.0.el7.x86_64.rpm

2) 安装依赖
yum -y install policycoreutils openssh-server openssh-clients postfix policycoreutils-python

3) 开始rpm包安装
rpm -ivh gitlab-ce-14.10.5-ce.0.el7.x86_64.rpm

gitlab安装使用,备份和升级_重启_02

 

 

配置访问url端口号等

vi /etc/gitlab/gitlab.rb
external_url 'http://192.168.109.128:9090' # ===>这里一定要加上http://

配置默认日志目录 

在 ​​/etc/gitlab/gitlab.rb​​​ 文件中,有许多用于各种类型日志的 ​​log_directory​​ 键。取消注释并更新要放置在其他地方的所有日志的值:

# For example:
gitlab_rails['log_directory'] = "/var/log/gitlab/gitlab-rails"
puma['log_directory'] = "/var/log/gitlab/puma"
registry['log_directory'] = "/var/log/gitlab/registry"
...

3.2 Gitlab邮箱配置 

在安装gitlab后,未添加邮件提供功能(比如,添加一个用户,就给他发邮件提醒),需要配置发邮件的 ​​smtp​​ 服务器配置。发信系统用的默认的postfix,smtp是默认开启的,两个都启用了,两个都不会工作。

 

修改完配置文件之后,初始化gitlab

gitlab-ctl reconfigure

 

这里以QQ exmail (腾讯企业邮箱)为例

其它邮箱配置参考:​​SMTP 配置 | 极狐GitLab​

gitlab_rails['smtp_enable'] = true
gitlab_rails['smtp_address'] = "smtp.exmail.qq.com"
gitlab_rails['smtp_port'] = 465
gitlab_rails['smtp_user_name'] = "[email protected]"
gitlab_rails['smtp_password'] = "password"
gitlab_rails['smtp_authentication'] = "login"
gitlab_rails['smtp_enable_starttls_auto'] = true
gitlab_rails['smtp_tls'] = true
gitlab_rails['gitlab_email_from'] = '[email protected]'
gitlab_rails['smtp_domain'] = "exmail.qq.com"

# 示例
gitlab_rails['smtp_enable'] = true
gitlab_rails['smtp_address'] = "smtp.exmail.qq.com"
gitlab_rails['smtp_port'] = 465
gitlab_rails['smtp_user_name'] = "[email protected]"
gitlab_rails['smtp_password'] = "123qwe"
gitlab_rails['smtp_authentication'] = "login"
gitlab_rails['smtp_enable_starttls_auto'] = true
gitlab_rails['smtp_tls'] = true
gitlab_rails['gitlab_email_from'] = '[email protected]'
gitlab_rails['smtp_domain'] = "exmail.qq.com"

 

修改后执行, 执行以下命令

gitlab-ctl reconfigure
gitlab-ctl restart

测试

测试邮件发信功能

gitlab-rails console

进入控制台后,输入

Notify.test_email('收件人邮箱', '邮件标题', '邮件正文').deliver_now
# 例如:
Notify.test_email('[email protected]', '邮件标题', '邮件正文').deliver_now

 

 

Gitlab常用命令

# 开启,关闭,重启: gitlab组件
gitlab-ctl {start|stop|restart|status}
gitlab-ctl start
gitlab-ctl stop
gitlab-ctl restart
gitlab-ctl status

# 重载配置文件(重新编译gitlab的配置)
gitlab-ctl reconfigure

# 验证配置文件
gitlab-ctl show-config

# 检查gitlab
gitlab-rake gitlab:check SANITIZE=true --trace

# 查看日志
gitlab-ctl tail
gitlab-ctl tail nginx/gitlab_access.log
gitlab-ctl tail nginx/gitlab_error.log

# 常用目录
日志地址:/var/log/gitlab/ # 对应各服务的打印日志
服务地址:/var/opt/gitlab/ # 对应各服务的主目录

gitlab安装使用,备份和升级_nginx_03

 

 

访问 GitLab页面

输入external_url中ip,即可访问gitlab

 

修改root账号密码

sudo gitlab-rake "gitlab:password:reset[root]" #密码需要输入2次,输入是不显示的哦。完成后,即可使用root账号登录

 

修改gitlab端口号

#修改/etc/gitlab/gitlab.rb文件
nginx['listen_port'] = 8088

#修改修改默认的gitlab nginx的web服务80端 /var/opt/gitlab/nginx/conf/gitlab-http.conf
server { ## HTTPS server
listen *:8088;

#初始化并重启组件:
gitlab-ctl reconfigure
gitlab-ctl restart

#移出防火墙中原端口:
firewall-cmd --permanent --remove-port=80/tcp

#添加新端口:
firewall-cmd --permanent --zone=public --add-port=8088/tcp

#重启防火墙
systemctl reload firewalld

#浏览器访问
http://ip:8088

防火墙相关指令

#查看端口监听状态
netstat -lnpt

#查询已开放的端口
netstat -anp
firewall-cmd --permanent --list-port

#查看防火墙状态
systemctl status firewalld

# 开机自启
systemctl enable firewalld

#禁止开机自启
systemctl disable firewalld.service

#开启防火墙
systemctl start firewalld
service firewalld start

#关闭防火墙
systemctl stop firewalld

#重启防火墙
systemctl restart firewalld.service
systemctl reload firewalld

#若遇到无法开启
#先用:
systemctl unmask firewalld.service
#然后:
systemctl start firewalld.service


#添加指定需要开放的端口:
firewall-cmd --add-port=123/tcp --permanent
firewall-cmd --permanent --zone=public --add-port=80/tcp

#查询指定端口是否开启成功:
firewall-cmd --query-port=6379/tcp

#移除指定端口:
firewall-cmd --permanent --remove-port=123/tcp

#添加开发的访问方式
irewall-cmd --permanent --add-service=http

#重载入添加的端口:
firewall-cmd --reload
systemctl reload firewalld
service firewalld restart

配置密钥文件

生成ssh

ssh-keygen -t rsa -C '[email protected]'

然后一路回车(-C 参数是邮箱地址)

复制ssh

打开
~/.ssh/id_rsa.pub文件
(~表示用户目录,windows就是C:\Users\Administrator),
复制其中的内容

浏览器界面设置

打开gitlab,
找到Profile Settings–>SSH Keys—>Add SSH Key,
并把上一步中复制的内容粘贴到Key所对应的文本框,
在Title对应的文本框中给这个sshkey设置一个名字,
点击Add key按钮

Gitlab Project设置ssh key

在GitLab的主页中新建一个Project 

gitlab安装使用,备份和升级_nginx_04

 

 

gitlab安装使用,备份和升级_nginx_05

 

 

添加ssh key导入步骤2中生成的密钥文件内容:

 

gitlab安装使用,备份和升级_重启_06

 

 

gitlab安装使用,备份和升级_重启_07

 

 

gitlab安装使用,备份和升级_git_08

 

 

GitLab备份和恢复

 

备份

vi /etc/gitlab/gitlab.rb

# 备份保存的位置,这里是默认位置,可修改成指定的位置
[root@node2 ~]# gitlab_rails['backup_path'] = "/var/opt/gitlab/backups"
# 设置备份保存的时间,超过此时间的日志将会被新覆盖
[root@node2 ~]# gitlab_rails['backup_keep_time'] = 604800 # 这是默认设置,保存7天

如果自定义了备份保存位置,则要修改备份目录的权限,比如:
[root@node2 ~]# chown -R git.git /data/backup/gitlab

# 重读配置文件
[root@node2 ~]# gitlab-ctl reconfigure

# 重启gitlab
[root@node2 ~]# gitlab-ctl restart

# 可以将此命令写入crontab,以实现定时备份
[root@node2 ~]# /usr/bin/gitlab-rake gitlab:backup:create

设置定时任务
[root@node2 ~]# crontab -e
#每天凌晨2点定时创建备份
0 2 * * * /usr/bin/gitlab-rake gitlab:backup:create

# 备份时间的识别
# 备份后的文件类似这样的形式:1494170842_gitlab_backup.tar,
# 可以根据前面的时间戳确认备份生成的时间
date -d @1494170842
2017年 05月 07日 星期日 11:27:22 EDT

gitlab安装使用,备份和升级_nginx_09

 

 

 

 

gitlab安装使用,备份和升级_重启_10

 

 

恢复gitlab

# 停止数据写入服务
gitlab-ctl stop unicorn
gitlab-ctl stop sidekiq

# 进行恢复
# 下面的时间戳就是刚刚备份的文件前面的时间戳
gitlab-rake gitlab:backup:restore BACKUP=1494170842

# 重启
gitlab-ctl restart

服务器修改过ssh端口的坑(需要修改配置ssh端口)
# 如修改了ssh端口,则需在gitlab中配置ssh地址
# gitlab会在前面加上协议头和端口号"ssh://[email protected]:55725/huangdc/test.git"

vim /etc/gitlab/gitlab.rb
gitlab_rails['gitlab_shell_ssh_port'] = 55725
#使配置生效
gitlab-ctl reconfigure
#重新启动GitLab
gitlab-ctl restart

 

gitlab安装使用,备份和升级_重启_11

 

 

升级:

假如你的gitlab版本是12.0.4,想升级到14.10.5

1,首先先把12.0.4升级到12.xx最高版本

  12.0.4升级到12.10.14,

2.再把12.xx最高版本升级到13.0.xx第一个版本

3.再把13.0.xx升级到13.xx第高版本

3.13.xx第高版本升级到14..0.xx第一个版本

4.再把14..0.xx升级到14.10.5

逐步升级=》12.0.4=》12.最高版本.xx=》13.0.第一个版本=》13.最高版本.xx=>14.0.第一个版本=>14.10.xx

 

 

迁移:

 

1,版本不变的情况下

备份数据,备份配置文件  拷贝到新服务器即可,

2,迁移后版本升级了

本地先把gielab升级到指定版本,升级完后再执行上面备份过程

 

标签:--,备份,gitlab,smtp,rails,升级,ctl
From: https://blog.51cto.com/u_12903656/5911988

相关文章

  • chrome 浏览器手动同步更新书签数据备份
    现在很多人会使用浏览器自带的同步工具,这样即使换了电脑,对于这个浏览器来说,与没换电脑一样,这就是同步的作用。chrome浏览器,只要有网络,只要登录了账号是自动同步的,所......
  • 批处理执行SQL备份
    建立mybackup.bat,输入以下内容直接运行该脚本,即可开始自动备份数据库也可把该脚本加入windows任务计划里执行-------------------------------------------------------......
  • 构建全真互联数字地图底座 腾讯地图产业版WeMap重磅升级
    前言伴随着地理信息产业的不断演进,以及LBS、大数据、5G、云、AI等新技术的持续应用,数实融合发展呈现出加速态势,数字地图也从移动互联网时代向产业互联网时代进化。12月1......
  • ubuntu16下升级python3的版本
    ubuntu16下升级python3的版本,这里是升级到3.8。1.首先添加安装源,在命令行输入如下命令:$sudoadd-apt-repositoryppa:jonathonf/python-3.82.更新apt$sudoaptupdate......
  • 暴力升级你的 ST-Link 及 STM32CubeIDE
    原文https://github.com/armink/HackSTLinkUpgrade背景一些ST-Link在使用最新的IDE时,经常提示需要升级其固件,但是升级始终失败,提示容量不足。在KeilMDK上可能就......
  • 暴力升级你的 ST-Link 及 STM32CubeIDE
    暴力升级你的ST-Link及STM32CubeIDE背景一些ST-Link在使用最新的IDE时,经常提示需要升级其固件,但是升级始终失败,提示容量不足。在KeilMDK上可能就提示一下升级......
  • Centos7.x将Python2升级到Python3
    查看Python版本python-V更新yum源yumupdate安装依赖yuminstallyum-utilsyum-builddeppython3下载pythonwgethttps://www.python.org/ftp/python/3.8.5/Py......
  • Centos7升级gcc
    不建议贸然升级,时间是比较久的并且容易出现一系列问题。升级GCC版本到11.1GCC11终于发正式版了,4月底官方终于发了11.1正式版.对于我们来说,项目实际使用基于C++17的......
  • mysql备份与恢复
    Mysql的备份日志MySQL的日志默认保存位置为/usr/local/mysql/data配置文件:vim/etc/my.cnf[mysqld]#错误日志,用来记录当MySQL启动、停止或运行时发生的错误信息,默......
  • oracle 10.2.0.1 64bit升级到10.2.0.4 64bit
    文档课题:oracle10.2.0.164bit升级到10.2.0.464bit.数据库:oracle10.2.0.164位系统:oel5.1164位1、前期准备1.1、关闭实例关闭需要升级的实例.SQL>shutdownimmediateD......