Gitolite3 не пишет
Я немного на краю света здесь. Я хочу установить Gitolite3 Smart HTTP поверх Apache. Я могу успешно тянуть, но не толкать (даже не дает никаких ошибок или уведомлений, даже в любом известном журнале). Я отключил selinux, пока не понял, что случилось. Моя ОС - CentOS6.4. Я вставляю все свои соответствующие конфы и логи, но все они кажутся нормальными..
Каков следующий шаг (и) для меня?
Может кто-нибудь сказать мне, если их записи в журнале gitolite3 для отправленных вызовов отличаются от моих ниже?
Процесс:
$ git clone http://flo@server/git/testing
$ cd testing/
$ echo "This is a test" > testing.txt
$ git add testing.txt
$ git status
$ git commit -am "Added test file"
$ git status
$ git push http://flo@server/git/testing
$ cd ..
$ rm -rf testing
$ git clone http://flo@server/git/testing
$ ll testing
total 0
/ И т.д. / HTTPD / Журналы / access_log
10.42.43.1 - - [07/Aug/2013:11:43:09 +0100] "GET /git/testing/info/refs?service=git-upload-pack HTTP/1.1" 401 481 "-" "git/1.7.1"
10.42.43.1 - uncleflo [07/Aug/2013:11:43:09 +0100] "GET /git/testing/info/refs?service=git-upload-pack HTTP/1.1" 200 38 "-" "git/1.7.1"
10.42.43.1 - - [07/Aug/2013:11:44:01 +0100] "GET /git/testing/info/refs?service=git-receive-pack HTTP/1.1" 401 481 "-" "git/1.7.1"
10.42.43.1 - uncleflo [07/Aug/2013:11:44:01 +0100] "GET /git/testing/info/refs?service=git-receive-pack HTTP/1.1" 200 151 "-" "git/1.7.1"
10.42.43.1 - - [07/Aug/2013:11:54:54 +0100] "GET /git/testing/info/refs?service=git-upload-pack HTTP/1.1" 401 481 "-" "git/1.7.1"
10.42.43.1 - uncleflo [07/Aug/2013:11:54:54 +0100] "GET /git/testing/info/refs?service=git-upload-pack HTTP/1.1" 200 38 "-" "git/1.7.1"
/etc/httpd/logs/suexec.log
[2013-08-07 11:43:09]: uid: (650/gitolite3) gid: (650/gitolite3) cmd: gitolite-suexec-wrapper.sh
[2013-08-07 11:44:01]: uid: (650/gitolite3) gid: (650/gitolite3) cmd: gitolite-suexec-wrapper.sh
[2013-08-07 11:54:54]: uid: (650/gitolite3) gid: (650/gitolite3) cmd: gitolite-suexec-wrapper.sh
/var/lib/gitolite3/.gitolite/logs/gitolite-2013-08.log
2013-08-07.11:43:09 6104 access(testing, uncleflo, R, 'any'),-> refs/.*
2013-08-07.11:43:09 6104 trigger,Writable,access_1,ACCESS_1,testing,uncleflo,R,any,refs/.*
2013-08-07.11:43:09 6104 pre_git testing uncleflo R any -> refs/.*
2013-08-07.11:43:09 6104 system,git,http-backend
2013-08-07.11:43:09 6104 END
2013-08-07.11:44:01 6122 access(testing, uncleflo, W, 'any'),-> refs/.*
2013-08-07.11:44:01 6122 trigger,Writable,access_1,ACCESS_1,testing,uncleflo,W,any,refs/.*
2013-08-07.11:44:01 6122 pre_git testing uncleflo W any -> refs/.*
2013-08-07.11:44:01 6122 system,git,http-backend
2013-08-07.11:44:01 6122 END
2013-08-07.11:54:55 6226 access(testing, uncleflo, R, 'any'),-> refs/.*
2013-08-07.11:54:55 6226 trigger,Writable,access_1,ACCESS_1,testing,uncleflo,R,any,refs/.*
2013-08-07.11:54:55 6226 pre_git testing uncleflo R any -> refs/.*
2013-08-07.11:54:55 6226 system,git,http-backend
2013-08-07.11:54:55 6226 END
Для репозитория: gitolite-admin / conf / gitolite.conf
repo testing
RW+ = @all
RW+ = daemon
/etc/httpd/conf.d/gitolite3.conf
<VirtualHost *:80>
# ServerName git.example.com
# ServerAlias git
# ServerAdmin you@example.com
DocumentRoot /var/www/git
<Directory /var/www/git>
Options None
AllowOverride none
Order allow,deny
Allow from all
</Directory>
SuexecUserGroup gitolite3 gitolite3
ScriptAlias /git/ /var/www/bin/gitolite-suexec-wrapper.sh/
ScriptAlias /gitmob/ /var/www/bin/gitolite-suexec-wrapper.sh/
<Location /git>
AuthType Basic
AuthName "Git Access"
Require valid-user
AuthUserFile /etc/httpd/git.passwd
</Location>
</VirtualHost>
/var/www/bin/gitolite-suexec-wrapper.sh
#!/bin/bash
#
# Suexec wrapper for gitolite-shell
#
export GIT_PROJECT_ROOT="/var/lib/gitolite3/repositories"
export GITOLITE_HTTP_HOME="/var/lib/gitolite3"
exec /usr/share/gitolite3/gitolite-shell
2 ответа
В пустом репо вы должны сначала создать ветку, прежде чем совершать:
git checkout -b master # creates the master branch
echo ... # creates the test file
git commit -am "first commit" # commit in the right branch
git push -u origin master # actually push something
Следующий толчок будет нужен только git push
,
См. " Почему мне нужно явно выдвинуть новую ветку? ", Чтобы узнать больше об этом начальном шаге.
Если вы не создаете ветку, вы делаете коммит в отдельной голове, которая никогда не толкается (отсюда и отсутствие видимых изменений на удаленной стороне - gitolite)
У меня также возникли некоторые проблемы при установке смарт-http с помощью gitolite. После успешного завершения я написал как в своем блоге.