Centos 安裝GitLab(從零開始配置)

pic

前言

上周末公司說要搭建一個Gitlabe用來管理代碼,于是自己就開始琢磨了,其中配置郵件這里踩了一個坑,被坑了兩天時間,現(xiàn)把搭建過程記錄下來。

注意事項:

1.注意你的服務(wù)器需要2G以上內(nèi)存(博主用的虛擬機(jī),當(dāng)時設(shè)置1G的內(nèi)存然后就訪問的時候報個502...)
2.Centos的版本是6.5的,用7.0的小伙伴可能部分有些不一樣。

第一種方法

先下載Gitlabe-----Gitlab地址

博主使用的是虛擬機(jī)安裝所以有遠(yuǎn)程桌面,這一步可以跳過。

如果鏈接遠(yuǎn)程桌面時,提示"遠(yuǎn)程桌面連接無法驗證您希望連接的計算機(jī)的身份"
解決方法:
1. 通過連接管理終端功能連接進(jìn)入云服務(wù)器。
2. 點擊任務(wù)欄powershell,然后輸入命令gpedit.msc,輸入完成后回車,回車后會顯示本地組策略編輯器。
3. 依次找到【計算機(jī)配置】->【管理模板】->【windows組件】->【遠(yuǎn)程桌面服務(wù)】->【遠(yuǎn)程桌面會話主機(jī)】->【安全】->【遠(yuǎn)程(RDP)連接要求使用指定的安全層】
4. 雙擊【遠(yuǎn)程(RDP)連接要求使用指定的安全層
5. 修改為已啟用,安全層選擇 rdp,最后點擊應(yīng)用確認(rèn)
將系統(tǒng)防火墻打開HTTP和SSH訪問
sudo yum install openssh-server
sudo yum install postfix (看情況來,如果你想用163,qq之類的發(fā)郵件可以不用執(zhí)行這句)
sudo lokkit -s http -s ssh 
scp 待上傳文件名 linux用戶名@服務(wù)器IP:存放到服務(wù)器的哪個位置

比如:scp /Users/xxx/Downloads/gitlab-ce-10.0.0-ce.0.el6.x86_64.rpm root@10.10.10.70:/home/soft/

也可以用Cyberduck 工具來上傳文件

cd 到上傳的Gitlabe的目錄下,執(zhí)行命令
rpm -i gitlab-ce-10.0.0-ce.0.el6.x86_64.rpm

配置gitlab

sudo gitlab-ctl reconfigure

第二種方法

將系統(tǒng)防火墻打開HTTP和SSH訪問

sudo yum install openssh-server
sudo yum install postfix (看情況來,如果你想用163,qq之類的發(fā)郵件可以不用執(zhí)行這句)
sudo lokkit -s http -s ssh 
curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.rpm.sh | sudo bash

sudo yum install -y gitlab-ee

配置Gitlab

GitLab默認(rèn)會占用80、8080和9090端口,如果你想安裝Jenkins,會通到端口沖突,Jenkins默認(rèn)也會使用8080端口,所以,這一步操作將會修改GitLab的默認(rèn)端口為11000、11001和11002。

sudo vi /etc/gitlab/gitlab.rb

將:
external_url 'http://127.0.0.1'
修改為:
external_url 'http://<你的服務(wù)器地址或域名>:11000'

將:
unicorn['port'] = 8080
修改為:
unicorn['port'] = 11001

將:
prometheus['listen_address'] = 'localhost:9090'
修改為:
prometheus['listen_address'] = 'localhost:11002'

每次修改完時,記得要使用reconfigure命令重新配置

sudo gitlab-ctl reconfigure

PS:這里比較重要,如果你的Gitlab是搭建在Centos系統(tǒng)上的,需要開放上面的端口(因為Centos默認(rèn)開放的端口只有22)

# 開放端口11000(記得還有11001和11002也要設(shè)置)
/sbin/iptables -I INPUT -p tcp --dport 11000 -j ACCEPT
# 將修改永久保存到防火墻中(不設(shè)置的話,下次重啟上面的設(shè)置就會失效)
/etc/rc.d/init.d/iptables save
# 查看安裝后的程序運行情況
sudo gitlab-ctl status

