安装 Dozzle:一个出色的实时 Docker 日志查看器

简介: 【2月更文挑战第1天】

在开始安装 Dozzle 之前,确保您的系统已经安装了 Docker 和 Docker Compose。如果尚未安装,您可以按照以下步骤在 Linux 系统上进行安装:

在 Ubuntu 上安装 Docker:

sudo apt-get update
sudo apt-get install docker.io

在 Ubuntu 上安装 Docker Compose:

sudo apt-get install docker-compose

在其他系统上安装 Docker 和 Docker Compose:

请根据您的操作系统,参考 Docker 官方文档进行安装。

下载 Dozzle

为了获取最新版本的 Dozzle,我们将从 GitHub 上克隆 Dozzle 仓库。执行以下命令:

git clone https://github.com/amir20/dozzle.git

这将在当前目录中创建一个名为 dozzle 的文件夹,其中包含 Dozzle 的源代码和配置文件。

配置 Dozzle

进入下载的 Dozzle 目录,并编辑 docker-compose.yml 文件以根据您的需求进行配置。打开文件:

cd dozzle
nano docker-compose.yml

在编辑器中,您可以看到一些默认的配置项,例如端口、日志文件路径等。根据您的喜好和环境,进行相应的更改。以下是一个示例配置:

version: '3'
services:
  dozzle:
    image: amir20/dozzle:latest
    ports:
      - "8080:8080"
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"

请确保您了解每个配置项的含义,以便更好地满足您的需求。

启动 Dozzle

保存并退出编辑器后,使用以下命令启动 Dozzle:

docker-compose up -d

这将下载并启动 Dozzle 容器。请注意,-d 标志表示以后台模式运行容器。

现在,Dozzle 将在指定的端口上运行,并且您可以通过浏览器访问该端口以查看实时日志。

使用 Dozzle 查看实时日志

打开您喜欢的 Web 浏览器,并输入以下地址:

http://localhost:8080

请确保将端口号替换为您在 docker-compose.yml 文件中配置的端口。这将打开 Dozzle 的 Web UI。

查看容器实时日志

在 Dozzle Web UI 中,您将看到列出的 Docker 容器名称。这些名称是根据您系统上运行的容器而生成的。点击您感兴趣的容器名称,即可查看该容器的实时日志。

日志信息将按照时间戳的顺序显示,这样您可以轻松地追踪容器的活动。每条日志条目都包含时间戳、日志级别和日志消息。

过滤日志

Dozzle 提供了过滤日志的功能,让您更方便地找到关注的信息。在 Web UI 界面的搜索框中输入您感兴趣的关键字,Dozzle 将仅显示包含该关键字的日志。

例如,如果您想查看特定容器的错误日志,只需在搜索框中输入关键字 "error",Dozzle 将过滤并显示相关的日志条目。

高级配置

Dozzle 支持许多高级配置选项,可以根据您的需求进行调整。您可以在 docker-compose.yml 文件中进行相应的更改,例如更改日志文件位置、调整刷新间隔等。

如果您需要更多关于高级配置的信息,可以查阅 Dozzle 的官方文档:

https://dozzle.dev/docs

Dozzle 高级功能和生产环境配置

HTTPS 支持

在生产环境中,安全性是至关重要的。您可以通过为 Dozzle 配置 HTTPS 来保护通信。为此,您可以使用反向代理工具(如 Nginx 或 Traefik)将流量转发到 Dozzle,并在代理中配置 SSL。

以下是使用 Nginx 作为反向代理的示例:

