1 - GitLab角色权限

1.1 组(同一组成员的行为权限)

  • 管理员创建不同的分组,然后设定分组的负责人(Owner)
  • Owner可以添加组员,为组创建项目,指定项目的负责人
  • 项目负责人可以添加项目成员并设定对应的级别

组中的角色与权限

  • Guest - 访客:可以创建issue、发表评论,不能读写版本库
  • Reporter - 报告者: QA、PM等,可以克隆代码,不能提交
  • Developer - 开发者: RD,可以克隆代码、开发、提交、push
  • Master - 主人:核心RD负责人,负责对Master分支进行维护,可以创建项目、添加tag、保护分支、添加项目成员、编辑项目
  • Owner - 拥有者: RD Leader,设置项目可见度、删除项目、迁移项目、管理组成员

角色对应的权限

1.2 项目(可见度,项目的访问权限)

  • Private - 私有,只有属于该项目的成员才能查看、拉取代码
  • Internal - 内部,可以被任何登录的用户查看、拉取代码
  • Public - 公开,任何人都可以查看、拉取代码

2 - 创建组和项目

2.1 创建组

只有管理员账户才可以创建群组(Group),创建时,一般默认是私有组,管理员是Owner。





添加组成员



2.2 创建项目

在组的页面,点击“新建项目”,有三种创建项目的方式

  • Blank project:创建一个空项目
  • Create from template:创建模板项目
  • Import project:从其他代码库导入项目



以新建空白项目为例:



3 - 本地Git配置

3.1 连接验证

特别注意:必须通过GitLab连接验证,才可以拉取和提交代码

GitLab默认提供SSH和HTTP两种方式拉取代码

  • SSH:将常用的本地开发环境的SSH公钥复制到GitLab用户配置中,无需输入用户名和代码
  • HTTP方式:直接使用用户名和密码,但每次都要重新输入
Anliven@Anliven-PC /d/Project
λ ssh-keygen -t rsa -C "anliven@126.com" -b 4096
Generating public/private rsa key pair.
Enter file in which to save the key (/c/Users/Anliven/.ssh/id_rsa):
Created directory '/c/Users/Anliven/.ssh'.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /c/Users/Anliven/.ssh/id_rsa.
Your public key has been saved in /c/Users/Anliven/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:sMAcpgAoRuKYZOTXBVJatSkrJ/as8sYh/T+nnVrHUMg anliven@126.com
The key's randomart image is:
+---[RSA 4096]----+
|O= .++oo |
|X+ ==.. + . |
|=o.o+o.o E . |
| . .oo . |
| .+ o. S. |
| ..o* o |
| o oo . o |
| . o.. .o.o |
| +o .+=o |
+----[SHA256]-----+
Anliven@Anliven-PC /d/Project
λ
Anliven@Anliven-PC /d/Project
λ cat /c/Users/Anliven/.ssh/id_rsa.pub
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDQSFpwR9eBCTKfTbPEE8TWIo75KfX3AczpXK6nTKGH248pxjfq7cDe2cGj1VOSqknMqvg0g1LLiXrgbIGbtclt49UKSFXxWnVm04rZHVsz9rtfzxuF/NmSqSv7isYLZvwaI4aGXkLwILOemqwCbPRybGlkIiU9sgFK6m5gBWpsA6WqbHGlll8o1jC1cIuiPcJuYwod4+ehI5GvH3Tr3rUjkWy0QEhFfV22Nt79mJ3D+xDpDP/SxhPtPWw1Ob1+10+0+xvSTvGR/gcLUnUXciIooJVSypTPLnGe+d4Y5i+jCzDRIxeXBEQrQXafoxTjPNMb/T84mkPH+MSSTnvAk6Oelcs9MJLDIlXcDGSKXSzl2XmjjiTglq0R5gnRtUL6jxcyR0Db5mEF5maumfyKz58/O5pSDGVRW13O6V0YGq6j8f5mcn8h1usdqabbirUGA5+7OB2Ek4KlLy/U6GkHtr5gY4zch08A8/xWowGppOjb8b/MqxJuLmQY1+vvUlupALd6nNmacugmlZK+ZsheTCJhdNHLBVl40b4UZdbD19LCI5cFonvJP979J4SIc8gHh7SXu7lSTRWciA0BKLrwhhHID1PHnF5o0re4kENZW4LYiXhBo998+7TtXiK+itnjUsfHRDPUvQC0OrhmLf/DAyanpRs65rXFONEaVGf4NS+PCQ== anliven@126.com
Anliven@Anliven-PC /d/Project
λ



