ConsulManager/README.md

157 lines
11 KiB
Markdown
Raw Normal View History

2022-07-05 08:28:53 +00:00
<div align="center">
[![StarsL.cn](https://img.shields.io/badge/website-StarsL.cn-orange)](https://starsl.cn)
2024-08-12 08:09:36 +00:00
[![Commits](https://img.shields.io/github/commit-activity/m/starsliao/TenSunS?color=ffff00)](https://github.com/starsliao/TenSunS/commits/main)
[![open issues](http://isitmaintained.com/badge/open/starsliao/TenSunS.svg)](https://github.com/starsliao/TenSunS/issues)
2022-12-22 04:06:33 +00:00
[![Python](https://img.shields.io/badge/python-%3C=v3.10-3776ab)](https://nodejs.org)
2022-07-06 00:08:57 +00:00
[![Node.js](https://img.shields.io/badge/node.js-%3E=v14-229954)](https://nodejs.org)
2024-08-12 08:09:36 +00:00
[![GitHub license](https://img.shields.io/badge/license-WTFPL-blueviolet)](https://github.com/starsliao/TenSunS/blob/main/LICENSE)
[![OSCS Status](https://www.oscs1024.com/platform/badge/starsliao/TenSunS.svg?size=small)](https://www.murphysec.com/dr/Zoyt5g0huRavAtItj2)
2022-07-05 08:28:53 +00:00
</div>
2023-07-24 19:10:42 +00:00
2023-07-30 19:35:35 +00:00
![tensuns-arch](https://raw.githubusercontent.com/starsliao/TenSunS/main/screenshot/tensuns-arch.png)
2023-05-08 03:34:50 +00:00
2023-07-30 16:23:15 +00:00
- **v1.0.0开始支持自定义登录页,登录后你可以在`系统设置`中自定义登录页:[欢迎Show出你的登录页](https://github.com/starsliao/TenSunS/issues/75)。**
2023-07-30 16:08:30 +00:00
- **如果你觉得本项目还不错,[烦请在这里留下脚印](https://github.com/starsliao/TenSunS/issues/74),简单登记下,也可以分享您的使用经验与实践,感谢支持!**
2022-12-31 10:17:26 +00:00
## 🏷目录
2022-06-16 05:00:45 +00:00
* [🚀概述](#概述)
2022-11-25 01:14:19 +00:00
* [🌈功能描述](#功能描述)
2022-11-25 01:17:53 +00:00
* [💾部署说明](#部署说明)
2022-06-16 05:00:45 +00:00
* [📌更新记录](#更新记录)
* [🎨截图预览](#截图预览点击查看完整截图)
* [🥇最佳实践](#最佳实践)
* [💖特别鸣谢](#特别鸣谢)
2022-07-03 14:56:46 +00:00
## 🦄概述
2023-07-30 14:22:32 +00:00
>**后羿 - TenSunS**(原ConsulManager)是一个使用Flask+Vue开发基于Consul的WEB运维平台弥补了Consul官方UI对Services管理的不足并且基于Consul的服务发现与键值存储实现了Prometheus自动发现多云厂商各资源信息基于Blackbox对站点监控的可视化维护以及对自建与云上资源的优雅管理与展示。
2022-07-03 14:51:34 +00:00
2022-11-25 01:13:44 +00:00
## 🌈功能描述
2022-11-25 01:12:56 +00:00
### 🎡1. Consul管理(比官方更优雅的Consul Web UI)
2022-04-09 10:31:57 +00:00
- 支持Consul Services的增删改查可以批量删除Service。
- 直观的查看每个Services实例的信息及整体Services的健康状态。
2022-07-27 20:52:22 +00:00
- 可以便捷的对Services实例的Tags、Meta、健康检查配置管理与查询。
2022-04-09 10:31:57 +00:00
2023-07-22 09:18:34 +00:00
### 💎2. 自建与云资源监控管理(ECS/RDS/Redis)
2022-07-03 14:51:34 +00:00
>**基于Consul实现Prometheus监控目标的自动发现。**
2022-07-27 20:40:47 +00:00
- ✔**当前已支持对接阿里云、腾讯云、华为云。**
2023-07-25 06:44:41 +00:00
- ⭐支持多云ECS/RDS/Redis的**资源、分组、标签**自动同步到Consul并接入到Prometheus自动发现(并提供云资源信息查询与自定义页面)
2022-12-03 01:52:35 +00:00
- ⭐支持多云ECS信息自动同步到**JumpServer**。
2023-07-22 09:20:41 +00:00
- ⭐支持多云**账户余额**与云资源**到期日**设置阈值告警通知。
2024-08-12 08:09:36 +00:00
- ⭐支持作为Exporter接入PrometheusPrometheus增加TenSunS的JOB后可抓取云厂商的部分MySQL/Redis指标。(弥补原生Exporter无法获取部分云MySQL/Redis指标的问题)
2023-07-22 09:20:41 +00:00
- ✔**支持自建主机/MySQL/Redis**接入WEB管理支持增删改查、批量导入导出自动同步到Consul并接入到Prometheus监控
- ✔提供了按需生成Prometheus配置与ECS/MySQL/Redis告警规则的功能。
- ✔设计了多个支持同步的各字段展示的Node_Exporter、Mysqld_Exporter、Redis_Exporter Grafana看板。
2022-07-03 14:51:34 +00:00
2022-11-25 01:12:56 +00:00
### 🚀3. 站点与接口监控管理
2022-07-03 14:51:34 +00:00
>**基于Consul + Prometheus + Blackbox_Exporter实现站点的自动发现与监控。**
- 使用Web页面即可对监控目标增删改查支持站点的分级分组查询管理。
- 支持对监控目标的批量删除与批量导入数据实时同步到Consul。
- 提供了Blackbox的配置、Prometheus的配置以及Prometheus站点监控的告警规则。
- 设计了一个支持各分级分组字段展示的Blackbox_Exporter Grafana看板。
2022-11-25 01:12:56 +00:00
### 💫4. 高危漏洞采集与实时告警
2022-06-14 14:17:08 +00:00
- 增加了高危风险漏洞采集与实时告警通知功能。
2022-06-12 17:39:33 +00:00
- 功能开启即可采集最新30个漏洞列表。
2022-06-13 06:55:44 +00:00
- 每小时采集一次,发现新漏洞立即推送到群机器人。
2022-06-14 02:29:04 +00:00
- 支持企微、钉钉、飞书群机器人通知。
2022-06-12 17:39:33 +00:00
2022-11-25 01:13:44 +00:00
---
2022-11-25 01:17:53 +00:00
## 💾部署说明
2023-07-31 07:49:01 +00:00
#### ♨TenSunS 版本更新只需在`docker-compose.yaml`所在目录执行`docker-compose pull && docker-compose up -d`即可完成更新。
2023-07-30 16:00:23 +00:00
#### 💥新增基于docker/K8S的一键部署脚本,Consul独立部署脚本,安装脚本统一放置install目录
2023-12-07 07:20:24 +00:00
##### 基于docker-compose安装
2023-07-30 16:22:14 +00:00
- [`install/docker-compose/all_install.sh`](https://github.com/starsliao/TenSunS/blob/main/install/docker-compose/all_install.sh)**推荐**:
1. **前提**服务器需要先安装好**docker和docker-compose**
2. **一键安装**`curl -s https://starsl.cn/static/img/all_install.sh|sudo bash`
2023-08-02 01:44:10 +00:00
3. 运行该脚本后会使用docker-compose启动TenSunS和Consul,安装路径是:/opt/tensuns
2023-07-30 16:35:01 +00:00
4. 脚本运行完成后会有使用提示及自动生成登录密码,**打开浏览器立刻登录TenSunS,开始体验吧!**
2023-07-30 16:00:23 +00:00
- [`install/docker-compose/consul_install_only.sh`](https://github.com/starsliao/TenSunS/blob/main/install/docker-compose/consul_install_only.sh) 独立的Consul安装脚本
- [`install/docker-compose/tensuns_install_only.sh`](https://github.com/starsliao/TenSunS/blob/main/install/docker-compose/tensuns_install_only.sh) 独立的TenSunS安装脚本已经有Consul的用户可以使用这个脚本
##### 基于K8S安装
- [`install/k8s/install.sh`](https://github.com/starsliao/TenSunS/blob/main/install/k8s/install.sh)
1. 运行后需要设置admin用户的密码。
2023-09-09 19:20:06 +00:00
2. 脚本执行完成后**只会生成TenSunS的安装yaml文件和Consul的安装yaml文件**,不会做其它操作,需要执行`kubectl apply`命令来完成安装。
2023-09-09 19:07:00 +00:00
>TenSunS是无状态的有一个初始化容器检查consul连接是否成功所以建议先安装Consul。Consul是StatefulSet需要先配置好存储volumeClaimTemplates默认是华为云自动创建存储的配置例子请自行参考修改。
2023-07-30 16:00:23 +00:00
3. 完成安装后即可使用任意K8S节点IP+31026端口访问调用的service是tensuns。
##### 注意
2023-07-30 16:01:40 +00:00
- 所有安装方式Consul的管理token会自动生成可以在Consul的配置文件或TenSunS的docker-compose中查看。
2023-07-30 16:00:23 +00:00
- 已经部署Consul的用户可以在TenSunS的docker-compose.yaml或者K8S yaml文件的环境变量部分找到:`consul_token`,`consul_url`,并配置上你的Consul信息;环境变量`admin_passwd`是TenSunS登录admin账号的密码。
2024-08-12 08:09:36 +00:00
- **安装使用中遇到问题,以及问题排查,请参考:[FAQ](https://github.com/starsliao/TenSunS/blob/main/docs/FAQ.md)**
2023-07-30 16:08:30 +00:00
##### 🎉活动
2023-07-30 16:00:23 +00:00
- **登录后你可以在`系统设置`中来`自定义登录页`[欢迎Show出你的登录页](https://github.com/starsliao/TenSunS/issues/75)。**
- **如果你觉得本项目还不错,[烦请在这里留下脚印](https://github.com/starsliao/TenSunS/issues/74),简单登记下,也可以分享您的使用经验与实践,感谢支持!**
2022-12-21 08:02:43 +00:00
2024-08-12 08:09:36 +00:00
## 📌[更新记录](https://github.com/starsliao/TenSunS/releases)
2022-01-29 04:21:59 +00:00
2024-08-12 08:09:36 +00:00
## 🎨截图预览([点击查看完整截图](https://github.com/starsliao/TenSunS/tree/main/screenshot#%E6%88%AA%E5%9B%BE)
2022-07-09 18:06:56 +00:00
<details><summary>💥点击展开</summary>
2022-04-10 04:25:11 +00:00
### Consul Web Manager 界面
2024-08-12 08:09:36 +00:00
![](https://raw.githubusercontent.com/starsliao/TenSunS/main/screenshot/consul3.PNG)
2022-07-27 02:53:52 +00:00
### 多云ECS同步Consul界面
2024-08-12 08:09:36 +00:00
![](https://raw.githubusercontent.com/starsliao/TenSunS/main/screenshot/ecs1.PNG)
2022-07-27 02:53:52 +00:00
### 多云ECS同步JumpServer界面
2022-07-25 20:45:42 +00:00
![图片](https://user-images.githubusercontent.com/3349611/180870935-56e536d2-0b71-4803-b5f8-0839a241c79a.png)
2022-06-14 13:28:47 +00:00
### Node Exporter Dashboard 截图
2024-08-12 08:09:36 +00:00
![](https://raw.githubusercontent.com/starsliao/TenSunS/main/vue-consul/public/node1.png)
![](https://raw.githubusercontent.com/starsliao/TenSunS/main/vue-consul/public/node2.png)
2022-02-10 17:36:36 +00:00
### Blackbox Manager 界面
2024-08-12 08:09:36 +00:00
![](https://raw.githubusercontent.com/starsliao/TenSunS/main/screenshot/blackbox1.PNG)
2022-06-14 13:28:47 +00:00
### Blackbox Exporter Dashboard 截图
2024-08-12 08:09:36 +00:00
![](https://raw.githubusercontent.com/starsliao/TenSunS/main/vue-consul/public/blackbox.png)
2022-06-12 17:45:12 +00:00
### 高危漏洞采集与通知 界面
2024-08-12 08:09:36 +00:00
![](https://raw.githubusercontent.com/starsliao/TenSunS/main/screenshot/bug.png)
2022-06-14 13:29:34 +00:00
##### 钉钉告警通知
2022-06-13 01:30:50 +00:00
![图片](https://user-images.githubusercontent.com/3349611/173263960-4d69fff9-82fe-42a1-ba18-4c78775cf35e.png)
2022-07-09 18:06:56 +00:00
</details>
2022-11-25 01:17:53 +00:00
2022-02-10 17:07:06 +00:00
---
2022-06-16 04:42:18 +00:00
## 🥇最佳实践
2024-08-12 08:09:36 +00:00
- #### [TenSunS实践与FAQ](https://github.com/starsliao/TenSunS/tree/main/docs)
- #### [应用场景1如何优雅的基于Consul自动同步ECS主机监控](https://github.com/starsliao/TenSunS/blob/main/docs/ECS%E4%B8%BB%E6%9C%BA%E7%9B%91%E6%8E%A7.md)
- #### [应用场景2如何优雅的使用Consul管理Blackbox站点监控](https://github.com/starsliao/TenSunS/blob/main/docs/blackbox%E7%AB%99%E7%82%B9%E7%9B%91%E6%8E%A7.md)
- #### [应用场景3如何把云主机自动同步到JumpServer](https://github.com/starsliao/TenSunS/blob/main/docs/%E5%A6%82%E4%BD%95%E6%8A%8A%E4%B8%BB%E6%9C%BA%E8%87%AA%E5%8A%A8%E5%90%8C%E6%AD%A5%E5%88%B0JumpServer.md)
- #### [应用场景4使用1个mysqld_exporter监控所有的MySQL实例](https://github.com/starsliao/TenSunS/blob/main/docs/%E5%A6%82%E4%BD%95%E4%BC%98%E9%9B%85%E7%9A%84%E4%BD%BF%E7%94%A8%E4%B8%80%E4%B8%AAmysqld_exporter%E7%9B%91%E6%8E%A7%E6%89%80%E6%9C%89%E7%9A%84MySQL%E5%AE%9E%E4%BE%8B.md)
- #### [应用场景5使用1个redis_exporter监控所有的Redis实例](https://github.com/starsliao/TenSunS/blob/main/docs/%E4%BD%BF%E7%94%A8%E4%B8%80%E4%B8%AAredis_exporter%E7%9B%91%E6%8E%A7%E6%89%80%E6%9C%89%E7%9A%84Redis%E5%AE%9E%E4%BE%8B.md)
2022-04-09 10:31:57 +00:00
2022-06-14 13:28:47 +00:00
## 💖特别鸣谢
2023-07-30 16:00:23 +00:00
### 赞赏与关注公众号【**云原生DevOps**】加入交流群(请备注:后羿),获取更多...
2022-09-14 09:07:33 +00:00
**如果看不到图片请点击该链接:[https://starsl.cn/static/img/thanks.png](https://starsl.cn/static/img/thanks.png)**
2022-04-29 04:02:51 +00:00
![](https://starsl.cn/static/img/thanks.png)
2022-04-10 03:42:18 +00:00
---
2022-06-04 09:59:56 +00:00
### 💰赞赏
2022-11-03 01:15:39 +00:00
##### 🥇榜一大哥:**@浩哥**
2022-12-07 02:11:59 +00:00
##### 🥈榜二大哥:**@南城阿宇** **@weibw**
2023-05-18 04:02:30 +00:00
##### 🥉榜三大哥:**@新的奇迹** **@李宫俊** **@锋** **@小明SQLBOY** **@Swancavalier**
2023-11-28 20:04:55 +00:00
##### 🏆榜N大哥@老叶 @mac🐬 🌈 @Stephen @蔡志昆 @风与尘的誓约 @Initᯤ⁶ᴳ @254209 @Runner91 @烂泥 @ASL·D·阿威 @惊雷 @默读自我 @MiracleWong
2022-04-19 20:55:56 +00:00
2022-04-09 11:19:28 +00:00
---
2022-04-09 11:15:47 +00:00
2022-06-04 09:59:56 +00:00
### ✅提交代码
2023-07-28 08:38:09 +00:00
[@dbdocker](https://github.com/dbdocker) [@anatsking](https://github.com/anatsking)
2022-04-10 03:42:18 +00:00
2022-04-09 11:19:28 +00:00
---
2022-04-09 11:11:00 +00:00
2023-07-22 09:28:08 +00:00
### 🎃提交bug与建议
2024-01-27 12:14:56 +00:00
@会飞的鱼 [@奈](https://github.com/Wp516781950) @Swancavalier [@Show_Lo](https://github.com/ShowXian) @郑不错 @init @weibw @Martin [@dong9205](https://github.com/dong9205) @MiracleWong [@dissipator](https://github.com/dissipator) @烂泥 [@SkipperSky](https://github.com/klllmxx)
2024-01-27 12:09:53 +00:00
2022-04-09 11:19:28 +00:00
---
2022-07-09 15:20:45 +00:00
### 🏆开源推荐
[🌉Go-Ldap-Admin: 基于Go+Vue实现的openLDAP后台管理项目](https://github.com/eryajf/go-ldap-admin)
---
2023-07-22 09:28:08 +00:00
## 💖感谢伟大的[Flask](https://github.com/pallets/flask)、[VUE](https://github.com/vuejs/vue)、[vue-admin-template](https://github.com/PanJiaChen/vue-admin-template)