server {
   
   
    listen 443 ssl;
    server_name your_domain.com;

    ssl_certificate /path/to/your/certificate.crt;
    ssl_certificate_key /path/to/your/private_key.key;

    location / {
   
   
        proxy_pass http://localhost:8080;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
}

请替换 your_domain.com/path/to/your/certificate.crt/path/to/your/private_key.key 为实际的域名和证书路径。

认证与授权

在生产环境中,您可能希望对 Dozzle 进行身份验证和授权,以确保只有授权的用户能够访问日志。这可以通过在反向代理中配置认证和授权来实现。

例如,使用 Nginx 进行基本身份验证:

location / {
   
   
    proxy_pass http://localhost:8080;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Proto $scheme;

    auth_basic "Restricted Access";
    auth_basic_user_file /path/to/htpasswd;
}

在这里,/path/to/htpasswd 是包含用户名和密码的文件。

多容器配置

如果您的系统中运行了多个 Docker 容器,并且您希望监控所有容器的日志,可以使用 Dozzle 的多容器配置。在 docker-compose.yml 文件中,您可以添加多个 dozzle 服务,每个服务监听一个不同的端口。

version: '3'
services:
  dozzle_1:
    image: amir20/dozzle:latest
    ports:
      - "8080:8080"
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"

  dozzle_2:
    image: amir20/dozzle:latest
    ports:
      - "8081:8080"
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"

这样,您可以通过访问不同的端口来查看不同容器的日志。

持久化存储

默认情况下,Dozzle 仅在容器运行时保存配置。如果您希望保留配置信息,可以将配置文件挂载到主机上。在 docker-compose.yml 中添加以下卷:

volumes:
  - "./config:/app/config"

这将把配置文件保存在项目根目录下的 config 文件夹中。

通过以上配置,您可以在生产环境中更加安全和灵活地使用 Dozzle。

Dozzle 进阶用法和其他功能

日志颜色化

Dozzle 支持将日志根据日志级别进行颜色化显示,使不同级别的日志更易于区分。在 docker-compose.yml 中,您可以添加 DOZZLE_OPTIONS 环境变量来启用颜色化。

services:
  dozzle:
    image: amir20/dozzle:latest
    ports:
      - "8080:8080"
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"
    environment:
      - DOZZLE_OPTIONS=color

这将在 Dozzle Web UI 中以不同的颜色显示不同日志级别的日志条目。

日志时间格式

如果您希望自定义显示在日志中的时间格式,可以通过在 docker-compose.yml 中添加 DOZZLE_OPTIONS 环境变量来实现。

services:
  dozzle:
    image: amir20/dozzle:latest
    ports:
      - "8080:8080"
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"
    environment:
      - DOZZLE_OPTIONS=timeFormat=YYYY-MM-DDTHH:mm:ss.SSSZ

这将使用指定的时间格式来显示日志时间戳。在这里,YYYY-MM-DDTHH:mm:ss.SSSZ 是一个示例时间格式。

实时搜索

Dozzle 提供了实时搜索功能,让您可以快速找到特定关键字的日志。在 Web UI 的搜索框中输入关键字,Dozzle 将动态过滤显示的日志。

定制化日志显示

通过在 docker-compose.yml 中配置 DOZZLE_OPTIONS 环境变量,您可以进一步定制 Dozzle 的行为。例如,您可以设置日志条目的最大显示数、日志刷新的时间间隔等。

services:
  dozzle:
    image: amir20/dozzle:latest
    ports:
      - "8080:8080"
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"
    environment:
      - DOZZLE_OPTIONS=maxEntries=100

在这里,maxEntries=100 将限制每个容器的最大显示日志条目数为 100。

使用 Dozzle API

Dozzle 还提供了 API,使您可以通过编程方式与 Dozzle 进行交互。通过 API,您可以获取容器列表、检索特定容器的日志等。详细的 API 文档可以在官方文档https://dozzle.dev/docs/api中找到。

通过这些进阶用法和功能,您可以更好地适应 Dozzle 到您的日志查看和分析工作流程中。

相关实践学习
通过日志服务实现云资源OSS的安全审计
本实验介绍如何通过日志服务实现云资源OSS的安全审计。
目录
相关文章
|
7月前
|
关系型数据库 应用服务中间件 nginx
Docker一键安装中间件(RocketMq、Nginx、MySql、Minio、Jenkins、Redis)
本系列脚本提供RocketMQ、Nginx、MySQL、MinIO、Jenkins和Redis的Docker一键安装与配置方案,适用于快速部署微服务基础环境。
|
5月前
|
关系型数据库 数据库 PostgreSQL
docker 安装 Postgres 17.6
本文介绍如何通过Docker安装和配置PostgreSQL 17.6。内容包括拉取镜像、导出配置文件、运行容器并挂载数据与配置文件目录,以及进入容器使用psql操作数据库的完整步骤,便于持久化管理和自定义配置。
748 3
docker 安装 Postgres 17.6
|
4月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
636 5
|
4月前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
459 2
|
8月前
|
存储 NoSQL MongoDB
Docker中安装MongoDB并配置数据、日志、配置文件持久化。
现在,你有了一个运行在Docker中的MongoDB,它拥有自己的小空间,对高楼大厦的崩塌视而不见(会话丢失和数据不持久化的问题)。这个MongoDB的数据、日志、配置文件都会妥妥地保存在你为它精心准备的地方,天旋地转,它也不会失去一丁点儿宝贵的记忆(即使在容器重启后)。
1017 4
|
7月前
|
Linux Docker Windows
windows docker安装报错适用于 Linux 的 Windows 子系统必须更新到最新版本才能继续。可通过运行 “wsl.exe --update” 进行更新。
适用于 Linux 的 Windows 子系统需更新至最新版本(如 wsl.2.4.11.0.x64.msi)以解决 2025 年 Windows 更新后可能出现的兼容性问题。用户可通过运行 “wsl.exe --update” 或访问提供的链接下载升级包进行更新。
2927 0
|
监控 Ubuntu Docker
Docker 1.13.0 详细更新日志
本文讲的是Docker 1.13.0 详细更新日志【编者的话】Docker发布1.13.0版本,此次版本更新内容较多,以下为该版本具体的变更。
1630 0