如何查看容器的日志?

时间:2020-09-20 07:41:33

标签: docker nginx dockerfile

我有一个Dockerfile

FROM centos:7

ENV container docker

RUN yum -y update && yum -y install net-tools && yum -y install initscripts && yum -y install epel-release && yum -y install nginx && yum clean all
RUN echo "daemon off;" >> /etc/nginx/nginx.conf

# expose Nginx ports http/https
EXPOSE 80 443

RUN curl https://www.sheldonbrown.com/web_sample1.html > /usr/share/nginx/index.html
RUN mv /usr/share/nginx/index.html /usr/share/nginx/html/index.html -f

RUN mkdir -p /local/nginx
RUN touch /local/nginx/start.sh
RUN chmod 755 /local/nginx/start.sh
RUN echo "#!/bin/bash" >> /local/nginx/start.sh
RUN echo "nginx" >> /local/nginx/start.sh
RUN echo "tail -f /var/log/nginx/access.log" >> /local/nginx/start.sh

ENTRYPOINT ["/bin/bash", "-c", "/local/nginx/start.sh"]

我正在使用docker build -t "my_nginx" .

然后使用docker run -i -t --rm -p 8888:80 --name nginx "my_nginx"

运行它

https:// localhost:8888 /显示页面,但未显示日志记录。

  • 如果我按Ctrl-C,nginx会停止,但会显示日志的尾巴。
  • 如果再次按Ctrl-C,则容器不见了。

问题:如何让nginx运行并在日志记录中显示尾巴(最好也可以使用“ docker logs”命令查看)

2 个答案:

答案 0 :(得分:1)

最简单的方法就是使用Docker Hub nginx image,它会为您处理。可能只有

的Dockerfile
FROM nginx:1.19
# Specifically use ADD because it will fetch a URL
ADD https://www.sheldonbrown.com/web_sample1.html /usr/share/nginx/html/index.html

如果您查看its Dockerfile,它实际上是使用符号链接来使Nginx的“正常”日志进入容器stdout

# forward request and error logs to docker log collector
RUN ln -sf /dev/stdout /var/log/nginx/access.log \
    && ln -sf /dev/stderr /var/log/nginx/error.log

这可以解决Dockerfile中的大多数机制:您可以仅将nginx作为主要容器命令运行,而无需尝试使用第二个进程来记录日志。您基本上可以修剪掉整个后半部分,然后得到

FROM centos:7

ENV container docker

RUN yum -y install epel-release \
 && yum -y install net-tools initscripts nginx \
 && yum clean all
RUN echo "daemon off;" >> /etc/nginx/nginx.conf \
 && ln -s /dev/stdout /var/log/nginx/access.log \
 && ln -s /dev/stderr /var/log/nginx/error.log
RUN curl -o /usr/share/nginx/html/index.html https://www.sheldonbrown.com/web_sample1.html

EXPOSE 80 443
CMD ["nginx"]

这里(带有任何这些图像)的另一种可能性是在容器的/var/log/nginx目录上装载您自己的卷。这样,您便可以在主机可见的目录中找到自己的目录,以便在方便时进行检查。

mkdir logs
docker run -v $PWD/logs:/var/log/nginx -d ...
less logs/access.log

(在Dockerfile中构造的shell脚本中,您使用Nginx daemon off指令作为前台进程运行,这意味着nginx命令将永远不会自行退出。表示脚本永远不会前进到tail行,这就是为什么您不会注销的原因。)

答案 1 :(得分:0)

您应该从Dockerfile中删除tail命令,使用docker run -it -d --rm -p 8888:80 --name nginx "my_nginx"运行容器,然后使用docker logs -f nginx