如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Apache HertzBeat是一款易用、开源的实时监控系统,通过Docker镜像可实现快速部署。该系统集监控、告警、通知功能于一体,支持无代理部署、高性能集群扩展、Prometheus生态兼容,提供强大的自定义监控和状态页面构建能力。适用于监控Web服务、数据库、缓存、操作系统、中间件、云原生等多种服务类型,帮助用户快速构建专属监控体系。
快速开始
通过Docker镜像可快速部署HertzBeat,支持单节点部署和集群扩展,以下为详细步骤。
Docker安装与部署
单节点快速部署
基础启动命令
执行以下命令启动HertzBeat容器:
shelldocker run -d -p 1157:1157 -p 1158:1158 --name hertzbeat apache/hertzbeat
-d:后台运行容器-p 1157:1157:映射Web界面端口(1157为默认Web端口)-p 1158:1158:映射集群通信端口(用于 collector 节点连接)--name hertzbeat:指定容器名称访问Web界面
容器启动后,通过浏览器访问 http://<主机IP>:1157,默认账号密码:admin/hertzbeat。
高级部署(含数据持久化与配置自定义)
如需数据持久化或自定义配置,可通过挂载卷实现:
shelldocker run -d -p 1157:1157 -p 1158:1158 \ -e LANG=en_US.UTF-8 \ -e TZ=Asia/Shanghai \ -v $(pwd)/data:/opt/hertzbeat/data \ # 数据持久化(H2数据库文件) -v $(pwd)/logs:/opt/hertzbeat/logs \ # 日志持久化 -v $(pwd)/application.yml:/opt/hertzbeat/config/application.yml \ # 自定义配置文件 -v $(pwd)/sureness.yml:/opt/hertzbeat/config/sureness.yml \ # 用户权限配置文件 --name hertzbeat apache/hertzbeat
参数说明:
-e LANG:设置系统语言-e TZ:设置时区(如 Asia/Shanghai 为北京时间)-v $(pwd)/data:/opt/hertzbeat/data:挂载数据目录,避免容器删除导致数据丢失-v $(pwd)/application.yml:挂载自定义配置文件,覆盖容器默认配置集群部署(可选,Collector节点)
如需扩展监控能力,可部署Collector节点组成集群:
shelldocker run -d \ -e IDENTITY=collector-01 \ # Collector唯一标识(集群内需唯一) -e MANAGER_HOST=192.168.1.100 \ # 主HertzBeat服务器IP -e MANAGER_PORT=1158 \ # 主服务器集群通信端口(默认1158) -e MODE=public \ # 运行模式(public:公共集群;private:云边协同) -v $(pwd)/collector-logs:/opt/hertzbeat-collector/logs \ # Collector日志持久化 --name hertzbeat-collector apache/hertzbeat-collector
启动后,通过主服务器Web界面(http://<主机IP>:1157)的“采集器管理”可查看已注册的Collector节点。
配置文件说明
如需自定义监控配置、数据存储方式或用户权限,需修改以下配置文件并挂载到容器中。
1. 主配置文件(application.yml)
创建 application.yml 并挂载,配置内容可参考 https://github.com/apache/hertzbeat/raw/master/script/application.yml%EF%BC%8C%E5%85%B3%E9%94%AE%E9%85%8D%E7%BD%AE%E9%A1%B9%E5%A6%82%E4%B8%8B%EF%BC%9A
数据存储配置(选择一种存储方式启用):
yamlwarehouse: store: # JPA存储(默认启用,适合小规模数据) jpa: enabled: true expire-time: 1h # 历史数据保留时间 max-history-record-num: 6000 # 最大保留记录数 # TDengine存储(大规模数据场景) td-engine: enabled: false url: jdbc:TAOS-RS://localhost:6041/hertzbeat username: root password: taosdata # IoTDB存储 iot-db: enabled: false host: 127.0.0.1 rpc-port: 6667 username: root password: root
告警通知配置(以邮件为例):
yamlalert: notice: mail: enabled: true host: smtp.example.com port: 465 username: alert@example.com password: your-password from: alert@example.com
2. 用户权限配置(sureness.yml)
创建 sureness.yml 配置用户账户与权限,参考 https://github.com/apache/hertzbeat/raw/master/script/sureness.yml%EF%BC%8C%E5%85%B3%E9%94%AE%E9%85%8D%E7%BD%AE%E9%A1%B9%E5%A6%82%E4%B8%8B%EF%BC%9A
用户账户配置:
yamlaccount: - appId: admin # 用户名 credential: hertzbeat # 密码 role: [admin] # 角色(admin:管理员;user:普通用户;guest:访客) - appId: user credential: user123 role: [user]
API权限控制:
yamlresourceRole: - /api/monitor/**===get===[admin,user,guest] # 监控数据查询权限 - /api/monitor/**===delete===[admin] # 监控配置删除权限(仅管理员)
以下是 apache/hertzbeat 相关的常用 Docker 镜像,适用于 不同场景 等不同场景:
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务