在Docker上部署datalust/Seq日志服务系统

应用环境

Ubuntu 20.04.6 LTS (GNU/Linux 5.15.0-139-generic x86_64)

Docker version 28.1.1, build 4eba377

Seq 是用于结构化应用程序日志和跟踪的实时搜索和分析服务器。其精心设计的用户界面、JSON 事件存储和熟悉的查询语言使其成为检测和诊断复杂应用程序和微服务中问题的高效平台。

Seq 是自托管的,可在 Windows 或 Docker/Linux 下运行。您可以在本地将 Seq 部署到自己的基础设施中,也可以在任何公有云中轻松启动实例。

可以从各种日志记录库和协议中提取应用程序遥测数据。警报和通知可以发送到各种输出。而且,输入和输出插件都可以用任何语言或使用 .NET 应用程序 SDK 编写。

文章目录

    • 拉取容器镜像
    • [1. 生成Run脚本](#1. 生成Run脚本)
      • [1.1 实例脚本](#1.1 实例脚本)
      • [1.2 参数解读](#1.2 参数解读)
    • [2. 运维管理](#2. 运维管理)
      • [2.1 配置Root账号](#2.1 配置Root账号)
      • [2.2 创建API Keys](#2.2 创建API Keys)
      • [2.3 清空日志事件](#2.3 清空日志事件)
      • [2.4 仪表盘](#2.4 仪表盘)
      • 参考文档

本文Seq 基于 Linux 的 Docker 映像非常适合部署到 Linux 主机和容器编排器,以及在 Linux 或 macOS 上进行本地开发,官方提供一个单用户免费的开发版本。

拉取容器镜像

bash 复制代码
# datalust/seq:2024.3.13545
sudo docker pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/datalust/seq:latest

# 添加标签名Tag
sudo docker tag swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/datalust/seq:latest datalust/seq:latest
# 移除标签名Tag
sudo docker rmi swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/datalust/seq:latest

国内镜像参考:
渡渡鸟镜像

1. 生成Run脚本

可参考:渡渡鸟-Run助手

1.1 实例脚本

bash 复制代码
sudo docker run -itd \
--restart=unless-stopped \
--name seq \
-e ACCEPT_EULA=Y \
-e SEQ_FIRSTRUN_ADMINPASSWORDHASH="" \
-v /docker/seq:/data \
-p 1080:80 \
-p 5341:5341 \
--memory=16g \
--memory-swap=16g \
--privileged=true \
datalust/seq:latest

1.2 参数解读

powershell 复制代码
# 将镜像进实例化成容器并运行
docker run

# 【i】保持STDIN(标准输入)开放,即使没有附加任何东西。这通常用于让容器的进程保持运行,即使没有附加到终端。例如,你可以在容器内部运行一个交互式shell
# 【t】分配一个伪终端(pseudo-TTY),这对于交互式shell非常重要,比如当你想要在容器中运行bash或sh时。
# 【d】后台运行,即所谓的"detached"模式。容器会在后台启动,并且你会得到容器的ID或名称
-itd

# 重启策略
## no:不自动重启,缺省时默认
## always:始终重启
## unless-stopped:Docker 服务重启后自动启动容器,除非容器被手动停止。可指定最大重试次数,例如 --restart=on-failure:3(最多重启3次)。
## on-failure:仅在容器非正常退出(退出状态码非0)时重启。
--restart=unless-stopped \

# 容器命名
--name seq

# 设置为Y表示接受 Seq 最终用户许可协议
-e ACCEPT_EULA=Y

# Seq 在生成返回 Seq 服务器的链接时将使用的基本 URI(可选;OIDC 登录、警报通知和 Kubernetes 入口支持通常需要)
## Example: api.canonicalUri=https://seq.example.com/
-e SEQ_API_CANONICALURI=

# 不使用缓存
-e SEQ_CACHE_SYSTEMRAMTARGET=0

# 设置初始管理员用户名和密码,SEQ_FIRSTRUN_*此步骤只能在容器首次启动时执行。在此之后设置将不起作用。
-e SEQ_FIRSTRUN_ADMINPASSWORDHASH="$SeqPwd"

# Web端口root访问密码Hash值为空,暂不设
-e SEQ_FIRSTRUN_ADMINPASSWORDHASH=""

# 挂载卷映射(宿主:容器)
## /docker/seq:/data:实例化数据
-v /docker/seq:/data

# 【p】映射策略,<宿主端口>:<容器端口>
## 80:http web端口,5341:http webapi端口
-p 1080:80
-p 5341:5341

# 最后一行所引用的docker镜像源

2. 运维管理

bash 复制代码
# 检查实例化配置
sudo docker run --rm -it -v seq datalust/seq config list
sudo docker run --rm -it -v seq datalust/seq:latest config list

# 调取运行日志[实时]
sudo docker logs -f seq --tail 20

# 登录后台bash终端
sudo docker exec -it seq /bin/bash

# bash后端修改密码
seqsvr auth --basic -u admin -p admin@pwd

# bash后端调取某天日志内容
cat /data/Logs/seq-202506xx.log

2.1 配置Root账号

可以通过调取运行日志,或者在Portainer Web管理端查看容器运行情况

然后直接访问到宿主机IP:1080地址,进入Seq Web日志管理系统

可按图上序号位置,将admin账号调整为root账号,同时设置其登录密码。由于本系统免费是单用户,多用户使用则可以通过TRY FREE FOR 30 DAYS进行申请30天免费使用,或直接通过旁边的按钮进行购买。

可按图上序号位置,将admin账号调整为root账号,同时设置其登录密码。由于本系统免费是单用户,多用户使用则可以通过TRY FREE FOR 30 DAYS进行申请30天免费使用,或直接通过旁边的按钮进行购买。

2.2 创建API Keys

API 密钥用于标识应用程序、写入事件以及与 Seq API 交互。每个 API 密钥都可以与一组属性相关联,这些属性将应用于使用它写入的事件。使用提取屏幕跟踪每个 API 密钥的提取。

按上图红色数字标识顺序打开后,填写以下几处内容

保存成功【SAVE CHANGES】后,会得到一串【API Key TOKEN】口令,客户端开发时会用到。

2.3 清空日志事件

按下图步骤操作(也可以点击【ADD POLICY】设定清理规则策略,来定时执行清理作业)

选择垃圾桶图标,点击【OK】。

2.4 仪表盘

参考文档

SEQ日志在.NET中快速集成轻量级分页式日志平台
.net 使用 Serilog 和 Seq 构建强大的日志系统
ASP.NET Core之Serilog、SEQ、ILogger构建可视化日志

相关推荐
志栋智能17 小时前
超自动化巡检剧本(Playbook):运维经验的数字化封装
运维·自动化
ElevenS_it18817 小时前
Nginx日志监控告警实战:access_log解析+5xx突增+慢请求+异常IP自动告警完整方案(Filebeat+Zabbix)
运维·网络·tcp/ip·nginx·zabbix
liulilittle17 小时前
Linux Swap 文件配置与持久化(虚拟内存)
linux·运维·服务器
未若君雅裁17 小时前
日志采集与ELK:从本地日志到集中检索分析
运维·elk·jenkins
零陵上将军_xdr18 小时前
从沙子到CPU——计算机硬件基础入门
linux·运维·硬件架构
vortex518 小时前
Linux 命令工具箱:util-linux 与 GNU Coreutils
linux·运维·gnu
AIex-YH18 小时前
三域贯通11/12:生物制造的“死亡之谷“,CDMO 是桥还是船?
运维·制造·策略模式
荒--18 小时前
MSF 使用
linux·运维·服务器
明航咨询-程老师18 小时前
信创运维困局:“救火队”模式走到尽头,平台工程如何重塑CISAW安全体系?
运维·安全·数据安全官,ccrc 认证,数据合规,职业发展规划
w32963627119 小时前
八、OpenCode 高阶玩法:CLI 自动化、CI/CD 集成与远程协作
运维·ci/cd·自动化·ai编程·开发工具·opencode