gitlab 分支保护
·
一、创建用户
1.填写用户信息
2.分配权限
3.修改用户初始密码
然后保存修改
二、将用户添加到指定的项目组
这里就看到我们添加的张三用户了
1.使用张三的身份克隆代码
[root@node-2 data]# git clone http://zhangsan@pangbing.com/root/taikang_test.git
Cloning into 'taikang_test'...
Password for 'http://zhangsan@pangbing.com':
remote: Counting objects: 3, done.
remote: Total 3 (delta 0), reused 0 (delta 0)
Unpacking objects: 100% (3/3), done.
[root@node-2 data]# cd taikang_test/
[root@node-2 taikang_test]# ls
readme rootv1
[root@node-2 taikang_test]# touch zhangsanv1
[root@node-2 taikang_test]# ls
readme rootv1 zhangsanv1
[root@node-2 taikang_test]# git add -A
[root@node-2 taikang_test]# git commit -m 'zhangsanv1'
[master 352056b] zhangsanv1
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 zhangsanv1
2.提交代码
[root@node-2 taikang_test]# git push origin master
Password for 'http://zhangsan@pangbing.com':
Counting objects: 3, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (2/2), 274 bytes | 0 bytes/s, done.
Total 2 (delta 0), reused 0 (delta 0)
remote: GitLab: You are not allowed to push code to protected branches on this project.
To http://zhangsan@pangbing.com/root/taikang_test.git
! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'http://zhangsan@pangbing.com/root/taikang_test.git'
这时候我们提交代码报了一个错误
2.1 全局分支保护
这是因为默认 master 分支是处于被保护状态下的,develop 角色是没有权限提交到 master 分支的。这是全局配置的分支保护
完全保护:开发人员不能推送提交,只有主程序员可以。不允许任何人强制推送或删除分支
2.2 项目分支保护功能
在每一个项目中都可以设置属于自己的项目的分支保护
由此可以看出上边提交代码错误,是因为zhangsan是开发者,没有权限提交到gitlab代码库
3.修改用户提交权限
这样就开发者也就可以提交到master分支了。或者把zhangsan直接变成
[root@node-2 taikang_test]# git add -A
[root@node-2 taikang_test]# git commit -m 'zhangsanv1'
[master 3a22927] zhangsanv1
1 file changed, 1 insertion(+)
[root@node-2 taikang_test]# git push origin master
Password for 'http://zhangsan@pangbing.com':
Counting objects: 8, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (6/6), 524 bytes | 0 bytes/s, done.
Total 6 (delta 0), reused 0 (delta 0)
To http://zhangsan@pangbing.com/root/taikang_test.git
2960619..3a22927 master -> master
三、生产中分支保护设置
在实际生产中 会设置一个test的分支,允许开发和主程序员同时push代码。但是master只能主程序员可以push.然后在将test分支合并到master分支上
四、复现生产分支保护设置
1.新建分支
图1:
图2:
图3:分支已经创建完成
2.分支上新建文件
3.客户端克隆仓库
#以zhangsan用户的身份克隆仓库
[root@node-2 data]# git clone http://zhangsan@pangbing.com/root/taikang_test.git
Cloning into 'taikang_test'...
Password for 'http://zhangsan@pangbing.com':
remote: Counting objects: 26, done.
remote: Compressing objects: 100% (18/18), done.
remote: Total 26 (delta 3), reused 11 (delta 2)
Unpacking objects: 100% (26/26), done.
虽然刚克隆下来的时候没有test-500分支,其实已经克隆下来了 直接切换分支即可。这里发现test-500文件也存在
[root@node-2 data]# cd taikang_test/
[root@node-2 taikang_test]# ls
readme zhangsanv1
[root@node-2 taikang_test]# git branch
* master
[root@node-2 taikang_test]# git checkout test-500
Branch test-500 set up to track remote branch test-500 from origin.
Switched to a new branch 'test-500'
[root@node-2 taikang_test]# ls
readme test-500 zhangsanv1
在test-500分支上创建新文件在提交
[root@node-2 taikang_test]# touch test01
[root@node-2 taikang_test]# echo "test01" > test01
[root@node-2 taikang_test]# git add -A
[root@node-2 taikang_test]# git commit -m 'test01'
[test-500 5e6f503] test01
1 file changed, 1 insertion(+)
create mode 100644 test01
[root@node-2 taikang_test]# git push origin test-500
Password for 'http://zhangsan@pangbing.com':
Counting objects: 4, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 332 bytes | 0 bytes/s, done.
Total 3 (delta 0), reused 0 (delta 0)
remote:
remote: To create a merge request for test-500, visit:
remote: http://pangbing.com/root/taikang_test/merge_requests/new?merge_request%5Bsource_branch%5D=test-500
remote:
To http://zhangsan@pangbing.com/root/taikang_test.git
f358476..5e6f503 test-500 -> test-500
4.以zhangsan的身份登录gitlab
图1:
图2:
在这里发现 系统会自动提示在taikang_test项目中有可以合并分支的请求
当然点击项目进入项目主页之后也会看到
5.发送合并代码请求
图1:
图2:
6.使用管理员登录gitlab 处理合并请求
图2:
图3:
图4:
7.验证合并
此时我们发现在master上已经有test-500分支上的文件了
更多推荐
已为社区贡献1条内容
所有评论(0)