首页数据库gitlab 数据库(怎么连接gitlab的数据库(gitlab搭建))

gitlab 数据库(怎么连接gitlab的数据库(gitlab搭建))

编程之家2023-10-20102次浏览

大家好,今天来为大家解答gitlab 数据库这个问题的一些问题点,包括怎么连接gitlab的数据库(gitlab搭建)也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~

gitlab 数据库(怎么连接gitlab的数据库(gitlab搭建))

怎么连接gitlab的数据库(gitlab搭建)

将GitLab的数据库导入阿里云PostgreSQLRDS

GitLab的数据库用的是PostgreSQL,之前由于阿里云RDS不支持PostgreSQL,只能将GitLab的数据库部署在云服务器上。

6月1日得知阿里云推出了PostgreSQLRDS,于是立马将GitLab的数据库迁移至PostgreSQLRDS。

下面分享一下迁移的主要操作步骤:

1)在GitLab服务器上备份GitLab数据库

操作命令:

gitlab 数据库(怎么连接gitlab的数据库(gitlab搭建))

sudogitlab-rakegitlab:backup:createSKIP=db

注:这个命令原本是只备份数据库,但实际运行时也会备份,可以在完成数据库备份时,ctrlC直接退出。

数据库备份成功后,会在/var/opt/gitlab/backups/db文件夹中看到database.sql文件,导入时只需将这个文件导入到阿里云RDS。

2)在阿里云RDS中创建GitLab的数据库帐户与数据库

在阿里云RDS控制台首页点击“登录数据库”,进入idb.rds.aliyun,选择对应的PostgreSQL实例。

a)创建2个帐户:gitlab,gitlab-psql

gitlab 数据库(怎么连接gitlab的数据库(gitlab搭建))

b)创建gitlabhq_proction数据库,所有者为gitlab。

3)在GitLab服务器上进行导入操作

a)cd/var/opt/gitlab/backups/db

b)psql-h[RDS实例网址]p3433-dgitlabhq_proction-Ugitlab-fdatabase.sql

如何在 CentOS 上安装 Gitlab

首先安装 EPEL和编译依赖库

$ rpm-ivh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm

如果你是非 64位,去上面的网址找到适合你发行版的最新版本的 epel rpm

$ yum-y update

$ yum-y install gcc gcc-c++ make autoconf libyaml-devel gdbm-devel ncurses-devel openssl-devel zlib-devel readline-devel curl-devel expat-devel gettext-devel tk-devel libxml2-devel libffi-devel libxslt-devel libicu-devel sendmail patch libyaml* pcre-devel sqlite-devel vim

安装 Python 2.7+

Gitlab要求 Python 2.5.5+以及 Ruby 1.9+

系统 Python默认是 2.6.x,如果你想把 Python升级到目前比较流行的 2.7.x就参照下面步骤,否则直接跳过。(Gitlab目前不支持 Python 3.0)

$ mkdir/tmp/gitlab&& cd/tmp/gitlab

$ curl--progress http://python.org/ftp/python/2.7.5/Python-2.7.5.tgz| tar xvf

$ cd Python-2.7.5

$./configure--prefix=/usr/local

$ make&& make altinstall

安装好之后,需要做两件事情,替换默认 python的版本至最新版本,

$ sudo ln-s/usr/local/bin/python2.7/usr/local/bin/python

因为系统默认 PATH的寻址路径是/usr/local/bin

最后看下 Python版本是否是刚刚安装的版本:

$ python--version

由于 yum是 python的一个 module,所以这块修改可能会引起无法调用 yum脚本,所以需要修改这个文件/usr/bin/yum的第一行为!#/usr/bin/python2.6

安装 Ruby 2.0

Ruby 1.9和 2.0的特性差别不大,索性升级至最新 2.0版本即可

$ cd/tmp/gitlab

$ curl--progress http://cache.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-p247.tar.gz| tar xz

