初入公司用不好git ?-- 本篇针对GitLab

这篇具有很好参考价值的文章主要介绍了初入公司用不好git ?-- 本篇针对GitLab。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本篇并不涉及git的所有知识,内容包括工作中每天用到的以及需要知道的

一、从远程仓库拉取指定分支到本地仓库,并创建个人分支

1. git clone 项目地址 (克隆整个项目)
2. git checkout dev (切换到dev分支,在本地创建dev分支并与远程进行关联)
3. git checkout -b 我的分支 (基于dev创建并切换到我的分支)
4. git push -u origin 我的分支 (将个人分支推送到远程仓库)
 二、(补充)基于以上补充几点基础知识点以便你更好理解并实践

1. 主分支:通常是master分支

2. 开发分支:基于主分支派生,你通常在这个分支上建立自己的分支

3. 特性分支:为开发单独功能,基于开发分支派生,属于“我的分支”

4. 发布分支:基于主分支派生,包含与发布相关的所有更改

5. 热修复分支:基于主分支派生,用于快速修复紧急问题

三、拿到项目以后的几个注意细节

1. cd到正确的项目,git checkout到正确的分支(往往一个大仓库里包含许多项目,要到你的项目中来)

2. 在执行每个子项目之前,都需要单独安装依赖,比如:npm install

四、配置全局的用户名和邮箱信息

1. 修改用户名:git config --global user.name "username"
2. 修改邮箱:git config --global user.email "email@example.com"
3. 查看用户名:git config user.name
4. 查看邮箱:git config user.email

五、查看自己的修改

git status 可以查看自己刚才修改代码的文件
git diff 可以查看自己刚才修改的具体代码

六、一张图来解释操作流程

初入公司用不好git ?-- 本篇针对GitLab,git,gitlab

Remote是远程仓库,Repository是本地仓库,workspace是我的工作区。

你从远程仓库clone代码到本地仓库,然后在本地仓库checkout到我的工作区,

当你每次修改完代码要提交,这也是你基本每天都需要做的步骤:

从我的工作区add到本地缓存区,然后commit到本地仓库,然后push进远程仓库,

下面我来仔细讲讲这一步该怎么做!

七、如何提交自己的代码

1. git status (查看修改)
2. git add . (提交到缓存区)
3. git commit -m "xxx" (提交到本地仓库)
4. git push (推进远程仓库)
5. git checkout master (切换到需要合并的分支,这里以master为例)
6. git pull (拉取这个分支的最新代码)
7. git merge master (合并,这个时候可以切换到自己的分支)
8. git status (可以在查看一下)
9. git push (push进去)

八、关于rebase

rebase也一直是让我比较头疼的地方,在工作中我尽量避免使用,我通常使用merge

初入公司用不好git ?-- 本篇针对GitLab,git,gitlab

rebase,变基,改变基底,feature分支是基于master分支B拉出来的分支,feature的基底是B,而master在B之后有新的提交,此时会把master分支的提交作为feature的新基底,在操作中就是把B之后的feature的提交暂存下来,然后删掉原来的提交,再找到master最新的提交位置,把存下来的提交接上去,解决冲突,feature的基底变成了M而不是B

初入公司用不好git ?-- 本篇针对GitLab,git,gitlab

当在feature分支上执行git rebase master时,git会从master和feature的共同祖先B开始提取feature分支上的修改,也就是C和D两个提交,提取到,然后将feature分支指向master分支的最新提交上,也就是M,最后把提取到的C和D接到M后面(依次拿M和C、D内容分别比较,处理冲突后生成新的C'和D')

开发场景:远程😭上有一个分支开发到B了,我从B拉了代码到我的分支进行开发,目前提交了两次,开发到D,另外一个人也从B拉到本地的master分支,他提交到了M,然后合到远程库上的master了,我想拉取master的最新代码,于是在我的分支上执行了rebase操作,即把远程的master分支给rebase下来,因为另一个人比我早开发完,所以此时的master上是他的最新内容,rebase后再看我的历史提交记录,就相当于我是基于另一个人提交的最新M进行开发的了。

