您的位置:首页 > 其它

svn利用hooks自动更新远程服务器上的项目

2016-04-24 15:06 513 查看
项目开发阶段往往需要频繁的提交代码,如果不加svn钩子的话,每次提交都要到项目目录下执行一下svn up,非常费事,所以今天决定加个把钩子做上。利用钩子更新远程项目的关键是实现ssh无密码登录。

svn仓库所在服务器(以下简称机器A) :6.111

项目所在服务器(以下简称机器B):6.28

一、首先我们实现ssh无密码登录(A->B)

1.在A机器上生成秘钥对

[root@domin ~]# ssh-keygen -t rsa
一路ENTER下去,秘钥对就可以成功生成啦。生成完的秘钥对保存/root/.ssh目录中(因为我是root用户)

[root@domin .ssh]# pwd
/root/.ssh
[root@domin .ssh]# ls
id_rsa  id_rsa.pub


2.将id_rsa.pub复制为authorized_keys,并将authorized_keys文件上传到B机器的

[root@domin .ssh]# cp id_rsa.pub authorized_keys
[root@domin .ssh]# scp authorized_keys root@192.168.6.28:/root/.ssh


3.ssh登录B机器,第一次需要输入密码,以后就不在需要了,至此,无密码登录就已经实现了

二、在B机器上创建更新svn的脚本

1.创建脚本文件/shell/svnup.sh

[root@domin shell]# vim svnup.sh


#!/bin/bash

/usr/bin/svn update /var/www/projcet #projcet为项目文件
[root@domin shell]# chmod 755 svnup.sh


三、创建钩子

svn仓库创建完后会有一个hooks文件夹,该文件夹下面已经自带了一些钩子文件,我们要用到的是post-commit

1.将post-commit.tmpl复制为post-commit

[root@101-server hooks]# cp post-commit.tmpl post-commit
2.注释掉post-commit里面的所有内容,并添加我们的更新命令

/usr/bin/ssh -l root 192.168.6.28 "/bin/bash /shell/svnup.sh"


四、总结

实现过程中有几个需要注意的地方,1..ssh目录和authorize_keys文件的权限,.ssh目录的权限是700,authorize_keys的权限应该为644.

2.post-commit文件和svnup.sh文件的权限,至少为755
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: