问题
Considering that Git does not recognize symbolic links that point outside of the repository, is there any problem using hard links?
Could Git break them? Can you please point me to detailed information?
回答1:
The 'tree' object, representing directories in Git, stores file name and (subset of) permissions. It doesn't store inode number (or other kind of file id). Therefore hard links cannot be represented in git, at least not without third party tools such as metastore or git-cache-meta (and I am not sure if it is possible even with those tools).
Git tries to not touch files that it doesn't need to update, but you have to take into account that git doesn't try to preserve hardlinks, so they can be broken by git.
About symbolic links pointing outside repository: git has no problems with them and should preserve contents of symbolic links... but utility of such links is dubious to me, as whether those symlinks would be broken or not depends on the filesystem layout outside git repository, and not under control of git.
回答2:
Ok, now this is a late reply =D
I found out that, using hooks, you can capture the git pull
event (when there is something to pull...) writing the script event handler to .git/hooks/post-merge
file.
First, you have to chmod +x
it.
Then, put the ln
commands inside it to recreate hard links at each pull. Neat huh!
It works, I just needed that for my project and ls -i
shows that files were automatically linked after pull
.
My example of .git/hooks/post-merge
:
#!/bin/sh
ln -f $GIT_DIR/../apresentacao/apresentacao.pdf $GIT_DIR/../capa/apresentacao.pdf
ln -f $GIT_DIR/../avaliacoesMono/avaliacao_monografias_2011_Nilo.pdf $GIT_DIR/../capa/avaliacoes.pdf
ln -f $GIT_DIR/../posters/poster_Nilo_sci.pdf $GIT_DIR/../capa/poster.pdf
ln -f $GIT_DIR/../monografia/monografia_Nilo.pdf $GIT_DIR/../capa/monografia_Nilo.pdf
IMPORTANT: As you can see, the path to any file in your repository should begin with $GIT_DIR
, then add the partial relative path to the file.
Also important: -f
is necessary, because you are recreating the destination file.
回答3:
From this msysgit issue
Junction points are not symbolic links; therefore, symbolic links are simply unsupported in msysGit.
Also, hard links were never tracked by Git.
The issue were Windows-oriented (since it is about msysgit) and debate about the potential support of symlink.
But the comment about hard link concerns Git in general.
回答4:
Google 'git preserve hard links' and it shows that git does not know how to preserve hard link structure AFAIK, perhaps by design.
Web projects of mine use hard links as follows:
www/products/index.php
www/products/dell_latitude_id577/index.php #(hard linked to above)
www/products/dell_inspiron_id323/index.php #(hard linked again to above)
me@server:www/products$ ls -l index.php
-rwxr-xr-x 3 me me 1958 Aug 22 22:10 index.php*
If I wanted to make changes to index.php I change it in one place and the hard links (product detail pages) point to the changes -- except git does not preserve this relationship during cloning and pulling on other computers.
me@server:www$ git pull
on another machine will create a new index.php for each hard link.
来源:https://stackoverflow.com/questions/3729278/git-and-hard-links