Nginx文件被配置为将error.log发送到/dev/stderr。
RUN ln -sf /dev/stdout /var/log/nginx/access.log
&& ln -sf /dev/stderr /var/log/nginx/error.log
当我们运行docker logs --tail=10 -f nginx
时,它会显示错误日志和访问日志的组合。是否有一个docker命令,所以我只能看到error.log或stderr的日志?
发布于 2020-05-02 18:25:26
尝试使用以下命令只获取error.log:
docker logs -f nginx 1>/dev/null
这张是access.log的:
docker logs -f nginx 2>/dev/null
发布于 2020-05-02 18:28:55
从您在问题中添加的Dockerfile片段来看,您使用的是正式的NGINX图像。
将NGINX映像配置为在默认情况下将主NGINX访问和错误日志发送到Docker日志收集器。这是通过将它们链接到stdout和stderr来完成的,这将导致来自这两个日志的所有消息存储在Docker主机上的文件/var/lib/Docker/containers/\/-json.log中。
一种方法是使用docker .
您可以在/etc/default/docker
中启用docker并以这种方式查询日志。
DOCKEROPTS='-H tcp://0.0.0.0:4243 -H unix:///var/run/docker.sock'
然后:
http://<docker host>:4243/containers/<container name>/logs?stderr=1
请参见:
https://www.docker.com/blog/tips-for-deploying-nginx-official-image-with-docker/
https://stackoverflow.com/questions/61564018
复制相似问题