$ cd ruby-2.0.0-p247

$./configure

$ make

$ make install

ruby 2.0已经内置 gem(v2.0.3),只需要安装 bundler

$ gem install bundler

若在执行 sudo ruby或 sudo gem找不到命令,因为编译的路径配置到了/usr/local/bin,我们只需要做下软链接到 root用户可以找到的$PATH路径:

$ ln-s/usr/local/bin/ruby/usr/bin/ruby

$ ln-s/usr/local/bin/gem/usr/bin/gem

$ ln-s/usr/local/bin/bundle/usr/bin/bundle

安装 Git和 Gitolite

$ yum-y install git-all gitolite

安装 Nginx

$ yum-y install nginx

$ service nginx start

nginx需要从 EPEL中安装,默认系统没有 nginx包。

安装 Mysql和 Redis

Gitlab要求强制安装 redis处理一些数据,另外支持 MySQL和 PostgreSQL,这里主要以 MySQL为例

$ yum-y install mysql mysql-devel mysql-server redis

配置 Mysql和 gitlab需要的用户和数据库

$ service mysqld start

$ mysql-u root

$ mysql> CREATE USER'gitlab'@'localhost' IDENTIFIED BY'gitlab';

$ mysql> CREATE DATABASE IF NOT EXISTS `gitlabhq_production` DEFAULT CHARACTER SET `utf8` COLLATE `utf8_unicode_ci`;

$ mysql> GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, INDEX, ALTER ON `gitlabhq_production`.* TO'gitlab'@'localhost';

$ mysql>\q

Redis使用默认配置即可,直接启动

$ service redis start

添加 Gitlab用户

$ useradd-c'GitLab' git

CentOS的命令没有办法直接禁止用户的访问的参数,需要用下面命令:

$ passwd-l git

安装 Gitlab-shell

使用 root账户切换到 git账户下操作,可以比官方教程省去一些麻烦的输入

$ su git&& cd/home/git

$ git clone https://github.com/gitlabhq/gitlab-shell.git

$ cd gitlab-shell

通过 git tag查看最新版本并切换之

$ git checkout v1.7.1

编辑配置文件修改你要设定的域名(domain),比如 http://gitlab.dev/

$ vim config.yml

完成之后执行安装脚本

$./bin/install

安装 Gitlab

$ cd/home/git

$ git clone https://github.com/gitlabhq/gitlabhq.git gitlab

$ cd/home/git/gitlab

通过 git tag查看最新版本并切换之

$ git checkout 6.0.1

这里需要配置的东西多一些,这里参考官方的文档,也可以安装我下面的步骤来:

$ cd/home/git/gitlab

复制配置文件,修改 host相关的配置项,主要是 domain要和上面的 http://gitlab.dev

$ cp config.yml{.example,}

$ vim config/gitlab.yml

确认 gitlab以下目录的权限是否正确

$ mkdir tmp/pids/

$ mkdir tmp/sockets/

$ chown-R git log/

$ chown-R git tmp/

$ chmod-R u+rwX log/

$ chmod-R u+rwX tmp/

$ chmod-R u+rwX tmp/pids/

$ chmod-R u+rwX tmp/sockets/

创建 satellites目录,这个目录是保存各个用户的仓库

$ mkdir/home/git/gitlab-satellites

创建 uploads目录(为什么 gitlab不在项目中创建呢==!)

$ mkdir public/uploads

$ chmod-R u+rwX public/uploads

复制 unicorn配置文件

$ cp config/unicorn.rb{.example,}

设置 ruby web容器的参数,比如 2GB RAM服务器可以设置 3个 worker。

如果系统其他服务占用了 unicorn的端口,记得改名。

$ vim config/unicorn.rb

设置一些 git全局参数

$ git config--global user.name"GitLab"

$ git config--global user.email"gitlab@localhost"

$ git config--global core.autocrlf input

配置 gitlab数据库设置

