环境准备

python版本2.6
git版本 1.8.4.1
ruby版本ruby-2.0.0-p353
gitlab-shell版本 v1.8.0
gitlab版本6.4.3

因centos6系列的python版本是2.6的,已经支持,所以不必升级python版本。
在centos5下面需要升级python版本>2.5

安装epel的yum源

1 yum -y install http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm

安装必要的软件包

1 yum -y install libicu-devel patch gcc-c++ readline-devel zlib-devel libffi-devel openssl-devel make autoconf automake libtool bison libxml2-devel libxslt-devel libyaml-devel zlib-devel openssl-devel cpio expat-devel gettext-devel curl-devel perl-ExtUtils-CBuilder perl-ExtUtils-MakeMaker

原文链接:http://www.linuxyan.com/web-server/353.html

安装git

因为git需要1.8版本以上,所以需要重新编译安装
移除当前git

1 yum remove git

下载1.8.4.1的git并安装

1 curl --progress https://git-core.googlecode.com/files/git-1.8.4.1.tar.gz | tar xz
2 cd git-1.8.4.1/
3 make prefix=/usr/local all
4 make prefix=/usr/local install
5 ln -fs /usr/local/bin/git* /usr/bin/

安装ruby环境

01 yum -y remove ruby
02 mkdir /tmp/ruby && cd /tmp/ruby
03 curl --progress ftp://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-p353.tar.gz | tar xz
04 cd ruby-2.0.0-p353/
05 ./configure --disable-install-rdoc
06 make && make install
07 gem source -r https://rubygems.org/
08 gem source -a http://ruby.taobao.org/
09 gem install bundler --no-ri --no-rdoc
10 ln -/usr/local/bin/ruby /usr/bin/ruby
11 ln -/usr/local/bin/gem /usr/bin/gem
12 ln -/usr/local/bin/bundle /usr/bin/bundle

添加git帐号并允许sudo

1 useradd --comment 'GitLab' git
2 echo "git ALL=(ALL)       NOPASSWD: ALL" >>/etc/sudoers

安装git-shell

01 cd /home/git
02 sudo -u git -H git clone https://gitlab.com/gitlab-org/gitlab-shell.git -b v1.8.0
03 cd gitlab-shell/
04 sudo -u git -H cp config.yml.example config.yml
05 vim config.yml
06 修改gitlab_url为gitlab的域名
07 gitlab_url: "http://localhost/"
08 修改为
09 gitlab_url: "http://git.linuxyan.com/"
10 #安装git-shell
11 sudo -u git -H ./bin/install

安装mysql以及建立gitlab数据库

01 yum install mysql mysql-devel mysql-server -y
02 /etc/init.d/mysqld start
03 chkconfig mysqld on
04 登录mysql创建gitab的帐号和数据库
05 mysql> CREATE USER 'gitlab'@'localhost' IDENTIFIED BY 'gitlab';
06 mysql> CREATE DATABASE IF NOT EXISTS `gitlabhq_production` DEFAULT CHARACTER SET `utf8` COLLATE `utf8_unicode_ci`;
07 mysql> GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, INDEX, ALTER ON `gitlabhq_production`.* TO 'gitlab'@'localhost';
08  
09 测试是否可以用git帐号登录数据库
10  
11 sudo -u git -H mysql -u gitlab --D gitlabhq_production

安装redis

1 yum -y install redis
2 /etc/init.d/redis start
3 chkconfig redis on

安装gitlab

01 cd /home/git
02 sudo -u git -H git clone https://gitlab.com/gitlab-org/gitlab-ce.git -6-4-stable gitlab
03 cd /home/git/gitlab
04 sudo -u git -H cp config/gitlab.yml.example config/gitlab.yml
05  
06 vim config/gitlab.yml
07 修改host为刚才git-shell里面设置的域名
08 ## GitLab settings
09 gitlab:
10 ## Web server settings
11   host: git.linuxyan.com
12   port: 80
13   https: false
14  
15 修改git的path
16 git:
17   bin_path: /usr/local/bin/git
18  
19 给文件夹添加相应的权限
20 chown -R git log/
21 chown -R git tmp/
22 chmod -R u+rwX  log/
23 chmod -R u+rwX  tmp/
24 创建必要的文件夹,以及复制配置文件
25 sudo -u git -H mkdir /home/git/gitlab-satellites
26 sudo -u git -H mkdir tmp/pids/
27 sudo -u git -H mkdir tmp/sockets/
28 sudo chmod -R u+rwX  tmp/pids/
29 sudo chmod -R u+rwX  tmp/sockets/
30 sudo -u git -H mkdir public/uploads
31 sudo chmod -R u+rwX  public/uploads
32 sudo -u git -H cp config/unicorn.rb.example config/unicorn.rb
33 sudo -u git -H cp config/initializers/rack_attack.rb.example config/initializers/rack_attack.rb

设置gitlab的全局帐号

1 sudo -u git -H git config --global user.name "GitLab"
2 sudo -u git -H git config --global user.email "gitlab@localhost"
3 sudo -u git -H git config --global core.autocrlf input

