校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Linux系統(tǒng)上Gitlab客戶端安裝配置全攻略

Linux系統(tǒng)上Gitlab客戶端安裝配置全攻略

熱門標(biāo)簽:高德地圖標(biāo)注在電腦上 柯城手機地圖如何做地圖標(biāo)注 襄陽地圖標(biāo)注店 金華呼叫中心外呼系統(tǒng)廠家 軟件電話機器人 杭州電銷機器人有效果嗎 小語股票電銷機器人 萊蕪移動外呼系統(tǒng) 申請400電話流程好嗎

1. 安裝依賴包
請記住,Debian 默認(rèn)并沒有安裝 sudo,請使用 root 安裝它:

復(fù)制代碼
代碼如下:

apt-get update apt-get upgrade apt-get install sudo

現(xiàn)在你可以安裝必須包:

復(fù)制代碼
代碼如下:

sudo apt-get update
sudo apt-get upgrade
sudo apt-get install -y wget curl gcc checkinstall libxml2-dev libxslt-dev libcurl4-openssl-dev libreadline6-dev libc6-dev libssl-dev libmysql++-dev make build-essential zlib1g-dev libicu-dev redis-server openssh-server git-core python-dev python-pip libyaml-dev postfix libpq-dev

數(shù)據(jù)庫
SQLite

復(fù)制代碼
代碼如下:

sudo apt-get install -y sqlite3 libsqlite3-dev

MySQL

復(fù)制代碼
代碼如下:

sudo apt-get install -y mysql-server mysql-client libmysqlclient-dev
# Login to MySQL
$ mysql -u root -p
# Create the GitLab production database
mysql> CREATE DATABASE IF NOT EXISTS `gitlabhq_production` DEFAULT CHARACTER SET `utf8` COLLATE `utf8_unicode_ci`;
# Create the MySQL User change $password to a real password
mysql> CREATE USER 'gitlab'@'localhost' IDENTIFIED BY '$password';
# Grant proper permissions to the MySQL User
mysql> GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, INDEX, ALTER ON `gitlabhq_production`.* TO 'gitlab'@'localhost';

PostgreSQL

復(fù)制代碼
代碼如下:

sudo apt-get install -y postgresql-9.2 postgresql-server-dev-9.2
# Connect to database server
sudo -u postgres psql -d template1
# Add a user called gitlab. Change $password to a real password
template1=# CREATE USER gitlab WITH PASSWORD '$password';
# Create the GitLab production database
template1=# CREATE DATABASE IF NOT EXISTS gitlabhq_production;
# Grant all privileges on database
template1=# GRANT ALL PRIVILEGES ON DATABASE gitlabhq_production to gitlab;
# Quit from PostgreSQL server
template1=# \q
# Try connect to new database
$ su - gitlab
$ psql -d gitlabhq_production -U gitlab

(譯者注:以上3種數(shù)據(jù)庫根據(jù)需要安裝其一即可)

2. 安裝 Ruby

復(fù)制代碼
代碼如下:

wget http://ftp.ruby-lang.org/pub/ruby/1.9/ruby-1.9.3-p194.tar.gz
tar xfvz ruby-1.9.3-p194.tar.gz
cd ruby-1.9.3-p194
./configure
make
sudo make install


3. 安裝 Gitolite
為 Git 創(chuàng)建用戶:

復(fù)制代碼
代碼如下:

sudo adduser \
--system \
--shell /bin/sh \
--gecos 'git version control' \
--group \
--disabled-password \
--home /home/git \
git

為 GitLab 創(chuàng)建用戶:

復(fù)制代碼
代碼如下:

# ubuntu/debian
sudo adduser --disabled-login --gecos 'gitlab system' gitlab

將 gitlab 用戶添加到 git 用戶組:

復(fù)制代碼
代碼如下:

sudo usermod -a -G git gitlab

將 git 用戶添加到 gitlab 用戶組:

復(fù)制代碼
代碼如下:

sudo usermod -a -G gitlab git

生成密鑰:

復(fù)制代碼
代碼如下:

sudo -H -u gitlab ssh-keygen -q -N '' -t rsa -f /home/gitlab/.ssh/id_rsa

克隆 GitLab 的 Gitolite 分支源代碼:

復(fù)制代碼
代碼如下:

