关闭

CentOS6安装gitlab

460人阅读 评论(0) 收藏 举报

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, request: "GET / HTTP/1.1", upstream: "http://unix:/var/opt/gitlab/gitlab-rails/sockets/gitlab.socket:/", host: "git.yuzhewo.com"

报错信息为(111: Connection refused)

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

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

1
[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/

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:192981次
    • 积分:3193
    • 等级:
    • 排名:第11126名
    • 原创:123篇
    • 转载:111篇
    • 译文:0篇
    • 评论:36条
    最新评论