设置数据库链接地址和权限

01 sudo -u git cp config/database.yml.mysql config/database.yml
02 sudo -u git -H vim  config/database.yml
03 修改链接数据库信息
04 production:
05   adapter: mysql2
06   encoding: utf8
07   reconnect: false
08   database: gitlabhq_production
09   pool: 10
10   username: gitlab
11   password: "gitlab"
12   # host: localhost
13   # socket: /tmp/mysql.sock

安装需要ruby的gems

1 cd /home/git/gitlab
2 vim  Gemfile
3 修改source "https://rubygems.org/"
4 为source "http://ruby.taobao.org/"
5 vim Gemfile.lock
6 修改remote: https://rubygems.org/
7 为remote: http://ruby.taobao.org/
8 安装
9 sudo -u git -H bundle install --deployment --without development test postgres aws

如果遇到如下错误:

1 Could not find modernizr-2.6.2 in any of the sources

则修改:

01 vim Gemfile
02 修改:gem "modernizr",        "2.6.2"
03 为gem "modernizr-rails",  "2.7.1"
04  
05 vim Gemfile.lock
06 修改:modernizr (2.6.2)
07 为:modernizr-rails (2.7.1)
08  
09 修改:modernizr (= 2.6.2)
10 为:modernizr-rails (= 2.7.1)

然后再执行安装

1 sudo -u git -H bundle install --deployment --without development test postgres aws

过程如下图:

初始化数据库

1 sudo -u git -H bundle exec rake gitlab:setup RAILS_ENV=production

初始化数据库之后,会告诉你默认的管理员用户和密码:

安装启动文件以及日志切割文件

1 cp lib/support/init.d/gitlab /etc/init.d/gitlab
2 cp lib/support/init.d/gitlab.default.example /etc/default/gitlab
3 cp lib/support/logrotate/gitlab /etc/logrotate.d/gitlab

检测当前环境

1 sudo -u git -H bundle exec rake gitlab:env:info RAILS_ENV=production

如下:

安装nginx

1 yum -y install nginx

修改配置文件:
vim /etc/nginx/nginx.conf

01 user              root git;
02 worker_processes  2;
03 pid        /var/run/nginx.pid;
04  
05 events {
06     worker_connections  1024;
07 }
08  
09 http {
10     include       /etc/nginx/mime.types;
11     default_type  application/octet-stream;
12  
13     log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
14                       '$status $body_bytes_sent "$http_referer" '
15                       '"$http_user_agent" "$http_x_forwarded_for"';
16 # GITLAB
17 # Maintainer: @randx
18 # App Version: 5.0
19  
20 upstream gitlab {
21   server unix:/home/git/gitlab/tmp/sockets/gitlab.socket;
22 }
23  
24 server {
25   listen *:80 default_server;         # e.g., listen 192.168.1.1:80; In most cases *:80 is a good idea
26   server_name YOUR_SERVER_FQDN;     # e.g., server_name source.example.com;
27   server_tokens off;     # don't show the version number, a security best practice
28   root /home/git/gitlab/public;
29  
30   # Set value of client_max_body_size to at least the value of git.max_size in gitlab.yml
31   client_max_body_size 5m;
32  
33   # individual nginx logs for this gitlab vhost
34   access_log  /var/log/nginx/gitlab_access.log;
35   error_log   /var/log/nginx/gitlab_error.log;
36  
37   location / {
38     # serve static files from defined root folder;.
39     # @gitlab is a named location for the upstream fallback, see below
40     try_files $uri $uri/index.html $uri.html @gitlab;
41   }
42  
43   # if a file, which is not found in the root folder is requested,
44   # then the proxy pass the request to the upsteam (gitlab unicorn)
45   location @gitlab {
46     proxy_read_timeout 300https://github.com/gitlabhq/gitlabhq/issues/694
47     proxy_connect_timeout 300https://github.com/gitlabhq/gitlabhq/issues/694
48     proxy_redirect     off;
49  
50     proxy_set_header   X-Forwarded-Proto $scheme;
51     proxy_set_header   Host              $http_host;
52     proxy_set_header   X-Real-IP         $remote_addr;
53     proxy_set_header   X-Forwarded-For   $proxy_add_x_forwarded_for;
54  
55     proxy_pass http://gitlab;
56   }
57 }
58  
59 }

更改权限,启动nginx

1 nginx -t
2 chown -R git.git /var/lib/nginx/
3 /etc/init.d/nginx start

拉取gitlab静态资源文件

1 sudo -u git -H bundle exec rake assets:precompile RAILS_ENV=production

启动gitlab

1 /etc/init.d/gitlab start

检测各个组件是否正常工作

1 sudo -u git -H bundle exec rake gitlab:check RAILS_ENV=production

检测没有错误就表示已经安装好了gitlab,如图:

这个时候就可以用浏览器打开http://git.linuxyan.com
初始管理员帐号和密码为:
admin@local.host
5iveL!fe
登录之后如下:

