解决Cannot start service XX: OCI runtime create failed: container_linux.go:348问题

问题描述:

最近在做一个国际化方案的时候,发现使用envsubst动态更改nginx模板中变量会报错,但是直接在镜像执行envsubst的命令是没有问题的

ERROR: for doge_viewer-dr_1  Cannot start service viewer-dr: OCI runtime create failed: container_linux.go:348: starting container process caused "exec: \"envsubst '$LOCALE' < /etc/nginx/conf.d/default.conf.template > /etc/nginx/conf.d/default.conf && exec nginx -g 'daemon off;'\": stat envsubst '$LOCALE' < /etc/nginx/conf.d/default.conf.template > /etc/nginx/conf.d/default.conf && exec nginx -g 'daemon off;': no such file or directory": unknown

Dockerflie如下:

FROM nginx:1.17.3-alpine

COPY ./dist/ /usr/share/nginx/html
ADD ./default.conf.template /etc/nginx/conf.d/default.conf.template


EXPOSE 80

CMD ["envsubst '$LOCALE' < /etc/nginx/conf.d/default.conf.template > /etc/nginx/conf.d/default.conf && exec nginx -g 'daemon off;'"]

解决方案:

刚开始跟着报错查问题,发现一直找不到正确的觉解方案,后来才发CMD语法用的不对,还是吃了读书少的亏啊,如果要使用上述方案的话,需要增加命令如下:

FROM nginx:1.17.3-alpine

COPY ./dist/ /usr/share/nginx/html
ADD ./default.conf.template /etc/nginx/conf.d/default.conf.template


EXPOSE 80

ENTRYPOINT [ "/bin/sh", "-c" ]
CMD ["envsubst '$LOCALE' < /etc/nginx/conf.d/default.conf.template > /etc/nginx/conf.d/default.conf && exec nginx -g 'daemon off;'"]

知识扩展:

1.ENTRYPOINT 两种写法

# exec 格式
ENTRYPOINT ["executable", "param1", "param2"]

# shell 格式
ENTRYPOINT command param1 param2

2.ENTRYPOINT 和 CMD 联合使用

  • 当指定了 ENTRYPOINT 后,CMD 的含义就发生了改变,不再是直接的运行其命令,而是将 CMD 的内容作为参数传给 ENTRYPOINT 指令
  • 换句话说实际执行时,会变成 
     ""

3.CMD 和 ENTRYPOINT 区别

CMD                   # 指定这个容器启动的时候要运行的命令,不可以追加命令
ENTRYPOINT            # 指定这个容器启动的时候要运行的命令,可以追加命令

你可能感兴趣的:(docker使用,linux,docker)