[转] 使用git自动部署简单网站

要做什么

假设你有一个博客,有一台网站服务器(或者很多台作负载均衡的服务器),当你的博客要升级时,你可能要在你自己的电脑上写好代码(可能包括本地调试好),然后提交到git(或svn),然后在每个服务器中checkout一份代码并重启服务器应用……

这里要介绍的是一种直接在本地提交代码,即可自动完成服务器部署的方法。

怎么做

假设你有网站主机(后面统称线上机):

user:user
host:1.2.3.4 password:passwd 

并且确保你的本地开发机器(后面统称开发机)与线上机均已安装好Git(不是Github)

1. 线上机增加三个文件夹:

mkdir ~/git-directory.git
mkdir ~/deploy-directory-1
mkdir ~/deploy-directory-2 

其中git-directory.git作为代码仓库,即开发机的代码统一提交到这里存放.

deploy-directory-1和deploy-directory-2是开发机上的部署目录,比如测试目录和正式线上内容目录

2. 线上机git仓库初始化:

cd ~/test.git
git init --bare
cd hook
cp post-receive.sample post-receive 

3. 在post-receive文件中写入以下内容:

#!/bin/sh
#
DIR_ONE=/home/user/deploy-directory-1
DIR_TWO=/home/user/deploy-directory-2
# git --work-tree=${DIR_ONE} clean -fd git --work-tree=${DIR_ONE} checkout --force # git --work-tree=${DIR_TWO} clean -fd git --work-tree=${DIR_TWO} checkout --force 

4. 本地机增加文件夹并克隆远程git仓库:

mkdir whatever
cd whatever
git init
git remote add origin user@1.2.3.4:/home/git/test.git

注:此处会要求输入线上机器的登陆密码(passwd)

最终效果

本地机目录可以自由增删文件,并提交到线上机git仓库.

例如:

touch README
git add README
git commit -m 'first blood' README
git push origin master 

此步操作完成后,查看线上机中第一步建立的那几个目录(git-directory.git、deploy-directory-1、deploy-directory-2),是不是多了一个你刚刚在本地创建的文件README?

还有一步

如果你的网站比较简单,到这一步就已经是完事了。

试想上面的例子,假如你的网站是静态网站,在deploy-directory-1、deploy-directory-2这两个文件夹中部署了同样的网站,一个用于测试,一个是真实环境,这样你就已经可以直接提交文件就完成上线了,是不是挺爽的?

事实上,通过这种方式,实际上git-directory.git就成了你的一个git服务器,上面第三步编辑的post-receive就是一个 钩子(hook)文件,实际上就是一个可执行的shell脚本,当你在你的本地提交代码(git push)时,git服务器收到你的文件提交同时会触发这个钩子的动作,也就是执行这个shell脚本。说到这里,接下来这个shell脚本能做什么,重 启服务器?触发构建?把文件部署到别的机器上……尽情地发挥你的想象吧!

转载于:https://www.cnblogs.com/qiangxia/p/5344215.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值