sudo -H -u git git clone -b gl-v304 https://github.com/gitlabhq/gitolite.git /home/git/gitolite

安裝:

復(fù)制代碼
代碼如下:

cd /home/git
sudo -u git -H mkdir bin
sudo -u git sh -c 'echo -e "PATH=\$PATH:/home/git/bin\nexport PATH" >> /home/git/.profile'
sudo -u git sh -c 'gitolite/install -ln /home/git/bin'
sudo cp /home/gitlab/.ssh/id_rsa.pub /home/git/gitlab.pub
sudo chmod 0444 /home/git/gitlab.pub
sudo -u git -H sh -c "PATH=/home/git/bin:$PATH; gitolite setup -pk /home/git/gitlab.pub"

權(quán)限:

復(fù)制代碼
代碼如下:

sudo chmod -R g+rwX /home/git/repositories/
sudo chown -R git:git /home/git/repositories/

檢查:退出并重新登錄以使 git 用戶組生效

復(fù)制代碼
代碼如下:

# 克隆 admin 資源庫以將 localhost 添加到 known_hosts
# 并且確認(rèn) gitlab 用戶有權(quán)訪問 gitolite
sudo -u gitlab -H git clone git@localhost:gitolite-admin.git /tmp/gitolite-admin
# 如果執(zhí)行成功,你可以將其刪除
sudo rm -rf /tmp/gitolite-admin

重要! 如果你不能克隆 gitolite-admin 資源庫,請不要繼續(xù)本次安裝,請根據(jù) Trouble Shooting Guide 并且確認(rèn)你已經(jīng)小心的完成上文的全部步驟。

筆者注:這一步測試能否克隆成功。本人沒有注意這個提示,完成后續(xù)安裝后發(fā)現(xiàn)怎么都不能通過git@localhost:gitolite-admin.git的方式克隆工程,原因就是ssh認(rèn)證失敗,所以請務(wù)必確認(rèn)這一點。順便說下本人ssh認(rèn)證失敗的原因: /etc/ssh/sshd_config配置文件里面PubkeyAuthentication的值為no,意味著不允許公鑰認(rèn)證,改為yes就可以了。如果還是不能克隆,重復(fù)下第3步,并且注意每個命令是否執(zhí)行成功。或者刪除git和gitlab用戶,重新執(zhí)行第3步。


4. 克隆 GitLab 源代碼并安裝先決條件

復(fù)制代碼
代碼如下:

sudo gem install charlock_holmes --version '0.6.8'
sudo pip install pygments
sudo gem install bundler
cd /home/gitlab
# Get gitlab code. Use this for stable setup
sudo -H -u gitlab git clone -b stable https://github.com/gitlabhq/gitlabhq.git gitlab

(2013/1/6,最近發(fā)現(xiàn)最新的版本是4.0.0.rc2,這個版本已經(jīng)沒有支持sqlite,而我選擇sql數(shù)據(jù)庫的時候沒有成功,
克隆之后執(zhí)行、

復(fù)制代碼
代碼如下:

sudo -u gitlab git checkout 2.9.1

可以回到2.9.1的版本,這個版本既支持sqlite,其gitlab管理界面也較美觀。3.1.0以后的版本管理界面都有點難看。)

復(fù)制代碼
代碼如下:

# Skip this for stable setup.(筆者注:執(zhí)行了上個命令就不用執(zhí)行這個命令了)
# Master branch (recent changes, less stable)
sudo -H -u gitlab git clone -b master https://github.com/gitlabhq/gitlabhq.git gitlab
cd gitlab
# Rename config files
sudo -u gitlab cp config/gitlab.yml.example config/gitlab.yml

選擇你希望使用的數(shù)據(jù)庫
         筆者注:建議選擇SQLite

復(fù)制代碼
代碼如下:

# SQLite
sudo -u gitlab cp config/database.yml.sqlite config/database.yml
# Mysql
sudo -u gitlab cp config/database.yml.mysql config/database.yml
# PostgreSQL
sudo -u gitlab cp config/database.yml.postgres config/database.yml
# 修改 config/database.yml 確認(rèn)輸入了正確的用戶名/密碼

安裝數(shù)據(jù)庫 gems

復(fù)制代碼
代碼如下:

