生产上的部署脚本功能

简介: #!/bin/bash #author by jackluo #要过滤的文件 ExcludeFile=(api.md dev.md .git .gitignore .htaccess .project README.
#!/bin/bash
#author by jackluo

#要过滤的文件
ExcludeFile=(api.md dev.md .git .gitignore .htaccess .project README.md)
#定义要copy的目录
new_git_code_dir=/data/projects/你自己的git仓库路径
production_code_dir=/data/projects/你生产上面的路径/
#检查这个字段是否存在这个数组中
function in_array()
{
    local f=($1)
    local a=($2)
    for i in ${a[*]};do
        #检查是否在在过滤文件中,在就返回 1,不在就返回 0
        if [[ $i = $f ]];then
            return 1;
        fi
    done    
}

cd $new_git_code_dir

echo "拉取代码..."
start=$(date +%s)
git pull
end=$(date +%s)
time=$(( $end - $start ))
echo "代码拉取完成...完成用了 $time 秒"


#列出目录中所有的文件
LISTDIR=`ls $new_git_code_dir`

echo "开始复制代码..."
start=$(date +%s)

for d in $LISTDIR;do
    #检查是不在拷的范围内
    in_array "$d" "${ExcludeFile[*]}"
    if [[  $? = 1 ]] ; then
        continue
    else
       echo "正在拷 $d..."
       /bin/cp -a ${new_git_code_dir}/$d ${production_code_dir}
    fi
done

end=$(date +%s)
time=$(( $end - $start ))
echo "复制代码完成... 完成用了 $time 秒"
echo "更改目录权限..."
chown fpm:fpm ${production_code_dir} -R &> /dev/null
echo "部署完成"

 

目录
相关文章
|
2月前
|
监控 Java 持续交付
内部网络监控软件的Groovy应用:持续集成与部署的自动化监控
在当今高度数字化的环境中,对于内部网络的监控变得至关重要。为了保证系统的稳定性和安全性,监控软件的自动化变得越来越必要。本文将介绍如何利用Groovy编程语言实现持续集成与部署的自动化内部网络监控软件,并通过代码示例展示其实现方式。
252 3
|
11月前
|
消息中间件 NoSQL 前端开发
应用系统服务安装全过程(从基础搭建框架到部署运行)
应用系统服务安装全过程(从基础搭建框架到部署运行)
139 0
应用系统服务安装全过程(从基础搭建框架到部署运行)
|
JSON 测试技术 数据格式
|
编解码 算法 测试技术
如何生产兼容性强的自动化测试脚本
如何生产兼容性强的自动化测试脚本
229 0
|
前端开发 JavaScript 中间件
SingnalR 开发到生产部署闭坑指南
前天倒腾了一份[SignalR在react/go技术栈的实践], 步骤和思路大部分是外围框架的应用, 今天趁热打铁, 给一个我总结的SignalR避坑指南。
SingnalR 开发到生产部署闭坑指南
|
Java 应用服务中间件 Shell
|
安全 关系型数据库 Java
在阿里云环境下搭建基于SonarQube的自动化安全代码检测平台
本文目的主要是提供一种思路和方法,让软件开发者像测试软件功能一样,测试软件安全缺陷,并且能够融入到整个的软件开发过程中。
8883 0