docker+django+vue实例开发之一:搭建开发环境(四)

4)将提交后的代码自动部署到服务器

在建立模板工程的过程中可以看到,每次push完前、后端工程代码后,还需要到服务端去手工拉取文件,这样效率很低,为此可以利用git的钩子文件机制,将手工拉取文件这部分做成linux bash脚本,每次push成功后自动调用即可。在远端服务器/home/git/repositories/TNDBXXXT.git/hooks/文件夹下(以git用户身份),添加新文件post-receive,内容如下:

##!/bin/sh

##author: clz

##判断是不是远端仓库 

IS_BARE=$(git rev-parse --is-bare-repository)

if [ -z "$IS_BARE" ]; then

echo >&2 "fatal: post-receive: IS_NOT_BARE"

exit 1

fi

##设置并转到代码部署目录

unset GIT_DIR 

DeployPath="/home/git/TNDBXXXT"

echo"===============================================" 

cd $DeployPath

echo "deploying the whole project"

##在部署目录拉取最新文件

git fetch --all

git reset --hard origin/master

echo "==============================================="

##将更新后的代码文件拷贝到docker容器目录,需先删除再拷贝

echo "delete prefile, and copy new file to deployment"

yes|rm -rf /home/git/docker/frontend/dist

yes|cp -rf code/pcfront/dist /home/git/docker/frontend/dist

yes|rm -rf /home/git/docker/backend/webapi

yes|cp -rf code/webapi /home/git/docker/backend/webapi

echo "==============================================="

##进入容器目录重启容器

echo "restart the docker service stack"

cd /home/git/docker

docker-compose restart

echo "======================end!====================="

上文件的功能就是将之前手工拉取文件进行了脚本化,事实上,在这里还可以运行测试脚本等做更多工作。

保存上述文件后设置权限即可

chmod +x post-receive

你可能感兴趣的:(docker+django+vue实例开发之一:搭建开发环境(四))