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
Git PHP提交的更多相关文章
- 如何避免git每次提交都输入密码
在ubuntu系统中,如何避免git每次提交都输入用户名和密码?操作步聚如下:1: cd 回车: 进入当前用户目录下:2: vim .git-credentials (如果没有安装vim 用其它编辑器 ...
- 如何利用git shell提交代码到github
在很早之前我根据找到的一些资料以及自己的实践总结了一篇如何将VS2015上的代码上传到GitHub上,后来我发现有小伙伴私信我,说跟我上面写的不一样,但是那段时间也比较忙,当我发现有人私信的时候差不过 ...
- GIT入门笔记(20)- git 开发提交代码过程梳理
git开发提交流程新项目开发,可以直接往master上提交老项目维护,可以在分支上修改提交,多次add和commit之后,也可以用pull合并主干和本地master,解决冲突后再push 1.检出代码 ...
- git 本地提交代码到 github 远程库,没有弹框 github login
git 本地提交代码到 github 远程库,没有弹框 github login: 原因: win10 有个凭据管理器,给保存了历史登陆用户名密码,导致无法切换用户. 解决办法: 删除历史登陆用户 ...
- git 命令提交项目到github
git 命令提交项目到github步骤如下: 1.使用git 命令客户端进入项目根路径,输入 git init 命令,创建github本地根目录 2.把文件加入到本地项目 git add . ,如 ...
- Git push 提交代码到远程global user.name错误解决办法
问题:安装了Git-1.9.4-preview和TortoiseGit等工具后,Git服务器开通了账号和密码并配置了邮箱.克隆了服务器代码到本地,按需求进行代码开发.提交本地代码到服务器时出现错误.具 ...
- 【git】提交代码到远程仓库
看完不用,就是一个字:忘! 之前学了两天git结果今天要用的时候,啥也想不起来.... 场景: 已有远程仓库: git@192.168.1.1:test/test.git 要提交代码到远程仓库的新分支 ...
- git纯净提交代码(只提交自己改过的文件)
添加远程仓库,这个远程仓库是要进行发起合并请求的仓库,简单来说就是项目的主要代码库,不是自己派生的代码库 git remote add main http://xxx 从远端仓库下载新分支与数据gi ...
- Git忽略提交规则 - .gitignore配置运维总结
在使用Git的过程中,我们喜欢有的文件比如日志,临时文件,编译的中间文件等不要提交到代码仓库,这时就要设置相应的忽略规则,来忽略这些文件的提交.简单来说一个场景:在你使用git add .的时候,遇到 ...
- 如何使用 Git LFS 提交大文件?
参考资料: An open source Git extension for versioning large files Git LFS的使用 如何使用 Git LFS 提交大文件? Git LFS ...
随机推荐
- Linux 下安装服务器安全狗
1.网上下载服务器安全狗的软件包 32位和64位 wget http://www.safedog.cn/server_safedog_linux.html/safedog_linux32.tar ...
- C#的Socket简单实现消息发送
Socket一般用于网络之间的通信,在这里,实现的是服务端与客户端的简单消息通信.首先是客户端的搭建,一般步骤是先建立Socket绑定本地的IP和端口,并对远端连接进行连接进行监听,这里的监听一般开启 ...
- 修改 apache http server 默认站点目录
1.打开apache中的 httpd.conf 文件,将DocumentRoot "D:/Program Files/Apache Software Foundation/Apache2.2 ...
- Delphi XE5教程3:实例程序
内容源自Delphi XE5 UPDATE 2官方帮助<Delphi Reference>,本人水平有限,欢迎各位高人修正相关错误! 也欢迎各位加入到Delphi学习资料汉化中来,有兴趣者 ...
- Response.Redirect和Server.Transfer
今天又比较闲,逛了逛园子,看看asp.net的内容,看到一篇关于这两个的比较: http://www.cnblogs.com/yunfeng8967/archive/2008/03/06/109323 ...
- nginx服务器绑定域名和设置根目录
首先进入nginx安装目录的配置目录conf,然后执行 vi conf/nginx.conf 打开nginx的配置文件,找到并修改红字部分 server { listen default_server ...
- EAI概述
企业的业务流程同时会涉及多个应用系统,因此要求这些系统能够协同,但接口,架构的不统一往往使得这些本应紧密集成的应用系统成了一个个“信息孤岛”.于是,企业应用集成(Enterprise Applicat ...
- Java中的继承和多态
1. 什么是继承,继承的特点? 子类继承父类的特征和行为,使得子类具有父类的各种属性和方法.或子类从父类继承方法,使得子类具有父类相同的行为. 特点:在继承关系中,父类更通用.子类更具体.父类具有更 ...
- spring-mysqlclient开源了
https://github.com/risedragon/spring-mysqlclient/wiki/spring-mysqlclient-user-guide 开源了一个项目,总结了几年的数据 ...
- cppcheck使用
一.splint介绍 splint是一个动态检查C语言程序安全弱点和编写错误的程序.splint会进行多种常规检查,包括未使用的变量,类型不一致,使用未定义变量,无法执行的代码,忽略返回值,执行路径未 ...