写点什么

10 个节省时间和改善工作流的 Git 技巧

  • 2020-02-27
  • 本文字数:3161 字

    阅读完需:约 10 分钟

10个节省时间和改善工作流的Git技巧


根据Git官方手册,它被定义为傻瓜式内容追踪器,它功能丰富,但有些功能却让人望而生畏。因此,我们只是重复使用那几个被记住的命令,而没有充分使用。

技巧 1: 优化配置

Git 在全局、用户和本地级别上都是高度可配置的。点击此处查看。

查找顺序

每个设置都可以被覆盖:


$CWD/.git/config    ▼ ▼ ▼$HOME/.gitconfig`    ▼ ▼ ▼$HOME/.config/git/config    ▼ ▼ ▼/etc/gitconfig
复制代码

修改设置

用你喜欢的编辑器或者 CLI 编辑任何配置文件:


# 全局设置git config --global <keypath> <value># 本地设置git config <keypath> <value>
复制代码


如果值包含空格字符,则需要用引号引起来。

显示当前设置

# 显示当前设置及其来源git config --list --show-origin
复制代码

一些有用的配置

# 设定身份git config --global user.name "<your name>"git config --global user.email <your email># 首选编辑器git config --global core.editor vim# 证书缓存# WINDOWSgit config --global credential.helper manager# LINUX (超时时间——以秒为单位)git config --global credential.helper "cache --timeout=3600"# MACOSgit config --global credential.helper osxkeychain
复制代码


点击此处查看详情。

技巧 2:别名(alias)

创建一个别名来保存常用的 git 命令:


# 创建别名git config --global alias.<alias-name> "<git command>"# 使用别名git <alias-name> <more optional arguments>
复制代码

一些有用的别名

# 撤销上次提交git config --global alias.undo "reset --soft HEAD^"# 将暂存区更新修订到上次提交(不改变提交信息)git config --global alias.amend "commit --amend --no-edit"# 压缩的状态输出git config --global alias.st "status -sb"# 用GRAPH为日志着色git config --global alias.lg "log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset'"# 删除所有已合并的分支git config --global alias.rmb "!git branch --merged | grep -v '*' | xargs -n 1 git branch -d"# 贡献排行git config --global alias.rank "shortlog -n -s --no-merges"
复制代码

技巧 3:查找 Commits 和更改

通过 Commits 信息查找

# 通过commit信息查找(所有分支)git log --all --grep='<search term>'# 通过commit信息查找(包含reflog)git log -g --grep='<search term>'
复制代码

通过更改查找

# 通过更新的内容查找git log -S '<search term>'
复制代码

通过日期查找

# 通过日期范围查找git log --after='DEC 15 2019' --until='JAN 10 2020'
复制代码

技巧 4:添加 hunk

git add <filepath>不仅能添加文件的所有变更,--path / -p参数还可以交互式暂存区块。点击此处查看详情。


# 补丁命令y = 暂存区块n = 不暂存这个区块q = 退出a = 暂存当前文件的此区块以及所有剩余区块d = 不暂存当前文件的此区块以及所有剩余区块/ = 查找区块 (正则表达式)s = 划分成更小的区块e = 手动编辑区块? = 打印帮助说明g = 选择要前往的区块j = 将区块设为未定,查看下一个未定区块J = 将区块设为未定,查看下一个区块k = 将区块设为未定,查看上一个未定区块J = 将区块设为未定,查看下一个区块
复制代码

技巧 5: 储藏(stash)更改而不提交

stash 将当前的更改临时搁置起来。在它的帮助下,可以返回当前状态的索引,并能在稍后应用已储藏的更改。


默认情况下,仅储藏当前跟踪文件中的更改,新文件将被忽略。


我们可以独立地创建和应用多个 stash。点击此处查看详情。

创建

# 创建新的STASHgit stash# 创建新的STASH (包含未追踪的更改)git stash -u/--include-untracked# 创建新的STASH并命名git stash save "<stash name>"# 交互式储藏git stash -p
复制代码

罗列

# 列出所有的STASH (为其他命令提供"n")git stash list
复制代码

浏览

# 浏览STASH内容git stash show# 浏览STASH差异git stash show -p
复制代码

应用

# 应用上一个STASH (删除stash)git stash pop# 应用上一个STASH (保留stash)git stash apply# 应用特定的STASH (n = stash列表序号)git stash pop/apply stash@{n}# 从STASH创建新的分支 (n = stash列表序号)git stash branch <new branch name> stash@{n}# 从STASH应用单个文件 (n = stash列表序号)git checkout stash@{n} -- <filepath>
复制代码

清理

# 删除特定的STASH (n = stash列表序号)git stash drop stash@{n}# 删除所有的STASHgit stash clear
复制代码

技巧 6:空运行(Dry Run)

许多 git 操作可能具有破坏性,例如,git clean -f将删除所有未跟踪的文件,而且无法恢复。


要避免出现这种灾难性的结果,许多命令都支持 dry-run,可以在实际产生结果前对其进行检查。不过遗憾的是,使用的选项不完全一致:


git clean -n/--dry-rungit add -n/--dry-rungit rm -n/--dry-run# GIT MERGE模拟DRY-RUNgit merge --no-commit --no-ff <branch>git diff --cachedgit merge --abort
复制代码


请注意,git commit -n根本不是*dry-run!*它实际上是--no-verify,作用是忽略所有pre-commit/commit-msg githooks

技巧 7:安全强制推送

在处理旧的 commit、创建新的 head 等情况时时很容易弄乱分支。git push --force可以覆盖远程变更,但不应该这样做!


git push --force是一种具有破坏性且危险的操作,因为它无条件生效,并且会破坏其他提交者已经推送的所有 commit。这对于其他人的代码仓库来说不一定是致命的,但是改变历史记录并影响其他人并不是一个好主意。


更好的选择是使用git push --force-with-lease


git 不会无条件地覆盖上游的远程仓库,而是检查是否有本地不可用的远程更改。如果有,它会失败并显示一条“stale info”消息,并告诉我们需要先运行git fetch。点击此处查看详情。

技巧 8:修改 commit 信息

Commit 是不可变的,且不能更改。不过可以用一条新的 commit 信息修订现有的 commit,这会覆盖原始 commit,因此请勿在已推送的 commit 中使用它。点击此处查看详情。


git commit --amend -m "<new commit message>" 
复制代码

技巧 9:修改历史

修改代码仓库的历史不仅限于修改上次提交信息,使用git rebase可以修改多个提交:


# 提交的范围git rebase -i/--interactive HEAD~<number of commits># 该hash之后的所有提交git rebase -i/--interactive <commit hash>
复制代码


在配置的编辑器中倒序列出所有的 commit,像这样:


# <command> <commit hash> <commit message>pick 5df8fbc revamped logicpick ca5154e README typos fixedpick a104aff added awesome new feature
复制代码


通过更改编辑器中的实际内容,可以为 git 提供一个方案,来说明如何进行 rebase:


# p, pick   = 使用提交而不更改# r, reword = 修改提交信息# e, edit   = 编辑提交# s, squash = 汇合提交# f, fixup  = 类似"squash",但是会丢弃提交信息# x, exec   = 运行命令 (其余行)# d, drop   = 移除提交
复制代码


保存编辑器后,git 将运行该方案以重写历史记录。


e, edit会暂停 rebase,就可以编辑代码仓库的当前状态。完成编辑后,运行git rebase --continue


如果过程中出现问题(例如合并冲突),我们需要重新开始,可以使用git rebase --abort。点击此处查看详情。

技巧 10:存档跟踪文件

可以使用不同格式(ziptar)来压缩特定引用的跟踪文件:


git archive --format <format> --output <filename> <ref>
复制代码


<ref>可以是一个分支、commit hash 或者一个标签。查看详情

额外提醒:单破折号

有一个快捷方式可以表示刚用过的分支:一个单破折号-


git checkout my-branch# 当前分支:my-branch<do some git operations, e.g. adding/commiting>git checkout develop# 当前分支:developgit merge -# 将my-branch合并到develop
复制代码


单破折号等同于@{-1}

总结

Git 还有很多话题可谈,这里只涉及一些皮毛。在另一篇文章中,我想展示如何用git bisect有效查找损坏的 commit,或者如何通过git reflog来运用任意git操作的完整历史记录。


阅读英文:


10 Git Tips To Save Time And Improve Your Workflow


2020-02-27 14:556444

评论

发布
暂无评论
发现更多内容

Forsage矩阵系统开发,智能合约搭建

薇電13242772558

数据结构与算法系列之链表操作全集(二)(GO)

书旅

数据结构 算法 Go 语言

快速掌握并发编程---深入学习ThreadLocal

田维常

独立显卡市场又一巨头跻入,英特尔锐炬® Xe MAX 独立显卡来了!

E科讯

SpringBoot-技术专题-war包部署读取外部配置Properties

洛神灬殇

Caffe 安装踩坑记录

Dreamer

caffe

当下工作流管理系统的发展趋势

Marilyn

敏捷开发 快速开发 软件架构 企业开发

一个研发团队是如何坚持7年技术分享的?

爱吃小舅的鱼

团队管理 程序员 敏捷开发 研发管理 技术分享

直播预告 | CloudQuery初体验——安装及多数据源连接

BinTools图尔兹

数据库 sql 安全 工具软件 dba

写文档太麻烦,试试这款 IDEA 插件吧!

程序员小航

Java markdown IDEA idea插件 文档

EDA最强攻略,如何为EDA选择存储?

焱融科技

分布式 高性能 存储 半导体 EDA

SpringBoot-技术专题-war包部署读取外部配置Yml

洛神灬殇

华为云的销售凭什么说“赢”了罗振宇?

ToB行业头条

tob

基于React+Koa实现一个h5编辑器

徐小夕

Java nodejs H5 React koa

C++ primer -- 第17章 输入,输出和文件

Dreamer

c++

接口测试人员需要掌握的知识技能

测试人生路

接口测试

TypeScript魔法堂:函数类型声明其实很复杂

肥仔John

Java typescript

在2020年更受关注和追捧的JS框架

葡萄城技术团队

react.js Vue js Svelte

C++ primer -- 第18章 探讨C++新标准

Dreamer

c++

MySQL中事务的持久性实现原理

X先生

MySQL 数据库 sql 数据库事务 事务

面试时说Redis是单线程的,被喷惨了!

redis 编程 程序员 计算机

精解四大集合框架:Set核心知识总结

田维常

程序员 后端

架构师训练营第 1 期 第 3 周作业

李循律

极客大学架构师训练营

架构师训练营第 1 期 第 5 周作业

李循律

极客大学架构师训练营

TensorFlow 篇 | TensorFlow 数据输入的最佳实践

Alex

tensorflow keras input pipeline dataset

专利申请其实并不难?四步教你玩转专利申请!

华为云开发者联盟

专利 保护

试用阿里网盘内测版-不限速、无广告、隐私安全我全都要

郭旭东

阿里云网盘

云图说|知道吗?在和你对话的那头,也许是个机器人哦~

华为云开发者联盟

华为 AI 机器人

目标检测综述

Dreamer

Docker底层技术

混沌畅想

Docker 容器 DevOps 底层技术

架构师训练营 1 期第 6 周作业

木头发芽

10个节省时间和改善工作流的Git技巧_文化 & 方法_Ben Weidig_InfoQ精选文章