综上所述,一个通过svn的钩子结合的Jenkins独有的特性,来构建这个网站代码上线的架构吧!不多啰嗦了。
-
安装svn 、 Jenkins的安装请看博客的链接
http://zzxtbl.blog.51cto.com/7620672/1744529 #svn 安装
http://zzxtbl.blog.51cto.com/7620672/1656380 #jenkins的安装
-
svn钩子脚本的配置(在你当前svn的当前的版本库下修改)
/svn/test/hooks/post-commit
REPOS="$1" REV="$2" LANG=en_US.UTF-8 LOGFILE=/var/log/svn.log # 钩子脚本的日志 # 脚本的标准输出和标准错误输出都打印到日志文件里 exec 1>>"$LOGFILE" exec 2>&1 SVNLOOK=/usr/bin/svnlook TIME=$(date "+%Y-%m-%d %H:%M:%S") AUTHOR=$($SVNLOOK author -r $REV "$REPOS") #提交作者 CHANGEDDIRS=$($SVNLOOK dirs-changed $REPOS) #修改的目录集合 MESSAGE=$($SVNLOOK log -r $REV "$REPOS") #提交时的备注信息,不建议用中文 # SVN客户端配置,需要自行修改********************************** CLIENTSVNROOT=/data/www #WEB服务器的代码根目录 SVNUSER="tiantian" SVNPASSWD="123456" #************************************************************** function myecho() { echo "$TIME" "$*" } myecho "**************************************************************" myecho "提交版本:$REV 作者:$AUTHOR" myecho "提交备注:$MESSAGE" myecho "修改目录:$(echo $CHANGEDDIRS | tr '/n' ' ')" MASTERDIR=$(echo "$CHANGEDDIRS" | head -1) #CHANGEDDIRS里的主目录 # 遍历提交的代码目录,同步到WEB服务器上 while [ "$CHANGEDDIRS" != "" ];do PROJECT=$(echo $MASTERDIR | awk -F / '{print $1}') # 判断项目文件夹 if [ "$PROJECT" == "php" ];then myecho myecho "项目:$PROJECT 同步目录:$MASTERDIR" myecho "同步 $MASTERDIR 到 $CLIENT1:$CLIENTSVNROOT/$MASTERDIR" # 无密码ssh连接到客户端服务器,执行svn up SVN=/usr/bin/svn svn up --non-interactive --username $SVNUSER --password $SVNPASSWD /$CLIENTSVNROOT/$MASTERDIR if [ $? -eq 0 ] then /usr/bin/rsync -az --delete $CLIENTSVNROOT /tmp/ #临时目录 fi elif [ "$PROJECT" == "tianshi" ];then myecho myecho "项目:$PROJECT 同步目录:$MASTERDIR" myecho "同步 $MASTERDIR 到 $CLIENT2:$CLIENTSVNROOT/$MASTERDIR" svn up --non-interactive --username $SVNUSER --password $SVNPASSWD /$CLIENTSVNROOT/$MASTERDIR if [ $? -eq 0 ] then /usr/bin/rsync -az --delete $CLIENTSVNROOT /tmp/ #临时目录 fi else : fi # 在目录集合里删除已经同步好的目录 CHANGEDDIRS=$(echo "$CHANGEDDIRS" | grep -v "^$MASTERDIR") # 获取新的需要同步的主目录 MASTERDIR=$(echo "$CHANGEDDIRS" | head -1) done 别忘了给钩子授权 chmod 755 post-commit
3.关于临时目录的要授予Apache权限和svn提交文件克隆
chown apache:apache -R /data/www
chown apache:apache -R /tmp/
chown apache:apache -R /var/log
svn提交文件克隆命令
svn co svn://192.168.40.128 –username tiantian –password 123456 /data/www
不操作这条命令会造成没权限法提交
2016-01-14 03:35:20 项目:php 同步目录:php/
2016-01-14 03:35:20 同步 php/ 到 :/data/www/php/
Skipped ‘/data/www/php’
4.版本控层已经写好了,看效果吧
5.jenkins项目的创建
主要是两个方面,一是源码管理,二是构建触发器,配置信息如下(其中* * * * *,即表示每分钟检测一遍代码,若发现有更新则自动触发构造项目)
6. Jenkins每次构建数据的同事执行同步的数据(rsync软件同步)
查看构建的结果
7.查看测试结果
总结:
svn+jenkins构建可持续化的程序。重点控制的环节在于svn版本的控制。
总结有些很简介。后续再添加吧。我也是小白。黑黑!!
原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/tech/opensource/196427.html