Вы можете просто нажать «Да» во всплывающем сообщении, когда он спросит, нужно ли упаковывать свободные объекты сейчас. Git GUI будет работать git gcдля вас, с хорошим индикатором выполнения GUI (хотя в большинстве случаев он отображается как застрявший).
ADTC
Ответы:
144
Объект (BLOB, деревья и коммиты) с SHA скажем - 810cae53e0f622d6804f063c04a83dbc3a11b7ca будет храниться в
(разделение на первые два символа для повышения производительности файловой системы, поскольку теперь не все объекты хранятся в одном каталоге)
Объекты, хранящиеся как указано выше, называются свободными объектами.
Когда вы запускаете репо, у вас есть в основном свободные объекты. Когда число увеличивается, оно становится неэффективным, и они сохраняются в файле пакета. Такие объекты называются упакованными объектами.
git gc
это то, что вы запускаете, чтобы упаковать объекты (Обычно свободные объекты, которые не нужны и несколько недель назад, также удаляются, и с --prune=<date>опцией вы можете принудительно удалить свободные объекты, которые больше не нужны. Например, когда вы изменяете коммит. Старый объект фиксации не больше не нужно.)
Эта --pruneопция включена по умолчанию, и, поскольку git gcона запускается автоматически при обычном использовании (например commit), вам обычно не нужно беспокоиться об этом. Я не использую git gui и не могу точно определить, где он запущен в источнике, но он либо выполняет свою собственную проверку, либо просто перехватывает gcсрабатывание вызываемой команды. Это, конечно, не о чем беспокоиться, просто вызвано нормальным использованием.
Каскабель
21
есть ли какие-то недостатки упаковки сыпучих предметов? Если нет, то почему Git не делает это автоматически?
Луис Рис
13
Я не думаю, что это правда, что это происходит автоматически. Я часто совершаю коммиты, но в упомянутом «git gui» было 50000 незакрепленных объектов (и мне было интересно, почему git был таким чертовски медленным, большой проект за ~ 4 года без ручного gc)
Кевин
1
@Kevin Повысилась ли производительность вашего крупного проекта после запуска git gcвручную? Я думаю, что это должно улучшиться, потому что потерянные объекты неэффективны, а 50 000 - это очень большое число. Я также обнаружил, что упаковка значительно уменьшает пространство, используемое .gitпапкой.
ADTC
3
@LouisRhys, «Когда объекты записываются на диск, он часто находится в свободном формате, так как доступ к этому формату менее затратный. Однако, в конечном итоге вы захотите сэкономить место за счет упаковки объектов» - из Git Book ссылка в ответе ниже
git gc
для вас, с хорошим индикатором выполнения GUI (хотя в большинстве случаев он отображается как застрявший).Ответы:
Объект (BLOB, деревья и коммиты) с SHA скажем - 810cae53e0f622d6804f063c04a83dbc3a11b7ca будет храниться в
(разделение на первые два символа для повышения производительности файловой системы, поскольку теперь не все объекты хранятся в одном каталоге)
Объекты, хранящиеся как указано выше, называются свободными объектами.
Когда вы запускаете репо, у вас есть в основном свободные объекты. Когда число увеличивается, оно становится неэффективным, и они сохраняются в файле пакета. Такие объекты называются упакованными объектами.
это то, что вы запускаете, чтобы упаковать объекты (Обычно свободные объекты, которые не нужны и несколько недель назад, также удаляются, и с
--prune=<date>
опцией вы можете принудительно удалить свободные объекты, которые больше не нужны. Например, когда вы изменяете коммит. Старый объект фиксации не больше не нужно.)источник
--prune
опция включена по умолчанию, и, посколькуgit gc
она запускается автоматически при обычном использовании (напримерcommit
), вам обычно не нужно беспокоиться об этом. Я не использую git gui и не могу точно определить, где он запущен в источнике, но он либо выполняет свою собственную проверку, либо просто перехватываетgc
срабатывание вызываемой команды. Это, конечно, не о чем беспокоиться, просто вызвано нормальным использованием.git gc
вручную? Я думаю, что это должно улучшиться, потому что потерянные объекты неэффективны, а 50 000 - это очень большое число. Я также обнаружил, что упаковка значительно уменьшает пространство, используемое.git
папкой.Книга Git объясняет это довольно хорошо: https://git-scm.com/book/en/v2/Git-Internals-Packfiles
источник