Git LFS (Large File Storage) 是一个 Git 扩展,它使 Git 更适合处理大型文件,如音频、视频、图像或任何其他二进制大文件。Git LFS 替换仓库中的大文件为文本指针文件,这些文件包含指向实际大文件位置的信息。这样,Git 仓库的大小显著减小,同时也保留了对大文件的版本控制能力。
使用 Git LFS 的步骤:
-
安装 Git LFS :
首先,你需要在你的机器上安装 Git LFS。你可以从 Git LFS 的官方网站下载并安装适合你操作系统的版本。
-
初始化 Git LFS :
在你的本地仓库中运行
git lfs install
命令。这会确保 Git LFS 的钩子被正确地设置在你的 Git 配置中。 -
指定要跟踪的文件类型 :
使用
git lfs track "*.ext"
命令来指定 Git LFS 应该跟踪的文件类型。例如,如果你想要跟踪所有.jpg
文件,你可以运行:git lfs track "*.jpg"
-
推送更改 :
推送之前,你可能需要添加
.gitattributes
文件到仓库中,这是 Git LFS 存储跟踪规则的地方。然后,你可以正常地提交和推送你的更改:git add .gitattributes git commit -m "Add LFS tracking for jpg files" git push
-
拉取文件 :
当你在其他克隆的仓库中拉取时,Git LFS 将自动下载并替换指针文件为实际的大文件。
使用场景示例:
假设你正在开发一个游戏项目,其中包含大量的纹理、模型和音效文件。这些文件通常都是二进制的且体积较大。为了有效地使用 Git 进行版本控制,你决定使用 Git LFS。
步骤:
-
安装和初始化 Git LFS:
# 安装 Git LFS curl -s https://packagecloud.io/install/repositories/github/git-lfs/script.deb.sh | sudo bash sudo apt-get install git-lfs git lfs install # 或者在Windows环境下通过PowerShell运行 iex ((New-Object System.Net.WebClient).DownloadString('https://raw.githubusercontent.com/git-lfs/git-lfs/main/install/main/install-sh')) git lfs install
-
指定要跟踪的文件类型:
git lfs track "*.png" git lfs track "*.wav" git lfs track "*.fbx"
-
推送更改:
git add .gitattributes git commit -m "Add LFS tracking for large binary files" git push
现在,当你在项目中添加、修改或删除大文件时,Git LFS 将自动处理它们,而不会显著增加仓库的大小。当其他团队成员克隆或拉取仓库时,Git LFS 将只下载他们需要的文件,而不是整个仓库的历史版本。
这样,你的团队就可以更高效地协作,同时保持对大文件的版本控制。