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 "[email protected]" 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 [email protected]".$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 ‘[email protected]‘" ;
        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 [email protected]".$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

时间: 2024-10-08 20:56:10

Git PHP提交的相关文章

GIT入门笔记(20)- git 开发提交代码过程梳理

git开发提交流程新项目开发,可以直接往master上提交老项目维护,可以在分支上修改提交,多次add和commit之后,也可以用pull合并主干和本地master,解决冲突后再push 1.检出代码 git clone http://gitserver/kubernetes/api-gateway-controller.git git clone http://gitserver/kubernetes/api-gateway-engine.git 引入为eclipse工程,修改代码 2.提交代

git 每次提交需要输入密码

亲测可行(第一种) 原文:git每次提交都要输入密码怎么办 ================COPY=========================== 不少用户反映在使用Git时,经常会遇到需要频繁输入密码的情况,那么,Ubuntu系统中git每次提交都要输入密码怎么办?该怎么避免呢?下面跟着学习啦小编一起来了解一下吧. git每次提交都要输入密码解决方法操作步聚如下: git每次提交都要输入密码解决方法一: 1: cd 回车;进入当前用户目录下; 2: vim .git-credentia

git 克隆,提交

git clone git-url git add . git comm -a -m ' desc ' git push ..然后还有一个.. 如果一直提示 *** Please tell me who you are. Run git config --global user.email "[email protected]" git config --global user.name "Your Name" to set your account's defau

轻松使用git命令提交代码

Github在Windows和Mac上都提供了很好的图形化的客户端,UI风格节约,功能轻松易用.但是我们仍然有必要熟悉git命令来维护代码,比如linux. 借用@sunshyran总结的git提交代码的五个步骤: 查看代码的修改状态 查看代码的修改内容 暂存需要提交的代码 提交已暂存的文件 同步到服务器 Step1.查看代码的修改状态 打开git shell(环境:以windows为例,安装好Github的客户端并配置好账户信息), 默认是在git的工作空间路径,ls命令可以查看workspa

git纯净提交代码(只提交自己改过的文件)

添加远程仓库,这个远程仓库是要进行发起合并请求的仓库,简单来说就是项目的主要代码库,不是自己派生的代码库 git remote add main http://xxx 从远端仓库下载新分支与数据git fetch main 创建新分支,以主仓库的master作为参照git checkout -b release main/master 创建自己派生库的新分支release,作为纯净分支git push origin release 非提交性合并git merge --squash origin 

shell脚本实现git快速提交代码与快速回滚

shell脚本实现git快速提交代码与快速回滚 创建一个commit库: [[email protected] cml]# echo "check github" > index.html [[email protected] cml]# cat index.html check github [[email protected] cml]# git add index.html [[email protected] cml]# git commit -m "check

git 无法提交空目录

git不能提交子文件夹? 空目录无法add,在最里面的目录下加上随便加上一个txt就可以了 原文地址:https://www.cnblogs.com/williamjie/p/10268330.html

Git忽略提交规则

转自:https://www.cnblogs.com/kevingrace/p/5690241.html 在使用Git的过程中,我们喜欢有的文件比如日志,临时文件,编译的中间文件等不要提交到代码仓库,这时就要设置相应的忽略规则,来忽略这些文件的提交.简单来说一个场景:在你使用git add .的时候,遇到了把你不想提交的文件也添加到了缓存中去的情况,比如项目的本地配置信息,如果你上传到Git中去其他人pull下来的时候就会和他本地的配置有冲突,所以这样的个性化配置文件我们一般不把它推送到git服

git文件提交

1,在.git同级目录即为工作区写入文件 ex: readme.txt 2,git bush 到当前路径 3,git add 文件名 ex:git add readme.txt (提交文件到暂存区) 4,git commit -m '创建readme文件' 一定要备注后提交到本地仓库 5,git add . 提交所有到暂存区 原文地址:https://www.cnblogs.com/li-shuang0221/p/11343224.html

规范git commit提交记录和版本发布记录

在开发过程中我们一般都会用到git管理代码,在git commit提交代码时我们一般对git commit message随便写点简单的描述,可是随着项目参与人数的增多,发现提交的commit记录越来越杂乱,不便查阅,在网上找了下解决方案,总结一下方便在公司项目中运用. commit message 格式 目前大家比较认可的是Angular团队的提交规范,很多工具也是基于此规范开发的.该提交规范格式如下: <type>(<scope>): <subject> <B