九、Merge 合并

把分叉的提交历史放回到一起,通常被用来合并两个分支,git merge接受两个commit指针,追溯到两个分支最近的共同分支,然后创建一个新的“merge commit",用来合并两个分支上各自的提交序列

有两种类型:

1. 快进式合并:目标分支是被合并分支的直接祖先,合并过程不会哦产生冲突

2. 三方合并: 目标分支和被合并分支在历史上有分叉,找到共同祖先进行比较,新的提交会包含两个分支的差异内容,可能出现冲突合并

十、git merge 和 git rebase 的区别

merge:是将分支A和分支B合并为一个新的提交,把修改合并,一个新的合并,保留了各个分支的独立性

rebase:将当前分支的修改和提交应用到目标分支的最新提交之后,线性的提交历史,避免合并产生的分叉

1. 拉取公共分支最新代码 -- rebase
2. 往公共分支上合并代码 -- merge

尽量不要使用rebase,因为有个缺点就是不知道我当前的分支是从哪个分支上拉出来的,因为基底变了,其他人想看分支的历史,就不再是原来的历史了,历史被篡改了

十一、git stash

分支有改变时不能提交又不能切换分支,会保存当前的工作进度,把暂存区和工作区的改动保存到栈中,需要时再恢复,执行完这个命令以后,git status是clean

1. git stash save "message" 这是带上注释
2. git stash pop 默认恢复git栈中最新的stash,建议在栈中只有一条时使用(栈删除)
3. git stash list 查看所有隐藏,每一行冒号前面的字符串就是标识此隐藏的id
4. git stash apply n 将内容恢复到当前分支下,n为stash list结果里的序号(栈保留)
5. git stash drop n 恢复隐藏后,从栈中移除指定的stash
6. git stash clear 移除全部的stash
7. git stash show 查看栈中最新保存的stash和当前目录的差异,显示改动

十二、git常用命令

git log 查看所有提交的记录
git branch 查看本地分支
git branch -r 查看远程分支
git branch -a 查看全部分支
git branch -d [分支名] 删除本地分支
git push origin :[分支名] 删除远程分支
git reset HEAD 使暂存区的代码退回到最近的一次状态,即撤销git add .

十三、常见报错

1. pull之前要commit
初入公司用不好git ?-- 本篇针对GitLab,git,gitlab2. 合并冲突:两个人改了同一个地方

解决:手动解决问题,看看使用什么代码,然后再进行提交操作

3. push未设置关联远程分支报错
使用git push报如下错误:fatal:The current branch master has no upstream branch

解决1: 根据需要替换分支名:git push --set-upstream origin master

解决2: 根据需要替换分支名,远程分支master不存在会创建:git push -u origin master

4. 冲突报错系列

初入公司用不好git ?-- 本篇针对GitLab,git,gitlab

方法:保留本地代码:中止合并 --> 重新合并 --> 重新拉取

step1: git merge --abort

step2: git reset --merge

step3: git pull文章来源地址https://www.toymoban.com/news/detail-752858.html

