我在x:/Archivos Python/EPPTRA2.git/
下有一个git-bare
存储库位置,所有团队都在从该存储库中提取和推送更改。/x
是我们办公室网络中的共享磁盘。
空间不足
但是最近我不得不推送许多大文件,发现没有足够的空间。
$ git push
Counting objects: 1077, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (1073/1073), done.
remote: fatal: write error: Not enough space
fatal: sha1 file '<stdout>' write error: Broken pipe
error: failed to push some refs to 'x:/Archivos Python/EPPTRA2.git/'
我想要实现的目标
我想将git-bare
存储库移动到另一个位置,比如说/s/EPPTRA.git/
该位置位于具有足够空间的其他共享网络磁盘中。然后更新队友的本地仓库,以确保它们指向新的git-bare
仓库位置。
问题
如何更改git-bare
存储库位置?
如何将上次提交推送到新的git-bare
存储库位置?
在我的所有团队成员都指向git-bare
存储库新位置之后,我需要执行哪些步骤?
我正在寻找来自git-bash
的命令以执行这些任务。
我相信我可以正确地实现我想要的。我想可能还有其他方法。
步骤 1:创建新的 git 裸存储库
首先从新位置/s
我创建了一个裸存储库:
$ cd /s
$ git init --bare EPPTRA2.git
Initialized empty Git repository in S:/EPPTRA2.git/
步骤 2:将非裸存储库镜像到新的 git 裸存储库
之后,我转到了一个非裸存储库,该存储库没有我上次提交,并将存储库镜像到裸存储库(我实际上在/s/epptra2
下有一个非裸存储库,可以使用那个(:
$ cd /s/epptra2
$ git push --mirror /s/epptra2.git
Counting objects: 22412, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (7300/7300), done.
Writing objects: 100% (22412/22412), 1.68 GiB | 1.96 MiB/s, done.
Total 22412 (delta 17271), reused 19487 (delta 15075)
步骤 3:更改远程源位置
然后我不得不删除以前的原点并创建一个新的原点:
$ cd /d/epptra2
$ git remote rm origin
$ git remote add origin /s/epptra2.git
$ git config master.remote origin
$ git config master.merge refs/heads/master
$ git branch -u origin/master
步骤 4:将提交的更改推送到新的裸存储库
最后,我推送了我从本地仓库完成的提交:
$ git push
Counting objects: 1077, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (1073/1073), done.
Writing objects: 100% (1077/1077), 4.53 GiB | 922.00 KiB/s, done.
Total 1077 (delta 441), reused 0 (delta 0)
To S:/epptra2.git
da05677..d1c8610 master -> master
步骤 5:更新所有本地存储库的远程来源
对于队友的本地存储库,我必须重复步骤 3,然后执行git pull
以确保一切正常。
注意:/d
是我的电脑中的本地磁盘,/s
和/x
是网络安装的驱动器。