美文网首页
二进制部署CICD

二进制部署CICD

作者: 六弦极品 | 来源:发表于2024-03-20 18:04 被阅读0次

一、jenkins构建脚本

dsp_cicd.sh

#! /bin/bash

tag=`date +%Y%m%d%H%M`
user="llsuser"
data_dir="/opt"
ip=$1
port=$2
branch=`echo $GIT_BRANCH |  awk -F'/' '{print $2}'`
proj=`echo $JOB_NAME |awk -F - '{print $1}'`
app_type=`echo $JOB_NAME|awk -F - '{print $NF}'`

## 前端应用CI
front_ci(){
    tar -cf ${JOB_NAME}_${branch}_${tag}.tar.gz dist
    ssh -i /root/.ssh/id_rsa_dsp -p ${port} ${user}@${ip} "if [ ! -d ${data_dir}/${proj}/${JOB_NAME} ];then mkdir ${data_dir}/${proj}/${JOB_NAME} -p; fi"
    scp -i /root/.ssh/id_rsa_dsp -P ${port} ${JOB_NAME}_${branch}_${tag}.tar.gz ${user}@${ip}:${data_dir}/${proj}/${JOB_NAME}/
}

## java应用CI
java_ci(){
    jar_name=`find * -name *${app_type}*.jar|grep -Ev 'job-core|executor-samples|api|original|SNAPSHOT|facility|sources|-ec'`    
    if [ `echo $jar_name|grep -c "jar"` -gt 0  ];then
        echo 部署的jar包名为:$jar_name
    else
        echo "jar包不存在 or jar包名不正确,请核查!"
        exit 1
    fi
    ssh -i /root/.ssh/id_rsa_dsp -p ${port} ${user}@${ip} "if [ ! -d ${data_dir}/${proj}/${JOB_NAME} ];then mkdir ${data_dir}/${proj}/${JOB_NAME} -p; fi"
    scp -i /root/.ssh/id_rsa_dsp -P ${port} $jar_name ${user}@${ip}:${data_dir}/${proj}/${JOB_NAME}/${JOB_NAME}_${branch}_${tag}.jar
}

## 前端应用发布
front_cd(){
    echo "--------发布应用--------"
    ssh -i /root/.ssh/id_rsa_dsp -p ${port} ${user}@${ip} "bash -x ${data_dir}/${proj}/dsp-deploy.sh ${JOB_NAME} ${data_dir}/${proj}/${JOB_NAME}/${JOB_NAME}_${branch}_${tag}.tar.gz"
}

## java应用发布
java_cd(){
    echo "--------发布应用--------"
    ssh -i /root/.ssh/id_rsa_dsp -p ${port} ${user}@${ip} "bash -x ${data_dir}/${proj}/dsp-deploy.sh ${JOB_NAME} ${data_dir}/${proj}/${JOB_NAME}/${JOB_NAME}_${branch}_${tag}.jar"
}

main(){
    if [ "$app_type" = "front" ]; then
       front_ci
       front_cd
    elif [ "$app_type" = "web" ] || [ "$app_type" = "service" ] || [ "$app_type" = "job" ];then
       java_ci
       java_cd
    fi 
}

main

二、发布脚本
dsp-deploy.sh

#!/bin/bash
source /etc/profile

PROJECT_DIR=$(cd $(dirname $BASH_SOURCE) && pwd)
service_name=$1
deploy_package=$2
proj=`echo $service_name |awk -F - '{print $1}'`
app_type=`echo $service_name|awk -F - '{print $NF}'`