到了这里,关于初入公司用不好git ?-- 本篇针对GitLab的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • git配置连接gitlab

    1、查看版本号(cmd) git --version 2、配置并查看git本地配置账号邮箱 $ git config --global user.name \\\"hd\\\" $ git config --global user.email \\\"hd@qq.com\\\" 查看配置信息 查看全部 $ git config -l 查看账号 $ git config user.name 配置本地账号邮箱: $ git config user.email 查看本地电脑有配置文件  C:Usershd.git

    2024年02月15日
    浏览(43)
  • CentOS 搭建 GitLab && Git

    1. 安装 sshd 依赖 输入以下命令: 注:因为我之前已经装过了 sshd 依赖,所以就如上图所示。没装过的耐心等待就好。 2. 启动并设置开机自启 依次输入以下命令: 3. 安装防火墙 如果已经安装了防火墙并且已经在运行状态,则可直接进行第 5 步。 那如何判断 CentOS7 是否安装了

    2024年02月15日
    浏览(51)
  • [GitLab] 安装Git 指定版本

    检查是否已经安装 如果已经安装,先卸载 在GitHub上选择需要下载的版本 Git版本 在/usr/local/目录下新建文件夹:git,并在/usr/local/git/文件夹内下载压缩包 解压 进入根目录 安装依赖库 编译git源码 安装git至/usr/local/git路径 编辑配置文件 在末尾追加 使配置文件生效 查询git版本

    2024年02月05日
    浏览(50)
  • Git & GitLab 使用及规范

    Git安装配置及基本使用 从官网下载安装包,手动完成安装。 打开 Git Bash 命令行工具,执行命令 ssh-keygen -t rsa -C Email-Addresss 生成一个密钥对。 登录到GitLab,点击右上角你的用户头像,点击 Edit Profile settings ,点击 SSH Keys ,点击 Add SSH Key ,填写 Title 栏,复制用户目录下 .ssh

    2024年02月09日
    浏览(38)
  • git学习笔记 - 下载gitlab项目

    一种是下载gitlab的master主分支的内容: 另一种下载指定分支的gitlab项目内容: 拓展 : 如果当你clone出现一些问题, 尤其是 timeout 相关问题, 可以如下操作: 在之前的 git clone http://xxxx 中的网址前面添加 https://ghproxy.com/ .

    2024年02月09日
    浏览(38)
  • 本地部署gitlab学习git使用

    最近想学习git使用了,在本地部署一个gitlab社区版玩玩吧~ gitlab只能部署在liunx系统上面,可以使用云服务器,也可以使用虚拟机等等, 下面介绍小电脑里面安装虚拟机,虚拟机安装centos7,centos7在一键安装宝塔,宝塔再一键安装gitlab社区版,一气呵成,无脑下一步即可 前面

    2024年02月08日
    浏览(58)
  • Git和Gitlab部署与使用

    版本控制概念 :记录开发文件的时间机器 分类 :1.本地版本控制系统、2.集中化的版本控制系统CVS、Subversion(SVN)、3.分布式版本控制系统GIT 产品 :github、git、gitlab 1.介绍 git是一个分布式的代码版本管理软件,而 gitlab, gierrit, github都是git作为基础扩展其他功能开发而来,支持

    2024年02月10日
    浏览(36)
  • Git、GitHub和GitLab的区别

    Git官网 Git 是一个 分布式 的版本控制系统。 版本控制系统 是一种用于记录一个或多个文件内容变化,方便查阅特定版本修订情况的系统。 没有使用版本控制系统之前,如果需要记录同一份文件不同版本的修改,可能会以“file_v1”、“file_v2”、“file_v3”等命名方式来保存不

    2024年02月04日
    浏览(36)
  • git第一次推送gitlab项目

    第一次本地项目提交git远程厂库 1、通过命令 git init 把这个目录变成git可以管理的仓库 2、把文件添加到本地暂缓区 3、commit提交到本地分支 4、去gitlib上拿到你项目的地址 5、切换main分支 6、提交远程仓库 提交步骤 1、首先你先通过git init git clone 基本环境准备好后,你写完自

    2024年02月02日
    浏览(51)
  • git使用指南——以gitlab为例

    注册gitlab 自行注册 新建项目 选择新建一个空白的项目 clone项目地址到本地 执行完之后,会在目录下生成如下内容: 进入里面,选择.git,要上传的内容(资料或代码复制到该目录下): 选择上传分支 如果不选择上传的分支,会默认上传到master分支上面 新建分支 打开项目页

    2024年01月24日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包