如何解决用阿里云效流水线持续集成部署Nuxt静态应用时流程卡住,进行不下去的问题

我有一个用Nuxt搭建的前端应用,部署时是用npm run generate命令生成静态页,然后上传到服务器上的指定目录来完成部署。

之前是写了一个shell脚本,用rsync命令实现的上传,个人用起来倒也比较方便,但是因为涉及到服务器登陆密码之类的敏感信息,不太方便分享给别人,想让其他人也能部署的话,就不太好解决。

后来接触到了云效流水线,感觉这是个好工具,配置好了之后,点一下运行按钮就能完成部署,给相关人员分配权限后,大家就都能部署了。

但是在配置Node.js构建这一步时,遇到了问题。构建一直在运行,过很长时间也完成不了,只能手动取消才能结束。

查了很多资料也没找到头绪,后来发现本地运行npm run generate命令后,并不会结束进程,而是在终端里一直停在那儿,按Ctrl + C后才会退出。

一下子明白了为什么在流水线里构建时会卡住了,是因为命令执行到这一步之后,没有结束,导致进程一直等待,后续的命令无法执行。

找到原因之后,就好办了。解决方案也比较直接,就是在nuxt.config.ts里通过生命周期钩子来结束进程。遗憾的是Nuxt没有提供类似"generate:done"的钩子,"prerender:routes"是最接近生成完成阶段的一个钩子,所以只能用它,再加一下延时,来实现生成静态页完成后,退出进程的效果。

代码如下:

TypeScript 复制代码
  hooks: {
    /**
     * 生成静态页后,退出进程,以防止阻断持续集成流水线的执行
     * 
     * nuxt未提供类似"generate:done"的钩子,
     * "prerender:routes"是最接近生成完成阶段的一个钩子,
     * 所以只能用它,再加一下延时,来实现生成静态页完成后,退出进程的效果
     */
    'prerender:routes': () => {
      setTimeout(() => {
        process.exit(0)
      }, 10000)
    },
  },

代码修改如图所示:

加上这个处理之后,Node.js构建任务就能正常执行了,整个流水线也能跑通了。

部署从此变的轻松加愉快,可谓一劳永逸地解决了问题。

本次分享就是这样,希望对您有所帮助。

相关推荐
Z兽兽3 小时前
React@18+Vite项目配置env文件
前端·react.js·前端框架
SuniaWang3 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
A_nanda3 小时前
根据AI提示排查vue前端项目
前端·javascript·vue.js
happymaker06264 小时前
web前端学习日记——DAY05(定位、浮动、视频音频播放)
前端·学习·音视频
~无忧花开~4 小时前
React状态管理完全指南
开发语言·前端·javascript·react.js·前端框架
xuhaoyu_cpp_java4 小时前
过滤器与监听器学习
java·经验分享·笔记·学习
LegendNoTitle4 小时前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
@大迁世界5 小时前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
LaughingZhu5 小时前
Product Hunt 每日热榜 | 2026-03-23
数据库·人工智能·经验分享·神经网络·chatgpt
BJ-Giser5 小时前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium