自动化部署之gitlab权限管理--issue管理

  • 创建Group,User,Project
  • 创建一个组,组名为java

    Group path http://192.168.56.11/java
    Visibility Level:    #为权限级别,一般使用Private
    Private
    Internal
    Public

    创建一个PM的用户作为项目管理者并加入到java组内

    创建一个项目:

    创建dev1和dev2的用户作为开发者,并加入到项目中

    2.测试dev1,dev2拉取代码库

    (1)生成ssh-key
    [[email protected] ~]# ssh-keygen 
    Generating public/private rsa key pair.
    Enter file in which to save the key (/root/.ssh/id_rsa): 
    Created directory '/root/.ssh'.
    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:Hf3O9F7sS9N04cFUr3Awb/Wec28gTpHYyRZMCzLW9q0 [email protected]
    The key's randomart image is:
    +---[RSA 2048]----+
    |        +..o=  .+|
    |       . oo*.Oo.o|
    |         [email protected]++o|
    |         . o.*oo+|
    |        S . o.=+=|
    |           oE= =*|
    |            . ooB|
    |              .+o|
    |               .+|
    +----[SHA256]-----+
    [[email protected] ~]# cat .ssh/id_rsa.pub 
    ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDLDVIqTAvJtj8Uc+SvhcKOKuDtURt3YBxHo9enUkDjOWtSygLZI4hSrEsnvjHdnxeBGOgjPrxEfMMdNCno4pox7V/8bIU9LRVp2eeQFS+N+bSmbJlTKyODa0tabPwT7URYoiFI3giQamQdA0AwwPCPM/RcXwHJsw4q0O/2woCqNKq2tHaUFBqojd2KvqavzpB+4+AdKJSoabwLhE8dzfjIR/eHY31Y2C/+m9sU504v+R0GsAqr5uifi6Ct9eFvumI54BvHssIpZFZmADTT35b1aP0WSwZb2VEhXjaia8L6h/6ANn1NuHGgYZqNiYT6JILESKbrc7PyJOn9DfHKSMq9 [email protected]
    
    (2)将公钥(id_rsa.pub)放进dev1账户中
    在admin账户下给dev1,dev2账户设置密码,然后使用dev1登录gitlab,做如下操作添加ssh-key:
    测试是否能正常拉取代码库app1
    [[email protected] ~]# git clone [email protected]:java/app1.git
    Cloning into 'app1'...
    The authenticity of host '192.168.56.11 (192.168.56.11)' can't be established.
    ECDSA key fingerprint is SHA256:p2lhKmsPQ6K+dWHHvbJg0GV+Ni9VM7vlViKrYsZLP1s.
    ECDSA key fingerprint is MD5:22:14:1c:37:de:47:1c:4a:2f:88:b1:dc:e2:d0:02:17.
    Are you sure you want to continue connecting (yes/no)? yes
    Warning: Permanently added '192.168.56.11' (ECDSA) to the list of known hosts.
    warning: You appear to have cloned an empty repository.
    Checking connectivity... done.
    [[email protected] ~]# ll
    total 6804
    -rw-------.  1 root root     948 Dec  3 01:21 anaconda-ks.cfg
    drwxr-xr-x   3 root root      17 Dec 20 15:00 app1
    drwxr-xr-x  22 root root   24576 Dec  8 22:16 git-2.7.4
    drwxr-xr-x   3 root root      65 Dec  9 01:23 test
    -rw-r--r--   1 root root 6918037 Dec  8 22:09 v2.7.4.zip
    [[email protected] ~]# cd app1
    [[email protected] app1]# ll
    total 4
    -rw-r--r-- 1 root root 19 Dec 20 15:05 readme

    到此,Linux环境下完成了gitlab的授权管理代码库。

    下面以PM用户进行创建开发计划

    开发一个官网V1.0版本,包含首页和新闻

    (1)创建里程碑(Milestone

    (2)依次把任务首页,新闻添加到里程碑,并进行任务分配给开发者

    (3)使用dev1用户登录查看,会有任务提示,如图:

    (4)dev1开发者收到任务,进行开发

    [[email protected] app1]# git checkout -b shouye    #创建首页分支
    Switched to a new branch 'shouye'
    [[email protected] app1]# git status
    On branch shouye
    nothing to commit, working directory clean
    [[email protected] app1]# echo "<h1> welcome to www.123.com" > index.html    #进行开发
    [[email protected] 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
    [[email protected] app1]# git add .
    [[email protected] app1]# git commit -m "shouye"    #开发完成,提交本地仓库
    [shouye babdcb5] shouye
     1 file changed, 1 insertion(+)
     create mode 100644 index.html
    [[email protected] 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 [email protected]:java/app1.git
     * [new branch]      shouye -> shouye
     
     可以看到有刚才创建的分支,点击"merge request"合并分支请求,之后PM用户登录处理合并请求。此时,一个功能的开发流程就完成。

    总结:

    1. PM在gitlab创建任务,分配给开发人员
    2. 开发人员领取任务后,在本地使用git clone拉取代码库
    3. 开发人员创建开发分支(git checkout -b dev),并进行开发
    4. 开发人员完成之后,提交到本地仓库(git commit )
    5. 开发人员在gitlab界面上申请分支合并请求(Merge request)
    6. PM在gitlab上查看提交和代码修改情况,确认无误后,确认将开发人员的分支合并到主分支(master)
    7. 开发人员在gitlab上Mark done确认开发完成,并关闭issue。这一步在提×××并请求时可以通过描述中填写"close #1"等字样,可以直接关闭issue。
    时间: 2024-10-01 00:31:28

    自动化部署之gitlab权限管理--issue管理的相关文章

    Jenkins+Ansible+Gitlab自动化部署三剑客-gitlab本地搭建

    实际操作 准备linux初始环境 关闭防火墙 systemctl stop firewalld 开机自己关闭 systemctl disable firewalld 设置安全配置 为关闭 vim /etc/sysconfig/selinux 重启虚拟机 reboot 查看安全策略是否关闭 getenforce 安装gitlab依赖软件 yum install curl policycoreutils openssh-server openssh-clients postfix 下载gitlab

    持续集成+自动化部署[代码流水线管理及Jenkins和gitlab集成]

    持续集成+自动化部署[代码流水线管理及Jenkins和gitlab集成] 标签(空格分隔): Jenkins 一.代码流水线管理 Pipeline名词顾名思义就是流水线的意思,因为公司可能会有很多项目.如果使用jenkins构建完成后,开发构建项目需要一项一项点击,比较麻烦.所以出现pipeline名词. 代码质量检查完毕之后,我们需要将代码部署到测试环境上去,进行自动化测试 新建部署代码项目 点击新建 这里只需要写一下描述 执行Shell脚本 温馨提示:执行命令主要涉及的是权限问题,我们要搞明

    SpringBoot项目 使用Jenkins进行自动化部署 (gitLab管理项目)_

    1.部署服务器创建好对应文件夹和启动脚本 创建文件夹 mkdir /wdcloud/app/rps/rps-module-category 创建启动脚本 cd /wdcloud/app/rps/rps-module-category vim rps-module-category.sh #!/bin/bash APP_HOME=/wdcloud/app/rps/rps-module-category APP_JAR=rps-module-category-*.jar APP_PIDS=$(ps

    Docker虚拟化技术系列之-自动化部署管理

    随着企业Docker容器越来越多,如果要靠手工去管理docker,肯定非常吃力,而且也不现实,这就需要我们把日常的操作变成自动化管理,通过脚本工具,将工作减轻到最小,解放运维人员,如下为企业Docker自动化部署脚本V1版本,如果需要更多其他的功能,可以自己定制和修改. 如下自动化管理脚本功能: 1)通过YUM自动安装Docker平台: 2)通过该脚本,可以自动配置桥接网络: 3)自动创建docker容器,给予centos操作系统: 4)自动收集创建好的Docker容器,集中管理: 5)通过PI

    程序包管理rpm,yum用法解析及自动化部署apache server实战,让您轻松拥有apache网站!

    程序包管理器rpm,yum用法及apache httpd服务的自动化部署 程序包管理? 通常来说在windows中将需要安装的程序,程序名.exe下载下来然后点击setup的安装程序或直接点击程序包,下一步下一步即可.而Linux中程序包不是exe,不同的主流发行版有着不同的程序包管理机制.比较主流的主要是rpm程序包管理器和deb程序包管理. 这里要区别: 包名(PACKAGEFILE): rpm包程序文件的全名程序名(PACKAGENAME): rpm包不带版本号的程序名,比如QQ而不是QQ

    使用 GitHub / GitLab 的 Webhooks 进行网站自动化部署

    老早就想写这个话题了,今天正好有机会研究了一下 git 的自动化部署.最终做到的效果就是,每当有新的 commit push 到 master 分支的时候,就自动在测试/生产服务器上进行 git pull 拉取最新的代码,免去了程序猿兼职运维 ssh 上去拉代码部署的重复性工作.我们也要 Agile development 不是?什么敏捷开发啊,极限编程啊,快速迭代啊,持续集成啊,精益创业啊,口号怎么高端怎么来,最后就是写了个自动化脚本…… 一.自动化部署脚本 首先要保证要部署的 Web 目录就

    基于Jenkins+Gitlab的自动化部署实战

    故事背景 一个中小型企业,是典型的互联网公司,当初期的时候可能运维只能标配到2~3人,此时随着公司的发展,项目会逐渐增多.前期部署项目可能都是手动的, 俗称"人肉部署",这简直是无比的痛苦,不能忍受的.这样开发的时间也会耽误,运维的时间也会耽误,全都浪费在这些重复性的工作上面,毫无价值可言, 这时候运维终于忍受不了,上了脚本.但是慢慢的发现项目依旧在增长,脚本每次还要更改给开发,效率低下,后来测试环境以及开发环境直接上了jeknins, 每台开发机器是jeknins agent端,自此

    Linux下的Jenkins+Tomcat+Maven+Gitlab+Shell环境的搭建使用(jenkins自动化部署)

    jenkins自动化部署 目标:jenkins上点构建(也可以自动检查代码变化自动构建)>>>项目部署完成. 一.安装jenkins 1.下载jenkins 这里我选择的是war包安装jenkins,简单不伤脑,别的博客写的jenkins版本都很旧,没用最新的,写个比较新的配置2.20版. 官网:https://jenkins.io/index.html WAR包下载地址:http://mirrors.tuna.tsinghua.edu.cn/jenkins/war/2.20/jenki

    Jenkins+Ansible+Gitlab自动化部署三剑客

    最近一直在学习Ansible的一些playbook的写法, 所以一直没有怎么更新, 想到目前大家对诸如saltstack, docker, Ansible等自动化部署相关的工具很感兴趣, 但又苦于没有可学习的中文实例, 这里我就把我这几个月所接触到目前国外比较流行的部署经验给大家分享一下. 首先给大家介绍的是Ansible, 恩, 重要的问题说三遍, 不是Saltstack, Ansible作为一个python写的自动化部署工具, 确实较之前我所接触的Chef, saltstack, puppe