我有这样的命令来启动这样的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-pretty
https://stackoverflow.com/questions/70144303
复制相似问题