git post-receive checkout to remote machine?

2020-06-28 04:35发布

问题:

If you add the following script as a hooks/post-receive hook to a bare git repository foo.git:

#!/bin/sh
GIT_WORK_TREE=/bar git checkout -f

then whenever someone pushes to the repository the current state will be updated in directory bar.

This requires bar and foo.git to be on the same machine.

What's the easiest way to modify it so that the checkout is made on a remote machine (say baz:/bar) ?

One way would be to:

#!/bin/sh
GIT_WORK_TREE=/tmp/bar git checkout -f
rsync ... /tmp/bar baz:/bar

Is there a better way? Perhaps not requiring an intermediate temp directory? (If not what are the correct options to pass to rsync such that the resulting directory is indentical to being checked out directly?)

回答1:

GIT_WORK_TREE=/bar means that bar is a git repo.

If bar is a git repo on the remote side, then it can pull from a bare repo bare_bar.git (also on the remote side), to which you can push to.

In other words, your post-receive hook would push to bare_bar repo through ssh, and a post-receive hook on that bare repo would trigger the pull from the actual repo bar: see "Creating a git repository from a production folder".


I'd prefer a solution that keeps the remote server free of any .git dirs (and even the git package itself ideally)

In that case, your current post-receive hook and its rsync command seems to be the only way to incrementally copy new data to a remote working tree.

  • git archive would archive everything each time.
  • git bundle would require git on the other side.