Git 小妙招:本地忽略文件变更,不影响远程仓库

✅ 正确做法:--assume-unchanged

复制代码
git update-index --assume-unchanged data/app.db

一条命令搞定。效果:

环境 行为
🖥️ 本地 Git 假装这个文件没有变化,git status 不显示,git add . 不会提交
☁️ 服务器 完全不受影响,正常跟踪、正常提交

🔑 原理

--assume-unchanged 是一个本地索引标记 ,只存在于当前机器的 .git 目录中,不会推送到远程仓库。所以每台机器可以独立决定要不要忽略某个文件的变更。

🔄 恢复跟踪

哪天想恢复?加个 --no

复制代码
git update-index --no-assume-unchanged data/app.db

📋 查看哪些文件被标记了

复制代码
git ls-files -v | findstr "^h"

小写 h 开头的就是被 assume-unchanged 标记的文件(Linux/Mac 用 grep 替代 findstr)。

⚠️ 注意事项

  1. git pull 有冲突时会失效 ------ 如果远程修改了这个文件,拉取时 Git 会提示冲突,需要先取消标记再处理
  2. git stashgit reset --hard 不受影响 ------ 这些操作会忽略标记,直接覆盖文件
  3. 换一台电脑需要重新标记 ------ 这是本地设置,clone 新仓库后要重新运行

🆚 和 .gitignore 的区别

.gitignore --assume-unchanged
作用范围 所有环境(会被提交) 仅当前机器
适用场景 不需要跟踪的文件(如 node_modules 已跟踪但本地不想提交变更的文件
对已跟踪文件有效? ❌ 无效 ✅ 有效
相关推荐
悟空瞎说11 小时前
# Git 交互式变基:优雅整理提交历史,告别杂乱 PR 记录
前端·git
身如柳絮随风扬11 小时前
Git 核心操作:rebase 与 merge 的区别,以及分支管理最佳实践
大数据·git
cccyi711 小时前
Git本地和远程邮箱一致,上传也有贡献显示,但是没有绿点或绿点延迟显示
git
暗暗别做白日梦14 小时前
Git 提交信息命名规范:feat、fix、refactor
git
憧憬成为java架构高手的小白16 小时前
git(基于b站狂神说学习)【未完结】
git·学习
likerhood16 小时前
Git 提交与推送常见报错处理笔记
笔记·git
chen_22716 小时前
KZPROJ Git Diff AI 审查工具
git·ai·claude·kanzi
向日的葵00617 小时前
大模型技术之git(第八章)
git
xuhaoyu_cpp_java19 小时前
Git学习(一)
经验分享·笔记·git·学习
Mr YiRan19 小时前
Android构建优化:基于Git Diff+TaskGraph
android·git·elasticsearch