# 重啟Gitlab服務(wù)
sudo gitlab-ctl restart

# 啟動和關(guān)閉Gitlab
sudo gitlab-ctl start/stop

郵箱設(shè)置(下面這里需要注意的地方,就是要把#號去掉,默認(rèn)有#這是被注釋的)

PS :這里要說一個坑,就是在安裝postfix后,你再去設(shè)置其他的郵箱是沒有效果的,博主也沒有試過兩者并存。所以你可以執(zhí)行yum list | grep postfix查看是否安裝了postfix,如果安裝了,你可以執(zhí)行yum remove postfix進(jìn)行刪除

如果你在上面的設(shè)置中,選擇了postfix發(fā)郵件,那么設(shè)置方法如下:

執(zhí)行vi /etc/gitlab/gitlab.rb進(jìn)入到配置文件,修改下面的參數(shù)

external_url 'http://<你的服務(wù)器地址或域名>:11000'

# gitlab_rails['gitlab_ssh_host'] = 'ssh.host_example.com'
# gitlab_rails['time_zone'] = 'UTC'

### Email Settings
 gitlab_rails['gitlab_email_enabled'] = true
 gitlab_rails['gitlab_email_from'] = 'gitlab@http://<你的服務(wù)器地址或域名>'
 gitlab_rails['gitlab_email_display_name'] = 'GitLab'
# gitlab_rails['gitlab_email_reply_to'] = 'noreply@example.com'

設(shè)置完成后,重配postfix,執(zhí)行sudo dpkg-reconfigure postfix 或者
sudo vi /etc/postfix/main.cf

執(zhí)行gitlab-ctl tail實時查看所有執(zhí)行日志,當(dāng)然你也可以進(jìn)入/var/log/maillog,查看log,想了解更多的postfix設(shè)置的點這里

163郵箱設(shè)置

### Email Settings
 gitlab_rails['gitlab_email_enabled'] = true
 
### GitLab email server settings
###! Docs: https://docs.gitlab.com/omnibus/settings/smtp.html
###! **Use smtp instead of sendmail/postfix.**

 gitlab_rails['smtp_enable'] = true
 gitlab_rails['smtp_address'] = "smtp.163.com"
 gitlab_rails['smtp_port'] = 25
 gitlab_rails['smtp_user_name'] = "xxxx@163.com"
 gitlab_rails['smtp_password'] = "這里填授權(quán)密碼"
 gitlab_rails['smtp_domain'] = "163.com"
 gitlab_rails['smtp_authentication'] = "login"
 gitlab_rails['smtp_enable_starttls_auto'] = true
 gitlab_rails['smtp_tls'] = true

###! **Can be: 'none', 'peer', 'client_once', 'fail_if_no_peer_cert'**
###! Docs: http://api.rubyonrails.org/classes/ActionMailer/Base.html
 gitlab_rails['smtp_openssl_verify_mode'] = 'peer'
 user['git_user_email'] = "xxxx@163.com"
 gitlab_rails['gitlab_email_from'] = "xxxx@163.com"

QQ企業(yè)郵箱設(shè)置

 gitlab_rails['smtp_enable'] = true
 gitlab_rails['smtp_address'] = "smtp.exmail.qq.com"
 gitlab_rails['smtp_port'] = 465
 gitlab_rails['smtp_user_name'] = "xxx@域名.com"
 gitlab_rails['smtp_password'] = "密碼"
 gitlab_rails['smtp_domain'] = "域名.com"
 gitlab_rails['smtp_authentication'] = "login"
 gitlab_rails['smtp_enable_starttls_auto'] = true
 gitlab_rails['smtp_tls'] = true

###! **Can be: 'none', 'peer', 'client_once', 'fail_if_no_peer_cert'**
###! Docs: http://api.rubyonrails.org/classes/ActionMailer/Base.html
 gitlab_rails['smtp_openssl_verify_mode'] = 'none'
 user['git_user_email'] = "xxx@域名.com"
 gitlab_rails['gitlab_email_from'] = "xxx@域名.com"

上面兩個郵箱的設(shè)置,參數(shù)user['git_user_email']gitlab_rails['gitlab_email_from']是手動添加上去的。在gitlab.rb里也是有這兩個參數(shù)的,只不過是被注釋了。

測試郵箱

// 進(jìn)入控制臺
gitlab-rails console
// 發(fā)送測試郵件
Notify.test_email('收件人郵箱', '郵件標(biāo)題', '郵件正文').deliver_now

更多的郵箱設(shè)置點這里

其他設(shè)置

批量添加用戶,下面是批量添加的腳本,復(fù)制就可用,也可以從這里下載
private_token可以從root用戶Settings-->Account查到。

#!/bin/bash
#批量創(chuàng)建gitlab用戶

url_path="http://<地址>/api/v4/users"
private_token="private_token"

userinfo=''
if [[ $# > 0 ]]
  then
  echo "路徑:$1"
  userinfo=$1
else
  echo "~~~~~~~~~~~~請輸入添加用戶文件的地址~~~~~~~~~~~~~~~"
  read path
  userinfo=$path
fi

while read line
do
    password=`echo $line | awk '{print $1}'`
    mail=`echo $line | awk '{print $2}'`
    username=`echo $line | awk '{print $3}'`
    name=`echo $line | awk '{print $4}'`
    curl -d "password=$password&email=$mail&username=$username&name=$name&private_token=$private_token" "$url_path"

done <$userinfo

使用時,需要一個添加用戶的text文件,格式如下:

12345678 test123@qq.com testname1 測試1
12345678 528634141@qq.com testname2 測試2

腳本使用,如下

sh /Users/xxx/Desktop/GitLabAddUser.sh

生成ssh

ssh-keygen -t rsa -C "your.email@example.com" -b 4096

pbcopy < ~/.ssh/id_rsa.pub

安裝過程中出現(xiàn)的問題:

1.在瀏覽器中訪問GitLab出現(xiàn)502錯誤
原因:1.內(nèi)存不足。2.修改了 gitlab.rb配置文件沒有執(zhí)行重新配置命令。
解決辦法:1.檢查系統(tǒng)的虛擬內(nèi)存是否隨機(jī)啟動了,如果系統(tǒng)無虛擬內(nèi)存,則增加虛擬內(nèi)存,再重新啟動系統(tǒng)。
2.使用sudo gitlab-ctl reconfigure重新配置。

2.80端口沖突
原因:Nginx默認(rèn)使用了80端口。
解決辦法:為了使Nginx與Apache能夠共存,并且為了簡化GitLab的URL地址,Nginx端口保持不變,修改Apache的端口為4040。這樣就可以直接用使用ip訪問Gitlab。而禪道則可以使用4040端口進(jìn)行訪問,像這樣:xxx.xx.xxx.xx:4040/zentao。具體修改的地方在/etc/httpd/conf/httpd.conf這個文件中,找到Listen 80這一句并將之注釋掉,在底下添加一句Listen 4040,保存后執(zhí)行service httpd restart重啟apache服務(wù)即可。

Listen 4040 

3.GitLab頭像無法正常顯示

原因:gravatar被墻

解決辦法:

編輯 /etc/gitlab/gitlab.rb
將
#gitlab_rails['gravatar_plain_url'] = 'http://gravatar.duoshuo.com/avatar/%{hash}?s=%{size}&d=identicon'
修改為:
gitlab_rails['gravatar_plain_url'] = 'http://gravatar.duoshuo.com/avatar/%{hash}?s=%{size}&d=identicon'
然后在命令行執(zhí)行:
sudo gitlab-ctl reconfigure 
sudo gitlab-rake cache:clear RAILS_ENV=production

4.EOFError: end of file reached
解決方法:

將
gitlab_rails['smtp_tls']  = false
修改為:
gitlab_rails['smtp_tls'] = true

其他問題

用戶之前已經(jīng)設(shè)置了其他的郵箱,修改郵箱后,發(fā)現(xiàn)原來的郵箱還是可以用的,你需要在Settings-->Emails里刪除原來的郵箱。

Ps:最后有什么不明白的,可以在下方評論或私信博主。

參考文章:

https://segmentfault.com/a/1190000002722631

https://www.douban.com/note/640641236/

https://my.oschina.net/kylinq/blog/868590

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容