在服务器上,我有裸存储库,它是开发过程的起源,并简化了到QA环境的部署。
所以在post-receive
它就是这么做的
GIT_WORK_TREE=/home/dev git checkout -f
但随着产品变得越来越复杂,还应该发生一些其他事情。所以现在它由deploy.sh
脚本处理,该脚本也被存储库跟踪。所以我想做的是能够而不是检查整个存储库只是结帐deploy.sh
并运行它。我认为这样的东西会起作用:
SOURCE_PATH="/home/dev"
GIT_WORK_TREE=$SOURCE_PATH git checkout deploy.sh
$SOURCE_PATH"/deploy.sh"
但它不起作用给出错误:
error: pathspec 'deploy.sh' did not match any file(s) known to git.
我究竟做错了什么?或者这样做是不可能的?
正如我在“checkout only one file from git”中解释的那样,如果没有克隆或首先获取文件,则无法仅签出一个文件。
但是你git show
that file,这意味着你可以将其内容转储到/another/path./deploy.sh
文件中,并执行该文件。
git-show HEAD:full/repo/path/to/deploy.sh > /another/path./deploy.sh
/another/path./deploy.sh
由于您从post-receive挂钩执行该操作,git-show
将显示最新版本的deploy.sh
文件。
另一种选择是尝试
GIT_WORK_TREE=$SOURCE_PATH git checkout -- path/to/deploy.sh
并直接在工作树中签出该文件。
'--
'帮助git命令理解它是一个文件,而不是像标签或命名分支这样的另一个参数。
根据OP AlexKey的测试,它要求工作树已经(完全)检出至少一次。
我知道这是ooooooooold,但是我发现了自己的用例,并且在将一些解决方案组合成一个简单的单行程序之前,我找了一段时间来寻找更好的解决方案:
GIT_WORK_TREE=/home/dev git checkout $branch -- deploy.sh
在我的情况下,我只是希望能够“偷看”我的一些裸存储库,而无需解开整个事物(其中一些是巨大的)。人们在谈论稀疏检查和其他类似的事情,但我只需要一次性功能。例如,要查看“Documents / Health Records”文件夹,我会执行以下操作:
GIT_WORK_TREE=/tmp/my-files git checkout master -- "Documents/Health Records"
瞧!它确实出现了。
这个git show或类似的git cat-file blob方法对文本文件的工作或多或少都很好,但它们对二进制文件毫无希望。
更好的方法,可以为任何类型的文件可靠地工作,甚至允许签出整个文件夹:
git archive mybranch folder/file.txt --output result.tar
它创建一个包含所需内容的tar存档,这个文件位于源代码管理中。与二进制文件完美配合。
您唯一需要做的就是提取此tar文件
tar -xf result.tar
有关详细信息,请参阅我的blogpost