3.2 添加README文件

在项目界面,根据提示添加README文件后,左侧会出现“仓库”功能

3.3 受保护的分支

新创建的项目默认会把master分支设置为“受保护的分支”,只有项目的Owner和Master才有权限直接向受保护的分支提交代码。

  • 后期项目开发时,可以创建普通的Develop分支,从而以Developer角色进行代码提交
  • 创建merge request请求,在项目Owner和Master进行代码审查无误后,将代码合并到master分支
  • 创建分支时,必须填写分支名称、从哪个分支、标签或具体的提交号拉出来

4 - 本地项目的Git配置

4.1 命令行指引

在项目页面,可以在“命令行指引”部分查看到配置方法

# Git 全局设置
git config --global user.name "Administrator"
git config --global user.email "admin@example.com"
# 创建一个新仓库
git clone http://192.168.16.102/testgroup/testproject.git
cd testproject
touch README.md
git add README.md
git commit -m "add README"
git push -u origin master
# 推送现有文件夹
cd existing_folder
git init
git remote add origin http://192.168.16.102/testgroup/testproject.git
git add .
git commit -m "Initial commit"
git push -u origin master
# 推送现有的 Git 仓库
cd existing_repo
git remote rename origin old-origin
git remote add origin http://192.168.16.102/testgroup/testproject.git
git push -u origin --all
git push -u origin --tags

4.2 Git本地用户配置示例

Anliven@Anliven-PC /d/Project
λ git config --global user.name "user01"
Anliven@Anliven-PC /d/Project
λ git config --global user.email "anliven@126.com"
Anliven@Anliven-PC /d/Project
λ
Anliven@Anliven-PC /d/Project
λ git config --list
core.symlinks=false
core.autocrlf=true
color.diff=auto
color.status=auto
color.branch=auto
color.interactive=true
pack.packsizelimit=2g
help.format=html
http.sslcainfo=/ssl/certs/ca-bundle.crt
diff.astextplain.textconv=astextplain
rebase.autosquash=true
filter.lfs.clean=git-lfs clean -- %f
filter.lfs.smudge=git-lfs smudge -- %f
filter.lfs.process=git-lfs filter-process
filter.lfs.required=true
credential.helper=manager
user.name=user01
user.email=anliven@126.com
Anliven@Anliven-PC /d/Project
λ
Anliven@Anliven-PC /d/Project
λ

4.3 拉取及提交代码示例

Anliven@Anliven-PC /d/Project
λ git clone http://192.168.16.102/testgroup/testproject.git
Cloning into 'testproject'...
remote: Enumerating objects: 3, done.
remote: Counting objects: 100% (3/3), done.
remote: Total 3 (delta 0), reused 0 (delta 0)
Unpacking objects: 100% (3/3), done.
Anliven@Anliven-PC /d/Project
λ ll
total 0
drwxr-xr-x 1 Anliven 197121 0 十一 28 00:05 testproject/
Anliven@Anliven-PC /d/Project
λ echo "hello" >> testproject/README.md
Anliven@Anliven-PC /d/Project
λ cd testproject/
Anliven@Anliven-PC /d/Project/testproject (master)
λ git status
On branch master
Your branch is up to date with 'origin/master'.
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
modified: README.md
no changes added to commit (use "git add" and/or "git commit -a")
Anliven@Anliven-PC /d/Project/testproject (master)
λ git add *
warning: LF will be replaced by CRLF in README.md.
The file will have its original line endings in your working directory
Anliven@Anliven-PC /d/Project/testproject (master)
λ git commit -m "test 002"
[master 6693ace] test 002
1 file changed, 1 insertion(+), 1 deletion(-)
Anliven@Anliven-PC /d/Project/testproject (master)
λ
Anliven@Anliven-PC /d/Project/testproject (master)
λ git push -u origin master
Enumerating objects: 5, done.
Counting objects: 100% (5/5), done.
Writing objects: 100% (3/3), 251 bytes | 251.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0)
To http://192.168.16.102/testgroup/testproject.git
defc521..6693ace master -> master
Branch 'master' set up to track remote branch 'master' from 'origin'.
Anliven@Anliven-PC /d/Project/testproject (master)
λ

