CentOS6安装gitlab

前端之家收集整理的这篇文章主要介绍了CentOS6安装gitlab前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

1、安装和配置必须的依赖

sudo yum install curl openssh-server openssh-clients postfix cronie
sudo service postfix start
sudo chkconfig postfix on
sudo lokkit -s http -s ssh

如果运行上面的命令,发现没有安装 lokkit,那么需要你手动 yum install lokkit
lokkit 可以帮助我们设定 iptables 打开 http 和 ssh

2、添加和安装依赖包
curl -sS https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.rpm.sh | sudo bash
sudo yum install gitlab-ce
这个依赖包有点大,建议用下载工具下载,然后用本地安装sudo yum localinstall

3、配置和启动gitlab

sudo gitlab-ctl reconfigure
到这里gitlab就可以正常运行了,如果要自定访问ip或者域名的话,可以修改配置文件
vi /etc/gitlab/gitlab.rb
打开后有一行 external_url 的設定改成要對外開放 web 的 url ,
例如我可以指定 git.yijiebuyi.com
只想內部使用也可以改成 http://192.168.0.11 这样的内部IP地址.

停止gitlab

gitlab-ctl stop
启动gitlab
gitlab-ctl start
GitLab 默认存放目录到 /var/opt/gitlab
如果要移动,备份此目录,比较保险的做法是,先停止 GitLab,然后备份目录,最后在重启GitLab


通过gitlab官方源安装好gitlab之后,程序包中会自带一个Nginx服务器,gitlab本身消耗系统资源严重,理论上最好单独部署在一台服务器上,但是为了节约成本,也会跟其他服务共用服务器,如果之前机器上就有Nginx服务则会冲突,可以修改配置,使用已经存在的Nginx

修改gitlab使用现有Nginx服务

修改gitlab.rb配置文件

1
2
3
4
5
6
7
8
9
# vim /etc/gitlab/gitlab.rb 

配置文件搜索 /# Nginx
# Nginx['enable'] = true
# Nginx['client_max_body_size'] = '250m'
# Nginx['redirect_http_to_https'] = false

修改上面配置为false
Nginx['enable'] = false

将gitlab生成Nginx配置复制到Nginx虚拟主机配置文件夹下

1
2
3
4
5
6
7
拷贝配置:
# cp /var/opt/gitlab/Nginx/conf/gitlab-http.conf /etc/Nginx/conf.d/

检测配置:
# Nginx -t
Nginx: [emerg] unknown log format "gitlab_access" in /etc/Nginx/conf.d/gitlab-http.conf:56
Nginx: configuration file /etc/Nginx/Nginx.conf test Failed

将配置中第13行结尾的gitlab_access去掉,即可完成验证。重启Nginx使配置生效。

页面502问题

替换完成后如果出现502问题,查看日志

权限问题

1
2
3
# tail -f /var/log/gitlab/Nginx/error.log 

2015/11/03 15:45:10 [error] 8931#0: *15 connect() to unix:/var/opt/gitlab/gitlab-rails/sockets/gitlab.socketFailed (13: Permission denied) while connecting to upstream,client: xxx.xxx.xxx.xx,server: git.xxxx.com,request: "GET / HTTP/1.1",upstream: "http://unix:/var/opt/gitlab/gitlab-rails/sockets/gitlab.socket:/",host: "git.xxxx.com"

通过Nginx日志可以看出,Nginx没有访问gitlab的socket权限,修改方式有多种,我的机器上Nginx的执行用户Nginx,而socket文件夹为

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
drwxr-x--- 2 git gitlab-www 4096 113 15:57 sockets

文件赋权限
# chmod -R o+x /var/opt/gitlab/gitlab-rails/sockets
 or
# chmod 755 /var/opt/gitlab/gitlab-rails/sockets

Nginx用户加入gitlab-www组
# usermod -a -G gitlab-www Nginx

修改配置
# vim /etc/gitlab/gitlab.rb 
web_server['external_users'] = ['Nginx']
# web_server['username'] = 'gitlab-www'
# web_server['group'] = 'gitlab-www'

gitlab程序未启动的问题

1
2015/11/03 15:41:02 [error] 8931#0: *8 connect() to unix:/var/opt/gitlab/gitlab-rails/sockets/gitlab.socket Failed (111: Connection refused) while connecting to upstream,client: 111.161.77.240,server: git.yuzhewo.com,host: "git.yuzhewo.com"

报错信息为(111: Connection refused)

cat /var/opt/gitlab/gitlab-rails/sockets/gitlab.socket 内容为空

怀疑gitlab服务未启动,查询启动日志,发现如下错误

[2015-11-03T16:12:06+00:00] ERROR: Cannot allocate memory - fork(2)

原因可能是系统内存不足,无法分配足够内存,导致启动失败,这种情况只能升级服务器配置来解决

参考链接

https://about.gitlab.com/downloads/#centos6

http://yijiebuyi.com/blog/49aa7d3793aeafeb77da67a4159ec1aa.html

http://www.yuzhewo.com/2015/11/03/%E4%BF%AE%E6%94%B9gitlab%E4%BD%BF%E7%94%A8%E7%8E%B0%E6%9C%89nginx%E6%9C%8D%E5%8A%A1%E5%8F%8A502%E9%97%AE%E9%A2%98%E8%A7%A3%E5%86%B3/

原文链接:https://www.f2er.com/centos/380981.html

猜你在找的CentOS相关文章