.eye-care { background-color: rgba(199, 237, 204, 1); padding: 10px }
.head-box { display: flex }
.text-indent { text-indent: 2em }
.text-bg { }
.bg { font-size: 12px; font-weight: 600; color: rgba(0, 0, 0, 1); margin-bottom: 20px }

GIT 运行流程图

GIT 常规操作

Git完整操作流程


创建分支

  • .gitignore文件

    选择哪些文件不需要git进行上传(版本管理,前端项目一般是nodemodules文件
  • git clone 的是dev的分支,怎么提交到other分支

    1. git branch -m oldBranch newBranch (切换分支: git branch -m dev function/hasdone)
    2. git push -u origin function/hasdone (push 的时候页更新一下分支)

    git clone -b xxx 拉取指定xxx分支的代码

  • git checkout -b 本地分支名 origin/远程分支名

    创建并指定特定远程分支
  • git branch -d 指定分支名 删除该分支

  • git push origin 指定分支名(如没有则新建)


命令行 diff 代码

  1. diff展示指定文件差异:git diff xxx文件

  2. diff展示总体差异

  • git diff branch1 branch2 --stat

    显示差异的概括陈述,branch2 比 branch1 增删的文件,branch1为参考分支
  • git diff branch1 branch2 具体文件路径

    显示两个分支在该文件的具体差异
  • git diff branch1 branch2

    显示两个分支的全部具体差异(不推荐)

命令行 diff 分支,查看分支commit的差异

  • git log branch1 ^branch2

    branch1分支有,而branch2分支没有
  • git log branch1..branch2

    b2 比 b1 多提交的commit日志
  • git log branch1...branch2

    单纯显示两个分支日志的不一样
  • git log -left-right branch1...branch2

    显示日志的不一样基础上显示不同点是在哪个分支上

rebase 合并分支

  • 当你push你的commit时,其他人先于你 提交了 一些commit,产生了冲突

    直接pull或者merge,都会在git log 你的日志上产生一个分叉然后合并的情况,分叉为其他人提交的commit
  • 优雅永不过时,`git rebase Main self`

    将Main 分支 合并到 self 分支,不会产生分支,self 分支上有而 Main 分支上没有的commit将会按需加入你的日志中
  • 尔后,你再 push 你的分支,将 self 分支上的commit 提交上去

    这样冲突就变成一个线性的状态,不会产生额外的分支

版本回退

  • git reset回退到历史版本

    1. git log --pretty=oneline : 找一个需要回到的版本hash号
    2. git reset --hard 版本hash 号

代码回退

    情况1、只在本地工作区(workspace)新增了文件A,状态为untrack
    • 删除 untrack file文件

      • 删除指定untrack file :git clean -f xxx文件
      • 删除所有untrack file :git clean -f
    • 删除 untrack file文件及目录

      • 删除指定untrack file :git clean -fd xxx文件/目录
      • 删除所有untrack file :git clean -fd
    情况2、只在本地工作区(workspace)修改了文件A(包括删除文件A),但还没有使用 git add 把A的修改暂存到暂存区(index),状态为Changes not staged for commit
    • 撤回所有修改:git checkout .
    • 撤回指定文件的修改:git checkout -- xxx文件
    情况3、已经使用git add暂存了本地修改,状态为Changes to be committed:
    • 撤回所有暂存修改:git reset head .
    • 撤回指定文件的修改:git reset head -- xxx文件
    情况4、已经使用git commit暂存了本地修改,状态为Your branch is ahead of ***
    • 如上文回退版本所示,强制回退到上一个版本:git reset --hard head^

      • 返回到某个节点,不保留修改 :git reset --hard commit_id,commit_id通过git log 查看
      • 返回到某个节点,保留修改 :git reset --soft commit_id

完整提交流程:

1. git add .
2. git stash save "提示信息" //存储到staged状态里面,不再进行跟踪
3. git merge 指定分支(可远可近) // 合并到本地代码
4. git [stash](https://www.cnblogs.com/zndxall/archive/2018/09/04/9586088.html "stash") pop 弹出并使用 / git stash apply 应用栈顶缓存

git四种基础状态



git报错处理

git提交报错:OpenSSL SSL_read: Connection was reset, errno 10054

解决:在每一次提交前修改全局配置:git config --global http.sslVerify "false"

centos7 git clone 报错:SSL certificate problem: unable to get local issuer certificate

解决:命令行输入git config --global http.sslVerify false

Git创建、diff代码、回退版本、撤回代码,学废了吗的更多相关文章

  1. 通过Tag标签回退版本修复bug

    tag是对历史一个提交id的引用,如果理解这句话就明白了使用git checkout tag即可切换到指定tag,例如:git checkout v0.1.0 切换到tag历史记录会处在分离头指针状态 ...

  2. Git的纯命令操作,Install,Clone , Commit,Push,Pull,版本回退,撤销更新,分支的创建/切换/更新/提交/合并,代码冲突

    Git的纯命令操作,Install,Clone , Commit,Push,Pull,版本回退,撤销更新,分支的创建/切换/更新/提交/合并,代码冲突 这篇是接着上篇分布式版本库--Windows下G ...

  3. git回退版本: 回退本地代码版本 + 回退服务器代码版本

    1.回退本地代码版本 借助IDEA开发工具回退版本,点击Version Control ,查看历史版本号: 右击想要回退的版本号,选择Reset Current Branch hear... 选择 H ...

  4. git的使用(包括创建远程仓库到上传代码到git的详细步骤以及git的一些常用命令)

    A创建远程仓库到上传代码到git 1)登陆或这注册git账号 https://github.com 2)创建远程仓库 3)打开终端输入命令 cd到你的本地项目根目录下,执行如下git命令 git in ...

  5. Git学习(二)——创建版本库、查看与回退版本

    一.创建版本库 版本库,又名仓库(Repository),可以简单理解为一个目录,这个目录里的所有文件可以被Git管理起来,每个文件的修改.删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者将来某 ...

  6. git创建远程项目并进行代码管理及相关命令

    1.windows下载Git     https://git-scm.com/downloads 然后一路点击安装 2.登录github,点击右上角创建仓库 3.在本地项目根目录下 输入如下命令 ss ...

  7. git代码回退

    情况1.还没有push可能 git add ,commit以后发现代码有点问题,想取消提交,用: reset git reset [--soft | --mixed | --hard] eg:  gi ...

  8. Git 如何优雅地回退代码

    前言 从接触编程就开始使用 Git 进行代码管理,先是自己玩 Github,又在工作中使用 Gitlab,虽然使用时间挺长,可是也只进行一些常用操作,如推拉代码.提交.合并等,更复杂的操作没有使用过, ...

  9. GIT如何根据历史记录回退代码

    ps: 因为使用这种方式回退后,回退的目标版本之后提交的代码都没了,所以建议先把当前代码打个tag 首先找到分支的提交记录 git log 将代码回退到历史版本 git reset --hard 0f ...

随机推荐

  1. vs完整编译Opencv+contrib

    准备条件 Opencv源码(以4.3.0为例) OpenContrib源码(以4.3.0)为例 最新版的CMake GUI CMake 生成项目 设置source code 和生成的build文件夹 ...

  2. 如何通过C#/VB.NET设置Word文档段落缩进

    缩进是指调整文本与页面边界之间的距离.在水平标尺,有四个段落缩进滑块:首行缩进.悬挂缩进.左缩进以及右缩进.在对于word文档的录入时,常常需要注意录入的格式,通过合理地设置段落格式,可以让文稿看起来 ...

  3. ubuntu语言支持打不开,点了没反应

    ubuntu语言支持打不开,点了没反应 sudo dpkg-reconfigure locales

  4. Python实现XMind测试用例快速转Excel用例

    转载请注明出处️ 作者:测试蔡坨坨 原文链接:caituotuo.top/c2d10f21.html 你好,我是测试蔡坨坨. 今天分享一个Python编写的小工具,实现XMind测试用例转Excel用 ...

  5. 中秋快乐!新鲜出炉一篇DjangoAdmin使用合集,DjangoAdmin的功能比你想象的强大!

    DjangoAdmin DjangoAdmin本身就是一套大而全的系统,官方文档中介绍了很多配置方法,但仍然有大量的骚操作是文档中没有的,所以遇到特殊需求的时候,求助文档不一定有用. 在我看来 Dja ...

  6. KubePi主界面添加镜像仓库并授权给集群,供创建Deployment时选择镜像使用

    1.添加kubeoperator自带的nexus仓库 2.添加harbor 3.把添加的镜像仓库授权给集群 4.关于镜像仓库secrets的有关说明 5.实际效果 6.从添加授权的镜像仓库创建工作负载 ...

  7. ProxySQL结构

    Qurey Processor 用于匹配查询规则并根据规则决定是否缓存查询或者将查询加入黑名单或者重新路由.重写查询或者镜像查询到其他hostgroup. User Auth 为底层后端数据库认证提供 ...

  8. MySQL数据库中配置文件 read_only 参数的有关说明

    1.对于MySQL单实例数据库和master库,如果需要设置为只读状态,需要进行如下操作和设置: 将MySQL设置为只读状态的命令(可以登录mysql执行下面命令, 或者在my.cnf配置文件中添加& ...

  9. 面试突击87:说一下 Spring 事务传播机制?

    Spring 事务传播机制是指,包含多个事务的方法在相互调用时,事务是如何在这些方法间传播的. 既然是"事务传播",所以事务的数量应该在两个或两个以上,Spring 事务传播机制的 ...

  10. 为什么 CRM 能帮助装备制造企业进行数字化转型?

    CRM确实能帮助装备制造企业进行数字化转型,体现在销售管理端,能方便的服务于"客户需求"为主旨的数字化转型思想,用客户的需求来指导生产等.但这个说法有点片面,毕竟那只是客户管理部分 ...