cari
Rumahalat pembangunangitKetahui pelangsingan gudang GIT dan arahan penghijrahan GIT LFS dalam sepuluh minit

Artikel ini membawa anda pengetahuan yang berkaitan tentang pelangsingan gudang GIT dan arahan penghijrahan GIT LFS Saya harap ia akan membantu semua orang.

Ketahui pelangsingan gudang GIT dan arahan penghijrahan GIT LFS dalam sepuluh minit

Latar Belakang

Saya menggunakan CI/CD pada beberapa projek git dan mendapati klon jenkins git gagal, dan menetapkan kedalaman dan masa klon gagal. Kami hanya boleh mempertimbangkan strategi seperti pengecilan saiz gudang. Didapati bahawa gudang mempunyai banyak fail binari, dan fail binari ini berubah dengan agak kerap Operasi ini akan menyebabkan gudang git berkembang dengan pesat dan Git itu sendiri hanya sesuai untuk menguruskan fail teks.

Izinkan saya memberitahu anda satu lagi kisah silam yang menarik. Saya pernah mempunyai rakan sekerja yang berminat dalam pengaturcaraan grafik git untuk menguruskannya. Projek syarikat kecil kerap berubah, menyebabkan tiada Berapa lama masa yang diambil untuk cakera keras pelayan git dalaman syarikat diisi oleh beberapa gudang gitnya?

GIT LFS (Storan Fail Besar)

Walaupun git tidak pernah sesuai untuk menguruskan fail binari, git kini nampaknya menyediakan git lfs, pemalam khusus untuk menguruskan fail besar, secara lalai .

Prinsip asasnya ialah menggunakan penuding fail (teks) dan bukannya storan fail sebenar Git hanya menyimpan sejarah perubahan penuding fail dan bukannya keseluruhan fail binari, dan secara automatik menyediakan cangkuk ini adalah mudah untuk operasi seperti klon, tarik, set semula, dan lain-lain untuk mendapatkan fail binari sumber secara automatik penunjuk fail ini Begitu juga, apabila mengemas kini komit fail binari, git akan menukar fail sumber secara automatik menjadi penunjuk fail dan memasukkannya ke dalam. git log, dan pada masa yang sama, fail sumber akan dimuat naik ke lfs. Jadi pada peringkat pengguna, penggunaan GIT LFS sebenarnya tidak masuk akal.

Migrasi

Di atas secara ringkas memperkenalkan GIT LFS Seterusnya, kita akan bercakap secara langsung tentang bagaimana untuk berhijrah secara langsung dan bukannya cara menggunakan LFS dari awal.
Ini kerana selalunya apabila menggunakan gudang git, anda mendapati gudang itu sangat besar dan klon sangat perlahan, dan kemudian anda berfikir untuk menggunakan LFS.

Penghijrahan memerlukan kami mempunyai hak pentadbir gudang dan menyahlindungi cawangan yang dilindungi; Penghijrahan LFS khusus dibahagikan kepada langkah berikut.

Sebaik-baiknya buat sandaran sebelum berhijrah dan berkomunikasi dengan baik dengan rakan sekerja pasukan Lagipun, operasi itu melibatkan -f operasi berisiko tinggi , dan mudah untuk dipersalahkan.

Konfigurasi pelayan GIT LFS

Jika anda membina beberapa perkhidmatan git bina sendiri, anda mungkin perlu mendayakan LFS pada bahagian pelayan, seperti gitlab.

Pemasangan klien GIT LFS

Pakej pemasangan git untuk tingkap disertakan dengan pemalam ini Tiada pemasangan tambahan diperlukan, pautan.

Cuba arahan berikut pada baris arahan.

git lfs

Jika terdapat maklumat yang serupa dengan output dokumen bantuan, ini bermakna sudah ada klien git lfs.

git-lfs/2.11.0 (GitHub; windows amd64; go 1.14.2; git 48b28d97)git lfs <command> [<args>]Git LFS is a system for managing and versioning large files in
association with a Git repository.  Instead of storing the large files
within the Git repository as blobs, Git LFS stores special "pointer
files" in the repository, while storing the actual file contents on a
Git LFS server.  The contents of the large file are downloaded
automatically when needed, for example when a Git branch containing
the large file is checked out.Git LFS works by using a "smudge" filter to look up the large file
contents based on the pointer file, and a "clean" filter to create a
new version of the pointer file when the large file's contents change.It also uses a pre-push hook to upload the large file contents to
the Git LFS server whenever a commit containing a new large file
version is about to be pushed to the corresponding Git server.</args></command>
Kemudian anda perlu melaksanakan perintah berikut untuk mengkonfigurasi persekitaran global LFS Ia hanya perlu dikonfigurasikan sekali, dan cangkuk gudang semasa juga akan dikemas kini

<.>git lfs install

Pindahkan gudang sejarah tempatan

