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

📌 场景

开发中经常遇到这种情况:项目里有个数据库文件(比如 app.db)或者配置文件,本地不想每次都提交 ,但服务器上需要正常跟踪

常见的错误做法是加到 .gitignore ------ 但 .gitignore 会被提交到仓库,所有环境都会忽略这个文件,包括你的服务器。

✅ 正确做法:--assume-unchanged

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

一条命令搞定。效果:

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

🔑 原理

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

🔄 恢复跟踪

哪天想恢复?加个 --no

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

📋 查看哪些文件被标记了

bash 复制代码
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 已跟踪但本地不想提交变更的文件
对已跟踪文件有效? ❌ 无效 ✅ 有效

一句话总结:想全局忽略用 .gitignore,想本地偷懒用 --assume-unchanged

相关推荐
孤飞2 天前
VS Code/Antigravity Remote SSH 连接要求输入密码?明明已经配了 SSH 密钥
技术分享
渣瓦攻城狮3 天前
互联网大厂Java面试实战:核心技术与场景分析
java·大数据·redis·spring·微服务·面试·技术分享
ApacheSeaTunnel1 个月前
保姆级 SeaTunnel 入门!再学不会小编当场表演倒立敲代码
大数据·数据集成·seatunnel·技术分享·数据同步
ApacheSeaTunnel1 个月前
告别手敲 Schema!SeaTunnel 集成 Gravitino 元数据 RestApi 这个新动作有点酷
大数据·ai·seatunnel·技术分享·数据同步·gravitino
G皮T2 个月前
【2025年度总结】“被动输入” 到 “主动输出”:一场认知的生死突围
经验分享·学习·成长·技术分享·年度总结·心得体会
ApacheSeaTunnel3 个月前
(四)收官篇!从分层架构到数据湖仓架构系列:数据服务层和数据应用层及湖仓技术趋势小结
数据库·开源·数据湖·技术分享·白鲸开源
ApacheSeaTunnel4 个月前
从小时级到分钟级:多点DMALL如何用Apache SeaTunnel把数据集成成本砍到1/3?
大数据·开源·数据集成·seatunnel·技术分享
ApacheSeaTunnel5 个月前
(三)数仓人必看!ODS 到 DWS 各层设计规范全解析,含同步/存储/质量核心要点
大数据·数仓·数据集成·技术分享
EasyGBS7 个月前
20250808:EasyGBS 对接大华 ICC 平台问题处理
服务器·音视频·技术分享