余果的博客

使用git部署站点

Introduction

user

余果

一个产品设计师。了解详情


Featured

使用git部署站点

余果 博客
本文写于2012年8月,到现在,本站的服务器已经发生了变化,请以最新的文章为准😜。

我最开始的时候迁移站点都是傻乎乎的用FTP一个文件一个文件上传,一个wordpress需要半小时,而且容易中断,后来damao告诉我用wget这个神器,就发现其实可以通过SSH在服务器端直接做一些操作,速度非常快。

最近一段时间越来越喜欢用git来管理代码,而且代码变化越来越块越来越多,现在的工作流不再合适。因为版本管理和代码部署脱节了——使用git来管理版本,更新了代码之后,还需要其他工具来把代码同步到服务器,这就很冗余了,所以我尝试用git直接把代码push到服务器。

在服务器上的设置:

首先需要一个支持SSH的服务器,比如miao.in,在终端中输入命令:

cd /var/www/yoursite
git init .
git config receive.denyCurrentBranch ignore
git config --bool receive.denyNonFastForwards false
cd .git/hooks
touch post-receive
chmod +x post-receive

然后在新创建的post-receive中输入:

#!/bin/sh
#
DIR_ONE=/home/ubuntu/yuguo.us/public
#
git --work-tree=${DIR_ONE} clean -fd
git --work-tree=${DIR_ONE} checkout --force

这里的DIR_ONE=后面就写目标文件夹。

在本地git中配置:

在本地git仓库对应的远程仓库中指定一个“生产仓库”,比如prod,对应的git命令是:

$ git remote add prod your-ssh-username@your-host:/var/www/yoursite/.git

这样就算配置完成了,如果要把本地git的代码推送到服务器,命令是:

$ git push prod master

master对应你自己的分支的名字就好,prod的意思是product。

FAQ

post-receive是干嘛的?

在git的hooks文件夹可以配置一些钩子,这些钩子在git特定操作的时候被触发,post-receive就是这样一种钩子,当push发生的时候,它会在远程代码仓库执行操作。所以我们用wget把这个post-receive放到本地覆盖。

我不用`git init`,而用git clone可以吗?

没问题,但是还是要完成接下来的配置操作。

为啥push成功之后,代码没有生效?

远程的git已经拥有所有的版本信息,但对应的HEAD节点还没有跟当前文档对应,你可以用SSH登录远程服务器之后git checkout master(或者你的分支),之后就无需再次checkout了。

本地的配置文件跟服务器配置文件不一样,怎么办?

善用.gitignore

还有问题?

多多使用以下命令来检查git状态:

git status
git log --pretty=oneline
git remote
git branch

还有问题请google、stackoverflow……

user

余果

一个产品设计师。 了解详情