赞
踩
大家有时候需要云效的流水线来一键部署,下面把关键的注意事项写出来。
1、登录云效
2、新建流水线,选择自己的ECS
3、选择代码,选择版本
4、java构建的时候需要注意,其中涉及到自己的jar,可能存在同一版本号,无法更新下载到最新的文件,所以部署的时候需要首先把以前的删除掉,然后再去打包,所以下面的命令需要修改一下。
- #com/naturobot是自己项目的包名
- rm -rf /root/.m2/repository/com/naturobot
- # 下面的命令不用改,原来是什么样的就是什么样的。
- mvn -B clean package -Dmaven.test.skip=true -Dautoconfig.skip
5、构建物的上传文件夹地址,大家注意一下。直接就是项目的文件夹路径,前面没有斜杠。这里需要注意,你的deploy.sh文件必须在项目中要存在的,文件名随便起,这里的路径一定要正确,不然找不到该文件就无法部署了。
6、deploy.sh文件demo
- #!/bin/bash
-
- # 修改APP_NAME为云效上的应用名
- APP_NAME=naturobot-user-service
- VERSION_NAME=0.0.1
-
- PROG_NAME=$0
- ACTION=$1
- APP_START_TIMEOUT=50 # 等待应用启动的时间
- APP_PORT=8031 # 应用端口
- HEALTH_CHECK_URL=http://127.0.0.1:${APP_PORT} # 应用健康检查URL
- HEALTH_CHECK_FILE_DIR=/opt/${APP_NAME}/status # 脚本会在这个目录下生成nginx-status文件
- APP_HOME=/opt/${APP_NAME} # 从package.tgz中解压出来的jar包放到这个目录下
- JAR_NAME=${APP_HOME}/${APP_NAME}-${VERSION_NAME}.jar # jar包的名字
- JAVA_OUT=${APP_HOME}/logs/start.log #应用的启动日志
-
- # 创建出相关目录
- mkdir -p ${HEALTH_CHECK_FILE_DIR}
- mkdir -p ${APP_HOME}
- mkdir -p ${APP_HOME}/logs
- usage() {
- echo "Usage: $PROG_NAME {start|stop|restart}"
- exit 2
- }
-
- health_check() {
- echo "check ${HEALTH_CHECK_URL} success"
- }
- start_application() {
- echo "starting java process"
- nohup java -jar -Dspring.profiles.active=test1230 ${APP_NAME}-${VERSION_NAME}.jar >/dev/null 2>&1 &
- echo "started java process"
- }
-
- stop_application() {
- checkjavapid=`ps -ef | grep java | grep ${APP_NAME}-${VERSION_NAME}.jar | grep -v grep |grep -v 'deploy1230.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}-${VERSION_NAME}.jar | grep -v grep |grep -v 'deploy1230.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
7、主机部署,这里就比较简单,如果配置主机组的时候什么ECS也看不到,那可能是你的RAM没有权限。找一个权限大一点的帐号或者分配一个权限。然后就是下载路径就是自己的ECS上的路径,想部署在哪里就写自己的文件夹地址就可以了。执行用户就是ROOT,不需要修改。比较重要的就是下面的部署脚本,需要懂得基础的linux命令。
- # 文件夹是否存在,不存在创建一个文件夹,存在也不报错
- mkdir -p /opt/naturobot-user-service
- # 删除以前的文件夹
- rm -rf /opt/naturobot-user-service/naturobot-user-service
- # 解压
- tar zxvf /opt/naturobot-user-service/package.tgz -C /opt/naturobot-user-service/
- # 复制
- mv -f /opt/naturobot-user-service/naturobot-user-service/target/naturobot-user-service-0.0.1.jar /opt/naturobot-user-service/naturobot-user-service-0.0.1.jar
- # 复制
- mv -f /opt/naturobot-user-service/naturobot-user-service/deploy1230.sh /opt/naturobot-user-service/deploy1230.sh
- # 删除
- rm -rf /opt/naturobot-user-service/naturobot-user-service
- # 赋权
- chmod 777 /opt/naturobot-user-service/naturobot-user-service-0.0.1.jar
- chmod 777 /opt/naturobot-user-service/deploy1230.sh
- cd /opt/naturobot-user-service
- #启动,这里不需要停止,是因为在deploy1230.sh文件中会先停止在启动。
- sh /opt/naturobot-user-service/deploy1230.sh restart
1、云效流水线 Flow 是什么,阿里官网是这样解释的。
「流水线」,又名「Flow」,是一款企业级、自动化的研发交付流水线, 提供灵活易用的持续集成、持续验证、 持续发布功能,帮助企业高质量、高效率的交付业务。
流水线是持续交付的载体,通过构建自动化、集成自动化、验证自动化、部署自动化,完成从开发到上线过程的持续交付。通过持续向团队提供及时反馈,让交付过程高效顺畅。
2、为什么选择「Flow」。
快速上手配置。相比较自建的持续交付工具,使用 Flow 仅仅需要几步,就可以快速搭建 CICD 流程。Flow 为你提供了开箱即用的构建环境,提供了数十种通用的流水线模版帮助你快速创建流水线,从此,你的企业无需花费精力维护你的 CICD 工具。同时,我们提供了支持各种场景的最佳实践文章供你参考,帮助你更快上手使用。Flow语言专项场景。
3、各种覆盖各种工具和技术栈
Flow 作为一款企业级的自动化交付流水线,全面覆盖研发场景中涉及的技术栈和工具链。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。