# mysql
sudo -u gitlab -H bundle install --without development test sqlite postgres --deployment
# 或者 postgres
sudo -u gitlab -H bundle install --without development test sqlite mysql --deployment
# 或者 sqlite
sudo -u gitlab -H bundle install --without development test mysql postgres --deployment

初始化數(shù)據(jù)庫

復(fù)制代碼
代碼如下:

sudo -u gitlab bundle exec rake gitlab:app:setup RAILS_ENV=production

設(shè)置 GitLab hooks

復(fù)制代碼
代碼如下:

sudo cp ./lib/hooks/post-receive /home/git/.gitolite/hooks/common/post-receive
sudo chown git:git /home/git/.gitolite/hooks/common/post-receive

確認(rèn)應(yīng)用程序狀態(tài):

復(fù)制代碼
代碼如下:

sudo -u gitlab bundle exec rake gitlab:app:status RAILS_ENV=production
# OUTPUT EXAMPLE
Starting diagnostic
config/database.yml............exists
config/gitlab.yml............exists
/home/git/repositories/............exists
/home/git/repositories/ is writable?............YES
remote: Counting objects: 603, done.
remote: Compressing objects: 100% (466/466), done.
remote: Total 603 (delta 174), reused 0 (delta 0)
Receiving objects: 100% (603/603), 53.29 KiB, done.
Resolving deltas: 100% (174/174), done.
Can clone gitolite-admin?............YES
UMASK for .gitolite.rc is 0007? ............YES
/home/git/share/gitolite/hooks/common/post-receive exists? ............YES

筆者注:如果所有結(jié)果都是 YES,恭喜!你可以繼續(xù)進行下一步。

5. 設(shè)置 web server
應(yīng)用可以用下一個命令行動:

復(fù)制代碼
代碼如下:

# 用于測試目的
sudo -u gitlab bundle exec rails s -e production
# 用于守護進程
sudo -u gitlab bundle exec rails s -e production -d

默認(rèn)登錄用戶名及密碼:

筆者注:記住這個用戶名和密碼,在通過瀏覽器登錄gitlab工程主頁的時候有用。

復(fù)制代碼
代碼如下:

admin@local.host
5iveL!fe


6. 運行 Resque 進程(用于處理工作隊列)

復(fù)制代碼
代碼如下:

# 手動啟動
sudo -u gitlab bundle exec rake environment resque:work QUEUE=* RAILS_ENV=production BACKGROUND=yes
# GitLab 啟動腳本
sudo -u gitlab ./resque.sh
# 如果你使用 root 運行此腳本,會導(dǎo)致 /home/gitlab/gitlab/tmp/pids/resque_worker.pid 文件的擁有者為 root
# 將導(dǎo)致 resque 在下一次系統(tǒng)初始化中無法啟動

自定義 Resque 使用的 Redis 連接

如果你希望 Resque 連接到一個非標(biāo)準(zhǔn)端口號或另一臺服務(wù)器上的 Redis,你可以在 config/resque.yml 文件修改連接信息:

復(fù)制代碼
代碼如下:

production: redis.example.com:6379

好了,我們已經(jīng)擁有了一個工作正常的 GitLab 了,但請繼續(xù)下去,有一些事情是必須完成的。

7.Nginx 與 Unicorn
(1). Unicorn

復(fù)制代碼
代碼如下:

cd /home/gitlab/gitlab
sudo -u gitlab cp config/unicorn.rb.example config/unicorn.rb
sudo -u gitlab bundle exec unicorn_rails -c config/unicorn.rb -E production -D

(2). Nginx

復(fù)制代碼
代碼如下:

# 初次安裝 Nginx
sudo apt-get install nginx
# 添加GitLab 到 nginx sites
sudo wget https://raw.github.com/gitlabhq/gitlab-recipes/master/nginx/gitlab -P /etc/nginx/sites-available/
sudo ln -s /etc/nginx/sites-available/gitlab /etc/nginx/sites-enabled/gitlab
# 修改 **YOUR_SERVER_IP** 與 **YOUR_SERVER_FQDN**
# 為起初的 IP 地址與準(zhǔn)備讓 GitLab 服務(wù)的域名
sudo vim /etc/nginx/sites-enabled/gitlab

