使用svn hooks 脚本post-commit时遇到的故障

由于网站上线,需要把新添加功能上传到测试环境进行测试,但由于程序员每天有大量的修改,如果总是登陆服务器手动更新svn工作副本(测试环境)太耗时耗精力,进而增加svn进行commit时,测试环境即时更新的功能。

 

post-commit脚本:

[c-sharp] view plaincopy
  1. #!/bin/sh  
  2. REPOS="$1"  
  3. REV="$2"  
  4. export LANG=en_US.UTF-8  
  5. /usr/bin/svn update /data0/htdocs/xxx.xxx.xx.xxx --username user --password xxxxxx 2>>/tmp/svn_hook_log.txt  
  6. echo `whoami`,$REPOS,$REV >> /tmp/svn_hook_var.txt  

问题1:

注意字符集问题,本机

LANG=en_US.UTF-8

则脚本中必须加入

export LANG = en_US.UTF-8

否则提交时被报错

 

问题2:

更新后报错,脚本执行失败

查看svn_hook_log.txt,内容是svn提示要缓冲明文密码到硬盘,需要输入yes或者no确认,因为得不到脚本回应,所以报错退出。

解决办法:需要在svn服务器配置文件中把store-plaintext-passwords 项前#号去掉并把值改为no

因为需要使用apache身份执行脚本,所以执行

cp -r /root/.subversion/ /var/www/   #apache用户家目录

再修改

vim /var/www/.subversion/servers

 store-plaintext-passwords = no

 

问题3:

在工作副本中手动执行了一次svn update后,就发现hooks脚本执行失败,并报错

svn: Can't open file '/data0/htdocs/xxx.xxx.xx.xx/styles/.svn/tmp/entries': Permission denied

一番排查、google后,得出结论,应该是以root身份执行svn update后,.svn文件夹下部分文件夹属主变为root,所以apache身份运行脚本时就没有权限写入了。

解决办法:到报错信息下的.svn路径中,执行chown apache:apache -R *

可能还有别的路径下.svn路径中有问题,在工作副本根下执行 chown apache:apache -R *

posted on 2012-04-21 11:50  coolnet  阅读(1253)  评论(0编辑  收藏  举报

导航