温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么用GitLab搭建自己的私有GitHub库

发布时间:2021-08-20 20:00:49 来源:亿速云 阅读:142 作者:chen 栏目:服务器

本篇内容主要讲解“怎么用GitLab搭建自己的私有GitHub库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用GitLab搭建自己的私有GitHub库”吧!

安装依赖

Debian/Ubuntu下:

复制代码 代码如下:


sudo apt-get install -y build-essential zlib1g-dev libyaml-dev libssl-dev libgdbm-dev libreadline-dev libncurses5-dev libffi-dev curl openssh-server redis-server checkinstall libxml2-dev libxslt-dev libcurl4-openssl-dev libicu-dev logrotate

安装python(注意需要2.5以上版本):

sudo apt-get install -y python python-docutils

安装git(注意需要1.7.10以上版本):

sudo apt-get install -y git-core

Centos下官方仓库的软件比较老旧,推荐先添加epel源,然后再安装依赖:

复制代码 代码如下:


sudo yum install git patch gcc-c++ readline-devel zlib-devel libffi-devel openssl-devel make autoconf automake libtool bison libxml2-devel libxslt-devel libyaml-devel git python python-docutils

安装 Ruby 2.0

需要安装Ruby2.0,软件仓库中的Ruby 1.8不支持:

mkdir /tmp/ruby && cd /tmp/ruby
curl --progress ftp://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-p353.tar.gz | tar xz
cd ruby-2.0.0-p353
./configure --disable-install-rdoc
make
sudo make install

安装Bundler Gem:

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

配置gitlab-shell

创建git用户:

sudo adduser --system --create-home --comment 'GitLab' git

配置gitlab-shell

su - git -c "git clone https://github.com/gitlabhq/gitlab-shell.git" 
su - git -c "cd gitlab-shell && git checkout v1.3.0" 
su - git -c "cp gitlab-shell/config.yml.example gitlab-shell/config.yml" 
sed -i "s/localhost/gitlab.51yip.com/g" /home/git/gitlab-shell/config.yml 
su - git -c "gitlab-shell/bin/install" 
chmod 600 /home/git/.ssh/authorized_keys 
chmod 700 /home/git/.ssh

数据库

GitLab支持 MySQL 和 PostgreSQL 数据库。下面以 MySQL为例,介绍安装方法:

Debian/Ubuntu下使用如下命令安装:

sudo apt-get install -y mysql-server mysql-client libmysqlclient-dev

Centos下使用如下命令:

sudo yum install mysql-server 
sudo chkconfig mysqld on

配置MySQL:

sudo echo "CREATE DATABASE IF NOT EXISTS gitlabhq_production DEFAULT CHARACTER SET 'utf8' COLLATE 'utf8_unicode_ci';" | mysql -u root 
sudo echo "UPDATE mysql.user SET Password=PASSWORD('123456') WHERE User='root'; FLUSH PRIVILEGES;" | mysql -u root

注意,用你的密码替换123456。

安装配置 gitlab

su - git -c "git clone https://github.com/gitlabhq/gitlabhq.git gitlab" 
su - git -c "cd gitlab;git checkout 5-1-stable" 
su git -c "cp config/gitlab.yml.example config/gitlab.yml" 
su git -c "mkdir /home/git/gitlab-satellites" 
su git -c "mkdir public/uploads" 
su git -c "mkdir -p tmp/sockets/" 
su git -c "mkdir -p tmp/pids/" 
sed -i "s/ host: localhost/ host: gitlab.segmentfault.com/g" config/gitlab.yml 
sed -i "s/from: gitlab@localhost/from: gitlab@gitlab.segmentfault.com/g" config/gitlab.yml 
su git -c "cp config/puma.rb.example config/puma.rb" 
su git -c 'git config --global user.name "GitLab"' 
su git -c 'git config --global user.email "gitlab@gitlab.segmentfault.com"'

注意将gitlab.segmentfault.com替换为你自己的内容。

配置数据库连接:

sudo su git -c "cp config/database.yml.mysql config/database.yml"
sudo sed -i "s/secure password/mysql的root密码/g" config/database.yml

安装MySQL需要的Gems

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

初始化:

sudo -u git -H bundle exec rake gitlab:setup RAILS_ENV=production
sudo cp lib/support/init.d/gitlab /etc/init.d/gitlab
sudo chmod +x /etc/init.d/gitlab
sudo update-rc.d gitlab defaults 21

查看是否配置妥当:

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

重启GitLab:

sudo service gitlab start

配置Nginx

Debian/Ubuntu下:

sudo apt-get install -y nginx

CentOS下:

sudo yum install nginx

下载配置文件样例:

sudo cp lib/support/nginx/gitlab /etc/nginx/sites-available/gitlab
sudo ln -s /etc/nginx/sites-available/gitlab /etc/nginx/sites-enabled/gitlab

修改 /etc/nginx/sites-available/gitlab,特别留意将 YOUR_SERVER_FQDN 改成自己的。

重启nginx:

sudo service nginx restart

好了,你可以登录GitLab了,默认安装后的用户名:admin@local.host,密码5iveL!fe。

到此,相信大家对“怎么用GitLab搭建自己的私有GitHub库”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI