美文网首页
Git分布式文件管理器——俗称高级工具人

Git分布式文件管理器——俗称高级工具人

作者: lk_erzanml | 来源:发表于2021-01-17 05:04 被阅读0次

加强记忆,都是廖雪峰的东西哈。https://www.liaoxuefeng.com/wiki/896043488029600/896067074338496

背景:

CVS及SVN都是集中式的版本控制系统,而Git是分布式版本控制系统。

配置:

git config --global user.name "Autumn-Paint"

git config --global user.email "dong84266@163.com"

git config --list

建立仓库--也可以克隆别人的:

git init

提交:

git add <filename>

git commit -m "message"

要随时掌握工作区的状态,使用git status命令。

如果git status告诉你有文件被修改过,用git diff可以查看修改内容。

查看工作区和版本库的差异:(上面那个是查看暂存区和工作区的差异)

git diff HEAD -- 文件名

恢复:

git log查看每次提交历史 。优化一下,git log --pretty=oneline

git reset --hard 1045a 退回到你想回去的提交(1045a是commitid,可以不用写全)

git reflog查看命令历史,可以退回到未来。找到未来的commitid,然会git reset就可以了。

撤回修改:(这个知道就好,git会有提示)

场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。退回到最近的git add 或者git commit状态。

场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD <file>,就回到了场景1,第二步按场景1操作。

场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。

命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容

克隆

git push origin master推送到远程仓库

git clone git@github.com:michaelliao/gitskills.git

分支:

查看分支:git branch

创建分支:git branch <name>

切换分支:git checkout <name>或者git switch <name>

创建+切换分支:git checkout -b <name>或者git switch -c <name>

合并某分支到当前分支:git merge <name>

删除分支:git branch -d <name>

冲突解决:

git merge 分支之后,会提示是否有冲突,有的话,手动修改冲突,然后重新add,commit就可以了。

关于git merge

git  merge  --no-ff  -m "merge with no-ff" dev  这个模式是普通模式,不加 --no-ff是快速模式,普通模式,合并会形成一个commit记录,快速模式下,合并后是没有记录的。

git stash保护工作现场

当手头工作没有完成时,先把工作现场git stash一下,然后去修复bug,修复后,再git stash pop,回到工作现场;

git stash list查看保存现场的有哪些

git stash pop 弹出保护现场的东西,并且把记录删除

git stash pop stash@{0} 根据你保护的序号弹出

在master分支上修复的bug,想要合并到当前dev分支,可以用git cherry-pick <commit>命令,把bug提交的修改“复制”到当前分支,避免重复劳动。

强制删除分支:

git branch -D <name>

将多个commit合并为一个:

git rebase -i HEAD~2这里是最近两次提交合并

记得将后面的pick改成s

变基

即更改本次分支提交的基准值为远程分支的基准值

例如:本地分支落后于远程release分支的情况;在本地分支rebase远程release分支,即可完成

git rebase origin/release

如果有冲突的话,需要进行解决冲突再使用下面命令

git rebase --continue

打标签:

git tag v1.0

git tag查看标签

默认标签是打在最新提交的commit上的。有时候,如果忘了打标签,比如,现在已经是周五了,但应该在周一打的标签没有打,怎么办?

方法是找到历史提交的commit id,然后打上就可以了:

比方说要对add merge这次提交打标签,它对应的commit id是f52c633,敲入命令:

 git tag v0.9f52c633

命令git tag -a <tagname> -m "blablabla..."可以指定标签信息;

git tag -d v0.1删除标签

git push origin v1.0推送到远程

命令git push origin <tagname>可以推送一个本地标签;

命令git push origin --tags可以推送全部未推送过的本地标签;

命令git tag -d <tagname>可以删除一个本地标签;

命令git push origin :refs/tags/<tagname>可以删除一个远程标签。

.gitignore文件:

忽略某些文件时,需要编写.gitignore;

.gitignore文件本身要放到版本库里,并且可以对.gitignore做版本管理!

相关文章

  • Git分布式文件管理器——俗称高级工具人

    加强记忆,都是廖雪峰的东西哈。https://www.liaoxuefeng.com/wiki/896043488...

  • Git

    Git 为开源分布式版本控件工具 Git 工作原理 工作区(Working Directory):仓库文件夹里除 ...

  • Git 入门笔记

    什么是Git 基于文件快照的分布式版本控制工具 Git基础概念 三个重要的工作区: 数据仓库:保存了所有Git提交...

  • 小白学git

    git学习之路 什么是git? git是一些命令工具的集合它可以用来追踪,记录文件的变动。它是采取分布式管理,分布...

  • Git

    什么是Git Git是一个分布式版本控制工具,主要用于管理开发过程中的源代码文件(Java类、xml文件、html...

  • GIT

    GIT GIT简单介绍 GIT:是一款开源的分布式版本控制工具 在所有的分布式的版本控制工具中,git是最快、最简...

  • 实用技术第3篇——git的使用

    源代码管理工具——git 什么是git? git是一款开源的分布式版本控制工具 在世界上所有的分布式版本控制工具中...

  • 源代码管理_Git概述

    1. Git简介 什么是git? git是一款开源的分布式控制工具;在世界上所有的分布式版本控制工具中,Git是最...

  • Git与github

    Git分布式版本控制工具 Git概述和基本使用 git分布式版本管理与svn(cvs)对比 类型:git是开源的分...

  • 今天来分享一点有价值的东西(git)

    一、简介 什么是git? git是一款开源的分布式版本控制工具 在世界上所有的分布式版本控制工具中,git是最快、...

网友评论

      本文标题:Git分布式文件管理器——俗称高级工具人

      本文链接:https://www.haomeiwen.com/subject/igxoaktx.html