$ cp config/database.yml{.mysql,}

$ vim config/database.yml

$ chmod o-rwx config/database.yml

安装必需的 Ruby Gems

$ cd/home/git/gitlab

$ [sudo] gem install charlock_holmes--version'0.6.9.4'

$ bundle install--deployment--without development test postgres aws

初始化数据库数据(执行输入 Yes继续创建)

$ bundle exec rake gitlab:setup RAILS_ENV=production

设置 init脚本

$ sudo cp lib/support/init.d/gitlab/etc/init.d/gitlab

$ sudo chmod+x/etc/init.d/gitlab

检查 Gitlab状态

$ bundle exec rake gitlab:env:info RAILS_ENV=production

启动 gitlab服务

$ sudo service gitlab start

再起检查,保证所有项目都是绿色

$ bundle exec rake gitlab:check RAILS_ENV=production

配置 nginx

根据 nginx的安装路径适当修改下面的路径即可,我们先把 gitlab提供的配置文件拷贝过去

$ sudo mkdir-p/etc/nginx/conf/sites/

$ sudo cp lib/support/nginx/gitlab/etc/nginx/conf/sites/gitlab.conf

根据 nginx版本和不同发行版的不同,配置结构可能不同根据你的实际情况加载 gitlab.conf

修改 gitlab.conf的 YOUR_SERVER_FQDN为上面设置的 domain。

最后修改 nginx.conf或者 default.conf加载/etc/nginx/conf/site下所有 conf文件

