0

0

宝塔面板如何通过面板接口实现服务器运行状态的外部看板?

P粉602998670

P粉602998670

发布时间:2026-03-18 17:29:45

|

848人浏览过

|

来源于php中文网

原创

可通过宝塔API、WebHook、定时任务、Nginx反代四种方式将服务器状态实时同步至外部看板:启用API并设白名单与密钥;调用/system/status接口获取JSON监控数据;配置WebHook推送告警事件;用计划任务导出status.json供轮询;或通过bt命令+Nginx暴露简化接口。

宝塔面板如何通过面板接口实现服务器运行状态的外部看板?

如果您希望在外部看板中实时展示宝塔面板所管理服务器的运行状态,可通过调用宝塔面板开放的API接口获取系统信息。以下是实现该功能的具体步骤:

一、启用并配置宝塔面板API接口

宝塔面板默认关闭API访问,需手动开启并设置密钥与IP白名单,确保接口可被外部安全调用。

1、登录宝塔面板后台,点击左侧菜单栏的【面板设置】。

2、向下滚动至【API接口】区域,勾选【启用API接口】选项。

3、在【API密钥】输入框中点击【生成密钥】按钮,获得一串32位随机字符串。

4、在【IP白名单】中填入外部看板所在服务器的公网IP地址,多个IP用英文逗号分隔。

5、点击【保存】使配置生效。

二、获取系统运行状态数据

通过HTTP GET请求调用系统监控类接口,可直接获取CPU、内存、磁盘、网络等实时指标,无需额外解析日志或执行命令。

1、构造请求URL:https://您的服务器IP:8888/api/system/status?access_key=您的API密钥

2、使用curl或Python requests等工具发起HTTPS请求,注意必须携带Header:X-Requested-With: XMLHttpRequest。

3、服务端返回JSON格式响应,包含cpu_percent、mem_total、mem_used、disk_usage等字段。

4、检查响应状态码是否为200,且response.data字段存在,确认数据有效。

三、使用WebHook方式推送状态至外部看板服务

宝塔支持通过自定义WebHook将关键事件(如CPU超阈值、网站宕机)主动推送到指定HTTP端点,适用于轻量级状态同步场景。

1、进入【监控报警】→【WebHook设置】,点击【添加WebHook】。

2、填写【WebHook地址】为外部看板提供的接收URL,例如https://dashboard.example.com/api/bt-hook。

3、在【触发条件】中勾选【系统负载过高】、【内存使用率过高】等所需监控项。

Hotpot AI Background Remover
Hotpot AI Background Remover

Hotpot.ai推出的图片背景移除工具

下载

4、设置【推送内容模板】为JSON格式,示例:{"event":"cpu_overload","value":"{{cpu}}","time":"{{time}}"}

5、点击【测试推送】验证看板服务能否正常接收并解析数据。

四、通过定时任务拉取并缓存状态数据

若外部看板部署环境无法直连宝塔HTTPS端口(如受防火墙限制),可借助宝塔内置计划任务定期导出状态快照供外部读取。

1、进入【计划任务】→【添加计划任务】,选择任务类型为【Shell脚本】。

2、在脚本内容中写入:curl -k "https://127.0.0.1:8888/api/system/status?access_key=YOUR_KEY" > /www/wwwroot/status.json

3、设置执行周期为每分钟一次,确保状态更新延迟控制在60秒内。

4、将/www/wwwroot目录绑定为静态资源服务路径,使外部看板可通过HTTP GET读取status.json。

5、在外部看板前端使用fetch轮询该JSON文件,解析后渲染至UI组件。

五、使用bt命令行工具配合Nginx反向代理暴露只读接口

利用宝塔内置bt命令获取原始监控数据,并通过Nginx反向代理对外提供无认证、仅限GET的简化接口,降低外部调用复杂度。

1、在SSH中执行bt 13查看系统信息,确认输出含uptime、load、memory等字段。

2、编写shell脚本/usr/local/bin/get_bt_status.sh,内容为echo $(bt 13 | grep -E "(uptime|load|memory)" | sed 's/ //g')。

3、为该脚本添加执行权限:chmod +x /usr/local/bin/get_bt_status.sh。

4、配置Nginx站点,在location /api/status中添加proxy_pass http://127.0.0.1:8888/api/status; 并启用fastcgi或rewrite转发至脚本输出。

5、外部看板请求https://your-domain.com/api/status即可获得精简文本状态,无需处理SSL证书或密钥。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
bootstrap安装教程
bootstrap安装教程

本专题整合了bootstrap安装相关教程,阅读专题下面的文章了解更多详细操作教程。

0

2026.03.18

bootstrap框架介绍
bootstrap框架介绍

本专题整合了bootstrap框架相关介绍,阅读专题下面的文章了解更多详细内容。

2

2026.03.18

vscode 格式化
vscode 格式化

本专题整合了vscode格式化相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.18

vscode设置中文教程
vscode设置中文教程

本专题整合了vscode设置中文相关内容,阅读专题下面的文章了解更多详细教程。

0

2026.03.18

vscode更新教程合集
vscode更新教程合集

本专题整合了vscode更新相关内容,阅读专题下面的文章了解更多详细教程。

2

2026.03.18

Gemini网页版零基础入门:5分钟上手Gemini聊天指南
Gemini网页版零基础入门:5分钟上手Gemini聊天指南

本专题专为零基础用户打造,5分钟快速掌握Gemini网页版核心用法。从账号登录到界面布局,详解如何发起对话、优化提示词及利用多模态功能。通过实战案例,教你高效获取信息、创作内容与分析数据。无论学习还是工作,轻松开启AI辅助新时代,让Gemini成为你的得力智能助手。

9

2026.03.18

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

8

2026.03.18

Java Spring Security权限控制与认证机制实战
Java Spring Security权限控制与认证机制实战

本专题围绕 Java 后端安全体系建设展开,重点讲解 Spring Security 在权限控制与认证机制中的应用实践。内容涵盖用户认证流程、权限模型设计、JWT 鉴权方案、OAuth2 集成以及接口安全防护策略。通过实际项目案例,帮助开发者构建安全可靠的后端认证体系,提升系统安全性与可扩展能力。

22

2026.03.18

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

170

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号