Git 使用技巧

常用配置设置

正确配置你的用户信息

GitHub 通过你的 ~/.gitconfig 文件提供的信息来追踪你的更改。如果你在多台机器上工作且 ~/.gitconfig 未正确配置,你很可能会得到重复的提交和混乱的历史记录。你需要根据你的 GitHub 凭证修改以下行。

复制代码
[user]
	name = 你的姓名
	email = 你的有效邮箱

正确配置你的 difftool 和 mergetool。

difftool 和 mergetool 是 Git 分别在执行差异比较或冲突解决操作时会运行的软件。

复制代码
[difftool "opendiff"]
	cmd = /usr/bin/opendiff \"$LOCAL\" \"$REMOTE\" -merge \"$MERGED\" | cat
[diff]
	tool = opendiff
[merge]
	tool = opendiff

为最常用的命令创建别名。

你会发现每天会多次使用相同的 Git 命令。为最常用的命令创建别名可以每天节省宝贵的时间。

复制代码
[alias]
	st = status
	ci = commit
	br = branch
	co = checkout
	ds = diff --staged
	changes = log -n1 -p --format=fuller
	amend = commit --amend -C HEAD
	undo = clean -f -d
	undoci = reset HEAD~1
	unstage = reset HEAD --
	lg = log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit
	ls = log --pretty=format:\"%C(yellow)%h %C(blue)%ad%C(red)%d %C(reset)%s%C(green) [%cn]\" --decorate --date=short
	lg-full = log --name-status --pretty=fuller

速查表

创建

操作 命令
克隆一个现有仓库 $ git clone ssh://user@domain.com/repo.git
创建一个新的本地仓库 $ git init

本地更改

操作 命令
查看工作目录中已更改的文件 $ git status
查看已跟踪文件的更改内容 $ git diff
将所有当前更改添加到下一次提交 $ git add .
<文件> 中的部分更改添加到下一次提交 $ git add -p <文件>
提交所有已跟踪文件中的本地更改 $ git commit -a
提交之前已暂存的更改 $ git commit
修改最后一次提交(不要修改已发布的提交! $ git commit --amend

提交历史

操作 命令
显示所有提交,从最新的开始 $ git log
显示特定文件随时间的变化 $ git log -p <文件>
查看谁在何时修改了 <文件> 的什么内容 $ git blame <文件>

分支与标签

操作 命令
列出所有现有分支 $ git branch
切换 HEAD 分支 $ git checkout <分支>
基于当前 HEAD 创建新分支 $ git branch <新分支>
基于远程分支创建新的跟踪分支 $ git checkout --track <远程/分支>
删除本地分支 $ git branch -d <分支>
为当前提交打上标签 $ git tag <标签名>

更新与发布

操作 命令
列出所有当前配置的远程仓库 $ git remote -v
显示远程仓库信息 $ git remote show <远程>
添加新的远程仓库,命名为 <远程> $ git remote add <远程> <URL>
<远程> 下载所有更改,但不合并到 HEAD $ git fetch <远程>
下载更改并直接合并/集成到 HEAD $ git pull <远程> <分支>
将本地更改发布到远程仓库 $ git push <远程> <分支>
删除远程仓库上的分支 $ git branch -dr <远程/分支>
发布你的标签 $ git push --tags

合并与变基

操作 命令
<分支> 合并到当前 HEAD $ git merge <分支>
将当前 HEAD 变基到 <分支> 上(不要对已发布的提交进行变基! $ git rebase <分支>
中止变基操作 $ git rebase --abort
解决冲突后继续变基 $ git rebase --continue
使用配置的合并工具解决冲突 $ git mergetool
使用编辑器手动解决冲突,并在解决后标记文件为已解决 $ git add <已解决文件> $ git rm <已解决文件>

撤销操作

操作 命令
丢弃工作目录中的所有本地更改 $ git reset --hard HEAD
丢弃特定文件的本地更改 $ git checkout HEAD <文件>
撤销一个提交(通过生成一个包含相反更改的新提交) $ git revert <提交>
将 HEAD 指针重置到先前的提交,并丢弃自那时起的所有更改 $ git reset --hard <提交>
将 HEAD 指针重置到先前的提交,并将所有更改保留为未暂存的更改 $ git reset <提交>
将 HEAD 指针重置到先前的提交,并保留未提交的本地更改 $ git reset --keep <提交>
相关推荐
摆烂且佛系1 天前
十分钟了解Git Cherry-Pick
git
星渊澈1 天前
从github上git clone 比较慢,如何解决。。
git·github
魔都吴所谓1 天前
【Ubuntu】离线环境下Git LFS(deb包)安装与验证完整教程
linux·git·ubuntu
REDcker1 天前
Git worktree:多工作区并行开发与实践
git·worktree
lifewange1 天前
Git版本管理
大数据·git·elasticsearch
尘世壹俗人1 天前
idea提交git版本由于中文文件名卡死不动
java·git·intellij-idea
oushaojun22 天前
git在项目中常用的操作集合
git
qq_396227952 天前
Git 分布式版本控制
分布式·git
无限进步_2 天前
【C++】反转字符串的进阶技巧:每隔k个字符反转k个
java·开发语言·c++·git·算法·github·visual studio
Rabbit_QL2 天前
【Git 报错处理】`remote origin already exists` 是什么意思?
git