准备工作

1、准备至少一台阿里云ECS服务器,并完成Java环境配置
2、创建云效代码仓库

Demo工程结构

在这里插入图片描述

模块说明
timeline-soa-dao数据访问层
timeline-soa-domainpojo 数据对象 vo试图对象 model 业务模型对象
timeline-soa-service业务逻辑,RPC接口,拦截器,过滤器
timeline-soa-webRestful接口

其他说明:
1、timeline-soa为工程根目录,实际打包路径为timeline-soa-web/target/timeline-soa-web-1.0-SNAPSHOT.jar
2、工程根目录下创建deploy.sh,用于启动jar包。
3、后续流水线配置中需要指定以上两项路径。

创建发布流水线

编辑流水线

代码源:选择阿里云Codeup
代码仓库:指定待构建发布的工程仓库
开启分支模式:测试环境打开
工作目录:保持和工程名一致
你好! 这是你第一次使用 **Markdown编辑器** 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。

配置分支集成

基础分支:此处选择master ,实际编译时请选择待发布的测试分支
在这里插入图片描述

配置Java构建上传

JDK版本以及Maven版本:选择JDK1.8 与Maven 3.5.2
构建命令 :- Pstg 指向工程的测试/预发环境
mvn clean -Dmaven.test.skip=true -Dautoconfig.skip=true install -Pstg
在这里插入图片描述

配置主机部署

主机组:选择阿里云ECS容器

在这里插入图片描述

部署脚本:
1、创建发布目录
2、解压缩发布包到发布目录
3、执行工程的启动脚本deploy.sh

部署策略:线上环境进行灰度验证时,需配置分批发布策略。第一批验证通过后,再行发布后续批次。

# 部署脚本会在部署组的每台机器上执行。一个典型脚本逻辑如下:先将制品包(在下载路径中配置的下载路径)解压缩到指定目录中,再执行启动脚本(通常在代码中维护,如示例中deploy.sh)。关于这个例子的详细解释见 https://help.aliyun.com/document_detail/153848.html \n\n # tar zxvf /home/admin/app/package.tgz -C /home/admin/app/\n # sh /home/admin/app/deploy.sh restart\n # 如果你是php之类的无需制品包的制品方式,可以使用git clone 或者 git pull将源代码更新到服务器,再执行其他命令 \n # git clone ***@***.git\n

mkdir -p /home/admin/timeline-soa-web-1.0-SNAPSHOT
tar zxvf /home/admin/app/package.tgz -C /home/admin/timeline-soa-web-1.0-SNAPSHOT/
sh /home/admin/timeline-soa-web-1.0-SNAPSHOT/deploy.sh restart

创建工程启动脚本

deploy.sh脚本如下:
应用端口:需匹配Spring boot中配置端口号。
应用健康URL:需更换为自己的心跳接口。
应用启动日志:可替换为自己的路径及命名方式。


#修改APP_NAME为云效上的应用名
APP_NAME=timeline-soa-web-1.0-SNAPSHOT


PROG_NAME=$0
ACTION=$1
APP_START_TIMEOUT=20    # 等待应用启动的时间
APP_PORT=8081          # 应用端口
HEALTH_CHECK_URL=http://127.0.0.1:${APP_PORT}/hello # 应用健康检查URL
HEALTH_CHECK_FILE_DIR=/home/admin/status   # 脚本会在这个目录下生成nginx-status文件
APP_HOME=/home/admin/${APP_NAME} # 从package.tgz中解压出来的jar包放到这个目录下
JAR_NAME=${APP_HOME}/timeline-soa-web/target/${APP_NAME}.jar # jar包的名字
JAVA_OUT=${APP_HOME}/logs/catalina.log  #应用的启动日志

#创建出相关目录
mkdir -p ${HEALTH_CHECK_FILE_DIR}
mkdir -p ${APP_HOME}/logs
usage() {
    echo "Usage: $PROG_NAME {start|stop|restart}"
    exit 2
}

health_check() {
    exptime=0
    echo "checking ${HEALTH_CHECK_URL}"
    while true
        do
            status_code=`/usr/bin/curl -L -o /dev/null --connect-timeout 5 -s -w %{http_code}  ${HEALTH_CHECK_URL}`
            if [ "$?" != "0" ]; then
               echo -n -e "\rapplication not started"
            else
                echo "code is $status_code"
                if [ "$status_code" == "200" ];then
                    break
                fi
            fi
            sleep 1
            ((exptime++))

            echo -e "\rWait app to pass health check: $exptime..."

            if [ $exptime -gt ${APP_START_TIMEOUT} ]; then
                echo 'app start failed'
               exit 1
            fi
        done
    echo "check ${HEALTH_CHECK_URL} success"
}
start_application() {
    echo "starting java process"
    nohup java -jar ${JAR_NAME} > ${JAVA_OUT} 2>&1 &
    echo "started java process"
}

stop_application() {
   checkjavapid=`ps -ef | grep java | grep ${APP_NAME} | grep -v grep |grep -v 'deploy.sh'| awk '{print$2}'`

   if [[ ! $checkjavapid ]];then
      echo -e "\rno java process"
      return
   fi

   echo "stop java process"
   times=60
   for e in $(seq 60)
   do
        sleep 1
        COSTTIME=$(($times - $e ))
        checkjavapid=`ps -ef | grep java | grep ${APP_NAME} | grep -v grep |grep -v 'deploy.sh'| awk '{print$2}'`
        if [[ $checkjavapid ]];then
            kill -9 $checkjavapid
            echo -e  "\r        -- stopping java lasts `expr $COSTTIME` seconds."
        else
            echo -e "\rjava process has exited"
            break;
        fi
   done
   echo ""
}
start() {
    start_application
    health_check
}
stop() {
    stop_application
}
case "$ACTION" in
    start)
        start
    ;;
    stop)
        stop
    ;;
    restart)
        stop
        start
    ;;
    *)
        usage
    ;;
esac

编译&构建日志追踪排查

发布异常请依据以下步骤排查
1、首先看deploy中定义的应用启动日志,排查是否项目编译构建异常
2、确认部署环节,日志是否正常启动
在这里插入图片描述
3、启动正常,运行异常请排查工程应用日志。
本例中应用日志路径请查看配置文件logback-spring.xml

Logo

一起探索未来云端世界的核心,云原生技术专区带您领略创新、高效和可扩展的云计算解决方案,引领您在数字化时代的成功之路。

更多推荐