个人原创,版权所有,转载请注明出处,并保留原文链接:
http://www.embbnux.com/2014/09/05/git_server_let_code_auto_deploy/
订阅BLOG:Blog of Embbnux 文章浏览量:4,209 views
之前在一台vps服务器上面搭建了git服务器,用来做代码管理,方便团队开发。但是问题也就相应的来了,使用git可以轻松的上传代码,而由于做的是web开发,每次还都得到服务器上把代码手动pull或者复制到网页所在的文件夹下,也就比较麻烦,不适合我这种懒人。git提供了hook机制,可以很容易的实现代码的自动部署。
个人原创,版权所有,转载请注明原文出处:
http://www.embbnux.com/2014/09/05/git_server_let_code_auto_deploy/
一 git机制简要介绍
git使用的是代码仓库,git服务端有仓库,称为远端仓库,我们clone下来的,本地也有一个仓库称为本地仓库。我们commit的时候是把代码提交到了本地仓库,push时,是把代码提交到了远端仓库。pull的时候是把代码从远端仓库下载到本地仓库。
代码仓库对代码的存储使用了版本指针,每个提交的版本都对应一个HEAD指针,当前版本指针随着代码的提交而一直改变。
二 自动部署原理
说说现在代码的分布情况,开发者电脑上的本地仓库,git服务器上的远端仓库,web服务器上的另一个本地仓库,我们浏览器访问的就是这里的代码。
要实现自动部署,就是要当开发者从本地仓库提交代码到远端仓库的时候,自动把代码部署到web服务器的本地仓库,实现开发者本地仓库和web服务器的本地仓库的同步。
三 实现自动部署
按照上面说的,就是要在开发者提交的时候,自动触发脚本,脚本去实现web端代码的部署.
这里就得讲一下git的hook机制,当git服务器接到各种事件时触发,这里使用的hook是
post-receive
这个hook在git服务器受到push请求,并且接受完代码提交时触发。
具体代码体现:
在git远端仓库的hooks目录下新建post-receive文件:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
|
保存后赋予可执行权限:
1 |
|
这样在开发者提交代码的时候,就会自动部署。
自动部署的时候,我这里使用的是git fetch,也可以使用git pull实现,这里两个的区别主要是pull事先fetch后然后再用merge,来合并本地和远端的代码。但是有个问题,如果开发者在提交过程出现失误,使用git reset复位后,现在远端的代码版本低于web端的代码版本,再使用pull的时候就不能实现和开发者本地的代码的同步。所以这里使用fetch后,在强制使用reset实现web端的代码版本指针和git服务端的一致。由于没有使用merge,所以以后web端的代码就不能在服务器上直接更改了,对web端代码的各种改变都应该使用开发者电脑进行代码提交,不然会报错。
参考:
http://argcv.com/articles/2078.c
http://blog.csdn.net/a06062125/article/details/11727273