我有这样的命令来启动这样的Node.js have服务器:
node --inspect=0.0.0.0:9229 --preserve-symlinks /app/api/dist/server.js | pino-pretty我把它作为CMD放到一个Dockerfile中
CMD ["node", "--inspect=0.0.0.0:9229", "--preserve-symlinks" ,"/app/api/dist/server.js", "|","pino-pretty"]该服务在调用docker run时启动,但|被忽略,因此不会将日志转发给pino-pretty。
我在这里做错什么了?
我可以将整个命令放入start.sh或使用CMD ["npm", "run", "start:prod"],但我想了解核心问题。
发布于 2021-11-28 14:58:02
我可以将整个命令放入start.sh或使用CMD "npm“、"run”、"start:prod“,但我想了解核心问题。
管道是一个shell结构,例如/bin/sh、/bin/bash和类似的shell的特性。当您使用json/exec语法定义CMD时,您将显式地告诉docker在没有shell的情况下运行命令。因此,您需要在脚本中运行命令,显式调用shell,或者使用字符串/shell语法运行以让停靠程序使用shell执行命令:
CMD node --inspect=0.0.0.0:9229 --preserve-symlinks /app/api/dist/server.js | pino-prettyhttps://stackoverflow.com/questions/70144303
复制相似问题