生产环境部署错误:解析 Prisma 模式引擎响应失败
最近在将应用部署到生产环境时,遇到了以下错误:
error: could not parse schema engine response: syntaxerror: unexpected token e in JSon at position 0
错误信息简短且缺乏上下文,难以排查。最近的代码变更仅限于少量区域设置关键字的修改,排除了代码本身的错误。
排查过程
网上搜索未果。仔细检查错误日志,发现此前有一条警告信息:
prisma:warn prisma failed to detect the libssl/openssl version to use, and may not work as expected. defaulting to "openssl-1.1.x".
通过 gitHub 搜索该警告信息,发现 Prisma 在新的 Alpine 镜像上无法找到 OpenSSL 3.0.x 版本。
原因分析:新的 Alpine docker 镜像缺少 Prisma 引擎所需的 OpenSSL 软件包。
解决方案
虽然网上建议使用 Node.js 18.5 版本或更换 Docker 镜像,但这可能导致与其他依赖包的冲突。
因此,最佳方案是直接在 Docker 镜像中安装 OpenSSL 软件包。
使用的 Docker 镜像基础版本:
from node:18-alpine
添加以下指令安装 OpenSSL:
# 更新并升级包管理器 RUN apk update && apk upgrade # 安装 OpenSSL 包 RUN apk add --no-cache openssl
以上步骤成功解决了问题。