GitLab概述 : 是一个利用 Ruby on Rails 开发的开源应用程序,实现一个自托管的Git项目仓库,可通过 Web 界面进行访问公开的戒者私人项目。Ruby on Rails 是一个可以使你开发、部署、维护 web 应用程序变得简单的框架  GitLab拥有与Github类似的功能,能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问, 它非常易于浏览提交过的版本并提供一个文件历史库。它还提供一个代码片段收集功能可以轻松实现代码复用,便于日后有需要的时候进行查找

官方网站 :https://about.gitlab.com/ 

 GitHub和GitLab的区别 : 

相同点 : 二者都是基于web的Git仓库,在很大程度上GitLab是仿照GitHub来做的,它们都提供了分享开源项目的平台,为开发团队提供了存储、分享、发布和合作开发项目的中心化云存储的场所

不同点 :

1、GitHub如果要使用私有仓库,是需要付费的 GitLab可以在上面创建私人的克费仓库

2、GitLab让开发团队对他们的代码仓库拥有更多的控制,相比于GitHub,它有不少的特色 :

允许克费设置仓库权限;

允许用户选择分享一个project的部分代码

允许用户设置project的获取权限,进一步的提升安全性

可以设置获取到团队整体的改进进度;通过 innersourcing让不在权限范围内的人访问不到该资源

总结 :从代码私有性方面来看,有时公司并不希望员工获取到全部的代码,这个时候GitLab无疑是更好的选择但对于开源项目而言,GitHub依然是代码托管的首选 

git相关概念 :

git      是一种版本控制系统,是一个命令,是一种工具

gitlib       是用于实现git功能的开发库

github     是一个基于git实现的在线代码托管仓库,包含一个网站界面,向互联网开放

gitlab      是一个基于git实现的在线代码仓库托管软件,一般用于在企业内部网络搭建git私服

gitlab-ce 社区版(免费) 

gitlab-ee是企业版(收费)

搭建GitLab平台

环境 : 最少4G内存 , 不然后期访问 gitlab web页面可能会报错

[root@gitlab ~]# cat /etc/centos-release
CentOS Linux release 7.5. (Core)
[root@gitlab ~]# free -h
total used free shared buff/cache available
Mem: .6G 194M .2G 11M 208M .2G
Swap: .0G 0B .0G

安装Gitlab的依赖包 :

[root@gitlab ~]# yum -y install curl policycoreutils openssh-server openssh-clients postfix
[root@gitlab ~]# systemctl enable postfix
[root@gitlab ~]# systemctl start postfix
[root@gitlab ~]# iptables -F
[root@gitlab ~]# systemctl stop firewalld
[root@gitlab ~]# systemctl disable firewalld

安装Gitlab-ce版

# 下载 gitlab-ce版yum源
[root@gitlab ~]# curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.rpm.sh |bash
[root@gitlab ~]# yum -y install gitlab-ce

 配置gitlab域名

[root@gitlab ~]# vim /etc/gitlab/gitlab.rb
# 13行 external_url 'http://gitlab.example.com' 改为 http://IP

加载配置文件并启动gitlab(加载配置文件需要点时间)

[root@gitlab ~]#  gitlab-ctl reconfigure
[root@gitlab ~]# gitlab-ctl status
run: alertmanager: (pid ) 70s; run: log: (pid ) 69s
run: gitaly: (pid ) 72s; run: log: (pid ) 70s
run: gitlab-monitor: (pid ) 71s; run: log: (pid ) 70s
run: gitlab-workhorse: (pid ) 72s; run: log: (pid ) 71s
run: logrotate: (pid ) 149s; run: log: (pid ) 71s
run: nginx: (pid ) 155s; run: log: (pid ) 71s
run: node-exporter: (pid ) 137s; run: log: (pid ) 70s
run: postgres-exporter: (pid ) 70s; run: log: (pid ) 69s
run: postgresql: (pid ) 205s; run: log: (pid ) 71s
run: prometheus: (pid ) 71s; run: log: (pid ) 69s
run: redis: (pid ) 211s; run: log: (pid ) 71s
run: redis-exporter: (pid ) 120s; run: log: (pid ) 71s
run: sidekiq: (pid ) 162s; run: log: (pid ) 71s
run: unicorn: (pid ) 168s; run: log: (pid ) 71s

 [root@gitlab ~]# netstat -antup | grep :80
 tcp 0 0 0.0.0.0:8060 0.0.0.0:* LISTEN 12033/nginx: master
 tcp 0 0 127.0.0.1:8080 0.0.0.0:* LISTEN 11981/unicorn maste
 tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 12033/nginx: master   # 默认使用nginx作为web服务器
 tcp 0 0 127.0.0.1:8082 0.0.0.0:* LISTEN 12001/sidekiq 5.1.3

 [root@gitlab ~]# free -h
       total   used   free   shared   buff/cache   available
  Mem:   7.6G   3.3G   1.5G      90M         2.8G        3.8G
  Swap:   2.0G     0B   2.0G