## 前端发布
deploy_front(){
    if test -d ${PROJECT_DIR}/front/${service_name}
        then
            echo exist
            rm -rf ${PROJECT_DIR}/front/${service_name}/*
            tar -xf ${deploy_package} -C ${PROJECT_DIR}/front/${service_name}
        else 
            echo "front_workdir ${PROJECT_DIR}/front/${service_name} does't exist."
            mkdir -p ${PROJECT_DIR}/front/${service_name}
            tar -xf ${deploy_package} -C ${PROJECT_DIR}/front/${service_name}
    fi
}

## java应用发布
deploy_java(){
    bash /opt/dsp/start.sh $service_name stop
    rm -f ${PROJECT_DIR}/jar/${service_name}.jar
    ln -s $deploy_package ${PROJECT_DIR}/jar/${service_name}.jar
    
    bash /opt/dsp/start.sh $service_name start
}

main(){
    if [ "$app_type" = "front" ]; then
       deploy_front
    elif [ "$app_type" = "web" ] || [ "$app_type" = "service" ] || [ "$app_type" = "job" ];then
       deploy_java
    fi 

}

main

三、服务启动脚本
start.sh

#!/bin/bash

#参数1:服务名   参数2:start stop restart status

source /etc/profile

## 项目目录
PROJECT_DIR=$(cd $(dirname $BASH_SOURCE) && pwd)

#jar包存放的总目录,不限制
PROJECT_JAR_ROOT=$PROJECT_DIR/jar
PROJECT_LOG_ROOT=$PROJECT_DIR/logs

##应用名
SERVICE_NAME=$1

cd $PROJECT_JAR_ROOT

## 应用jar包和日志绝对路径
JARPATH=$PROJECT_JAR_ROOT/${SERVICE_NAME}.jar
LOGPATH=$PROJECT_LOG_ROOT/${SERVICE_NAME}/${SERVICE_NAME}.log

## jar包启动相关参数
parameter="-Xms512M -Xmx1024M --add-opens java.base/jdk.internal.misc=ALL-UNNAMED --add-opens java.base/sun.nio.ch=ALL-UNNAMED -Dio.netty.tryReflectionSetAccessible=true -Ddubbo.reference.check=false -Dfile.encoding=utf-8"
JAR_PARAMS="-Dspring.config.location=${PROJECT_DIR}/config/application-${SERVICE_NAME}.properties -Dlog.path=${PROJECT_DIR}/logs -Dserver.tomcat.basedir=/opt/dsp"

if [ ! -f $JARPATH ];then
    echo "不存在此${SERVICE_NAME}应用服务,请核查!"
    echo "参数1:服务名   参数2:start stop restart status"
    echo "example:./start.sh exchange-web status"
    ls $PROJECT_JAR_ROOT
    exit
fi

function start()
{
    pidlist=`ps -ef | grep ${JARPATH} | grep -v "grep" | awk '{print $2}'`
    if [ "$pidlist" = "" ]
    then
        nohup /usr/bin/java $parameter ${JAR_PARAMS} -jar ${JARPATH} > /dev/null 2>&1 &
        while [ "$pidlist" = "" ];do
            pidlist=`ps -ef | grep ${JARPATH} | grep -v "grep" | awk '{print $2}'`
            echo "wait......"
            sleep 1
        done;
        echo -e "Starting ${SERVICE_NAME} :     \033[32;49;1m [ OK ] \033[39;49;0m"
        sleep 1

    else
        echo -e "${SERVICE_NAME} is already \033[32;49;1m RUNNING... \033[39;49;0m"
    fi
}

function stop()
{
    pidlist=`ps -ef | grep ${JARPATH} | grep -v "grep" | awk '{print $2}'`
    if [ "$pidlist" = "" ]
    then
        echo -e "${SERVICE_NAME} is already done before... \033[31;49;1m [ DIED ] \033[39;49;0m"
    else
        kill -9  $pidlist
        while [ "$pidlist" != "" ];do
            pidlist=`ps -ef | grep ${JARPATH} | grep -v "grep" | awk '{print $2}'`
            echo "wait......"
            sleep 1
        done;
        echo -e "Stopping ${SERVICE_NAME}:     \033[32;49;1m [ OK ] \033[39;49;0m"
    fi
}

function status()
{
    pidlist=`ps -ef | grep ${JARPATH} | grep -v "grep" | awk '{print $2}'`
    if [ "$pidlist" = "" ]
    then
        echo -e "${SERVICE_NAME} is \033[31;49;1m NOT RUNNING... \033[39;49;0m"
    else
        echo -e "${SERVICE_NAME} is   \033[32;49;1m RUNNING \033[39;49;0m"
    fi
}

case "$2" in
    start)
    start
    ;;

    stop)
    stop
    ;;

    restart)
    stop
    start
    ;;

    status)
    status
    ;;

    *)
    echo "Usage : start | stop | restart | status"
    ;;
esac

相关文章

  • gitlab-CICD共享runner基本配置

    gitlab-CICD共享runner基本配置 使用docker部署runner 多个项目使用共享runner 部...

  • 搭建gitlab并使用CICD部署HelloWorld

    搭建gitlab并使用CICD部署HelloWorld 博客地址: www.vonchange.com 闲置主机做...

  • Gitlab CICD 部署到aws lambda

    本次cicd的流水线是解决python的flask自动部署到lambda,实现通过apigateway访问flas...

  • 二进制部署k8s集群

    部署k8s有多种方式,本章我们采取二进制的部署方式来部署k8s集群,二进制部署麻烦点,但是可以在我们通过部署各个组...

  • DevOps:CICD篇

    一、什么是CICD? CI是持续集成,开发人员如何能够快速构建、测试、发布;CD是持续部署,运维人员如何能快速部署...

  • jenkins联合docker部署cicd

    CI:持续集成CD:持续部署 在jenkins容器中安装ansible 由于该项目的jenkins容器是alpin...

  • CICD_jenkins部署allure

    1.系统管理->插件管理->安装对应插件Allure Jenkins Plugin 2.Python运行的时候注意...

  • k8s kubeadm部署过程

    先使用二进制部署了几次,全部失败了,原因还未找到,所以使用kubeadm部署先用起来再说。使用二进制部署时,老是出...

  • 部署自动打包环境

    部署自动打包环境 概述 基于Gitlab-CICD配置的自动打包环境。 在Gitlab上创建Tag时,会执行包含D...

  • Helm3 快速入门 —— 2、Helm3 安装部署

    第2章、Helm3 安装部署 一、各环境安装部署 1、Linux 1)二进制包安装 1⃣️ 下载二进制包 2⃣️ ...

网友评论

      本文标题:二进制部署CICD

      本文链接:https://www.haomeiwen.com/subject/zdixtjtx.html