Idea asas lfs migrasi: lfs menulis semula sejarah tempatan—> kesan migrasi.

Jadi lebih baik kita menyegerakkan gudang tempatan dengan yang jauh, dan mencipta cawangan tempatan untuk semua cawangan terpencil

Kemudian cd ke gudang tempatan anda dan laksanakan arahan berikut, –include mengandungi ungkapan glob, Tambah nama fail yang anda mahu LFS uruskan, –semuanya mewakili semua cawangan tempatan

git lfs migrate import --include="*.bin,*.lib,*.so,*.dll,*.a,*.param,*.zip,*.gz" --everything
Selepas menulis semula cawangan tempatan, teg, dll.,
migrate: Sorting commits: ..., done.
migrate: Rewriting commits: 100% (193/193), done.
  develop                       bacb490a80ea46d73bd3866c2e7cf7ad199ce5eb -> 72884bcb4629417bad73ea3d485d08a0708909cd
  feature/npu-platform          a3645632756becc527c7f4d58514b3c479f824d3 -> e227900a3903b3a6955e4dffee48daeceac6cdff
  master                        1ccdecdcb4b5d6224a6e24c6f87793bfcc15ee4c -> 1d9fc2139600ef3d92a20d65bb5db89021b8c488
  0.1.0                         07c6b2aa732506f1cc88cedb551f37f376b6efa6 -> 8e55193221dfca9f6bb28ccd9cca85af9c5958c9
  1.0.0                         0f694efcd7aa9df641836e1ea6eebbb730b940b5 -> 3f9e77575120b6e56b34790c998a362116da75f5
migrate: Updating refs: ..., done.

kami boleh melaksanakannya di sini dahulu

git lfs ls-files

Semak fail mana yang telah ditukar kepada pengurusan lfs dan semak jika terdapat sebarang peninggalan
Ketahui pelangsingan gudang GIT dan arahan penghijrahan GIT LFS dalam sepuluh minitPada masa ini, tidak kira cawangan mana anda berada, Fail .gitattributes akan muncul , dan kandungan yang serupa dengan yang berikut akan ditambahkan.

Pada masa yang sama, anda dapat melihat bahawa semua fail perduaan kami telah ditukar kepada bentuk teks berikut
*.bin filter=lfs diff=lfs merge=lfs -text
*.lib filter=lfs diff=lfs merge=lfs -text
*.so filter=lfs diff=lfs merge=lfs -text
*.dll filter=lfs diff=lfs merge=lfs -text
*.a filter=lfs diff=lfs merge=lfs -text
*.param filter=lfs diff=lfs merge=lfs -text
*.zip filter=lfs diff=lfs merge=lfs -text
*.gz filter=lfs diff=lfs merge=lfs -text

Sahkan bahawa ia betul, dan kemudian ia boleh ditolak ke hujung terpencil;
version https://git-lfs.github.com/spec/v1
oid sha256:9171c8350d72ccca6ad60ac80b577157ad1f9fd44ca05744216e02ccbfcdf491
size 10260
Disebabkan lfs Migrasi akan menulis semula semua komit dan mengubah suai nilai cincang, jadi kita perlu menambah –froce

Langkah ini memerlukan pembatalan cawangan yang dilindungi (cawangan yang dilindungi tidak boleh -f)

penghijrahan gudang terpencil seperti itu selesai
git push --force --all

迁移一些补充说明

  1. 迁移者的本地仓库lfs文件转源文件:经过以上步骤,由于我们将所有文件都已经转成文件指针,我们需要将文件下载回来才能正常使用该仓库。
    需要注意,其他人重新clone 或者同步 lfs迁移过的remote仓库 是不需要该步,只针对迁移作者本地的仓库。
git lfs pull
  1. 团队中其他成员迁移前的本地仓库同步: 由于远程仓库的历史已经被全部重写,所以无法直接同步,最好是删除本地分支,重新拉取远程分支,如果本地已经有部分commit需要提交,可以重名本地分支,拉取远程再做cherry pick。git tag 同理,删除迁移前的tag。
  2. 本地仓库清理:上面的迁移成功将二进制文件迁移成git lfs 对象,git log 也不在存储源文件文件变更而是指针变更,但是在本地.git文件夹中仍存在之前不再需要的git log 缓存,执行以下命令做清理。
git reflog expire --expire-unreachable=now --all
git gc --prune=now

清理前后仓库对比

lfs直观来讲更多的是针对仓库大clone慢的问题,我这边lfs迁移前后各备份各一个小型远程仓库做测试,
用的测试仓库二进制文件比较小,总大50m内,且变更次数也在个位数。
clone下来的仓库大小对比。
和我预估差不多,总的来说更适合二进制文件频繁变更,如果单纯是文件大,但文件不变更的话,在clone的时候区别不大,毕竟lfs在clone仍有下载源文件的步骤,除开下载,操作文件指针对git来说理论仍会有性能提升,但是可能感知不强。
Ketahui pelangsingan gudang GIT dan arahan penghijrahan GIT LFS dalam sepuluh minit

