git 经典应用场景

2022-07-25  本文已影响0人  爱打盹的鱼

查看提交

如果你用git commit -a提交了一次变化(changes),而你又不确定到底这次提交了哪些内容。你就可以用下面的命令显示当前HEAD上的最近一次的提交(commit):

(main)$ git show
或者
$ gitlog-n1 -p

修改提交信息

提交信息(commit message)写错了且这次提交(commit)还没有推(push), 你可以通过下面的方法来修改提交信息(commit message):

$ git commit --amend --only  # 打开默认编辑器
或者
$ git commit --amend --only -m 'xxxxxxx' # 编辑信息一次完成

修改用户名和邮箱

git commit --amend --author "New Authorname <authoremail@mydomain.com>"

移除一个文件

git checkout HEAD^ myfile
git add -A
git commit --amend

删除最后一次提交

删除推了的提交(pushed commits),你可以使用下面的方法。这会不可逆的改变你的历史,也会搞乱那些已经从该仓库拉取(pulled)了的人的历史。

git reset HEAD^ --hard
git push -f [remote] [branch]

没有推到远程, 可以把Git重置(reset)到最后一次提交前的状态(同时保存暂存的变化):

git reset --soft HEAD@{1}

删除任意提交(commit)

警告:不到万不得已的时候不要这么做.

git rebase --onto SHA1_OF_BAD_COMMIT^ SHA1_OF_BAD_COMMIT
git push -f [remote] [branch]

修改之前的提交需要强制推送

rebasing(见下面)和修正(amending)会用一个新的提交(commit)代替旧的, 如果之前已经往远程仓库上推过一次修正前的提交(commit),就必须强推(force push) (-f)。
注意 – 确保指明一个分支!

 git push origin mybranch -f

做了一次重置,找回内容

意外的做了 git reset --hard, 通常能找回自己的提交(commit), 因为Git对每件事都会有日志,并且会保存几天。

git reflog

显示过去提交(commit)的列表,选择需要回到的版本(commit)的SHA,重置一次:

git reset --hard SHA1234e

暂存

添加到上一次提交

git commit --amend

暂存一个文件的一部分:

git add --patch filename.x  #暂存文件的一部分
git add -N filename.x #添加新文件
git diff --cached # 显示哪些行只是保存在本地

文件变化添加到两个提交里

git add #会把整个文件加入到一个提交. 
git add -p #允许交互式的选择你想要提交的部分.

暂存、未暂存变更

git commit -m "WP" #将所有的内容变为未暂存 
git add .
git stash # 暂存你的未暂存的内容并进行stash
git reset HEAD^  #最后一个commit将原本暂存的内容变为未暂存,最后stash pop回来
git stash pop --index 0

注意1: 使用pop仅仅是因为想尽可能保持幂等。
注意2: 假如不加上--index会把暂存的文件标记为存储。

未暂存

移动到新分支

git checkout -b my-newbranch

移动到已存在分支

 git stash
git checkout my-branch
git stash pop

丢弃未提交的变化

重置源(origin)和你本地(local)之间的一些提交(commit):

# one commit
git reset --hard HEAD^
# two commits
git reset --hard HEAD^^
# four commits
git reset --hard HEAD~4
# or
git checkout -f

重置某个特殊的文件

git reset filename

丢弃未暂存的内容

git checkout -p
或者
git stash -p
git reset --hard
git stash pop
或
git stash -p
git stash drop

分支

错误拉取处理

git reflog # 查询head指向
git reset --hard c5vb5a # 重置分支

删除本地提交,回复本地分支和远程分支一致

# 显示提前(ahead)源(origin)多少个提交
git status
# resest
git reset --hard origin/my-branch

创建新分支

git branch my-branch # 创建新分支
git checkout my-branch # 签出新分支工作

提交到不同分支

git log # 查看提交日志
# 重置正确分支
git reset --hard aqwe8re
# 创建bug修复分支
git checkout -b bug21
# 提交修复
git cherry-pick edf52e8

删除远程仓库已经删除的分支

git fetch -p

恢复删除的分支

git reflog
git checkout -b my-branch-del

删除一个远程分支

git push origin --delete my-branch
# OR
git push origin :my-branch

删除本地分支

git branch -D my-branch

拉取远端分支

# 拉取远端所有分支
git fetch --all
# 远程my-branch分支签出到本地my-branch
git checkout --track origin/my-branch

rebasing 和 merging

撤销rebase/merge

git reset --hard ORIG_HEAD

已经rebase,不进行强推

git checkout my-branch
git rebase -i main
git checkout main
git merge --ff-only my-branch

安全合并

--no-commit 执行合并(merge)但不自动提交, 做提交前检查和修改的机会。
no-ff 为特性分支(feature branch)的存在过留下记录, 保持项目历史一致

 git merge --no-ff --no-commit my-branch

分支合并成一个提交

git merge --squash my-branch

组合(combine)未推的提交(unpushed commit)

git rebase -i @{u}

检查分支上的所有提交(commit)都合并(merge)过

git log --graph --left-right --cherry-pick --oneline HEAD...feature/dev-scroll
# OR 
git log main ^feature/dev-scroll --no-merges

rebase 问题

编辑屏幕出现'noop'
意味着你rebase的分支和当前分支在同一个提交(commit)上, 或者 领先(ahead) 当前分支。你可以尝试:

检查确保主(main)分支没有问题
rebase HEAD~2 或者更早

解决冲突

1、查询冲突:
git status
2、差异查看
git mergetool -t opendiff
3、修改变化文件
git add changed.xx
git rebase --continue
#任何时候想结束整个rebase 过程,回来rebase前的分支状态:
git rebase --abort

Stash

暂存所有改动

git stash
git stash -u # -u来排除一些文件

暂存指定文件

# 暂存一个文件
git stash push  path/filename.x
# OR 暂存多个文件
git stash push  path/filename.x path/filename2.x

暂存记录

git stash save <message>
# OR
git stash push -m <message>

使用某个指定暂存

# 查看你的stash记录
git stash list
# apply某个stash
git stash apply "stash@{n}"
# or
git stash apply "stash@{2.hours.ago}"

保留未暂存的内容

 git stash create
git stash store -m "commit-message" CREATED_SHA1

克隆所有子模块

git clone --recursive git://github.com/xxx/xxx.git
git submodule update --init --recursive

删除标签(tag)

git tag -d <tag_name>
git push <remote> :refs/tags/<tag_name>

恢复已删除标签(tag)

# 找到无法访问的标签
git fsck --unreachable | grep tag
git update-ref refs/tags/<tag_name> <hash>

文件

修改文件名

git mv --force myfile MyFile

Git删除一个文件,但保留该文件

git rm --cached log.txt

配置

缓存一个仓库(repository)的用户名和密码

git config --global credential.helper cache
git config --global credential.helper 'cache --timeout=3600'
上一篇下一篇

猜你喜欢

热点阅读