自動化部署之gitlab權限管理--issue管理

一.刪除測試項目html

先進入項目,選擇編輯項目java

二.拉取到最下方,移除項目node

三 輸入你要刪除的項目名稱linux

 

二 建立Group,User,Projectgit

2.1 建立一個組,組名爲javabash

Group path http://10.0.0.12/java
Visibility Level:    #爲權限級別,通常使用Private
Private
Internal
Public

group裏面的用戶會集成項目的權限,因此組裏面通常只添加管理員和項目經理的權限,後面在單獨給某個項目分配權限.app

 

2.2 建立用戶(用戶最好對接到ldap或者ad域中)dom

建立一個項目ssh

 

 2.3 設置app項目的用戶權限ide

管理員權限和項目經理的權限已經經過組默認繼承過來了

2.4 測試user1,user2拉取代碼庫

生成密鑰

[root@7mini-node1 ~]# ssh-keygen 
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): 
/root/.ssh/id_rsa already exists.
Overwrite (y/n)? y
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:yS/DX9BAbakf9oPRJ5YC+iwwlMu+C2Ps6DE1GmqzKGA root@7mini-node1
The key's randomart image is:
+---[RSA 2048]----+
|       .  .. .   |
|      o  .. +    |
|     o . ..+ . . |
|      =....o= = .|
|  . o. oSo.o.B o |
|.E = .....o.o o  |
|+o+ =  .+.. .  . |
|+ o* o.  + .     |
|ooo . ..  .      |
+----[SHA256]-----+
[root@7mini-node1 ~]# cat .ssh/id_rsa.pub 
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCU4UsK8DAhs3NjohtfaNTU8zJ/RHZBMRmY0c9xTFTtjZZtbONCgJGYAMIb6fjRBWG5pSS+EqA49vgM3TOnBasLlngbYxOMuwGT6OMMxB90hkOeOPn1Jg3Vhy7+1l2iem/O4+F1EsA5Q61d02VqQ/HUsLZ/Ka4Y1FDCVIrq9L38bfLq32esOVsxl9PaL/vJlTzqXozVNc169M5G8zdJycni9XdHuVH3tk4BkU4JmSHCaBHtcZRKzLJ1nT3Ox2W19JReuuLRbZNI1I9HDmdsWqlbj3kmOd6FWA7S9rWuzCN353q53BXi5GX/xq0hYgoukNSmZ+JLB8BOpfNPqdUXPdV7 root@7mini-node1
將公鑰(id_rsa.pub)放進dev1帳戶中
在admin帳戶下給dev1,dev2帳戶設置密碼,而後使用dev1登陸gitlab,作以下操做添加ssh-key:

測試是否能正常拉取代碼庫app
[root@7mini-node1 ~]# git clone git@10.0.0.12:java/app.git
Cloning into 'app'...
warning: You appear to have cloned an empty repository.
Checking connectivity... done

下面以PM用戶進行建立開發計劃

 

三 開發一個官網V1.0版本,包含首頁和新聞

3.1 建立里程碑(Milestone

3.2 依次把任務首頁,新聞添加到里程碑,並進行任務分配給開發者

 

 

3. 3 使用dev1用戶登陸查看,會有任務提示,如圖:

 

3.4 dev1開發者收到任務,進行開發

[root@linux-node1 app1]# git checkout -b shouye    #建立首頁分支
Switched to a new branch 'shouye'
[root@linux-node1 app1]# git status
On branch shouye
nothing to commit, working directory clean
[root@linux-node1 app1]# echo "<h1> welcome to www.123.com" > index.html    #進行開發
[root@linux-node1 app1]# ll
total 8
-rw-r--r-- 1 root root 28 Dec 20 15:50 index.html
-rw-r--r-- 1 root root 19 Dec 20 15:05 readme
[root@linux-node1 app1]# git add .
[root@linux-node1 app1]# git commit -m "shouye"    #開發完成,提交本地倉庫
[shouye babdcb5] shouye
 1 file changed, 1 insertion(+)
 create mode 100644 index.html
[root@linux-node1 app1]# git push origin shouye    #提交到遠程庫
Counting objects: 3, done.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 292 bytes | 0 bytes/s, done.
Total 3 (delta 0), reused 0 (delta 0)
remote: 
remote: To create a merge request for shouye, visit:
remote:   http://192.168.56.11/java/app1/merge_requests/new?merge_request%5Bsource_branch%5D=shouye
remote: 
To git@192.168.56.11:java/app1.git
 * [new branch]      shouye -> shouye
 

 3.4 能夠看到有剛纔建立的分支,點擊"merge request"合併分支請求,以後PM用戶登陸處理合並請求。此時,一個功能的開發流程就完成。

image.png

3.5 首頁項目測試沒問題後,在user1用戶請求項目經理融合到master分支上面去,經理確認。

 

總結:PM在gitlab建立任務,分配給開發人員開發人員領取任務後,在本地使用git clone拉取代碼庫開發人員建立開發分支(git checkout -b dev),並進行開發開發人員完成以後,提交到本地倉庫(git commit )開發人員在gitlab界面上申請分支合併請求(Merge request)PM在gitlab上查看提交和代碼修改狀況,確認無誤後,確認將開發人員的分支合併到主分支(master)開發人員在gitlab上Mark done確認開發完成,並關閉issue。這一步在提×××並請求時能夠經過描述中填寫"close #1"等字樣,能夠直接關閉issue。

相關文章
相關標籤/搜索