筆者注:本人最初的時候不知道這個配置文件怎么配置,在瀏覽器里輸入服務(wù)器ip的時候老是出現(xiàn)“welcome to nginx”頁面。
后來的配置是

復(fù)制代碼
代碼如下:

listion 80; #監(jiān)聽所有80端口的客戶端請求
server_name: 192.168.1.120; #這是我ubuntu服務(wù)器的ip地址。因為我們是小組局域網(wǎng)訪問,所以直接配ip地址就可以了。遠程訪問的話可以通過vpn鏈接。
# 重啟 nginx:
sudo /etc/init.d/nginx restart

(3). Init 腳本
在 /etc/init.d/gitlab 創(chuàng)建 init 腳本:

復(fù)制代碼
代碼如下:

sudo wget https://raw.github.com/gitlabhq/gitlab-recipes/master/init.d/gitlab -P /etc/init.d/
sudo chmod +x /etc/init.d/gitlab

設(shè)置 GitLab 自動啟動:

復(fù)制代碼
代碼如下:

sudo update-rc.d gitlab defaults 21

現(xiàn)在你可以用這種方式啟動/重啟/停止 GitLab 服務(wù):

復(fù)制代碼
代碼如下:

sudo /etc/init.d/gitlab restart


標(biāo)簽:玉樹 九江 孝感 昌都 海東 優(yōu)質(zhì)穩(wěn)定 臺州 哈密

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Linux系統(tǒng)上Gitlab客戶端安裝配置全攻略》,本文關(guān)鍵詞  Linux,系統(tǒng),上,Gitlab,客戶端,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Linux系統(tǒng)上Gitlab客戶端安裝配置全攻略》相關(guān)的同類信息!
  • 本頁收集關(guān)于Linux系統(tǒng)上Gitlab客戶端安裝配置全攻略的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    久久国产精品99精品国产| 韩国视频一区二区| 一本到不卡精品视频在线观看| 欧美日韩一级二级三级| jlzzjlzz国产精品久久| 蜜臀va亚洲va欧美va天堂| 国产女人水真多18毛片18精品视频| 日本精品免费观看高清观看| 亚洲一区二区三区四区五区黄| 国产在线视频一区二区| 国产精品久久久久久妇女6080| 国产女人18毛片水真多成人如厕 | 国产中文一区二区三区| 亚洲午夜久久久久久久久电影院 | 一本大道久久a久久综合| 亚洲最色的网站| 国产91丝袜在线播放0| 色就色 综合激情| 中文字幕av一区二区三区免费看| 国产最新精品免费| 99re这里只有精品6| 在线看日本不卡| 亚洲综合一区二区精品导航| 99re热这里只有精品视频| 久久久精品一品道一区| 懂色中文一区二区在线播放| 国产精品乱码妇女bbbb| 欧美一区二区三区四区视频| 欧美三级视频在线播放| 色婷婷亚洲精品| 日本道精品一区二区三区| 亚洲欧美偷拍三级| 欧美中文一区二区三区| 免费成人你懂的| 国产成人啪免费观看软件| 国产一区二区三区| 欧美精品一区二区三区久久久| 久久国产乱子精品免费女| 亚洲欧洲美洲综合色网| 亚洲男女一区二区三区| 日本vs亚洲vs韩国一区三区二区| 国产精品一线二线三线| 亚洲欧美日韩电影| 久久综合色一综合色88| 欧美精品第1页| 欧美唯美清纯偷拍| 91黄视频在线观看| 91视频国产资源| 精品一区二区三区日韩| 亚洲香肠在线观看| 亚洲欧美另类在线| 丝袜美腿亚洲一区| 国内外精品视频| 色综合久久天天综合网| 欧美日韩国产免费| 亚洲主播在线观看| 日本成人在线网站| 日韩精品久久理论片| 成人午夜av影视| 国产精品白丝在线| 日本精品免费观看高清观看| 一区二区成人在线| 日韩一本二本av| 一本色道久久综合亚洲精品按摩| 欧美电影免费观看完整版| 国产精品久久久久一区二区三区| 人人狠狠综合久久亚洲| 日本韩国一区二区三区视频| 久久精品人人做人人综合| 免费观看在线色综合| 欧美日韩精品一二三区| 亚洲三级电影网站| 色偷偷久久人人79超碰人人澡| 久久久精品tv| 91尤物视频在线观看| 亚洲天堂久久久久久久| 色婷婷综合久色| 日日夜夜精品视频免费| 日韩一区二区不卡| 国产在线一区二区| 国产精品成人在线观看| 欧美伊人久久久久久久久影院 | 亚洲成人动漫在线观看| 91福利视频久久久久| 亚洲第一会所有码转帖| 欧美大尺度电影在线| 国产成人高清视频| 一区二区三区四区中文字幕| 7777女厕盗摄久久久| 丁香网亚洲国际| 日韩精品一二三| 亚洲欧洲精品一区二区精品久久久 | 一本一本大道香蕉久在线精品| 天堂av在线一区| 国产亚洲一区字幕| 欧美一区二区在线播放| 在线视频国产一区| 99免费精品在线| 高清久久久久久| 激情六月婷婷综合| 奇米色一区二区三区四区| 国产精品久久毛片a| 欧美一卡2卡3卡4卡| 91福利社在线观看| 欧美综合一区二区三区| aaa亚洲精品一二三区| 九九久久精品视频| 精品无人码麻豆乱码1区2区| 亚洲成av人片一区二区三区| 国产精品国产三级国产普通话蜜臀 | 暴力调教一区二区三区| 国产丶欧美丶日本不卡视频| 精品一区二区综合| 精品亚洲成av人在线观看| 精彩视频一区二区| 国产精品1区2区3区| 国产成人在线看| 91免费看视频| 欧美精品色一区二区三区| 91麻豆精品国产91久久久久久| 色偷偷久久一区二区三区| 欧美性大战xxxxx久久久| 欧美日韩成人综合天天影院 | 成人欧美一区二区三区视频网页 | 欧美艳星brazzers| 欧美一级日韩不卡播放免费| 久久久精品综合| 亚洲午夜久久久| 久久99久久久欧美国产| av一区二区三区在线| www.欧美.com| 日韩欧美不卡在线观看视频| 国产欧美精品一区二区三区四区| 国产精品免费视频观看| 亚洲国产成人91porn| 成人综合在线观看| 91精品国产入口在线| 精品美女在线播放| 日本v片在线高清不卡在线观看| 99久久婷婷国产综合精品电影 | 三级欧美在线一区| 在线亚洲+欧美+日本专区| 国产日韩欧美亚洲| 国产福利一区在线| 国产午夜精品久久久久久免费视 | 久久久久99精品国产片| 天天综合日日夜夜精品| 在线观看免费成人| 一区二区久久久| 91视频在线看| 亚洲一区二区三区激情| 欧美日韩国产高清一区二区| 亚洲精品写真福利| 欧美最猛性xxxxx直播| 一区二区三区蜜桃| 91精品国产综合久久久久久久| 亚洲制服丝袜在线| 777精品伊人久久久久大香线蕉| 日韩精品久久久久久| 精品国产免费久久 | 欧美剧情电影在线观看完整版免费励志电影| 亚洲国产电影在线观看| 91美女视频网站| 丝瓜av网站精品一区二区| 欧美一区二区三区不卡| 国产成人一区二区精品非洲| 亚洲三级在线播放| 久久久综合精品| 337p亚洲精品色噜噜| av午夜一区麻豆| 蜜臀久久久99精品久久久久久| 精品1区2区在线观看| 欧美午夜精品一区二区三区| 激情文学综合丁香| 亚洲国产婷婷综合在线精品| 欧美国产精品v| 欧美成人激情免费网| 色94色欧美sute亚洲13| 成人一区二区在线观看| 精品在线你懂的| 日韩高清在线一区| 首页国产丝袜综合| 亚洲一区免费观看| 一区二区三区在线视频观看58 | 99精品国产热久久91蜜凸| 老司机午夜精品| 久草精品在线观看| 亚洲伦在线观看| 亚洲精品免费在线观看| 亚洲欧洲综合另类在线| 国产精品初高中害羞小美女文| 国产女人18毛片水真多成人如厕 | 久久久噜噜噜久噜久久综合| 日韩免费性生活视频播放| 在线播放/欧美激情| 精品国产乱码久久久久久久 | 日韩美女天天操| 亚洲国产成人一区二区三区| 中文字幕国产一区| 亚洲黄色录像片|