http{

include/etc/nginx/conf/site/*.conf;

server{

}

}

保存后,重启各个服务

$ sudo service nginx reload

$ sudo service gitlab restart

开始 Gitlab之旅

配置好 hosts即可访问 gitlab.dev

$ echo"127.0.0.1 gitlab.dev">>/etc/hosts

默认的用户名密码:

admin@local.host

5iveL!fe

各种坑

1.错误日志报权限错误

2013/11/07 00:42:21 [crit] 15875#0:*2 stat()"/home/git/gitlab/public/favicon.ico.html" failed(13: Permission denied), client: 33.33.33.1, server: gitlab.web.lo, request:"GET/favicon.ico HTTP/1.1", host:"gitlab.web.lo"

2013/11/07 00:42:21 [crit] 15875#0:*2 connect() to unix:/home/git/gitlab/tmp/sockets/gitlab.socket failed(13: Permission denied) while connecting to upstream, client: 33.33.33.1, server: gitlab.web.lo, request:"GET/favicon.ico HTTP/1.1", upstream:"http://unix:/home/git/gitlab/tmp/sockets/gitlab.socket:/favicon.ico", host:"gitlab.web.lo"

2013/11/07 00:42:31 [crit] 15875#0:*2 stat()"/home/git/gitlab/public/" failed(13: Permission denied), client: 33.33.33.1, server: gitlab.web.lo, request:"GET/ HTTP/1.1", host:"gitlab.web.lo"

2013/11/07 00:42:31 [crit] 15875#0:*2 stat()"/home/git/gitlab/public//index.html" failed(13: Permission denied), client: 33.33.33.1, server: gitlab.web.lo, request:"GET/ HTTP/1.1", host:"gitlab.web.lo"

2013/11/07 00:42:31 [crit] 15875#0:*2 stat()"/home/git/gitlab/public/.html" failed(13: Permission denied), client: 33.33.33.1, server: gitlab.web.lo, request:"GET/ HTTP/1.1", host:"gitlab.web.lo"

2013/11/07 00:42:31 [crit] 15875#0:*2 connect() to unix:/home/git/gitlab/tmp/sockets/gitlab.socket failed(13: Permission denied) while connecting to upstream, client: 33.33.33.1, server: gitlab.web.lo, request:"GET/ HTTP/1.1", upstream:"http://unix:/home/git/gitlab/tmp/sockets/gitlab.socket:/", host:"gitlab.web.lo"

2013/11/07 00:42:31 [crit] 15875#0:*2 stat()"/home/git/gitlab/public/favicon.ico" failed(13: Permission denied), client: 33.33.33.1, server: gitlab.web.lo, request:"GET/favicon.ico HTTP/1.1", host:"gitlab.web.lo"

2013/11/07 00:42:31 [crit] 15875#0:*2 stat()"/home/git/gitlab/public/favicon.ico/index.html" failed(13: Permission denied), client: 33.33.33.1, server: gitlab.web.lo, request:"GET/favicon.ico HTTP/1.1", host:"gitlab.web.lo"

2013/11/07 00:42:31 [crit] 15875#0:*2 stat()"/home/git/gitlab/public/favicon.ico.html" failed(13: Permission denied), client: 33.33.33.1, server: gitlab.web.lo, request:"GET/favicon.ico HTTP/1.1", host:"gitlab.web.lo"

2013/11/07 00:42:31 [crit] 15875#0:*2 connect() to unix:/home/git/gitlab/tmp/sockets/gitlab.socket failed(13: Permission denied) while connecting to upstream, client: 33.33.33.1, server: gitlab.web.lo, request:"GET/favicon.ico HTTP/1.1", upstream:"http://unix:/home/git/gitlab/tmp/sockets/gitlab.socket:/favicon.ico", host:"gitlab.web.lo"

解决方案:

$(sudo) chmod o+x/home/git

2. 8080端口被占用

这样主要是因为 nginx的配置是做 unicorn的代理转发,实际上 gitlab是由 unicorn容器驱动,而在配置里默认绑定的是 8080端口

$ vim/home/git/gitlab/config/unicorn.rb

找到 listen"127.0.0.1:8080",:tcp_nopush=> true修改成其他未占用的端口号即可。

如何访问GitLab默认安装的PostgreSQL数据库

将GitLab的数据库导入阿里云PostgreSQL RDS

GitLab的数据库用的是PostgreSQL,之前由于阿里云RDS不支持PostgreSQL,只能将GitLab的数据库部署在云服务器上。

6月1日得知阿里云推出了PostgreSQL RDS,于是立马将GitLab的数据库迁移至PostgreSQL RDS。

下面分享一下迁移的主要操作步骤:

1)在GitLab服务器上备份GitLab数据库

操作命令:

sudo gitlab-rake gitlab:backup:create SKIP=db

注:这个命令原本是只备份数据库,但实际运行时也会备份repositories,可以在完成数据库备份时,ctrl+C直接退出。

数据库备份成功后,会在/var/opt/gitlab/backups/db文件夹中看到 database.sql文件,导入时只需将这个文件导入到阿里云RDS。

2)在阿里云RDS中创建GitLab的数据库帐户与数据库

在阿里云RDS控制台首页点击逗登录数据库地,进入idb.rds.aliyun.com,选择对应的PostgreSQL实例。

a)创建2个帐户:gitlab, gitlab-psql

b)创建gitlabhq_production数据库,所有者为gitlab。

3)在GitLab服务器上进行导入操作

a) cd/var/opt/gitlab/backups/db

b) psql-h [RDS实例网址] p 3433-d gitlabhq_production-U gitlab-f database.sql

如何将GitLab的数据库从PostgreSQL迁移至MySQL

如何将GitLab的数据库从PostgreSQL迁移至MySQL

转数据库偷懒的做法就是:用一台装有sql server的机器,运行DTS程序(导入导出数据),然后源选择postgresql,目标选择mysql,直接导。。。记得装ms的两个数据库驱动程序很多情况下,简单的数据库一下就能导过去,但是出于需要,还是建议人工建表,核对字段比较稳妥

OK,本文到此结束,希望对大家有所帮助。

文件数据库有哪些(数据库文件有哪些类型)手机web服务器(手机web服务器在哪打开)