使用svn hooks 脚本post-commit时遇到的故障
由于网站上线,需要把新添加功能上传到测试环境进行测试,但由于程序员每天有大量的修改,如果总是登陆服务器手动更新svn工作副本(测试环境)太耗时耗精力,进而增加svn进行commit时,测试环境即时更新的功能。
post-commit脚本:
- #!/bin/sh
- REPOS="$1"
- REV="$2"
- export LANG=en_US.UTF-8
- /usr/bin/svn update /data0/htdocs/xxx.xxx.xx.xxx --username user --password xxxxxx 2>>/tmp/svn_hook_log.txt
- 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 *