摘要:要求实现直接完成代码部署到服务器的目录实现方式利用的中的来实现代码提交完成之后的动作。对于代码部署目录和仓库我们已经通过进行了关联了,因为我们一旦将代码到仓库,那么会自动检出到目录下。
要求
实现git push 直接完成代码部署到服务器的目录
实现方式利用git的hooks中的post-receive来实现代码提交完成之后的动作。将仓库指定一个--work-tree然后进行检出操作checkout --force
目录结构我自己的项目结构是这样的,每一个仓库对应一个项目,例如public/wx项目对应repo/wx.git仓库
. ├── public │ └── wx // 这是我们的web代码部署目录 │ ├── index.php │ ├── test2.php │ ├── test3.php │ └── test.php └── repo // 这个是我们的仓库目录 └── wx.git // 这个对应wx项目的仓库 ├── branches ├── config ├── description ├── HEAD ├── hooks // post-receive钩子代码写在这里面 ├── index ├── info ├── objects └── refs
再看下hooks文件目录
. ├── applypatch-msg.sample ├── commit-msg.sample ├── post-commit.sample ├── post-receive ├── post-receive.sample ├── post-update.sample ├── pre-applypatch.sample ├── pre-commit.sample ├── prepare-commit-msg.sample ├── pre-rebase.sample └── update.sample
我们将post-receive.sample复制一份post-receive,并且编写代码如下
# 指定我的代码检出目录 DIR=/www/public/wx git --work-tree=${DIR} clean -fd # 直接强制检出 git --work-tree=${DIR} checkout --force如何生成目录
上面看到的repo目录中的wx.git实际上是一个裸仓库,我们用下面的命令来生成这样一个仓库。
cd /www/repo git init --bare wx.git
对于代码部署目录和仓库我们已经通过post-receive进行了关联了,因为我们一旦将代码push到仓库,那么会自动检出到publish/wx目录下。
远程部署在本地电脑上,我们添加远程仓库
git init git remote add origin root@xxx.xxx.xxx.xxx:/www/repo/wx.git
这个时候我们添加了远程仓库,那么我们来测试下push操作
touch index.php git add . git commit -m "test" git push
可能会提示一个--set-upstream,直接执行下就好了。执行完之后我们登陆服务器,会发现文件已经出现在public/wx/index.php
注意点如果我们没有配置ssh免密码登陆的话,我们需要在push代码的时候输入密码
如果我们添加的远程仓库不是root@xxx.xxx.xx.xx,例如是abc@xx.xx.xx.xx,那么我们要确保abc用户对wx.git目录下的文件有777权限。
新增仓库需要登陆远程服务器进行初始化repo_name.git仓库
需要手动创建public/repo_name文件夹,并且修改权限为777
需要重新编写hooks/post-recieve文件,修改里面的DIR路径为public/repo_name
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/23255.html
摘要:以上命令表示到网站目录,并更新。随后还要把改成可执行本地环境提交代码至服务器 原理和流程 1、git用户执行 git push 操作 2、远程仓库发现有用户执行了push操作,就会执行一个脚本 post-receive(钩子) 3、在 post-receive 脚本中,将git仓库的代码拷贝到web站点目录下 1、进入服务器安装git,并建立仓库 sudo yum install g...
摘要:搭建服务器编写自动部署脚本今天试了下在服务器上搭建服务器,并且编写一个简单的自动部署脚本。好了,试试吧原文连接搭建服务器编写自动部署脚本更多分享知识点请扫码关注 搭建Git服务器、编写自动部署脚本 showImg(https://segmentfault.com/img/bVbs9fB?w=675&h=221); 今天试了下在linux服务器上搭建Git服务器,并且编写一个简单的自动部...
原文链接 随着Vateral主题的开发接近了尾声,在对主题速度优化的时候发现之前用的githubpage问题多多:首先就是因为在国内的原因,访问速度本身就很慢,曾经有次加载一张16kb的图标时间耗费了26s!!?其次,在对资源做CDN托管加速时,域名是需要备案的,显然githubpage也是做不了的;所以果断舍弃了这个把hexo搭建到了我的阿里云服务器上 总体来说还是比把hexo搭建到github...
摘要:博客的架构先搞明白博客从搭建到自动发布的架构,才能更好的理解我们每一步进行的操作。整个搭建流程第一部分服务器环境搭建,包括安装配置创建用户。在裸库的文件夹中,新建文件。 1. 博客的架构 先搞明白Hexo博客从搭建到自动发布的架构,才能更好的理解我们每一步进行的操作。不然只跟着步骤过了一遍,却不知道为什么这么做。 首先看这张架构图:showImg(https://segmentfaul...
阅读 2410·2021-11-18 10:02
阅读 1924·2021-10-13 09:40
阅读 3002·2021-09-07 10:07
阅读 2111·2021-09-04 16:48
阅读 1006·2019-08-30 13:18
阅读 2455·2019-08-29 14:03
阅读 2924·2019-08-29 12:54
阅读 3159·2019-08-26 11:41