Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
520 views
in Technique[技术] by (71.8m points)

unix - deploying a website/webapp via git/gitolite permissions error

I've setup a development/testing server where developers can push repositories to a remote repo/webserver via gitolite/git. On the repository site everything works well and developers can use the server however:

Problem:

I want to deploy the code to an apache documentroot (chown'd apache:apcahe and chmod'd 755). I am following these instructions and when edit my post-receive hook as describe like so:

#!/bin/sh
echo "deploying to DocumentRoot"
GIT_WORK_TREE=/var/www/www.example.com git checkout -f

however now when I run git push from my local repo I get permissions errors like:

error: git checkout-index: unable to create file .gitignore (Permission denied)
error: git checkout-index: unable to create file .htaccess (Permission denied)

And my document root is empty...The post-receive hook is running as the user 'gitolite' (not sure whether that's important).

gitolite is already in the sudoers list so I want to run something like:

GIT_WORK_TREE=/var/www/www.example.com sudo git checkout -f

but this doesn't seem to work either, I want to avoid calling a separate shell script if possible.

Any ideas would be really appreciated.

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

First, make sure the git account is in the same group than the apache account.
(Or you need to go back to my previous answer that you want to avoid)

You report this works:

 sudo GIT_WORK_TREE=..... git checkout -f

But with a bare repo, you could also see get:

 fatal: You are on a branch yet to be born

(I wouldn't recommend trying to make your gitolite-managed bare repo a non-bare one as in this blog post

git config core.worktree /home/user/myproject
git config core.bare false
git config receive.denycurrentbranch ignore

)

I prefer making sure /var/www/www.example.com directory is a git repo, in which you can pull, instead of trying to checkout.
So the hook I like is more:

cd /var/www/www.example.com
git --git-dir=/var/www/www.example.com/.git --git-work-tree=/var/www/www.example.com pull

(with origin, the remote name which is used by default by git pull, refering to the gitolite bare repo)


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...