# 真的很吃内存

登录gitlab

第一次登录 gitlab,需要为root 用户修改密码,root用户也是gitlab的超级管理员

改成密码后, 登录 http://192.168.94.11/   用户名 :root 

gitlab搭建成功

gitlab主配置文件:/etc/gitlab/gitlab.rb      # 可以自定义一些邮件服务等

日志目录:/var/log/gitlab/                          # 对应各服务

服务目录:/var/opt/gitlab/                         # 对应各服务的主目录

仓库目录:/var/opt/gitlab/git-data            # 记录项目仓库等提交信息

重启服务:gitlab-ctl  stop/start/restart    # 启动命令 

注册新用户和关闭 gitlab注册功能 :

退出root用户 默认情况下可以直接注册账号 http://192.168.94.11/users/sign_in  开始注册 

可以关闭注册功能

 用管理员用户登录 Admin Area→setting→取消Sing-up enabled 选项对勾

然后下拉网页 , 在Sign-up restrictions 配置项的末尾有 保存修改 

这样就关闭了注册功能

centos7 部署汉化版gitlab 

gitlab中文社区版的项目 :

v7-v8.8是由 Larry Li发起的“GitLab 中文社区版项目” https://gitlab.com/larryli/gitlab

从 v8.9 之后,@xhang 开始继续该汉化项目 (https://gitlab.com/xhang/gitlab

下载汉化包: 

# 上面下载的是gitlab-ce 11.2. 这里下载对应版本的汉化包
[root@gitlab ~]# git clone https://gitlab.com/xhang/gitlab.git -b v11.2.1-zh

汉化的方法就是把下载的汉化包替换现有的web页面

[root@gitlab ~]# gitlab-ctl stop
[root@gitlab ~]# /usr/bin/cp -rvf /root/gitlab/* /opt/gitlab/embedded/service/gitlab-rails/
# gitlab-rails下面存放的都是web 界面相关的文件

重启服务

[root@gitlab ~]# gitlab-ctl restart

登录gitlab查看

gitlab的使用 :

1 新建项目

2 创建用户

3 重置用户密码

4 删除用户

1 新建项目

新建项目前,先创建项目所在的组(也就是说这个项目文件是保存在哪个组里

 

Visibility Level(项目可见级别):

Private(私有的,只有你自己戒者组内的成员能访问)

Internal(所有登录 gitlab平台的用户都可能访问)

Public(公开的,所有人都可以访问)三种选项。即不登录gitlab也可以访问 

稍后会创建秘钥 , 实现无交互上传和下载代码 , 方便后期进行Jenkins自动部署

2 创建用户

个人资料可以不填

创建完用户会发邮件到你的添写的邮箱 , 点击进入给创建的用户修密码 , 邮件有时候会收到 ,有时候收不到

就算能收到 , 也不及时 , 所以让root用户修改密码是最快 , 最有效的

3 修改密码

4 删除用户

把用户damowang添加到damowang的群组里 , 身份选择"主程序员" , 后期就可以提交代码了 , "开发人员" 是没有权限提交代码的

在项目中添加一个文件index.html 

 安装 git并 clone代码 

[root@gitlab ~]# yum -y install git

初次运行Git钱的配置

一般在新的系统上, 我们都需要先配置先自己的Git 工作环境 ,  配置工作只需要一次 , 以后升级时还会沿用现在的配置

第一个要配置的是你个人的用户名称和电子邮箱地址 , 这两条配置很重要 ,每次Git提交时都会引用这两条信息 , 说明是谁提交了更新 , 所以会随更新内容一起被永久纳入历史记录

Git运行的环境变量有点像 .bashrc , 决定了Git 在各个环节的具体工作方式和行为 , 这些变量可以存放在以下两个地方 : 

~/.gitconfig文件 : 用户目录下的配置文件是适用于该用户 , 若使用 gitconfig时 用--global选项 , 读取的就是这个文件

[root@git damowang.cn-web]#  git config --global user.name "damowang.cn"
[root@git damowang.cn-web]# git config --global user.email "damowang.cn@gmail.com"
[root@git damowang.cn-web]# cat ~/.gitconfig
[user]
name = damowang.cn
email = damowang.cn@gmail.com

当前项目的 Git 目录中的配置文件, 也就是工作目录中的 .git/config 文件 这里的配置仅仅 针对当前项目有效 每一个级别的配置都会覆盖上层的相同配置,所以 .git/config 里的配置会覆盖 ~/.gitconfig中的同名变量

如果要在某个特定的项目中使用其他名字或者邮件地址,先进到项目目录下,然后只要去掉 --global 选 项重新配置即可 最后配置的用户和邮件地址会保存在当前项目的 .git/config 文件里 

[root@git damowang.cn-web]# pwd
/git/damowang.cn-web
[root@git damowang.cn-web]# cat ./.git/config
[core]
repositoryformatversion =
filemode = true
bare = false
logallrefupdates = true
[remote "origin"]
url = http://192.168.94.11/damowang/damowang.cn-web.git
fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
remote = origin
merge = refs/heads/master
[root@git damowang.cn-web]# git config user.name "damowang.cn"
[root@git damowang.cn-web]# git config user.email "damowang.cn@gmail.com"
[root@git damowang.cn-web]# cat ./.git/config
[core]
repositoryformatversion = 0
filemode = true
bare = false
logallrefupdates = true
[remote "origin"]
url = http://192.168.94.11/damowang/damowang.cn-web.git
fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
remote = origin
merge = refs/heads/master
[user]
name = damowang.cn
email = damowang.cn@gmail.com

git 常用命令: git config --global user.name “name“   # 设置全局用户名

git config --global user.email  mail           # 设置全局邮箱

git config --global  --list                    # 列出用户全局设置

git  add index.html            # 添加文件到暂存区

git commit -m “描述内容“        # 提交文件到工作区

git status               # 查看工作区的状态

git push               # 提交代码到git 服务器上

git pull                 # 获取代码到本地 

git log               #查看操作日志 

 vim  .gitignore    #定义忽略文件 git reset --hard  HEAD^    # git 版本回滚, HEAD为当前版本,加一个^为上一个,^^为上上一 个版本

git reflog           # 获取每次提交的ID,可以使用--hard根据提交的ID 迚行版本回退

git reset --hard 5ae4b06    # 回退到指定id的版本

git branch           # 查看当前所处的分支 git checkout --  file   #从服务器更新某个那文件覆盖本地的文

git checkout --  file     # 从服务器更新某个那文件覆盖本地的文件

把修改过的 index.html 文件更新主版本中 

[root@git damowang.cn-web]# echo "mail.damowang.cn" >> index.html
[root@git damowang.cn-web]# git add index.html
[root@git damowang.cn-web]# git commit -m "add mail.damowang.cn"
[master 6bff0da] add mail.damowang.cn
file changed, insertion(+), deletion(-)
[root@git damowang.cn-web]#    # 上传到master主干下 
Username for 'http://192.168.94.11': damowang.cn
Password for 'http://damowang.cn@192.168.94.11':
Counting objects: , done.
Writing objects: % (/), bytes | bytes/s, done.
Total (delta ), reused (delta )
To http://192.168.94.11/damowang/damowang.cn-web.git
2c6153b..6bff0da master -> master
分支 master 设置为跟踪来自 origin 的远程分支 master。
[root@git damowang.cn-web]# rm -rf index.html    # 删除一些代码 
[root@git damowang.cn-web]# git reset --hard HEAD  # 回滚到最新版本
HEAD 现在位于 6bff0da add mail.damowang.cn
[root@git damowang.cn-web]# ls
index.html
[root@git damowang.cn-web]# git reflog  # 获取每次提交的ID
6bff0da HEAD@{}: commit: add mail.damowang.cn
2c6153b HEAD@{}: clone: from http://192.168.94.11/damowang/damowang.cn-web.git

工作区和暂存区及分支概述 

工作区就是编辑文件的目录区域,需要将工作区的修改好的文件 add到暂存区才能提交到git服务器,在工作区有多个文件的时候可以将一个或多个文件添加至暂存区,再提交到git服务器即可

在服务器创建分支 

[root@git damowang.cn-web]# git branch mail  # 创建一个分支
[root@git damowang.cn-web]# git checkout mail  # 切换到分支 mail
切换到分支 'mail'
[root@git damowang.cn-web]# git branch  # 查看当前所在分支
* mail
master
[root@git damowang.cn-web]# echo "damowang" > test.txt  
[root@git damowang.cn-web]# git add test.txt
[root@git damowang.cn-web]# git commit -m "add test.txt"  # 提交到暂存区中
[mail f4cd6f0] add test.txt
file changed, insertion(+)
create mode test.txt
[root@git damowang.cn-web]# git push -u origin mail  # 上传到分支mail
Username for 'http://192.168.94.11': damowang.cn
Password for 'http://damowang.cn@192.168.94.11':
Counting objects: , done.
Delta compression using up to threads.
Compressing objects: % (/), done.
Writing objects: % (/), bytes | bytes/s, done.
Total (delta ), reused (delta )
remote:
remote: To create a merge request for mail, visit:
remote: http://192.168.94.11/damowang/damowang.cn-web/merge_requests/new?merge_request%5Bsource_branch%5D=mail
remote:
To http://192.168.94.11/damowang/damowang.cn-web.git
* [new branch] mail -> mail
分支 mail 设置为跟踪来自 origin 的远程分支 mail。

使用ssh密钥对实现免交互提交拉取代码

[root@git ~]# ssh-keygen -t rsa -f ~/.ssh/id_rsa -P ""
ssh-rsa
[root@git ~]# cat ~/.ssh/id_rsa.pub
AAAAB3NzaC1yc2EAAAADAQABAAABAQCj7G88QrpBo/Shw4WhpOHyHQKEm8xzCsL7++LWyhXUr4GaX43tMRwoOhAPu/UZkyk0regya0DdXy9dJgiOcUDpaACDZRsFPst5Nw7EKgd90BI4HWAuHQ+gNPxyJtHpyXAJuRXeSWWxiYa5KM+YH5ix0TpSDNbnwxiVQSxB0slgwI25qL0naCBbiKZ0lvQOaDKJoF5aVrQngASQgXBCOlhWrKI6ZcuAMnpW5kD5/4GJr6Y8RibbNros+8BGMwG7z64Hv2Fl5wh6t52quLxTn+pCCkcLcTFiC0DBHcyFdVBqALYU2UaqC+ee6zNDQ13UZTBAKKqjwmws42GEo2j1mjgN root@gitlab

登录gitlab 增加SSH密钥

复制git克隆地址拉取代码 , 再上传代码 , 看是否免交互

 

CentOS 7 部署GitLab的更多相关文章

  1. 在 CentOS 上部署 GitLab (自托管的Git项目仓库)

    参考资料https://github.com/mattias-ohlsson/gitlab-installer/blob/master/gitlab-install-el6.sh 环境准备OS: Ce ...

  2. CentOS 7 部署Gitlab+Jenkins持续集成(CI)环境

    持续集成概述及运行流程 : 持续集成概述 :持续集成(Continuous integration)持续集成是指开发者在代码的开发过程中 ,可以频繁的将代码部署集成到主干,并进行自动化测试  开发→代 ...

  3. centos 安装 部署 gitlab github

    https://www.cnblogs.com/wenwei-blog/p/5861450.html 我这里使用的是centos 7 64bit,我试过centos 6也是可以的! 1. 安装依赖软件 ...

  4. [转]Centos 7 安装部署 GitLab 服务器

    Centos 7 安装部署 GitLab 服务器 转自:https://www.jianshu.com/p/79bfded68899 文前说明 作为码农中的一员,需要不断的学习,我工作之余将一些分析总 ...

  5. 一、CentOS 7安装部署GitLab服务器

    一.CentOS 7安装部署GitLab服务器 1.安装依赖软件 yum -y install policycoreutils policycoreutils-python openssh-serve ...

  6. CentOS 下搭建Gitlab

    centos7安装部署gitlab服务器   我这里使用的是centos 7 64bit,我试过centos 6也是可以的! 1. 安装依赖软件 yum -y install policycoreut ...

  7. Docker-compose部署gitlab中文版

    目录 Docker-compose部署gitlab 1.安装Docker 2.安装Docker-compose 3.安装Gitlab Docker-compose部署gitlab 1.安装Docker ...

  8. CentOS 7 搭建 GitLab

    概述 GitLab 是我在日常工作中使用的代码仓库管理系统,它带有非常友好的 Web 界面,并且功能丰富.下面将介绍我在 CentOS 7 上搭建 GitLab 的步骤,以及遇到的一些问题. 关于不同 ...

  9. CentOS7配置中文支持与部署GitLab服务器

    给你的 CentOS 7 安装中文支持 1.首先需要中文字体以便支持命令行终端的中文显示需求: yum groupinstall "fonts" 碰到提示输入 y 回车继续安装,大 ...

随机推荐

  1. 我的第二本译作《精通OpenStack》上架啦:书籍介绍和译者序

    1. 书籍简介 英文书名:Mastering OpenStack Second Edition 作者:[德] 奥马尔-海德希尔(Omar Khedher)[印] 坚登-杜塔-乔杜里(Chanda Du ...

  2. [PKUSC2018]星际穿越

    [PKUSC2018]星际穿越 题目大意: 有一排编号为\(1\sim n\)的\(n(n\le3\times10^5)\)个点,第\(i(i\ge 2)\)个点与\([l_i,i-1]\)之间所有点 ...

  3. Python开发技术详解PDF

    Python开发技术详解(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1F5J9mFfHKgwhkC5KuPd0Pw 提取码:xxy3 复制这段内容后打开百度网盘手 ...

  4. Node.js_文件系统 FS

    文件系统 FS——File System 所谓的文件系统,就是对计算机中的文件进行增.删.查.改等操作 是一个服务器的基础 node 通过核心 FS 模块来操作文件系统 简单写 // 1. 导入 fs ...

  5. linux学习:特殊符号,数学运算,图像与数组与部分终端命令用法整理

    指令:let.expr.array.convert.tput.date.read.md5.ln.apt.系统信息 一:特殊符号用法整理 系统变量 $# 是传给脚本的参数个数 $0 是脚本本身的名字 $ ...

  6. 软件体系架构之ssh框架阅读笔记

    首先我们要了解一下什么是ssh框架? SSH是 struts+spring+hibernate的一个集成框架,是目前比较流行的一种Web应用程序开源框架. ssh框架系统从职责上分为四层:web层 业 ...

  7. word/pdf互转的链接

    参考链接 http://www.greenxf.com/soft/98467.html

  8. 19个实例学会plsql

    --p1 begin dbms_output.put_line('你好 世界'); end; --p2 引入变量 declare age ; height ; begin dbms_output.pu ...

  9. pycharm 的 激活流程

    激活流程 一.通过Activation code 方式激活 注册码获取地址为:http://idea.lanyus.com/ 在idea或者pycharm的Activation code中输入 注册码 ...

  10. Autofac之类型注册

    本次主要学习一下Autofac中实现类型注册的几种方式,这里并不打算一开始就从基于接口开发的服务关联切入,而是先从一个简单的类型注册来学起,虽然实际开发中可能不会这么做,但是个人感觉从这里学起理解能能 ...