没用过.gitIgnore还敢自称高级开发?

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

没用过.gitIgnore还敢自称高级开发?

有态度的小码甲   2020-04-10 我要评论

Git是跟踪项目中所有文件的好工具,
但是,您会希望在项目的整个生命周期中不要跟踪某些文件及其变化

  • 系统文件(i.e. Mac系统的.Ds_Store)
  • 应用程序配置文件(i.e. app.config, .env)
  • 构建组件(i.e. *.pyc)
  • 安装的依赖(i.e. node_modules)
  • 个人文件(i.e. tood.txt)
  • 应用程序数据和日志(i.e. .log,.sqlite)

Git有一个gitignore概念:以.gitignore文件定义哪些文件将被Git排除跟踪, 被.gitignore匹配到的文件将不会显示在Git的Untracked files列表。

通过本文你将学习到:

  1. 使用gitignore防止Git文件跟踪
  2. 只在你的系统上忽略文件
  3. 在你的系统上跨仓库忽略文件
  4. 忽略已经提交文件变更

使用.gitignore防止跟踪文件

.gitignore文件可以控制Git仓库中应排除跟踪的文件(可由文件类型、路径、通配符等确立)。

  1. Visual Studio
    使用VS为项目创建(或连接)代码仓库的时候,Visual Studio自动在你的仓库中创建了.gitignore文件。
  2. 命令行
    从https://github.com/github/gitignore下载特定项目类型的.gitignore文件模板,修改以便充分适配你的项目,当然你也可以完全自定义一个.gitignore文件:

Git将.gitignore应用于文件夹及其子文件夹,建议您将.gitignore放在存储库的根文件夹中,以免造成混淆。

实践中有时会在项目的目录嵌套定义.gitignore文件, 虽然不常见,但对于有个性规则的子目录,嵌套定义.gitignore文件有用。

自定义.gitignore

只要你修改了.gitignore文件,Git立即开始忽略这些文件; 如果你希望团队成员都忽略相同的文件,请提交这次git变更。
.gitignore中的每一行都排除一个文件或一组(与模式匹配的)文件, .gitignore语法很灵活:

# 忽略单个文件
mycode.class

# 忽略整个目录
/mydebugdir/

# 忽略文件类型
*.json

# 将前置规则取反,这个文件将被Git跟踪
!package.json

Windows使用者注意:.gitignore文件中的路径使用正斜杠分隔符,而不是反斜杠

只在你的系统忽略文件

.gitignore文件被提交并推送之后,就会在团队共享。
若只想在你的系统上排除文件,请编辑仓库中的.git/info/exclude文件: 修改这个文件不会共享给其他人,这个动作只对这个仓库有效

系统中跨仓库忽略

利用git config工具建立全局.gitignore文件,

git config core.excludesfile C:\Users\frank\.gitignore_global

这个操作帮助你全局忽略绝不会提交的文件类型,比如编译文件

已经提交的文件,再忽略变更

临时忽略变更

在开发阶段,有时候要忽略文件变更,特别是你拿到源代码需要针对本地环境做一些修改

git update-index --skip-worktree <file>

恢复文件追踪

git update-index --no-skip-worktree <file>

永久忽略文件变更

如果文件已经被Git跟踪,再将这个文件添加到.gitignore文件并不会忽略文件变更。
你需要从Git Index中移除这个文件的信息:

  1. 在.gitignore文件中添加这个文件
  2. 从Index移除文件信息
git rm --cached  <file>
  1. 提交删除文件和更新的.gitignore到您的仓库

以上步骤不会从系统中删除文件,只是告诉Git以后忽略该文件的变更.

总结

在本文中,我们看到了Git如何为我们提供一种机制,告诉我们不应在存储库中跟踪哪些文件,
这是一项强大的功能,可提供丰富的语法以及层次结构,以更好地控制哪些文件被忽略以及哪些文件未被忽略。

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们