Git PHP提交

作了个小的DEMO,能够查看:php

https://github.com/feixiang/webgit.git  html

这几天一直在郁闷的事情。 Git在shell里面执行得好好的,apache运行用户也改为了git,可是,在提交Git工程的时候却无法提交。git

  刚开始觉得是文件权限问题,由于权限问题是Linux上的最大问题。github

  但是,尽管把目录都设成了777的权限(不要学,测试用),仍是无法提交,因而心都凉了...web

  今天在询问某个同事的时候,无心中将apache用户从git改回apache,意外地发现!居然可以提交成功!shell

  以前将apache用户设置为git是由于在web服务器上部署了Git,组成Git + ftp + web的开发环境。 后来又试了试改git的用户组,依然没有成功。数据库

  再试了试将apache用户改为nobody,意外地发现!居然也能提交成功!apache

  看到这里,我开始怀疑是否是Gitolite(git权限控制系统)限制了ssh用户链接。因而尝试了用一个没有ssh认证的用户去做为apache用户,可是没有用... 因而,又想了想,是否是apache用户有什么特殊权限呢?其实这个方向应该是不对的...省略... 的确有多是ssh认证的时候出现的问题.... to be continue...服务器

  ————————————2012年11月12日 16时更新————————————————ssh

   终于解决了这个问题! 缘由终究仍是权限问题! 分析这个问题要从apache的日志来分析。

  分析error_log日志帮助我完成了这个任务。在个人服务器RedHat上,apache的日志文件在 /var/log/httpd/

  接上文:在git用户commit提交的时候,老是提交不成功,且没有输出。固然,这只是在php的环境下没有输出,其实!

  是发生了内部错误,apache把这些错误记录在了error_log里面。

  当时,我获得的错误大概是这样的: [html]

* Please tell me who you are. Run git config --global user.email "you@example.com" git config --global user.name "Your Name" to set your account's default identity. Omit --global to set the identity only in this repository. fatal: empty ident not allowed [/html]

  原来是Git提交的时候,git没有识别到当前提交的用户的配置,而后被Gitolite阻止了。

   可是git用户明明已经设置了用户名和email了。 这里又涉及到Git config 的全局 --global 设置和当前git仓库的config设置。

   因为apache目录被限制在个人web目录下,git用户没法读取到全局配置的信息,固然无法肯定提交的用户!

  根据这个思路,我从新在php中对每一个git仓库初始化进行了局部的config的设置。

  因而,再进行提交! 因而!提交成功!Push成功!

  专心解决问题,深刻分析日志...在解决这个问题的时候,发现apache的日志文件很是大,咱们能够另外设置,限制日志文件的大小。

   附上PHP代码,非专业,边学边用...

   

复制代码
function commitProject($project)
    {
        $remote = "localhost" ;
        $GIT = "/usr/bin/git";
        $commitMsg = $_GET['commit'] ;
        $Root = $_SERVER['DOCUMENT_ROOT'];
        $projectRoot = "$Root/$project";
            
        chdir($projectRoot);
        //先判断git是否创建
        if( !file_exists(".git") )
        {
           //不存在则先创建Git仓库
          $cmd = "$GIT init" ;
          exec( $cmd ,$rs,$status );
          //添加remote origin
          $cmd = "$GIT remote add origin git@".$remote.":hometouch.$project" ;
          exec( $cmd ,$rs,$status );
          //去掉文件属性更改
          $cmd = "$GIT config core.filemode false" ;
          exec( $cmd ,$rs,$status );
        }
        //下面执行命令
        if( $commitMsg == "" )
            $commitMsg = date("Y.m.d") ;    
        
        //确认提交用户名
        $cmd = "$GIT config user.name 'gitForFtp'" ;
        exec( $cmd ,$rs,$status );
        $cmd = "$GIT config user.email 'gitForFtp@server.com'" ;
        exec( $cmd ,$rs,$status );
        //去掉文件属性更改
        $cmd = "$GIT config core.filemode false" ;
        exec( $cmd ,$rs,$status );
          
        $cmd = "$GIT add *" ;
        echo "cmd : ".$cmd."<br />";
        exec( $cmd ,$rs,$status );
        unset($rs);

        $cmd = "$GIT commit -a -m \"$commitMsg\"" ;
        echo "cmd : ".$cmd."<br />";
        exec( $cmd ,$rs,$status );
        //print_array($rs);
        unset($rs);
        echo ($status==0) ? ("commit成功<br />") : ("commit失败<br />") ;
        
        // 防止 ip改变, 这里修改提交的ip
        $cmd = "$GIT remote set-url origin git@".$remote.":hometouch.$project" ;
        exec( $cmd ,$rs,$status );
        
        $cmd = "$GIT push -f origin master" ;
        echo "cmd : ".$cmd."<br />";
        exec( $cmd ,$rs,$status );
        echo ($status==0) ? ("Push成功<br />") : ("Push失败<br />") ;
        //print_array($rs);
        unset($rs); 
    }
复制代码

 

  这里又遇到的一个问题是,

error: insufficient permission for adding an object to repository database .git/objects

  这个是由于之前是手动提交的,因此初始化项目的用户不是git,因此致使.git目录的全部者不是git,这样提交的时候就无法写入.git数据库,致使这个错误。解决方法很简单,改变.git目录拥有者便可

sudo chown -R git:git repo.git

相关文章
相关标签/搜索