• GitLab的使用


    目录

    一、腾讯云 / 阿里云 购买服务器

    二、服务器上安装GitLab-ce

    三、使用git

    1、首先把服务器上的代码克隆下来

    2、将所有有改动的全部添加到要提交的本地库中

    3、将修改提交到本地库

    4、将本地库的commit推送到远程服务器

    5、拉取服务器上最新资源:

    6、在不同的分支之间切换:git checkout 分支名

    7、合并分支:git merge 分支名

    8.创建分支

    9.查看分支

    10.切换分支

    11.分支合并

    12.删除分支

    13、合并分支:

    四、配置gitlab的ssh keys


    一、腾讯云 / 阿里云 购买服务器

    二、服务器上安装GitLab-ce

    找到买的服务器--点远程连接--workbench远程连接--立即登录

    1.相关环境、依赖安装
    yum -y install policycoreutils openssh-server openssh-clients postfix
    yum install  policycoreutils-python
    systemctl enable sshd && sudo systemctl start sshd
    systemctl enable postfix && systemctl start postfix
     
    2.关闭防火墙或者防火墙增加白名单
    systemctl stop firewalld.service
     
    3.下载软件
    wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el6/gitlab-ce-13.6.7-ce.0.el6.x86_64.rpm
     
    4.开始安装
    rpm -i gitlab-ce-13.6.7-ce.0.el6.x86_64.rpm
     
    5.修改默认端口
    cd /etc/gitlab
    vi gitlab.rb
     
    6.在文件中修改 external_url和nginx['listen_port']的key对应的内容
    external_url 'http://114.96.82.2:8280'
    nginx['listen_port'] = 8280
     
    6.重启
    gitlab-ctl reconfigure
    gitlab-ctl restart
     
     
    7.页面输入即可访问
    'http://ip:端口号

    三、使用git

    1、首先把服务器上的代码克隆下来

    1. git clone


    2、将所有有改动的全部添加到要提交的本地库中

    也可以用git add 文件名进行单独文件的提交

    1. git add .


    3、将修改提交到本地库

    1. git commit -a -m "提交添加的注释信息"

    4、将本地库的commit推送到远程服务器

    1. git push

    5、拉取服务器上最新资源:

    1. git pull

    6、在不同的分支之间切换:git checkout 分支名

    注意事项:切换分支的时候,如果当前分支有改动没有提交,是不能切换分支的,需要先把改动的内容提交或者放入缓存区

    1. git checkout release/v1.0.0

    7、合并分支:git merge 分支名

    1. git merge feature/login

    从当前分支merge feature/login分支的内容,如果有两个人修改了同一个文件的同一行,则会有冲突,可以在IDE工具上先解决当前冲突然后再提交。

    8.创建分支

    使用:"git branch 分支名称" 创建分支


    9.查看分支

    使用:"git branch" 查看分支


    期中 * 号表示现在选中的分支(默认选中开发主线)

    10.切换分支

    使用:"git checkout 分支名称" 切换分支

    这时会提示我们切换到分支”bin“ ,使用"git branch"查看分支,*号就显示到分支”bin“上

    这时候我们就可以在分支上工作,不会影响到主线的代码。当我们工作完成,需要把分支改动提交到主线时,我们就要用到分支合并"git merge 来源分支"

    11.分支合并

    "git merge 来源分支" 合并分支 (备注:必须在master分支上才能合并开发分支)
    合并分支前,我们需要先利用切换分支命令"git checkout master" 转换到主线。

    切换成功有提示
    确认切换到主线后,再"git merge 来源分支" 合并分支

    12.删除分支

    "git branch -d 分支名称" 删除分支(分支被合并后才允许删除)(-D 强制删除)

    13、合并分支:

    方法一:使用merge命令合并分支
    1、目标:将dev分支合并到master分支
    1.1、首先切换到master分支上
    git checkout master

    1.2、如果是多人开发的话 需要把远程master上的代码pull下来
    git pull origin master
    //如果是自己一个开发就没有必要了,为了保险期间还是pull

    1.3、然后我们把dev分支的代码合并到master上
    git merge dev 
    //如果有冲突,手动解决冲突就行。

    1.4、然后查看状态及执行提交命令
    git status

    On branch master Your branch is ahead of 'origin/master' by 12 commits.   (use "git push" to publish your >local commits) nothing to commit, working tree clean

    //上面的意思就是你有12个commit,需要push到远程master上 
    > 最后执行下面提交命令 
    git push origin master 

    方法二、合并某个分支上的单个commit(cherry-pick命令)
    比如 feature 分支上的commit 82ecb31非常重要,它含有一个bug的修改,或其他人想访问的内容。
    无论什么原因,你现在只需要将82ecb31合并到master,而不合并feature上的其他commits;
    所以我们用git cherry-pick命令来做:

    git checkout master  
    git cherry-pick 82ecb31

    这样就好啦。
    现在82ecb31就被合并到master分支,并在master中添加了commit(作为一个新的commit)。
    cherry-pick和merge比较类似,如果git不能合并代码改动(比如遇到合并冲突),git需要你自己来解决冲突并手动添加commit。

    这里git cherry-pick每次合并过来会显示文件冲突(其实并没有冲突代码部分,只需手动解决既可)。

    四、配置gitlab的ssh keys

    1、打开win+r==>cmd

    2、git config --global user.name "gitlab的名字"

    3、git config --global user.email "输入邮箱"

    4、git config --global --list    //查看是否有

    5、ssh-keygen  //三次回车

    6、打开git base here 然后再输入

    在~/.ssh/下会生成两个文件,id_rsa和id_rsa.pub

    id_rsa是私钥

    id_rsa.pub是公钥

    7、查看是否生成了id_rsa和id_rsa.pub
    cd ~/.ssh
    ls
    cat id_rsa.pub

    查看 ssh 公钥方法:

    1、通过命令窗口

    a. 打开你的 git bash 窗口

    b. 进入 .ssh 目录:cd ~/.ssh

    c. 找到 id_rsa.pub 文件:ls

    d. 查看公钥:cat id_rsa.pub 或者 vim id_rsa.pub

    查看密钥,如图:

     

  • 相关阅读:
    基于编码的数字签名综述
    从 WebStorm 转到 VSCode!使用一周体验报告
    swift加载h5页面空白
    关于Windows 7操作系统进行磁盘碎片整理时提示“已使用其他程序计划了磁盘碎片整理程序”的解决办法
    webpack配置杂记
    访问者模式(Visitor Pattern)
    两种方式实现css取消页面鼠标双击选中文字或单击拖动选中文字的效果
    资源描述框架的用途及实际应用解析
    Spring 高级依赖注入 —— Bean的延迟依赖查找功能,ObjectFactory 和 ObjectProvider
    Python150题day01
  • 原文地址:https://blog.csdn.net/qq_52301431/article/details/127967852