轻量级服务器监控系统
实时监控 CPU、内存、磁盘、网络等指标
- 🔐 共享密钥认证 - 所有客户端使用统一的共享密钥连接服务器,简化部署配置
- 🏷️ 特殊标签支持 - 新增
traffic:in/out和speed:in/out标签,实时显示流量统计和网络速率 - 🎨 自定义 CSS/JS - 支持全站自定义样式和脚本,打造个性化监控面板
curl -fsSL https://raw.githubusercontent.com/xhhcn/Pulse/main/install-pulse-server.sh | sudo bash脚本会自动:
- ✅ 检测系统架构
- ✅ 下载对应的二进制文件
- ✅ 配置 systemd 服务
- ✅ 启动服务并设置开机自启
amd64:
sudo systemctl stop pulse-server && sudo wget https://github.com/xhhcn/Pulse/releases/latest/download/pulse-server-standalone-linux-amd64 -O /opt/pulse/pulse-server && sudo chmod +x /opt/pulse/pulse-server && sudo systemctl start pulse-serverarm64:
sudo systemctl stop pulse-server && sudo wget https://github.com/xhhcn/Pulse/releases/latest/download/pulse-server-standalone-linux-arm64 -O /opt/pulse/pulse-server && sudo chmod +x /opt/pulse/pulse-server && sudo systemctl start pulse-server仅删除程序(保留数据):
sudo systemctl stop pulse-server && sudo systemctl disable pulse-server && sudo rm -f /etc/systemd/system/pulse-server.service /opt/pulse/pulse-server && sudo systemctl daemon-reload完全删除(包括数据):
sudo systemctl stop pulse-server && sudo systemctl disable pulse-server && sudo rm -f /etc/systemd/system/pulse-server.service && sudo rm -rf /opt/pulse && sudo systemctl daemon-reloadLinux (amd64)
# 下载
wget https://github.com/xhhcn/Pulse/releases/latest/download/pulse-server-standalone-linux-amd64
chmod +x pulse-server-standalone-linux-amd64
# 运行
./pulse-server-standalone-linux-amd64Linux (arm64)
# 下载
wget https://github.com/xhhcn/Pulse/releases/latest/download/pulse-server-standalone-linux-arm64
chmod +x pulse-server-standalone-linux-arm64
# 运行
./pulse-server-standalone-linux-arm64访问 http://YOUR_IP:8008 查看监控面板
mkdir pulse && cd pulse
curl -sSL https://raw.githubusercontent.com/xhhcn/Pulse/main/docker-compose.yaml -o docker-compose.yaml
docker compose up -dIPv6 支持:如果您的服务器需要 IPv6 支持,请参考下方的 Docker IPv6 配置 章节。
docker run -d \
--name pulse-monitor \
-p 8008:8008 \
-v $(pwd)/pulse-data:/app/data \
--restart unless-stopped \
xhh1128/pulse:latest访问 http://YOUR_IP:8008 查看监控面板
Pulse 支持 IPv4/IPv6 双栈,如果您的服务器需要 IPv6 支持,请按照以下步骤配置:
-
确保宿主机已启用 IPv6
# 检查 IPv6 是否启用 ip -6 addr show # 检查 IPv6 转发是否启用 sysctl net.ipv6.conf.all.forwarding # 如果输出为 0,需要启用: sudo sysctl -w net.ipv6.conf.all.forwarding=1 # 永久启用(编辑 /etc/sysctl.conf) echo "net.ipv6.conf.all.forwarding=1" | sudo tee -a /etc/sysctl.conf
-
配置 Docker Daemon 启用 IPv6
编辑或创建
/etc/docker/daemon.json:{ "ipv6": true, "fixed-cidr-v6": "fd00:dead:beef:c0::/80", "experimental": true, "ip6tables": true }说明:
ipv6: true- 全局启用 Docker 的 IPv6 支持(必需)fixed-cidr-v6- Docker 使用的 IPv6 子网范围(可根据实际情况调整)experimental: true- 启用实验性功能(某些 IPv6 功能需要)ip6tables: true- 启用 IPv6 的 iptables 支持(用于网络隔离和端口映射)
重启 Docker 服务使配置生效:
sudo systemctl restart docker
-
配置 docker-compose.yaml 启用 IPv6
在
docker-compose.yaml中配置网络启用 IPv6:services: pulse: image: xhh1128/pulse:latest container_name: pulse-monitor ports: - 8008:8008 volumes: - pulse-data:/app/data restart: unless-stopped networks: - pulse-network volumes: pulse-data: networks: pulse-network: enable_ipv6: true ipam: driver: default
-
重新创建容器
docker compose down docker compose up -d
-
验证 IPv6 配置
# 检查容器 IPv6 地址 docker exec pulse-monitor ip -6 addr show # 测试 IPv6 连接(如果容器有 ping6) docker exec pulse-monitor ping6 -c 2 2001:4860:4860::8888
curl -sSL https://raw.githubusercontent.com/xhhcn/Pulse/main/client/install.sh | sudo bash -s -- \
--id <ID> --server <SERVER_URL> --secret <SECRET>powershell -ExecutionPolicy Bypass -Command "& { $env:AgentId='<ID>'; $env:ServerBase='<SERVER_URL>'; $env:Secret='<SECRET>'; irm https://raw.githubusercontent.com/xhhcn/Pulse/main/client/install.ps1 | iex }"| 参数 | 说明 |
|---|---|
<ID> |
服务器唯一标识(在管理后台添加系统时设置) |
<SERVER_URL> |
服务端地址,如 http://your-server:8008 |
<SECRET> |
认证密钥(在管理后台添加系统后自动生成,可在系统详情中查看) |
注意:
--secret参数是可选的。如果服务端系统配置了 secret,则必须提供正确的 secret 才能成功注册。
Linux:
sudo systemctl stop pulse-client && sudo systemctl disable pulse-client && sudo rm -f /opt/pulse/probe-client /etc/systemd/system/pulse-client.service && sudo systemctl daemon-reloadWindows (管理员 PowerShell):
Stop-ScheduledTask -TaskName 'PulseClient' -ErrorAction SilentlyContinue; Unregister-ScheduledTask -TaskName 'PulseClient' -Confirm:$false -ErrorAction SilentlyContinue; Remove-NetFirewallRule -DisplayName 'Pulse Monitoring Client*' -ErrorAction SilentlyContinue; Remove-Item -Path "$env:ProgramFiles\Pulse" -Recurse -Force -ErrorAction SilentlyContinue- 访问
http://YOUR_IP:8008/admin进入管理后台 - 首次访问设置管理密码
- 点击 Add System 添加服务器
- 添加系统后,系统会自动生成一个 Secret(认证密钥)
- 在目标机器上运行客户端安装命令,必须包含正确的 Secret
- 数据自动上报,实时显示
提示:在管理后台的系统列表中,点击系统右侧的复制按钮可以快速复制包含 Secret 的安装命令。
| 指标 | 内容 |
|---|---|
| CPU | 使用率、核心数、型号 |
| 内存 | 使用率、总量 |
| 磁盘 | 使用率、总量 |
| 网络 | 上传/下载速率、TCPing延迟 |
| 系统 | 运行时间、IP、位置 |
- 私有化模式
- Logo和名称自定义
- CPU类型检测
- 客户端一键部署