推荐学习:《Git教程

Atas ialah kandungan terperinci Ketahui pelangsingan gudang GIT dan arahan penghijrahan GIT LFS dalam sepuluh minit. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Artikel ini dikembalikan pada:CSDN. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
Git vs Github: Meneroka Peranan MerekaGit vs Github: Meneroka Peranan MerekaApr 16, 2025 am 12:06 AM

Git dan GitHub adalah alat yang berbeza: Git adalah sistem kawalan versi yang diedarkan untuk menguruskan versi kod dan pembangunan kolaboratif; GitHub adalah platform dalam talian berdasarkan Git, menyediakan kod hosting dan alat kerjasama. Ciri -ciri utama Git termasuk pengurusan versi, pengurusan cawangan, dan pembangunan kolaboratif, sementara GitHub menyediakan hosting kod, alat kerjasama dan keupayaan rangkaian sosial.

GitHub: Hub untuk pembangunan sumber dan perisian terbukaGitHub: Hub untuk pembangunan sumber dan perisian terbukaApr 15, 2025 am 12:10 AM

GitHub adalah platform hosting sistem kawalan berasaskan Git yang menyediakan kawalan versi, pembangunan kolaboratif dan fungsi komunikasi komuniti. Menggunakan GitHub dapat meningkatkan kecekapan pembangunan dan kualiti kod.

Git dan GitHub: Apa hubungannya?Git dan GitHub: Apa hubungannya?Apr 14, 2025 am 12:10 AM

Git dan GitHub adalah alat yang berbeza: Git adalah perisian untuk kawalan versi, dan GitHub adalah platform dalam talian berdasarkan Git. 1. GIT membolehkan anda menjejaki perubahan fail dan pembangunan kolaboratif. 2. GitHub menyediakan alat hosting dan kolaborasi kod untuk meningkatkan kecekapan pembangunan pasukan.

GitHub: Platform untuk pemaju dan projekGitHub: Platform untuk pemaju dan projekApr 13, 2025 am 12:01 AM

Ciri -ciri teras GitHub termasuk kawalan versi, pengurusan cawangan, kajian kod, penjejakan isu dan pengurusan projek. 1. Kawalan versi dan pengurusan cawangan adalah berdasarkan Git, yang membolehkan pengesanan perubahan kod dan pembangunan eksperimen. 2. Kajian Kod dilaksanakan melalui PullRequest untuk meningkatkan kualiti kod dan kerjasama pasukan. 3. Isu Penjejakan dan Pengurusan Projek dijalankan melalui isu -isu dan Lembaga Pengurusan Projek untuk meningkatkan ketelusan projek dan kebolehkesanan.

Github dalam Tindakan: Contoh dan Kes GunakanGithub dalam Tindakan: Contoh dan Kes GunakanApr 12, 2025 am 12:16 AM

GitHub adalah alat yang berkuasa untuk meningkatkan kecekapan dan kualiti pembangunan perisian. 1) Kawalan versi: Menguruskan perubahan kod melalui Git. 2) PullRequests: Melakukan semakan kod dan meningkatkan kualiti kod. 3) Isu: Bug trek dan kemajuan projek. 4) GitHubactions: Automatikkan proses pembinaan, ujian dan penempatan.

Git vs Github: Kawalan Versi dan Kod HostingGit vs Github: Kawalan Versi dan Kod HostingApr 11, 2025 am 11:33 AM

Git adalah sistem kawalan versi, dan GitHub adalah platform hosting kod berasaskan Git. Git digunakan untuk menguruskan versi kod dan menyokong operasi tempatan; Github menyediakan alat kerjasama dalam talian seperti Penjejakan Isu dan PullRequest.

Apakah git dengan kata -kata mudah?Apakah git dengan kata -kata mudah?Apr 09, 2025 am 12:12 AM

GIT adalah sistem kawalan versi yang diedarkan sumber terbuka yang membantu pemaju menjejaki perubahan fail, bekerjasama dan menguruskan versi kod. Fungsi terasnya termasuk: 1) pengubahsuaian kod rekod, 2) sandaran kepada versi terdahulu, 3) pembangunan kerjasama, dan 4) membuat dan menguruskan cawangan untuk pembangunan selari.

Adakah git sama dengan GitHub?Adakah git sama dengan GitHub?Apr 08, 2025 am 12:13 AM

Git dan GitHub bukan perkara yang sama. Git adalah sistem kawalan versi, dan GitHub adalah platform hosting kod berasaskan Git. Git digunakan untuk menguruskan versi kod, dan GitHub menyediakan persekitaran kerjasama dalam talian.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),