面向npm的实时仪表板Dashly

之前介绍过读取 npm 日志的 GoAccess,这次介绍的是能动态跟踪和显示您 npm 中所有服务的轻量级实时仪表板 -- Dashly

简介

什么是 Dashly ?

Dashly 是一个为 Nginx Proxy Manager 用户定制的实时仪表板。它通过自动与 NPM 数据库同步来简化您监控和组织服务的方式。这意味着您无需手动编辑仪表板配置文件(如 YAML),它会根据 NPM 中的域配置动态跟踪和显示您的所有服务。

主要特点

  1. 自动更新Dashly 会自动从 Nginx Proxy Manager 数据库读取数据,实时更新仪表板,免去手动编辑 YAML 配置文件的麻烦。
  2. 交互式用户界面:用户可以通过拖放的方式组织服务,切换网格和列表视图,并快速搜索和过滤服务。
  3. 可自定义外观:支持多种主题,包括亮色和暗色模式,用户可以选择隐藏非活动服务。
  4. 分组管理:允许用户将服务分类到可自定义的组中,方便重命名和排序。
  5. 简化管理Dashly 针对 Nginx Proxy Manager 用户,帮助他们更轻松地监控和组织服务,提升效率。

整体而言,Dashly 是一个轻量级且功能强大的工具,旨在帮助用户更好地管理和监控其网络服务。

准备

既然是面向 Nginx Proxy Manager 的,那首先应该是要安装 npm,不过目前 Dashly 只支持 SQLite,所以不能用 MariaDB 做数据库的安装方法

文章传送门:反向代理服务器nginx-proxy-manager

而是要采用下文中的方法安装 npm

文章传送门:用自定义域名访问tailscale节点

简单来说就是,不要设置数据库变量

yaml 复制代码
version: '3'

services:
  app:
    image: 'jc21/nginx-proxy-manager:latest'
    container_name: npm
    restart: unless-stopped
    ports:
      - '80:80'
      - '81:81'
      - '443:443'
    volumes:
      - ./data:/data
      - ./letsencrypt:/etc/letsencrypt

npm 设置正常后,可以添加几个站点试试

FileStation 中找到 npm 的数据库 database.sqlite 文件

右键属性,可以获取到完整的路径

准备工作完成后,可以开始我们今天的正题,安装 Dashly

安装

在群晖上以 Docker 方式安装。

在注册表中搜索 dashly ,选择第一个 lklynet/dashly,版本选择 latest

本文写作时, latest 版本还是测试版,最新的稳定版是 v2.0.2

docker 文件夹中,创建一个新文件夹 dashly,并在其中建一个子文件夹 data

文件夹 装载路径 说明
docker/npm/data/database.sqlite /nginx/database.sqlite npm 的数据库文件
docker/dashly/data /data 存放设置文件

端口

本地端口不冲突就行,不确定的话可以用命令查一下

bash 复制代码
# 查看端口占用
netstat -tunlp | grep 端口号
本地端口 容器端口
8732 8080

命令行安装

如果你熟悉命令行,可能用 docker cli 更快捷

bash 复制代码
# 新建文件夹 dashly 和 子目录
mkdir -p /volume1/docker/dashly/data

# 进入 dashly 目录
cd /volume1/docker/dashly

# 运行容器
docker run -d \
  --name dashly \
  --restart unless-stopped \
  -p 8732:8080 \
  -v /volume1/docker/npm/data/database.sqlite:/nginx/database.sqlite:ro \
  -v $(pwd)/data:/data \
  lklynet/dashly:latest

也可以用 docker-compose 安装,将下面的内容保存为 docker-compose.yml 文件

yaml 复制代码
version: '3'

services:
  dashly:
    image: lklynet/dashly:latest
    container_name: dashly
    restart: unless-stopped
    ports:
      - "8732:8080"
    volumes:
      - /volume1/docker/npm/data/database.sqlite:/nginx/database.sqlite:ro
      - ./data:/data

然后执行下面的命令

bash 复制代码
# 新建文件夹 dashly 和 子目录
mkdir -p /volume1/docker/dashly/data

# 进入 dashly 目录
cd /volume1/docker/dashly

# 将 docker-compose.yml 放入当前目录

# 一键启动
docker-compose up -d

运行

在浏览器中输入 http://群晖IP:8732 就能看到主界面

点右上角的 Edit 添加分类等

参考文档

lklynet/dashly: Dashly is a customizable, real-time dashboard for Nginx Proxy Manager users

地址:https://github.com/lklynet/dashly
Dashly - Dynamic Dashboard for Nginx Proxy

地址:https://dashly.lkly.net/

相关推荐
梵法利亚9 分钟前
Ubuntu-docker安装mysql
mysql·ubuntu·docker
anguruanjian1 小时前
安固软件指南:确保外发文件安全的全面策略
服务器·网络·安全·企业微信·安固软件
esmember1 小时前
电路研究9.3.1——合宙Air780EP中的AT开发指南:TCP 使用 SSL 示例
网络·at指令·tcp 使用 ssl 示例
自由鬼1 小时前
免费开源抓包工具Wireshark介绍
运维·服务器·网络·测试工具·网络安全·wireshark
真正的醒悟3 小时前
SSL-VPN案例
网络·windows·ssl
愚公搬代码5 小时前
【愚公系列】《Python网络爬虫从入门到精通》045-Charles的SSL证书的安装
网络·爬虫·python·网络协议·ssl
猴的哥儿5 小时前
Ubuntu 22.04 LTS 入门教学文档
linux·运维·ubuntu·docker
不脱发的猴子8 小时前
Wireshark使用教程
网络·测试工具·wireshark
小羊在奋斗10 小时前
【Linux网络】NAT技术、DNS系统、五种IO模型
linux·网络·智能路由器
暴躁的小胡!!!12 小时前
Linux权限维持之协议后门(七)
linux·运维·服务器·网络·安全