From 1a8e00047ff4574941bef3fd51cff65c0dd7e17f Mon Sep 17 00:00:00 2001 From: lizw <1183409807@qq.com> Date: Fri, 14 Jun 2024 16:16:04 +0800 Subject: [PATCH] 12wms86-sd-test.sh --- 00base/tmp.sh | 4 +- hua_wei_yun/12wms86-sd-test.sh | 220 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 223 insertions(+), 1 deletion(-) create mode 100644 hua_wei_yun/12wms86-sd-test.sh diff --git a/00base/tmp.sh b/00base/tmp.sh index 6dd87ad..1a76c90 100644 --- a/00base/tmp.sh +++ b/00base/tmp.sh @@ -65,4 +65,6 @@ bash <(curl -s http://git.yvanui.com/lizhiwei/jztd-deploy/raw/master/00base/07en -java 0 \ -gradle 0 \ -maven 0 \ --jenkins 1 \ No newline at end of file +-jenkins 1 + + diff --git a/hua_wei_yun/12wms86-sd-test.sh b/hua_wei_yun/12wms86-sd-test.sh new file mode 100644 index 0000000..46f3f12 --- /dev/null +++ b/hua_wei_yun/12wms86-sd-test.sh @@ -0,0 +1,220 @@ +#!/bin/bash +#set -x +set -e + +codePath=/home/www/deploy/wms85_sd_test +gitUrlArr=( + "www@git.yvanui.com:jztd/wms85std.git" + # "http://git.yvanui.com/jztd/wms85std.git" + "www@git.yvanui.com:lizhiwei/yvan-framework.git" + # "http://git.yvanui.com/lizhiwei/yvan-framework.git" + "www@git.yvanui.com:luoyifan/yvan-ui.git" + # "http://git.yvanui.com/luoyifan/yvan-ui.git" +) + +branchArr=( + "sd_dsl2" + "8.6" + "master" +) +positionArr=( + "." + "yvan-framework" + "yvan-ui" +) +# 是否需要构建,-1:自动;0:不需要;1:需要 +needBuild=( +"1" +"1" +"1" +) + +echoPrefix="\033[36m+" +echoSuffix="\033[0m" + +# 强制覆盖本地的代码 git fetch --all && git reset --hard origin/master +isChange="1" # 仓库是否发生变化,0:未变化;非0:变化 +pullCode() { + # Usage: pullCode "codePath" "gitUrl" "branch" "position" + path=$1 # 代码保存路径 + gitUrl=$2 # git仓库地址 + branch=${3:-"master"} # git分支 + position=${4:-""} # 使用“.”clone到当前文件夹 + isChange="1" + # 创建文件夹 + if [ ! -d "$path" ]; then + echo -e "$echoPrefix 请检查服务器是否正确,再执行: mkdir -p $path $echoSuffix" + exit + fi + + # git clone + echo -e "$echoPrefix cd $path $echoSuffix" + cd $path + if [ "`ls -A $path`" == "" ] || [ ! -d "$path/$position" ] || [ "`ls -A $path/$position`" = "" ]; then + echo -e "$echoPrefix git clone $gitUrl $position $echoSuffix" + git clone $gitUrl $position + isChange="2" + fi + + # 进入文件夹,切换分支,git pull + if [ "$position" != "" ]; then + echo -e "$echoPrefix cd $position $echoSuffix" + cd $position + fi + echo -e "$echoPrefix git checkout $branch $echoSuffix" + git checkout $branch + echo -e "$echoPrefix git checkout . $echoSuffix" + git checkout . + echo -e "$echoPrefix git pull $echoSuffix" + if [ "`git pull`" == "Already up-to-date." ] && [ $isChange == "1" ]; then + isChange="0" + fi + echo "" +} + +buildCode() { +# # 构建 yvan-ui +# if [ "${needBuild[0]}" != "0" ]; then +# echo -e "$echoPrefix cd $codePath/yvan-ui $echoSuffix" +# cd "$codePath/yvan-ui" +# echo -e "$echoPrefix yarn run init $echoSuffix" +# yarn run init +# # echo -e "$echoPrefix yarn run dev2 $echoSuffix" +# # yarn run dev2 +# echo "" +# else +# echo "yvan-ui 文件未变化" +# fi +# +# # 构建 wms-ui +# if [ "${needBuild[0]}" != "0" ]; then +# echo -e "$echoPrefix cd $codePath/wms-ui $echoSuffix" +# cd "$codePath/wms-ui" +# echo -e "$echoPrefix yarn $echoSuffix" +# yarn +# echo -e "$echoPrefix yarn link yvan-ui $echoSuffix" +# yarn link yvan-ui +# echo "" +# else +# echo "yvan-ui 文件未变化" +# fi + + # 构建 java + echo -e "$echoPrefix cd $codePath $echoSuffix" + cd $codePath + echo -e "$echoPrefix gradle build -x test $echoSuffix" + gradle build -x test + echo "" +} + +logPath=/data/logs/wms85_sd_test/server.log +dirPath=/home/www/deploy/wms85_sd_test/wms-modules/wms-system/build/libs/ +serverName=wms85_sd_test + +cmd=$1 +profiles=${2:-"test-sd"} + +#------------------------------------------------------------------- +JAVA_MEM_OPTS=" -DappName=${serverName} -server -Xmx2g -Xms2g" +DATABASE_OPTS=" -Ddatabase.codeset=ISO-8859-1 -Ddatabase.logging=false" +JAVA_OPTS_EXT=" -Djava.awt.headless=true -Djava.net.preferIPv4Stack=true -Dapplication.codeset=UTF-8 -Dfile.encoding=UTF-8 -Duser.timezone=Asia/Shanghai" +#------------------------------------------------------------------- + +startServer() { + pid=$1 + if [ -z $pid ];then + echo -e "$echoPrefix cd $dirPath../runtime/ $echoSuffix" + cd $dirPath../runtime/ + echo -e "$echoPrefix java $JAVA_MEM_OPTS $DATABASE_OPTS $JAVA_OPTS_EXT -jar ./wms-system-0.0.0-SNAPSHOT.jar --spring.profiles.active=global,$profiles --server.port=8006 >>/dev/null 2>&1 & $echoSuffix" + java $JAVA_MEM_OPTS $DATABASE_OPTS $JAVA_OPTS_EXT -jar ./wms-system-0.0.0-SNAPSHOT.jar --spring.profiles.active=global,$profiles --server.port=8006 >>/dev/null 2>&1 & + echo "$serverName 启动成功!" + else + echo "$serverName 正在运行..." + fi + echo "查看日志: tail -F $logPath -n 100" +} + +stopServer() { + pid=$1 + if [ -z $pid ];then + echo "$serverName 未运行" + else + echo -e "$echoPrefix ps -ef | grep "DappName=${serverName}" | grep -v 'grep' | awk '{print \$2}' | xargs kill $echoSuffix" + ps -ef | grep "DappName=${serverName}" | grep -v 'grep' | awk '{print $2}' | xargs kill + echo "$serverName 已停止!" + fi +} + +deployPull() { + for ((idx=0; idx<${#gitUrlArr[@]}; idx++)); do + pullCode $codePath ${gitUrlArr[idx]} ${branchArr[idx]} ${positionArr[idx]} + if [ "${needBuild[idx]}" == "-1" ]; then + needBuild[idx]=$isChange + fi + done + echo "###--代码更新完成--------------------------------------------------------------------------###" + echo "" +} + +deployServer() { + pid=$1 + deployPull + buildCode + echo "###--代码构建完成--------------------------------------------------------------------------###" + # 重启服务 + if [ ! -z $pid ];then + stopServer $pid + sleep 8s + fi + # 移动编译后的文件 + echo -e "$echoPrefix cd $dirPath $echoSuffix" + cd $dirPath + echo -e "$echoPrefix rm -rf ../runtime $echoSuffix" + rm -rf ../runtime + echo -e "$echoPrefix cp -r ./ ../runtime $echoSuffix" + cp -r ./ ../runtime + echo "" + startServer +} + +restartServer() { + pid=$1 + if [ ! -z $pid ];then + stopServer $pid + sleep 3s + fi + startServer +} + +logs() { + tail -F $logPath -n 100 +} + +pid=`ps -ef | grep "DappName=${serverName}" | grep -v 'grep' | awk '{print $2}'` +# 操作参数: pull deploy restart start stop kill log logs +if [ "$cmd" == "pull" ];then + deployPull + if [ -z $pid ];then + echo "$serverName 未运行 | 输入操作参数: pull deploy restart start stop kill log logs" + fi +elif [ "$cmd" == "deploy" ];then + deployServer $pid +elif [ "$cmd" == "restart" ];then + restartServer $pid +elif [ "$cmd" == "start" ];then + startServer $pid +elif [ "$cmd" == "stop" ] || [ "$cmd" == "kill" ];then + stopServer $pid +elif [ "$cmd" == "log" ] || [ "$cmd" == "logs" ];then + logs +else + if [ -z $pid ];then + echo "$serverName 未运行 | 输入操作参数: pull deploy restart start stop kill log logs" + else + echo "输入操作参数: pull deploy restart start stop kill log logs" + echo "pid=$pid | $serverName 正在运行... | 查看日志: tail -F $logPath -n 100" + fi +fi + +# wms86测试 - 顺德 +# bash <(curl -s http://git.yvanui.com/lizhiwei/jztd-deploy/raw/master/hua_wei_yun/12wms86-sd-test.sh) [cmd profiles]