GitLab - 一些基础使用的更多相关文章

  1. GITLAB服务基础

    1.GITLAB介绍 一个基于GIT的源码托管解决方案基于Ruby on rails开发集成了nginx postgreSQL redis sidekiq等组件 2. 资源 官网:https://ab ...

  2. gitlab升级和迁移

    由于近期公司gitlab服务器老是卡顿和出现其他问题,然后也很久没有升级过了,现在版本还是8.10.5,而官网最新版本已经是11.2了.另一个原因是gitlab所在的这台服务器快到期了,想换一台配置更 ...

  3. Gitlab 备份迁移恢复报错gtar: .: Cannot mkdir: No such file or directory

    1. 版本信息 OS: centos 6.9 Gitlab: gitlab-ce.10.7.4 gitlab-ce.10.8.0 gitlab-ce.10.8.3 gitlab-ce.10.8.4 2 ...

  4. Gitlab+Jenkins学习目录

    Gitlab+Jenkins基础篇 Gitlab+Jenkins学习之路(一)之Git基础 Gitlab+Jenkins学习之路(二)之gitlab部署 Gitlab+Jenkins学习之路(三)之g ...

  5. gitlab相关

    1.gitlab的概述 1.gitlab是什么 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务. 基础功能免费,高级功能收费 2.为什么要使用gitla ...

  6. gitlab系列详解

    虚拟机的安装1.安装virtualboxhttps://www.virtualbox.org/2.安装centos6.63.配置网络右键-->网络-->网卡2-->host-only ...

  7. 【ASP.NET Core分布式项目实战】(六)Gitlab安装

    Gitlab GitLab是由GitLabInc.开发,使用MIT许可证的基于网络的Git仓库管理工具,且具有wiki和issue跟踪功能.使用Git作为代码管理工具,并在此基础上搭建起来的web服务 ...

  8. GitLab CI/CD的官译【原】

    CI / CD方法简介 软件开发的持续集成基于自动执行脚本,以最大限度地减少在开发应用程序时引入错误的可能性.从新代码的开发到部署,它们需要较少的人为干预甚至根本不需要干预. 它涉及在每次小迭代中不断 ...

  9. GitLab企业级代码管理仓库

    原文:https://www.cnblogs.com/wsnbba/p/10171052.html   使用GitHub或者码云等公共代码仓库 使用GitLab私有仓库 GitLab是什么? 是一个用 ...

随机推荐

  1. 微信小程序~模板template引用

    当您的项目需要多次使用同一个布局和样式的时候,您就可以考虑使用template(模板)来减少冗余代码. 使用方式: 1.新建一个template文件夹来存放您的通用模板: 2.在文件夹里面新建一个wx ...

  2. CSE301 – Bio-Computation

    CSE301 – Bio-Computation Assessment 3Contribution to overall module assessment 10%Submission deadlin ...

  3. c#中的多态学习总结

    c#的多台方法,大体上和c++的类似,但是有点区别的,我这里刚刚初学,因此把重点记录下. 多态是同一个行为具有多个不同表现形式或形态的能力. 多态性意味着有多重形式.在面向对象编程范式中,多态性往往表 ...

  4. ACM-ICPC 2018 南京赛区现场赛 K. Kangaroo Puzzle (思维+构造)

    题目链接:https://codeforc.es/gym/101981/attachments 题意:在 n * m 的平面上有若干个袋鼠和墙(1为袋鼠,0为墙),每次可以把所有袋鼠整体往一个方向移动 ...

  5. vue之大文件分段上传、断点续传

    需求: 支持大文件批量上传(20G)和下载,同时需要保证上传期间用户电脑不出现卡死等体验: 内网百兆网络上传速度为12MB/S 服务器内存占用低 支持文件夹上传,文件夹中的文件数量达到1万个以上,且包 ...

  6. C# await async Task

    //原文:https://www.cnblogs.com/yan7/p/8401681.html //原文:https://www.cnblogs.com/s5689412/p/10073507.ht ...

  7. [转]查看 docker 容器使用的资源

    作者:sparkdev 出处:http://www.cnblogs.com/sparkdev/     在容器的使用过程中,如果能及时的掌握容器使用的系统资源,无论对开发还是运维工作都是非常有益的.幸 ...

  8. (浙江金华)Day 1 组合数计数

    目录 Day 1 组合计数 1.组合数 (1).C(n,m) 读作n选m,二项式系数 : (2).n个东西里选m个的方案数 不关心选的顺序: (3).二项式系数--->多项式系数: 2.组合数计 ...

  9. [内网渗透] MSF路由转发/网络代理

    这里只做记录,不做详解 0x01 路由转发 已经拿到一台公网服务器: 1.1 方法1 进到meterpreter的会话: route #查看路由信息 background退出当前会话,通过会话2,转发 ...

  10. 深度学习图像配准 Image Registration: From SIFT to Deep Learning

    Image Registration is a fundamental step in Computer Vision. In this article, we present OpenCV feat ...