Linux通过shell执行自动化部署
背景
通过shell判断是否存在补丁更新,进行自动化的部署
代码
#!/bin/sh
#Edit:何彦霆
#version:1.0. beta #执行环境初始化
source /hxspace/production/bin/setenv.sh #变量说明
#$-外部提供,日期补丁(格式要求BD_2017--)
#Paths_Way-补丁存放目录
#Tomcat_Way-tomcat中间件目录
#Tomcat_Start_Way-tomcat中间件启动文件位置(加载so存在该限制,不能直接使用工程下的启动文件)
#Env_Wabapp_Way-web应用目录
#Env_Bus_Way-BUS工程目录 BD_Data=$
Paths_Way="/mnt/patches"
Tomcat_Way="/hxspace/production/server/apache-tomcat-8.5.9"
Tomcat_Start_Way="/hxspace/production/bin"
Env_Wabapp_Way="/hxspace/production/webroot"
Env_Bus_Way="/hxspace/production/bus" function Env_WEB_updata()
{
WEB_name=$
WEB_way=$ #判断Mall_WEB组件更新
if [ -d ./${WEB_name} ];then echo "存在${WEB_name}补丁,准备进行${WEB_name}环境更新" #down掉服务器tomcat
sh ${Tomcat_Way}/bin/shutdown.sh
sleep 5s #清空部署启动目录下,WEB应用文件
mkdir -p ${Env_Wabapp_Way}/${WEB_way}
rm -rf ${Env_Wabapp_Way}/${WEB_way}/*
cp -rf ${Paths_Way}/${BD_Data}/${WEB_name}/* ${Env_Wabapp_Way}/${WEB_way} #启动WEB
sh ${Tomcat_Start_Way}/tomcat_run.sh
echo "Mall_WEB环境更新完成" else echo "${WEB_name}更新补丁不存在,${WEB_name}更新结束" fi } function Env_BUS_updata()
{
BUS_name=$1
BUS_port=$2
BUS_way=$3
echo ${BUS_name}
echo ${BUS_port}
echo ${BUS_way}
#判断组件更新
#if [ -d ./${BUS_name}* ];then
result=`ls -l | grep ${BUS_name}*`
#if [[ "$result" != "" ]];then
if [ -d ./${result} ];then echo "存在${BUS_name}补丁,准备进行${BUS_name}环境更新" #判断Server 进程是否存在 - centos 使用判断监控PID
Sc_Pid=`netstat -nlp | grep ${BUS_port} | awk '{print $7}' | awk -F "/" '{print $1}'` #判断20025端口是否被监听,如果正在监听,kill
if [ ! $Sc_Pid ]; then echo "IS NULL" else echo "NOT NULL"
kill -9 $Sc_Pid fi #拷贝壳子进行覆盖
mkdir -p ${Env_Bus_Way}/${BUS_way}
cp -rf './TBAServer(2.1.9.4)'/* ${Env_Bus_Way}/${BUS_way} if [ -d ./${BUS_name}_conf ];then echo "${BUS_name}_conf存在补丁,准备进行环境更新" #清空部署启动目录下,Collect_bus_conf文件
rm -rf ${Env_Bus_Way}/${BUS_way}/config.ini
rm -rf ${Env_Bus_Way}/${BUS_way}/classes/*
rm -rf ${Env_Bus_Way}/${BUS_way}/*.so mkdir -p ${Env_Bus_Way}/${BUS_way}
cp -rf ${Paths_Way}/${BD_Data}/${BUS_name}_conf/* ${Env_Bus_Way}/${BUS_way} #启动bus-采用重启
sh ${Env_Bus_Way}/${BUS_way}/restart.sh
echo "${BUS_name}_conf补丁,更新完成" else echo "${BUS_name}_conf补丁不存在" fi if [ -d ./${BUS_name}_lib ];then echo "${BUS_name}_lib存在补丁,准备进行环境更新" #清空部署启动目录下,${BUS_name}_lib文件
mkdir -p ${Env_Bus_Way}/${BUS_way}/lib
rm -rf ${Env_Bus_Way}/${BUS_way}/lib/* cp -rf ${Paths_Way}/${BD_Data}/${BUS_name}_lib/* ${Env_Bus_Way}/${BUS_way}/lib #启动bus-采用重启
sh ${Env_Bus_Way}/${BUS_way}/restart.sh
echo "${BUS_name}_lib补丁,更新完成" else echo "${BUS_name}_lib补丁不存在" fi if [ -d ./${BUS_name}_classes ];then echo "${BUS_name}_classes存在补丁,准备进行环境更新" #清空部署启动目录下,${BUS_name}_classes文件
#工程classes文件同配置文件classes同目录,才用覆盖的方式
mkdir -p ${Env_Bus_Way}/${BUS_way}/classes cp -rf ${Paths_Way}/${BD_Data}/${BUS_name}_classes/* ${Env_Bus_Way}/${BUS_way}/classes #启动bus-采用重启
sh ${Env_Bus_Way}/${BUS_way}/restart.sh
echo "${BUS_name}_classes补丁,更新完成" else echo "${BUS_name}_classes补丁不存在" fi else
echo "${BUS_name}无补丁"
fi
} #切换至补丁目录
cd ${Paths_Way} #判断补丁目录下是否存在指定补丁
if [ -d ./$BD_Data ];then
echo "存在该补丁,准备进行环境更新"
cd ./$BD_Data
# BUS 更新,$1 - 补丁文件名 $2 - BUS监听端口 $3 BUS部署路径
Env_BUS_updata HX_ChenDu_LC_Mall_bus_test 20025 mall_bus Env_BUS_updata HX_ChenDu_LC_MallTimer_bus_test 20032 mall_timer Env_BUS_updata HX_ChenDu_pmc_bus_test 20028 pmc_bus Env_BUS_updata HX_ChenDu_pmc_Collect_bus_test 20042 collector_bus #WEB更新,$1 - 补丁文件名 $2 - WEB部署路径
Env_WEB_updata HX_ChenDu_LC_Mall_WEB_Linux_Test mall #Env_WEB_updata HX_ChenDu_pmc_Collect_bus_test mkt else
echo "补丁不存在,更新结束"
exit 0
fi
自动通过目录标示判断是否存在该模块补丁,进行补丁的移动合并和更新
Linux通过shell执行自动化部署的更多相关文章
- shell脚本自动化部署服务
shell脚本自动化部署 !/bin/bash #export PATH=$PATH:/export/maven/bin run_flag_dir="/data0/shell/deploy_ ...
- shell脚本自动化部署
由于公司技术部团队较小,没有专门的运维团队,所以运维工作技术部承包了. 一.纯人工部署是这样的: 1. 本地打包:一般 maven clean package 2. 借助xftp上传到服务器对应目录 ...
- jenkins结合ansible用shell实现自动化部署和回滚
最近用jenkins+gitlab+ansible做持续化集成,自动化部署和版本回滚.然而deploy plugin没能做到增量升级和回滚操作,折腾了很久决定自己写个脚本来简单实现. 环境: cent ...
- 登录linux时 shell执行顺序
# .bash_history,.bash_logout,.bash_profile,.bashrc/etc/profile 全局.bash_history 记录当前登录用户历史操作的命令.bash_ ...
- linux下使用shell脚本自动化部署项目
在Java开发项目时经常要把正在开发的项目发布到测试服务器中去测试,一般的话是要把项目先打成war包,然后把war包发布到服务器中,关闭服务器, 最后重新启动服务器,虽然这过程不是很繁琐,但如果是多个 ...
- jenkins+maven+Tomcat+shell构建自动化部署
https://yq.aliyun.com/articles/685931 1.官网下载war包:jenkins本质上就是一个web应用,直接下载jenkins的war包通过tomcat运行即可.ht ...
- Shell脚本-自动化部署WEB
#! /bin/ ] then echo "#### 参数有误,\$1:构建号必填" exit fi cd /root/workspace/xinya_erp/xinya_web ...
- Shell脚本-自动化部署反向代理、WEB、nfs
部署nginx反向代理三个web服务,调度算法使用加权轮询(由于物理原因只开启两台服务器) AutoNginxNfsService.sh #/bin/bash systemctl status ngi ...
- shell脚本自动化部署XX的案例(附数组使用)
#!/bin/sh #Auto Make install MFS Files # cat <<EOF ++++++++++++++++Welcome To Use Auto Install ...
随机推荐
- Javascript事件模型(一):DOM0事件和DOM2事件
javascript事件模型,本文主要有以下内容: DOM0事件模型 DOM2事件模型 一.DOM0事件模型 早期的事件模型称为DOM0级别. DOM0的事件具有极好的跨浏览器优势, 会以最快的速度 ...
- nodeJS之流stream
前面的话 当内存中无法一次装下需要处理的数据时,或者一边读取一边处理更加高效时,我们就需要用到数据流.NodeJS中通过各种Stream来提供对数据流的操作.本文将详细说明NodeJS中的流strea ...
- SQL Server使用导入导出向导导入超过4000个字符的字段的数据
在使用SQL Server导入导出向导导入数据的时候,我们经常会碰到某个单元格的数据超长而被截断报错的情况.本文针对这种场景给出相应的解决方案. 环境描述:SQL Server 2012,文件源: ...
- windows8.1安装之后的感想
这蛋疼的换了系统之后,发现windows8在界面方面确实花了不少功夫,但是自我感觉,比较适合触屏的平板电脑用. 我笔记本操作体验一般般.windows8不吃内存.这是真的.我机子占了25%左右.刚 ...
- H5 web 存储之 Webstorage
H5提供了两种在客户端存储数据的方式:localStorage 持久化的本地存储(浏览器关闭重新打开数据依然存在)sessionStorage 针对一个session的本地存储之前这些都是由cooki ...
- python 标准库 -- logging
线程安全的日志记录模块. 一. 使用示例 import logging logging.basicConfig(filename="app.log", format="% ...
- ecshop商品页增加编辑器fckeditor
最近在做ecshop的项目,需要在商品单页中增加一项FCKEditor的文本编辑器,但在ecshop的论坛和百度里搜出的方法,试了好几个都没有用,终于找到一个可以正确使用的,和大家分享. ecshop ...
- IBM芯片新功能:诊断癌症
治愈任何疾病的最好方法是什么?-------------- 当然是把它扼杀在摇篮里. "早发现早治疗"已经是老生常谈,但要准确监测疾病又谈何容易?不过现在,IBM这枚小小的芯片就能 ...
- Vulkan Tutorial 22 Index buffer
操作系统:Windows8.1 显卡:Nivida GTX965M 开发工具:Visual Studio 2017 Introduction 在实际产品的运行环境中3D模型的数据往往共享多个三角形之间 ...
- 基于Angularjs实现图片上传和下载
根据ng-file-uoload实现文件上传和下载实现 网上down下来ng-file-uoload.js,在项目中记得引入服务哦. 示例代码: FileUploaderCtrl.$inject = ...