centos6安装部署git服务器(gitlab6.4)的更多相关文章

  1. GIT-Linux(CentOS7)系统部署git服务器

    GIT-Linux(CentOS7)系统部署git服务器 root账号登录 一. 安装并配置必要的依赖关系在CentOS系统上安装所需的依赖:ssh,防火墙,postfix(用于邮件通知) ,wget ...

  2. GIT-windows系统部署git服务器

    windows系统部署git服务器 因为需要所以就来利用IIS(Internet Information Service )来进行搭建. 进入正文: 不管你是什么win7.win8.win8.1还是w ...

  3. [转]Centos 7 安装部署 GitLab 服务器

    Centos 7 安装部署 GitLab 服务器 转自:https://www.jianshu.com/p/79bfded68899 文前说明 作为码农中的一员,需要不断的学习,我工作之余将一些分析总 ...

  4. 部署git服务器 gitServer 软件

    部署git服务器 gitServer 软件 搭建git服务器也并不是非常的难,有这么多优秀的软件,选择一个适合自己就行了 1. windows版本 http://gitstack.com/ 免费版本, ...

  5. [转载]Ubuntu安装配置 git 服务器和客户端

    原文地址:Ubuntu安装配置 git 服务器和客户端作者:ding404 1.配置前准备 服务器:安装ssh server另外还装了gitosis做git的权限管理 sudo apt-get ins ...

  6. 二十二. 安装部署Tomcat服务器、使用Tomcat部署虚拟主机、使用Varnish加速Web

    web proxy web1 web2   1.安装部署Tomcat服务器 web1 1.1 使用RPM安装JDK环境 ]# yum -y install java-1.8.0-openjdk ]# ...

  7. 一、CentOS 7安装部署GitLab服务器

    一.CentOS 7安装部署GitLab服务器 1.安装依赖软件 yum -y install policycoreutils policycoreutils-python openssh-serve ...

  8. Linux安装部署FTP服务器

    Linux安装部署FTP服务器   本文章会将安装FTP服务器的步骤以及一些遇到的问题来记录下 因为项目中要与第三方对接数据,需要用到FTP服务器以提供他们每天上传数据,因为之前在本地的VMware虚 ...

  9. 高级运维(四):Nginx常见问题处理、安装部署Tomcat服务器、使用Tomcat部署虚拟主机

    一.Nginx常见问题处理 目标: 本案例要求对Nginx服务器进行适当优化,以提升服务器的处理性能: 1> 不显示Nginx软件版本号 2> 如果客户端访问服务器提示“Too many ...

随机推荐

  1. PL/SQL报无效的窗口句柄的解决办法

    在远程服务器上使用pl sql developer查询oralce数据库的时候,遇到很长的文本变量想点开小窗口看下具体内容, 但系统弹窗提示“无效的窗口句柄”,听同事介绍原来需要开启一个windows ...

  2. Emacs中Golang的设置

    欲善其事,先利其器.下面记录一些使用Emacs24做golang开发中的一些有用设置,备忘用. 一,golang中的代码跳转 emacs24的go-mode中默认用godef-describe,god ...

  3. SQL之group by 和 having

    转自:mysql必知必会——GROUP BY和HAVING GROUP BY语法可以根据给定数据列的每个成员对查询结果进行分组统计,最终得到一个分组汇总表. select子句中的列名必须为分组列或列函 ...

  4. 像python一样运行js的__main__

    在测试时,使用单文件进行简单测试既简洁又清晰.js其实也是可以做到的 if (require && require.main == module) { console.log(&quo ...

  5. JavaScript 浏览器对象模型 (BOM)

    浏览器对象模型 (BOM) 使 JavaScript 有能力与浏览器“对话”. 浏览器对象模型 (BOM) 浏览器对象模型(Browser Object Model)尚无正式标准. 由于现代浏览器已经 ...

  6. MySQL的初次见面礼基础实战篇

    [版权申明] http://blog.csdn.net/javazejian/article/details/61614366 出自[zejian的博客] 关联文章: MySQL的初次见面礼基础实战篇 ...

  7. apk 静默安装

    老大要我弄个自动更新,要用到静默安装,网上找到了些大拿的代码,我拿去改吧改吧,先贴出来: /** * 软件静默安装 * @param apkAbsolutePath apk文件所在路径 * @retu ...

  8. Oracle 12C -- 清空audit记录

    1.使用job清空 SQL> dbms_audit_mgmt.create_purge_job ( audit_trail_type=> DBMS_AUDIT_MGMT.AUDIT_TRA ...

  9. SharePoint 2013 Farm 安装指南——构建一个双层SharePoint Farm

    最近要对公司里的SharePoint进行升级,由于旧的系统SharePoint 2010已经有2年了,上面改动比较多,而且权限也很混乱了,所以下定决心要对其做一次升级,重新部署一台新的SharePoi ...

  10. [转]Greenplum 通过gpfdist + EXTERNAL TABLE 并行导入数据

    摘要: Greenplum 提供了快速导入数据的方法,下面通过一个例子演示给大家. Greenplum 提供了快速导入数据的方法,下面通过一个例子演示给大家. 我们用TPCH测试中最大的表做导入测试 ...