首页 > 代码库 > GitLab 的一键安装方式

GitLab 的一键安装方式

一、安装环境的介绍

Centos 6.7  x86_64   2.6.32-573.el6.x86_64   IP:192.168.159.129   #公司内部测试服务器

GitLab版本:9.1.2

软件包下载地址:https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el6/

二、安装过程

#rpm -ivh gitlab-ce-9.1.2-ce.0.el6.x86_64.rpm 
Preparing...                ########################################### [100%]
   1:gitlab-ce              ########################################### [100%]
hostname: Host name lookup failure


       *.                  *.
      ***                 ***
     *****               *****
    .******             *******
    ********            ********
   ,,,,,,,,,***********,,,,,,,,,
  ,,,,,,,,,,,*********,,,,,,,,,,,
  .,,,,,,,,,,,*******,,,,,,,,,,,,
      ,,,,,,,,,*****,,,,,,,,,.
         ,,,,,,,****,,,,,,
            .,,,***,,,,
                ,*,.

     _______ __  __          __
    / ____(_) /_/ /   ____ _/ /_
   / / __/ / __/ /   / __ `/ __   / /_/ / / /_/ /___/ /_/ / /_/ /
  \____/_/\__/_____/\__,_/_.___/


gitlab: Thank you for installing GitLab!
gitlab: To configure and start GitLab, RUN THE FOLLOWING COMMAND:

sudo gitlab-ctl reconfigure

gitlab: GitLab should be reachable at http://gitlab.example.com
gitlab: Otherwise configure GitLab for your system by editing /etc/gitlab/gitlab.rb file
gitlab: And running reconfigure again.
gitlab: 
gitlab: For a comprehensive list of configuration options please see the Omnibus GitLab readme
gitlab: https://gitlab.com/gitlab-org/omnibus-gitlab/blob/master/README.md
gitlab: 
It looks like GitLab has not been configured yet; skipping the upgrade script.
根据上面的提示执行:
#sudo gitlab-ctl reconfigure
Starting Chef Client, version 12.12.15
resolving cookbooks for run list: ["gitlab"]
Synchronizing Cookbooks:
  - gitlab (0.0.1)
  - package (0.0.0)
  - runit (0.14.2)
Installing Cookbook Gems:
Compiling Cookbooks...
Recipe: gitlab::default
  * directory[/etc/gitlab] action create
    - change mode from ‘0755‘ to ‘0775‘
init (upstart 0.6.5)
  Converging 378 resources
  * directory[/etc/gitlab] action create (up to date)
  * directory[Create /var/opt/gitlab] action create
    - create new directory /var/opt/gitlab
    - change mode from ‘‘ to ‘0755‘
    - change owner from ‘‘ to ‘root‘
    - change group from ‘‘ to ‘root‘
  * directory[/opt/gitlab/embedded/etc] action create
    - create new directory /opt/gitlab/embedded/etc
    - change mode from ‘‘ to ‘0755‘
    - change owner from ‘‘ to ‘root‘
    - change group from ‘‘ to ‘root‘
  * template[/opt/gitlab/embedded/etc/gitconfig] action create
    - create new file /opt/gitlab/embedded/etc/gitconfig
    - update content in file /opt/gitlab/embedded/etc/gitconfig from none to 5fe039
    --- /opt/gitlab/embedded/etc/gitconfig      2017-05-25 10:46:30.027207736 +0800
    +++ /opt/gitlab/embedded/etc/.chef-gitconfig20170525-6666-jc6wi6    2017-05-25 10:46:30.026207736 +0800
    @@ -1 +1,10 @@
    +[pack]
    +  threads = 1
    +[receive]
    +  fsckObjects = true
    +[repack]
    +  writeBitmaps = true
    +[transfer]
    +  hideRefs=^refs/tmp/
    +hideRefs=^refs/keep-around/
    - change mode from ‘‘ to ‘0755‘
Recipe: gitlab::web-server
  * group[Webserver user and group] action create
    - create group gitlab-www
  * user[Webserver user and group] action create
    - create user gitlab-www
Recipe: gitlab::users
………………………………                        #会输出很多初始化的信息
    +
    - change owner from ‘‘ to ‘root‘
    - change group from ‘‘ to ‘root‘
  * ruby_block[reload gitlab-monitor svlogd configuration] action nothing (skipped due to action :nothing)
  * file[/opt/gitlab/sv/gitlab-monitor/down] action delete (up to date)
  * link[/opt/gitlab/init/gitlab-monitor] action create
    - create symlink at /opt/gitlab/init/gitlab-monitor to /opt/gitlab/embedded/bin/sv
  * link[/opt/gitlab/service/gitlab-monitor] action create
    - create symlink at /opt/gitlab/service/gitlab-monitor to /opt/gitlab/sv/gitlab-monitor
  * ruby_block[supervise_gitlab-monitor_sleep] action run
    - execute the ruby block supervise_gitlab-monitor_sleep
  * service[gitlab-monitor] action nothing (skipped due to action :nothing)
  * execute[/opt/gitlab/bin/gitlab-ctl start gitlab-monitor] action run
    [execute] ok: run: gitlab-monitor: (pid 7720) 1s
    - execute /opt/gitlab/bin/gitlab-ctl start gitlab-monitor
Recipe: gitlab::default
  * link[/opt/gitlab/service/gitlab-git-http-server] action delete (up to date)
  * directory[/opt/gitlab/sv/gitlab-git-http-server] action delete (up to date)
Recipe: gitlab::gitlab-rails
  * execute[clear the gitlab-rails cache] action run
    - execute /opt/gitlab/bin/gitlab-rake cache:clear
Recipe: gitlab::redis
  * ruby_block[reload redis svlogd configuration] action create
    - execute the ruby block reload redis svlogd configuration
Recipe: gitlab::postgresql
  * ruby_block[reload postgresql svlogd configuration] action create
    - execute the ruby block reload postgresql svlogd configuration
Recipe: gitlab::unicorn
  * ruby_block[reload unicorn svlogd configuration] action create
    - execute the ruby block reload unicorn svlogd configuration
Recipe: gitlab::sidekiq
  * ruby_block[reload sidekiq svlogd configuration] action create
    - execute the ruby block reload sidekiq svlogd configuration
Recipe: gitlab::gitaly
  * service[gitaly] action restart
    - restart service service[gitaly]
  * ruby_block[reload gitaly svlogd configuration] action create
    - execute the ruby block reload gitaly svlogd configuration
Recipe: gitlab::gitlab-workhorse
  * service[gitlab-workhorse] action restart
    - restart service service[gitlab-workhorse]
  * ruby_block[reload gitlab-workhorse svlogd configuration] action create
    - execute the ruby block reload gitlab-workhorse svlogd configuration
Recipe: gitlab::nginx
  * ruby_block[reload nginx svlogd configuration] action create
    - execute the ruby block reload nginx svlogd configuration
Recipe: gitlab::logrotate
  * ruby_block[reload logrotate svlogd configuration] action create
    - execute the ruby block reload logrotate svlogd configuration
Recipe: gitlab::prometheus
  * service[prometheus] action restart
    - restart service service[prometheus]
  * ruby_block[reload prometheus svlogd configuration] action create
    - execute the ruby block reload prometheus svlogd configuration
Recipe: gitlab::node-exporter
  * ruby_block[reload node-exporter svlogd configuration] action create
    - execute the ruby block reload node-exporter svlogd configuration
Recipe: gitlab::redis-exporter
  * ruby_block[reload redis-exporter svlogd configuration] action create
    - execute the ruby block reload redis-exporter svlogd configuration
Recipe: gitlab::postgres-exporter
  * service[postgres-exporter] action restart
    - restart service service[postgres-exporter]
  * ruby_block[reload postgres-exporter svlogd configuration] action create
    - execute the ruby block reload postgres-exporter svlogd configuration
Recipe: gitlab::gitlab-monitor
  * service[gitlab-monitor] action restart
    - restart service service[gitlab-monitor]
  * ruby_block[reload gitlab-monitor svlogd configuration] action create
    - execute the ruby block reload gitlab-monitor svlogd configuration

Running handlers:
Running handlers complete
Chef Client finished, 325/427 resources updated in 03 minutes 29 seconds
gitlab Reconfigured!
可以看到提示执行了3分钟29秒!
查看启动情况
#netstat -tunlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name   
tcp        0      0 127.0.0.1:9121              0.0.0.0:*                   LISTEN      7685/redis_exporter 
tcp        0      0 127.0.0.1:9090              0.0.0.0:*                   LISTEN      7839/prometheus     
tcp        0      0 127.0.0.1:9187              0.0.0.0:*                   LISTEN      7850/postgres_expor 
tcp        0      0 127.0.0.1:9100              0.0.0.0:*                   LISTEN      7638/node_exporter  
tcp        0      0 127.0.0.1:9168              0.0.0.0:*                   LISTEN      7865/ruby           
tcp        0      0 127.0.0.1:8080              0.0.0.0:*                   LISTEN      7519/unicorn master 
tcp        0      0 0.0.0.0:80                  0.0.0.0:*                   LISTEN      7561/nginx          
tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      5506/sshd           
tcp        0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN      5585/master         
tcp        0      0 0.0.0.0:8060                0.0.0.0:*                   LISTEN      7561/nginx          
tcp        0      0 :::3306                     :::*                        LISTEN      6289/mysqld         
tcp        0      0 ::1:9168                    :::*                        LISTEN      7865/ruby           
tcp        0      0 :::22                       :::*                        LISTEN      5506/sshd           
tcp        0      0 ::1:25                      :::*                        LISTEN      5585/master         
关闭
# sudo gitlab-ctl stop
ok: down: gitaly: 0s, normally up
ok: down: gitlab-monitor: 1s, normally up
ok: down: gitlab-workhorse: 0s, normally up
ok: down: logrotate: 0s, normally up
ok: down: nginx: 0s, normally up
ok: down: node-exporter: 0s, normally up
ok: down: postgres-exporter: 1s, normally up
ok: down: postgresql: 1s, normally up
ok: down: prometheus: 0s, normally up
ok: down: redis: 0s, normally up
ok: down: redis-exporter: 0s, normally up
ok: down: sidekiq: 0s, normally up
ok: down: unicorn: 0s, normally up
启动
# sudo gitlab-ctl start
ok: run: gitaly: (pid 8296) 0s
ok: run: gitlab-monitor: (pid 8301) 0s
ok: run: gitlab-workhorse: (pid 8304) 1s
ok: run: logrotate: (pid 8312) 0s
ok: run: nginx: (pid 8318) 1s
ok: run: node-exporter: (pid 8324) 0s
ok: run: postgres-exporter: (pid 8329) 1s
ok: run: postgresql: (pid 8334) 0s
ok: run: prometheus: (pid 8342) 0s
ok: run: redis: (pid 8350) 1s
ok: run: redis-exporter: (pid 8354) 0s
ok: run: sidekiq: (pid 8359) 1s
ok: run: unicorn: (pid 8362) 0s
重启
#sudo gitlab-ctl restart      #其实不加sudo也可以!
查看添加了几个用户,如下:
#tail -5 /etc/passwd
gitlab-www:x:498:499::/var/opt/gitlab/nginx:/bin/false
git:x:497:498::/var/opt/gitlab:/bin/sh
gitlab-redis:x:496:497::/var/opt/gitlab/redis:/bin/false
gitlab-psql:x:495:496::/var/opt/gitlab/postgresql:/bin/sh
gitlab-prometheus:x:494:495::/var/opt/gitlab/prometheus:/bin/sh

三、登录验证

在浏览器输入http://192.168.159.129  就可以看到GitLab的界面了,如下:

技术分享

第一次登录需要设置新密码,并且密码长度不能小于8!设置好之后,会跳转到登录界面,如下:

技术分享

默认用户名是root,然后输入刚才新设置的密码,登录之后,界面如下:

技术分享

到这里一键安装GitLab就完成了,就可以进行创建项目之类的操作了。

四、postgresql相关命令介绍

注:因为使用一键安装GitLab的rpm包,默认数据库是postgresql,所以对于不熟悉的朋友,可以参考!

查看postgresql的数据存放目录
[root@web1 gitlab]# su - gitlab-psql
-sh-4.1$ ll
total 4
drwx------ 19 gitlab-psql root 4096 May 25 10:55 data
-sh-4.1$ ll data/
total 112
drwx------ 6 gitlab-psql root         4096 May 25 10:46 base
drwx------ 2 gitlab-psql root         4096 May 25 10:55 global
drwx------ 2 gitlab-psql root         4096 May 25 10:46 pg_clog
drwx------ 2 gitlab-psql root         4096 May 25 10:46 pg_commit_ts
drwx------ 2 gitlab-psql root         4096 May 25 10:46 pg_dynshmem
-rw-r--r-- 1 gitlab-psql root         3198 May 25 10:46 pg_hba.conf
-rw-r--r-- 1 gitlab-psql root         1789 May 25 10:46 pg_ident.conf
drwx------ 4 gitlab-psql root         4096 May 25 10:46 pg_logical
drwx------ 4 gitlab-psql root         4096 May 25 10:46 pg_multixact
drwx------ 2 gitlab-psql root         4096 May 25 10:55 pg_notify
drwx------ 2 gitlab-psql root         4096 May 25 10:46 pg_replslot
drwx------ 2 gitlab-psql root         4096 May 25 10:46 pg_serial
drwx------ 2 gitlab-psql root         4096 May 25 10:46 pg_snapshots
drwx------ 2 gitlab-psql root         4096 May 25 10:55 pg_stat
drwx------ 2 gitlab-psql root         4096 May 25 11:11 pg_stat_tmp
drwx------ 2 gitlab-psql root         4096 May 25 10:46 pg_subtrans
drwx------ 2 gitlab-psql root         4096 May 25 10:46 pg_tblspc
drwx------ 2 gitlab-psql root         4096 May 25 10:46 pg_twophase
-rw------- 1 gitlab-psql root            4 May 25 10:46 PG_VERSION
drwx------ 3 gitlab-psql root         4096 May 25 11:10 pg_xlog
-rw------- 1 gitlab-psql root           88 May 25 10:46 postgresql.auto.conf
-rw-r--r-- 1 gitlab-psql root        20132 May 25 10:46 postgresql.conf
-rw------- 1 gitlab-psql gitlab-psql    90 May 25 10:55 postmaster.opts
-rw------- 1 gitlab-psql gitlab-psql   101 May 25 10:55 postmaster.pid
postgresql 版本
#cat PG_VERSION 
9.6
查看postgresql的进程
#ps aux | grep postgre
root       7378  0.0  0.0   3940   360 ?        Ss   10:46   0:00 runsv postgresql
root       7379  0.0  0.0   4084   472 ?        S    10:46   0:00 svlogd -tt /var/log/gitlab/postgresql
root       7697  0.0  0.0   3940   356 ?        Ss   10:48   0:00 runsv postgres-exporter
root       7698  0.0  0.0   4084   476 ?        S    10:48   0:00 svlogd -tt /var/log/gitlab/postgres-exporter
495       13278  0.0  0.6 127968 11924 ?        Ssl  11:41   0:03 /opt/gitlab/embedded/bin/postgres_exporter -web.listen-address=localhost:9187
495       13283  0.0  1.7 545204 34160 ?        Ss   11:41   0:00 /opt/gitlab/embedded/bin/postgres -D /var/opt/gitlab/postgresql/data
495       13287  0.0  1.0 545320 20344 ?        Ss   11:41   0:02 postgres: checkpointer process                                      
495       13288  0.0  0.2 545204  5032 ?        Ss   11:41   0:00 postgres: writer process                                            
495       13289  0.0  0.8 545204 16228 ?        Ss   11:41   0:00 postgres: wal writer process                                        
495       13290  0.0  0.1 545776  2196 ?        Ss   11:41   0:00 postgres: autovacuum launcher process                               
495       13291  0.0  0.0  31012  1460 ?        Ss   11:41   0:00 postgres: stats collector process                                   
495       13332  0.0  0.4 644080  8408 ?        Ss   11:41   0:01 postgres: gitlab-psql postgres [local] idle                         
495       14219  0.0  0.4 644128  8892 ?        Ss   11:50   0:00 postgres: gitlab gitlabhq_production [local] idle                   
495       15207  0.0  0.4 643884  8160 ?        Ss   12:00   0:00 postgres: gitlab gitlabhq_production [local] idle                   
495       15208  0.0  0.4 643888  8392 ?        Ss   12:00   0:00 postgres: gitlab gitlabhq_production [local] idle                   
495       19681  0.0  0.3 643428  6804 ?        Ss   12:46   0:00 postgres: gitlab gitlabhq_production [local] idle                   
495       19706  0.0  0.3 643428  6812 ?        Ss   12:47   0:00 postgres: gitlab gitlabhq_production [local] idle      

可以看到启动之后的postgresql有2个默认数据库,一个是postgres,一个是gitlabhq_production!
进入postgresql控制台方法,在postgreSQL的安装目的bin下执行命令: 
用法:psql database_name,
例:/usr/local/pgsql/bin/psql mydb
指定host、用户名和数据库的话,如:
/usr/local/pgsql/bin/psql -h localhost -U postgres -d testdb
注:-h 也可以指定socket文件目录
#########################################
进入postgresql的gitlabhq_production库
#su - gitlab-psql
-sh-4.1$ /opt/gitlab/embedded/bin/psql -h /var/opt/gitlab/postgresql -d gitlabhq_production
psql (9.6.1)
Type "help" for help.
gitlabhq_production=# help
You are using psql, the command-line interface to PostgreSQL.
Type:  \copyright for distribution terms
       \h for help with SQL commands
       \? for help with psql commands
       \g or terminate with semicolon to execute query
       \q to quit
gitlabhq_production=# \q      #退出
注意:-h 后面指定服务器ip或者socket文件所在目录
进入postpgresql的postgres库
#su - gitlab-psql
-sh-4.1$ psql -h /var/opt/gitlab/postgresql -d postgres
psql (9.6.1)
Type "help" for help.
postgres=# 
##############################################
postgresql的其他用法介绍
创建数据库
CREATE DATABASE test WITH OWNER = postgres ENCODING = ‘UTF8‘;
查看版本: 
#psql --version 或 SELECT version();
查看所有数据库:\l
选择数据库:\c databasename
查看所有表:\dt
查看某个表的结构:\d tablename
退出psql控制台:\q
查看所有索引:\di

查看表的索引:
select * from pg_indexes where tablename=‘log‘;
查看数据库大小:
select pg_size_pretty(pg_database_size(‘test_db‘));
查看所有数据库大小
select pg_database.datname, pg_database_size(pg_database.datname) AS size from pg_database;
查看表的大小:
select pg_size_pretty(pg_relation_size(‘test_table‘));
查看表的总大小,包括索引大小  
select pg_size_pretty(pg_total_relation_size(‘test‘)); 
查看所有表空间  
select spcname from pg_tablespace;          
查看表空间大小
select pg_size_pretty(pg_tablespace_size(‘pg_default‘));

导出备份数据库:
pg_dump -h localhost -U postgres databasename > /tmp/databasename.bak.yyyymmdd.sql
导入恢复数据库(sql文件是pg_dump导出的文件就行,可以是整个数据库,也可以只是单个表,也可以只是结构等):
psql -h localhost -U postgres -d databasename < /tmp/databasename.bak.yyyymmdd.sql

导出某个表:
pg_dump -h localhost -U postgres -t tablename dbname > test.sql
导出某个表的结构,加参数"-s":
pg_dump -h localhost -U postgres -t tablename -s dbname > test_construct.sql
导出某个表的数据,加参数"-a":
pg_dump -h localhost -U postgres -t tablename -a dbname > test_data.sql
查看序列:
select * from information_schema.sequences where sequence_schema = ‘public‘;

不足之处,请多多留言指教!

本文出自 “知识体系” 博客,请务必保留此出处http://linuxg.blog.51cto.com/4410110/1929362

GitLab 的一键安装方式