• Git PHP提交


    做了个小的DEMO,可以查看:

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

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

      刚开始以为是文件权限问题,因为权限问题是Linux上的最大问题

      可是,尽管把目录都设成了777的权限(不要学,测试用),还是没法提交,于是心都凉了...

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

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

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

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

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

       终于解决了这个问题! 原因终究还是权限问题! 分析这个问题要从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

  • 相关阅读:
    spoj DQUERY
    省选模拟赛 爬山法
    bzoj1874 [BeiJing2009 WinterCamp]取石子游戏
    bzoj1013 [JSOI2008]球形空间产生器sphere
    省选模拟赛 让苍天知道我不认输(40分)
    省选模拟赛 厌世者打击(60分)
    省选模拟赛 至危警告
    bzoj4449 [Neerc2015]Distance on Triangulation
    省选模拟赛 cti
    数组、ArrayList、List、LinkedList的区别
  • 原文地址:https://www.cnblogs.com/trying/p/2863822.html
Copyright © 2020-2023  润新知