设为首页 收藏本站
查看: 590|回复: 0

[经验分享] CentOS安装gitLab服务器

[复制链接]

尚未签到

发表于 2018-1-10 15:11:59 | 显示全部楼层 |阅读模式
  首先利用gitlab-install-el6.sh安装,比较简单:
  (出处:http://www.iyunv.com/Linux/2013-06/85754.htm)
  1:如果有条件,提供一台全新的Server,仅仅只安装了一些系统的软件包,可以直接使用一键安装的脚本来搭建,非常容易,具体步骤如下: 2.1.1 安装EPEL扩展源
  切换到root用户
  

1 $ sudo -i  

2 # rpm -ivh http://fr2.rpmfind.net/linux/epel/6/x86_64/epel-release-6-8.noarch.rpm  

  2: 安装git
  

1 # yum install git  

  3:下载gitlab-installer.sh安装脚本
  

1 # git clone https://github.com/mattias-ohlsson/gitlab-installer.git  

  4:执行安装脚本
  

1 # cd gitlab-installer/  
2 # ./gitlab-install-el6.sh
  

  等待脚本执行完毕后,会提示如下信息(比如Server主机名为:heydevops-node-2):
  

1 ### Done ########################################  

2 #  

3 # You have your MySQL root password in this file:  

4 # /config/database.yml  

5 #  

6 # Point your browser to:  

7 # http://heydevops-node-2 (or: http://[host-ip])  
8 # Default admin username: admin@local.host
  
9 # Default admin password: 5iveL!fe
  
10 #
  
11 #################################################
  

  5:将脚本的Ruby版本指向到ruby-1.9.3-p392
  

# vim /home/git/gitlab-shell/bin/gitlab-shell  

  
#
!/usr/local/rvm/bin/ruby-1.9.3-p392  

  6:使用GitLab
  接着,就可以通过 http://[host-ip] ([host-ip]是Server的IP)来访问GitHub了。
  -----------------------------------------------------------------------------
  下面是编译安装:
  (出处:http://www.bkjia.com/Linux/1031587.html?qqdrsign=05096)
  首先申明此文档是根据别人的安装步骤上进行修改的!解决了上面的很多问题。
参考资料:http://www.01happy.com/centos-6-5-install-gitlab/

GitLab,是一个使用 Ruby on Rails 开发的开源应用程序,与Github类似,能够浏览源代码,管理缺陷和注释,非常适合在团队内部使用。

官 方只提供了Debian/Ubuntu系统下的安装说明文档,如果需要在centos下安装,可以参考这篇:https://github.com /gitlabhq/gitlab-recipes/tree/master/install/centos,笔者依照这篇文章的说明,成功的在 centos系统上安装了gitlab,分享一下自己的安装过程和碰到的问题。

安装的英文文档:centos-6-5-install-gitlab.zip

先秀下安装完成后的成果。

centos安装gitlab成果

开始之前

在 开始之前请先查看官方的刚需文档:https://github.com/gitlabhq/gitlabhq/blob/master/doc /install/requirements.md ,该文档说明了系统,软件和硬件等各方面的需求。详细的了解这些,可以避免碰到很多怪异的问题。

安装步骤总览



  • 基础操作系统(CentOS 6.4 Minimal,升级后为6.5)
  • Ruby (版本: 2.0.0p353)
  • 创建项目运行用户(创建git账号,方便权限管理)
  • GitLab Shell(版本:1.8.0)
  • 数据库(可以支持mysql和PostgreSQL,这里使用mysql,版本:5.1.17)
  • GitLab(版本:6.3.1)
  • Web服务器(可支持nginx和apache,这里使用nginx,版本:1.0.15)
  • 防火墙(iptables)
1、安装操作系统

这个比较简单,安装完成之后记的配置下网络,使其可以在启动时自动连接。而后需要升级系统和安装一些相应的软件和依赖包,以下逐一说明。

Tips:如果不能连接国外的网络,经常出现网络错误或者couldn’t notresolve host这样的错误,建议修改dns服务器为8.8.8.8和8.8.4.4。

a、升级操作系统和安装wget

  

1 $ sudo yum -y update  

2 $ sudo yum -y install wget  


升级完成后,系统版本是6.5。

笔者注:和英文文档不同,笔者这里是先升级系统和安装wget,不然后面的操作会提示wget命令找到。

b、增加EPEL安装源

EPEL,即Extra Packages for Enterprise Linux,这个软件仓库里有很多非常常用的软件,而且是专门针对RHEL设计的,对RHEL标准yum源是一个很好的补充,完全免费使用,由 Fedora项目维护,所以如果你使用的是RHEL,或者CentOS,Scientific等RHEL系的linux,可以非常放心的使用EPEL的 yum源。

下载并安装GPG key

  

1 $ sudo wget -O /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6https://www.fedoraproject.org/static/0608B895.txt  
2
  
3 $ sudo rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6
  

  检验下是否安装成功
  

$ sudo rpm -qa gpg*  

  安装epel-release-6-8.noarch包
  

1 $ sudo rpm -Uvhhttp://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm  

  提示:不要在意x86_64,在i686的机器上一样能使用。
  c、增加PUIAS安装源
PUIAS Linux是面向桌面和服务器的完整的操作系统,它靠编译Red HatEnterprise Linux的源代码包来创建。除了这些上游的软件包外,该项目还提供一些其他的软件仓库:“Addons”包含了通常的Red Hat发行中未收入的额外软件包,“Computational”提供专门针对科学计算的软件,“Unsupported”则收入各种各样的测试性软件 包。该发行由美国普林斯顿 大学的高等研究所维护。

创建/etc/yum.repos.d/PUIAS_6_computational.repo,并添加如下内容:

  

[PUIAS_6_computational]  
name
=PUIAS computational Base $releasever -$basearch  
mirrorlist
=http://puias.math.ias.edu/data/puias/computational/$releasever/$basearch/mirrorlist  
#baseurl=http://puias.math.ias.edu/data/puias/computational/$releasever/$basearch
  
gpgcheck=1
  
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-puias
  

  下载并安装GPG key
  

1 $ sudo wget -O/etc/pki/rpm-gpg/RPM-GPG-KEY-puiashttp://springdale.math.ias.edu/data/puias/6/x86_64/os/RPM-GPG-KEY-puias  
2
  
3 $ sudo rpm --import/etc/pki/rpm-gpg/RPM-GPG-KEY-puias
  

  检验下是否安装成功
  

1 $ sudo rpm -qa gpg*  

  Tips:安装完EPEL和PUIAS两个源后,可以检测下:
  

1 $ sudo yum repolist  

  d、安装GitLab的所需依赖包和工具
  

1 $ su -  
2
  
3 $ yum -y groupinstall 'Development Tools'
  
4
  
5 $ yum -y install vim-enhanced readlinereadline-devel ncurses-devel gdbm-devel glibc-devel tcl-devel openssl-develcurl-devel expat-devel db4-devel byacc sqlite-devel gcc-c++ libyamllibyaml-devel libffi libffi-devel libxml2 libxml2-devel libxslt libxslt-devellibicu libicu-devel system-config-firewall-tui python-devel redis sudo wgetcrontabs logwatch logrotate perl-Time-HiRes git
  

  RHEL提示
  如果部分包不能安装,例如: eg. gdbm-devel, libffi-devel andlibicu-devel,那么增加rhel6的安装源。
  

1 $ yum-config-manager --enablerhel-6-server-optional-rpms  

  e、配置redis
  配置redis使其在开机时启动:
  

1 $ sudo chkconfig redis on  

2 $ sudo service redis start  


f、配置邮件服务器

笔者注:这个过程笔者没有配置,请参考英文文档。

2、安装Ruby

下载并编译:

  

1 $ su -  
2
  
3 $ mkdir /tmp/ruby && cd /tmp/ruby
  
4
  
5 $ curl --progressftp://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-p353.tar.gz | tar xz
  
6
  
7 $ cd ruby-2.0.0-p353
  
8
  
9 $ ./configure --prefix=/usr/local/
  
10
  
11 $ make && make install
  

  安装完成后,重新登录终端确保$PATH生效,检测ruby的安装成功与否:
  

1 $ su -  
2
  
3 $ which ruby
  
4
  
5 输出:/usr/local/bin/ruby
  
6
  
7 $ ruby -v
  
8
  
9 输出:ruby2.0.0p353 (2013-11-22 revision 43784) [x86_64-linux]
  

  安装bundle:
  

1 $ sudo gem install bundler --no-ri --no-rdoc  


1.如果提示sudo: gem: command not found,使用root账号登录执行该命令即可。

2.如果TM的还失败:用以下命令切换下载源,切换成功之后再执行$ gem install bundler --no-ri --no-rdoc

  

1 $ gem sources --remove https://rubygems.org/  
2
  
3 $ gem sources -a http://ruby.taobao.org/
  
4
  
5 $ gem sources -l
  


3、系统用户

创建用户git

  

1 $ su -  
2
  
3 $ adduser --system --shell /bin/bash --comment'GitLab' --create-home --home-dir /home/git/ git
  


因为git用户不需要登录,所以这里不需要设置git的密码。

转发所有邮件

笔者注:因为上面没有配置发送邮件,这里也省略。

4、配置GitLab shell

GitLab shell是专门为GitLab开发的提供ssh访问和版本管理的软件。

先使用root登录,而后切换成git

  

1 $ su -  
2
  
3 $ su - git
  

  克隆gitlab shell
  

1 $ git clonehttps://github.com/gitlabhq/gitlab-shell.git  
2
  
3 $ cd gitlab-shell
  

  切换成1.8.0版本,并编辑配置
  

1 $ git checkout v1.8.0  
2
  
3 $ cp config.yml.example config.yml
  


这里最重要的是将gitlab_url修改成gitlab的访问域名。形如:http://test.gitlab.com/

笔 者注:如果gitlab是使用https访问,则需将http替换成https,配置文件中的self_signed_cert要修改成 true,否则gitlab shell在通过api和gitlab进行通信的时候就会出现错误,导致项目push出错。因为后面配置web服务器的时候是使用ssl,所以这里要按照 ssl的方式配置。

Tips: 另外如果使用的域名是测试域名,不要忘记在系统的/etc/hosts做域名映射。如图:

安装一些需要的目录和文件

  

1 $ ./bin/install  


5、安装数据库

笔者这里使用的是msyql,关于PostgreSQL的安装请参考原文档。

安装mysql并设置开机启动:

  

1 $ su -  
2
  
3 $ yum install -y mysql-server mysql-devel
  
4
  
5 $ chkconfig mysqld on
  
6
  
7 $ service mysqld start
  


如果启动失败:解决方案如下:

如果是权限问题,则先改变权限 #chown -R mysql:mysql /var/lib/mysql

设置mysql root账号的密码:

  

1 $ /usr/bin/mysql_secure_installation  


创建新用户和数据库给gitlab使用

# 登录数据库

  

1 $ mysql -u root -p  


# 输入root密码

# 为gitlab创建使用用户

  

1 CREATE USER 'gitlab'@'localhost'>  

  # 创建gitlaba使用的数据库
  

1 CREATE DATABASE IF NOT EXISTS`gitlabhq_production` DEFAULT CHARACTERSET `utf8`COLLATE`utf8_unicode_ci`;  

  # 给予gitlab用户权限
  

1 GRANT SELECT, LOCK TABLES, INSERT, UPDATE,DELETE, CREATE, DROP, INDEX,>  

  # 登出数据库
  

1 \q  


6、安装GitLab

将GitLab安装在git的家目录下:

  

1 $ su -  
2
  
3 $ su - git
  


a、克隆GitLab并切换分支到6-3-stable

# 克隆GitLab

  

1 $ git clonehttps://github.com/gitlabhq/gitlabhq.git gitlab  

  # 进入gitlab目录
  

1 $ cd /home/git/gitlab  

  # 切换到6-3-stable分支
  

$ git checkout 6-3-stable  


b、配置项目

# 复制配置文件

  

1 $ cp config/gitlab.yml.exampleconfig/gitlab.yml  


# 修改配置文件中的访问域名

(your_domain_name为项目的访问域名)

  

1 $ sed -i 's|localhost|your_domain_name|g'config/gitlab.yml  

  修改后为:
  注意:host:172.16.9.120;port:8888 email_from:email@email.com
  # 设定log和tmp目录所有者和权限
  

1 $ chown -R git log/  
2
  
3 $ chown -R git tmp/
  
4
  
5 $ chmod -R u+rwX log/
  
6
  
7 $ chmod -R u+rwX tmp/
  

  # 创建gitlab-satellites目录
  

1 $ mkdir /home/git/gitlab-satellites  

  # 创建tmp/pids/和tmp/sockets/目录,确保gitlab有相应的权限
  

1 $ mkdir tmp/pids/  
2
  
3 $ mkdir tmp/sockets/
  
4
  
5 $ chmod -R u+rwX tmp/pids/
  
6
  
7 $ chmod -R u+rwX tmp/sockets/
  

  # 创建public/uploads目录
  

1 $ mkdir public/uploads  

2  
3 $ chmod -R u+rwX public/uploads
  

  # 复制unicorn配置
  

1 $ cp config/unicorn.rb.exampleconfig/unicorn.rb  


# 编辑unicorn配置

(笔者这里采用默认配置)

  

1 $ vim config/unicorn.rb  


修改后为:

# 配置git的用户和邮件

  

1 $ git config --global user.name"GitLab"  
2
  
3 $ git config --global user.email"gitlab@your_domain_name"
  
4
  
5 $ git config --global core.autocrlf input
  

  这边的配置比较复杂,细心些就行了。
  c、配置数据库访问文件
  

1 $ cp config/database.yml.mysqlconfig/database.yml  

  编辑config/database.yml,设置其中连接数据库的账号密码,笔者的配置部分如下:
  

1 #  

2  
3 # PRODUCTION
  
4
  
5 #
  
6
  
7 production:
  
8
  
9 adapter: mysql2
  
10
  
11 encoding: utf8
  
12
  
13 reconnect: false
  
14
  
15 database:gitlabhq_production
  
16
  
17 pool: 10
  
18
  
19 username: gitlab
  
20
  
21 password:"gitlab"
  
22
  
23 # host: localhost
  
24
  
25 # socket:/tmp/mysql.sock
  


修改其中username和password就可以了,其中密码就是上面数据库步骤中创建gitlab用户的密码。

确保该文件只有git账号有权限读取。

  

1 $ chmod o-rwx config/database.yml  

  d、安装Gems
  

1 $ su -  
2
  
3 $ gem install charlock_holmes --version'0.6.9.4'
  
4
  
5 $ exit
  

  安装mysql包
  

1 $ cd /home/git/gitlab/  
2
  
3 $ bundle install --deployment --withoutdevelopment test postgres puma aws
  

  1.如果执行失败:处理方法:
  参考网址:http://www.myexception.cn/open-source/1739499.html
  2.如果TM的还失败,提示mysql2-0.3.11下载&安装失败,解决方案如下:
  gem install mysql2 -v '0.3.11'
参考网址:https://ruby-china.org/topics/23280

e、初始化数据和激活高级功能

  

1 $ cd /home/git/gitlab  

2  
3 $ bundle exec rake gitlab:setupRAILS_ENV=production
  

  这步完成后,会生一个默认的管理员账号:
  

admin@local.host  

  
5iveL
!fe  

  f、安装启动脚本
  

1 $ su -  
2
  
3 $ wget -O /etc/init.d/gitlabhttps://raw.github.com/gitlabhq/gitlab-recipes/master/init/sysvinit/centos/gitlab-unicorn
  
4
  
5 $ chmod +x /etc/init.d/gitlab
  
6
  
7 $ chkconfig --add gitlab
  

  开机时启动
  

1 $ chkconfig gitlab on  

  g、检测应用程序状态
  

1 $ su - git  

2  
3 $ cd gitlab/
  
4
  
5 $ bundle exec rake gitlab:env:infoRAILS_ENV=production
  
6
  
7 $ exit
  


可以查看到系统、Ruby、GitLab和GitLabShell的版本和其他信息。

启动GitLab实例

  

1 $ service gitlab start  


如果启动失败,解决方案如下:

参考网址:http://www.01happy.com/centos-6-5-install-gitlab/(底下评论)

h、查看应用更加详细的信息

  

1 $ su - git  

2  
3 $ cd gitlab/
  
4
  
5 $ bundle exec rake gitlab:checkRAILS_ENV=production
  

  这里会提示一个Init script up-to-date的错误,如下:
  

1 Init script up-to-date? ... no  

2  
3 Try fixing it:
  
4
  
5 Redownload the init script
  
6
  
7 For more information see:
  
8
  
9 doc/install/installation.md in section "Install InitScript"
  
10
  
11 Please fix the error above and rerun the checks.
  


原文说明不用介意这个问题。

7、安装web服务器

笔者选择的是nginx,关于apache方面的请参考原文档

  

1 $ su -  
2
  
3 $ yum -y install nginx
  
4
  
5 $ chkconfig nginx on
  
6
  
7 $ mkdir /etc/nginx/sites-available
  
8
  
9 $ mkdir /etc/nginx/sites-enabled
  
10
  
11 $ wget -O /etc/nginx/sites-available/gitlab https://gitlab.com/gitlab-org/gitlab-ce/blob/master/lib/support/nginx/gitlab-ssl
  


在/etc/nginx/conf.d/建立gitlab.conf文件,文件内容为:见文件夹gitlab.conf文件(附件也有)

将nginx加入git用户组

  

1 $ usermod -a -G git nginx  

2  
3 $ chmod g+rx /home/git/
  

  添加ssl证书或者自己生成一个
  

1 $ cd /etc/nginx  

2  
3 $ openssl req -new -x509 -nodes -days 3560-out gitlab.crt -keyout gitlab.key
  

  启动nginx
  

1 $ service nginx start  


8、配置防火墙

配置iptables,使用户可以访问http、https和ssh的端口。

  

1 $ lokkit -s http -s https -s ssh  

  重新启动防火墙
  

1 $ service iptables restart  

  至此就算安装完成了。默认的账号密码:
  

admin@local.host  

  
5iveL
!fe  


问题记录

a、网站不能添加用户和创建项目问题?

查了下日志,发现是权限的问题:

Errno::EACCES (Permission denied – /home/git/gitlab/log/application.log):

修改用户和所属用户组为git就可以了。

b、无法push?

在 上面安装GitLab shell步骤时,一开始笔者是将配置中的gitlab_url设置成http://test.gitlab.com/,结果在push的时候出错了,后 来查看GitLab项目日志,才发现GitLab shell和GitLab通信的时候产生了一个301跳转。这点通过GitLab的nginx配置也能看的出来。后来将http替换成 https,self_signed_cert设置成true就OK了。

总结

安 装的过程比较长,其中大部分时间花在了包的下载上。笔者以前没有接触过ruby,安装的过程中也了解了下Ruby、Gem、Bundle等软件, 受益匪浅。一般来讲,照着上面的步骤安装,如果系统,软件等版本都一致的话,应该能成功安装。如果出现问题,可以多查查日志。GitLab项目的日志在该 项目的log目录内。GitLab shell的日志在GitLab shell项目中的gitlab-shell.log

附件:gitlab.conf文件内容:

  

  1 ## GitLab  

2  
  3 ## Contributors: randx, yin8086, sashkab, orkoden, axilleas
  
  4
  
  5 ##
  
  6
  
  7 ## Modified from nginx http version
  
  8
  
  9 ## Modified fromhttp://blog.phusion.nl/2012/04/21/tutorial-setting-up-gitlab-on-debian-6/
  
10
  
11 ## Modified fromhttps://raymii.org/s/tutorials/Strong_SSL_Security_On_nginx.html
  
12
  
13 ##
  
14
  
15 ## Lines starting with two hashes (##) are comments with information.
  
16
  
17 ## Lines starting with one hash (#) are configuration parameters that canbe uncommented.
  
18
  
19 ##
  
20
  
21 ##################################
  
22
  
23 ## CHUNKED TRANSFER ##
  
24
  
25 ##################################
  
26
  
27 ##
  
28
  
29 ## It is a known issue that Git-over-HTTP requires chunked transferencoding [0]
  
30
  
31 ## which is not supported by Nginx < 1.3.9 [1]. As a result, pushing alarge object
  
32
  
33 ## with Git (i.e. a single large file) can lead to a 411 error. In theoryyou can get
  
34
  
35 ## around this by tweaking this configuration file and either:
  
36
  
37 ## - installing an old version of Nginx with the chunkin module [2]compiled in, or
  
38
  
39 ## - using a newer version of Nginx.
  
40
  
41 ##
  
42
  
43 ## At the time of writing we do not know if either of these theoreticalsolutions works.
  
44
  
45 ## As a workaround users can use Git over SSH to push large files.
  
46
  
47 ##
  
48
  
49 ## [0]https://git.kernel.org/cgit/git/git.git/tree/Documentation/technical/http-protocol.txt#n99
  
50
  
51 ## [1] https://github.com/agentzh/chunkin-nginx-module#status
  
52
  
53 ## [2] https://github.com/agentzh/chunkin-nginx-module
  
54
  
55 ##
  
56
  
57 ##
  
58
  
59 ###################################
  
60
  
61 ## SSL configuration ##
  
62
  
63 ###################################
  
64
  
65 ##
  
66
  
67 ## See installation.md#using-https for additional HTTPS configurationdetails.
  
68
  
69 upstream gitlab {
  
70
  
71 serverunix:/home/git/gitlab/tmp/sockets/gitlab.socket fail_timeout=0;
  
72
  
73 }
  
74
  
75 ## Normal HTTP host
  
76
  
77 server {
  
78
  
79 listen 80;
  
80
  
81 server_name 172.16.9.120; ##Replace this with something like gitlab.example.com
  
82
  
83 server_tokens off; ## Don't showthe nginx version number, a security best practice
  
84
  
85 ## Redirects all traffic to theHTTPS host
  
86
  
87 root /nowhere; ## root doesn't have to be avalid path since we are redirecting
  
88
  
89 location / {
  
90
  
91 proxy_passhttp://172.16.9.120:8888;
  
92
  
93 }
  
94
  
95 }
  
96
  
97 ## HTTPS host
  
98
  
99 server {
  
100
  
101 listen 443 ssl;
  
102
  
103 server_name 172.16.9.120; ##Replace this with something like gitlab.example.com
  
104
  
105 server_tokens off;
  
106
  
107 root /home/git/gitlab/public;
  
108
  
109 ## Increase this if you want toupload large attachments
  
110
  
111 ## Or if you want to accept largegit objects over http
  
112
  
113 client_max_body_size 20m;
  
114
  
115 ## Strong SSL Security
  
116
  
117 ##https://raymii.org/s/tutorials/Strong_SSL_Security_On_nginx.html &https://cipherli.st/
  
118
  
119 ssl on;
  
120
  
121 ssl_certificate/etc/nginx/gitlab.crt;
  
122
  
123 ssl_certificate_key/etc/nginx/gitlab.key;
  
124

  
125 # GitLab needs backwardscompatible ciphers to retain compatibility with Java>  
126
  
127 ssl_ciphers"ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:DHE-RSA-AES256-SHA256:DHE-RSA-AES128-SHA256:DHE-RSA-AES256-SHA:DHE-RSA-AES128-SHA:ECDHE-RSA-DES-CBC3-SHA:EDH-RSA-DES-CBC3-SHA:AES256-GCM-SHA384:AES128-GCM-SHA256:AES256-SHA256:AES128-SHA256:AES256-SHA:AES128-SHA:DES-CBC3-SHA:HIGH:!aNULL:!eNULL:!EXPORT:!DES:!MD5:!PSK:!RC4";
  
128
  
129 ssl_protocols TLSv1 TLSv1.1TLSv1.2;
  
130
  
131 ssl_prefer_server_ciphers on;
  
132
  
133 ssl_session_cache shared:SSL:10m;
  
134
  
135 ## [WARNING] The following headerstates that the browser should only communicate
  
136
  
137 ## with your server over a secureconnection for the next 24 months.
  
138
  
139 add_headerStrict-Transport-Security max-age=63072000;
  
140
  
141 add_header X-Frame-OptionsSAMEORIGIN;
  
142
  
143 add_header X-Content-Type-Optionsnosniff;
  
144
  
145 ## [Optional] If your certficatehas OCSP, enable OCSP stapling to reduce the overhead and latency of runningSSL.
  
146
  
147 ## Replace with yourssl_trusted_certificate. For more info see:
  
148
  
149 ## -https://medium.com/devops-programming/4445f4862461
  
150
  
151 ## -https://www.ruby-forum.com/topic/4419319
  
152
  
153 ## -https://www.digitalocean.com/community/tutorials/how-to-configure-ocsp-stapling-on-apache-and-nginx
  
154
  
155 # ssl_stapling on;
  
156
  
157 # ssl_stapling_verify on;
  
158
  
159 # ssl_trusted_certificate/etc/nginx/ssl/stapling.trusted.crt;
  
160
  
161 # resolver 208.67.222.222 208.67.222.220valid=300s; # Can change to your DNS resolver if desired
  
162
  
163 # resolver_timeout 5s;
  
164
  
165 ## [Optional] Generate a strongerDHE parameter:
  
166
  
167 ## sudo openssl dhparam -out/etc/ssl/certs/dhparam.pem 4096
  
168
  
169 ##
  
170
  
171 # ssl_dhparam/etc/ssl/certs/dhparam.pem;
  
172
  
173 ## Individual nginx logs for thisGitLab vhost
  
174
  
175 access_log /var/log/nginx/gitlab_access.log;
  
176
  
177 error_log /var/log/nginx/gitlab_error.log;
  
178
  
179 location / {
  
180
  
181 ## Serve static files fromdefined root folder.
  
182
  
183 ## @gitlab is a named locationfor the upstream fallback, see below.
  
184
  
185 try_files $uri $uri/index.html$uri.html @gitlab;
  
186
  
187 }
  
188
  
189 ## If a file, which is not foundin the root folder is requested,
  
190
  
191 ## then the proxy passes therequest to the upsteam (gitlab unicorn).
  
192
  
193 location @gitlab {
  
194
  
195 ## If you use HTTPS make sureyou disable gzip compression
  
196
  
197 ## to be safe against BREACHattack.
  
198
  
199 gzip off;
  
200
  
201 ##https://github.com/gitlabhq/gitlabhq/issues/694
  
202
  
203 ## Some requests take more than30 seconds.
  
204
  
205 proxy_read_timeout 300;
  
206
  
207 proxy_connect_timeout 300;
  
208
  
209 proxy_redirect off;
  
210
  
211 proxy_set_header Host $http_host;
  
212
  
213 proxy_set_header X-Real-IP $remote_addr;
  
214
  
215 proxy_set_header X-Forwarded-Ssl on;
  
216
  
217 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  
218
  
219 proxy_set_header X-Forwarded-Proto $scheme;
  
220
  
221 proxy_set_header X-Frame-Options SAMEORIGIN;
  
222
  
223 proxy_passhttp://172.16.9.120:8888;
  
224
  
225 }
  
226
  
227 ## Enable gzip compression as perrails guide:
  
228
  
229 ## http://guides.rubyonrails.org/asset_pipeline.html#gzip-compression
  
230
  
231 ## WARNING: If you are usingrelative urls remove the block below
  
232
  
233 ## See config/application.rb under"Relative url support" for the list of
  
234

  
235 ## other files that need to bechanged for>  
236
  
237 location ~ ^/(assets)/ {
  
238
  
239 root /home/git/gitlab/public;
  
240
  
241 gzip_static on; # to servepre-gzipped version
  
242
  
243 expires max;
  
244
  
245 add_header Cache-Control public;
  
246
  
247 }
  
248
  
249 error_page 502 /502.html;
  
250
  
251 }
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-433584-1-1.html 上篇帖子: gitlab备份与恢复操作方法 下篇帖子: window下 配置gitlab ssh非端口22端口
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表