阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

搭建开源美观的数据库监控系统-Lepus

387次阅读
没有评论

共计 5499 个字符,预计需要花费 14 分钟才能阅读完成。

搭建开源美观的数据库监控系统 -Lepus

天兔数据库监控系统 -Lepus

欢迎大家使用天兔数据库监控系统(以下简称为 Lepus)。Lepus 是一套开源的数据库监控平台,目前已经支持 MySQL、Oracle、PostgresQL、GreatSQL、MongoDB、Redis 等数据库的基本监控和告警。Lepus 无需在每台数据库服务器部署脚本或 Agent,只需要在数据库创建授权帐号后,即可进行远程监控,适合监控数据库服务器较多的公司和监控云中数据库,这将为企业大大减化监控部署流程,同时 Lepus 系统内置了丰富的性能监控指标,让企业能够在数据库宕机前发现潜在性能问题进行处理,减少企业因为数据库问题导致的直接损失。

开源地址:https://gitee.com/lepus-group/lepus

官网:https://www.lepus.cc/

Lepus 有 v3 版本和 v5 版本

搭建开源美观的数据库监控系统 -Lepus

Docker 安装 v3 版本

https://hub.docker.com/r/georce/lepus
docker run -itd --name lepus \
--restart always \
-p 83:80 \
-p 50920:3306 \
docker.io/georce/lepus

http://IP:83
USERNAME: admin
PASSWORD: Lepusadmin
搭建开源美观的数据库监控系统 -Lepus

V3 版本的控制面板

搭建开源美观的数据库监控系统 -Lepus

本教程主要在 centos7 下安装 v5 版本,并且使用监控 MySQL。

系统说明

 系统:centos7
IP: 192.168.1.3
数据库:
192.168.1.6:3306
用户名:root
密码:123456

软件要求

Lepus-V5 部署需要部署以下软件:

软件名称 推荐版本 必须 备注
Golang 1.4-1.8 源码编译运行必须安装 / 使用二进制方式无需安装(直接 yum install golang)
MySQL 5.6 用于存储基础数据和事件数据(本文安装教程略)
InfluxDB 1.x 事件数据默认存储 MySQL,支持存储到 InfluxDB, 如有使用 InfluxDB 需求则必须需要部署(笔者未安装)
Redis 5.x 用于报警系统限流(本文安装教程略)
NSQ 1.2.x 基于 gaolang 的高性能消息队列,用于事件消息传输(参考以下)

centos7 安装 NSQ

NSQ 是实时的分布式消息处理平台,其设计的目的是用来大规模地处理每天数以十亿计级别的消息。

参考文档:https://nsq.io/overview/quick_start.html

1. 下载软件

二进制下载路径:https://github.com/nsqio/nsq/releases

版本:nsq-1.2.1.linux-amd64.go1.16.6.tar.gz

上传到 CentOS 服务器,解压即可。

启动 进入解压路径的 /bin 目录

2. 安装 NSQ

进入解压路径的 /data/NSQ 目录

# mkdir /data/NSQ
# wget http://js.funet8.com/centos_software/nsq-1.2.1.linux-amd64.go1.16.6.tar.gz # 备用下载地址
# tar -zxvf nsq-1.2.1.linux-amd64.go1.16.6.tar.gz
# cd nsq-1.2.1.linux-amd64.go1.16.6/bin

1. 启动 nsqlookupd(nohup 后台启动):
# nohup ./nsqlookupd &

2. 启动 nsqd(nohup 后台启动)
# nohup ./nsqd --lookupd-tcp-address=192.168.1.3:4160 &

3. 启动 nsqadmin(nohup 后台启动)
# nohup ./nsqadmin --lookupd-http-address=192.168.1.3:4161 &

4. 启动日志查看:bin 目录会自动生成 nohup 日志, 查看命令如下:
# tail -f nohup.out

3.NSQ 消息测试

启动 nsq_to_file,将消息写入 /tmp 文件的日志文件,文件名默认由主题 topic+ 主机 + 日期时间戳组成

# nohup ./nsq_to_file --topic=test --output-dir=/tmp --lookupd-http-address=192.168.1.3:4161 &

使用 curl 命令,发布一条消息, 返回 OK

# curl -d 'hello world' 'http://192.168.1.3:4151/pub?topic=test'
OK

浏览器方问 web 界面:http://192.168.1.3:4171/,界面如下:

搭建开源美观的数据库监控系统 -Lepus

安装 Lepus

Linux 环境使用二进制安装 Lepus

1. 下载二进制版本 Lepus

进入官网下载页面,根据操作系统选择 Linux 或者 Windows 对应的二进制包,下载 lepus 二进制包,下载地址:https://www.lepus.cc/downloads/

Linux 环境二进制包文件名为:lepus.5.x.linux-amd64.tar.gz,Windows 环境二进制包文件名为:lepus.5.x.windows-amd64.zip

本文下载:lepus.5.1.linux-amd64.tar.gz

2. 下载并修改文件

cd /data/
wget http://js.funet8.com/centos_software/lepus.5.1.linux-amd64.tar.gz # 备用下载地址
tar -zxvf lepus.5.1.linux-amd64.tar.gz
mv lepus.5.1.linux-amd64 lepus.5.1

3. 导入初始化数据库

进入 lepus 二进制目录,并导入数据库初始化表结构和数据

在 192.168.1.6 的数据库上数据库 ’lepus_db’

cd lepus.5.1/sql
mysql -uroot -h192.168.1.6 -P'3306' -p'123456' lepus_db < init_table.sql
mysql -uroot -h192.168.1.6 -P'3306' -p'123456' lepus_db < init_data.sql
搭建开源美观的数据库监控系统 -Lepus

4. 生成配置文件

从 example 中复制配置文件,并进行设置,设置里包含连接 MySQL、Redis、NSQ、告警邮件网关,(MySQL、Redis、NSQ 为必须安装,InfluxDB 为可选,开源组件请大家自行安装部署)。

cp etc/proxy.example.ini etc/proxy.ini
cp etc/alarm.example.ini etc/alarm.ini
cp etc/config.example.ini etc/config.ini

由于数据库不是本机,所以需要修改配置

#  vim etc/proxy.ini
修改如下 

[main]

port = 8800 log = /tmp/lepus_proxy.log debug=1 enable_influxdb=0

[nsq]

nsq_server = 127.0.0.1:4150

[mysql]

mysql_host = 192.168.1.6 mysql_port = 3306 mysql_user = root mysql_password = 123456 mysql_database = lepus_db

[influxdb]

influx_host = 192.168.1.6 influx_port = 8086 influx_user = root influx_password = 123456 influx_database = lepus_db # vim etc/alarm.ini 修改如下

[main]

debug=1 log = /tmp/lepus_alarm.log

[nsq]

nsq_server = 127.0.0.1:4150

[mysql]

mysql_host = 192.168.1.6 mysql_port = 3306 mysql_user = root mysql_password = 123456 mysql_database = lepus_db

[redis]

redis_host = 127.0.0.1 redis_port = 6379 redis_pass = password

[mail]

mail_host = smtp.163.com mail_port = 465 mail_user = alarm@163.com mail_pass = password mail_from = alarm@163.com # vim etc/config.ini 修改配置

[main]

log_dir = /tmp/ debug = 1 interval = 10 proxy = http://127.0.0.1:8800 db_pass_key = L1e2p3u4s5Abc321

[mysql]

mysql_host = 192.168.1.6 mysql_port = 3306 mysql_user = root mysql_password = 123456 mysql_database = lepus_db

5. 启动服务组件

请按照以下顺序依次启动组件,启动报错请检查配置文件,未报错需要将任务放到后台运行。

启动 Proxy 模块

# cd /data/lepus.5.1/bin/
# ./lepus_proxy --config=../etc/proxy.ini

启动 Task 模块

# ./lepus_task --config=../etc/config.ini

启动 Alarm 模块

./lepus_alarm --config=../etc/alarm.ini

启动后可以查看进程

# ps -ef|grep lepus
root      3810  3135  0 Jun16 pts/0    00:00:00 ./lepus_proxy --config=../etc/proxy.ini
root      3816  3135  0 Jun16 pts/0    00:00:00 ./lepus_task --config=../etc/config.ini
root      5329  5000  0 09:55 pts/1    00:00:00 ./lepus_alarm --config=../etc/alarm.ini

查看运行日志,没有 Error 则运行正常,如果日志过多可以将配置文件 debug 设置为 0,则不会输出 debug 日志。

tail -f /tmp/lepus_proxy.log
tail -f /tmp/lepus_task.log
tail -f /tmp/lepus_alarm.log

提示:Lepus 安装完成后还需要安装运行 Lepus Console 控制台。

安装 Lepus-console

Lepus Console 控制台是用于配置和管理 Lepus 的 WEB 管理界面,没有控制台,Lepus 也可以正常运行,您也可以通过操作数据库数据进行监控和报警,但是使用 Lepus Console 会让使用更加便捷,并且查询随时查询监控事件数据和性能图表。

下载 Lepus Console 安装包

1. 进入官网下载页面,根据操作系统选择 Linux 或者 Windows 对应的 Lepus Console 二进制包,下载 lepus 二进制包,下载地址:https://www.lepus.cc/downloads/

笔者下载 lepus-console.5.1.linux-amd64.tar.gz

mkdir /data/lepus-console
cd /data/lepus-console
wget http://js.funet8.com/centos_software/lepus-console.5.1.linux-amd64.tar.gz # 备用下载地址
tar -zxvf lepus-console.5.1.linux-amd64.tar.gz
mv lepus-console.5.1.linux-amd64 lepus-console.5.1

2. 进入 lepus-console-linux-amd64 目录

cd lepus-console.5.1

3. 复制和修改配置文件

# cp setting.example.yml setting.yml
修改配置文件
# vim setting.yml 
填写以下,只修改 mysql 的配置:log:
  path: "/tmp/lepus_api.log"
  level: "debug"
  debug: true

dataSource:
  eventStorageEngine: mysql
  host: 192.168.1.6
  port: 3306
  user: root
  password: 123456
  database: lepus_db
  influxHost: 127.0.0.1
  influxPort: 8086
  influxUser: admin
  influxPassword:
  influxDatabase: lepus_db

token:
  storage: "mysql"
  key: "S9p2+dsfM1CzLF=="
  name: "lepus-pro"
  expired: "3d"

decrypt:
  signKey: "1234567890abcdef"
  dbPassKey: "L1e2p3u4s5Abc321"

4. 运行控制台

# ./lepus_console
...
[GIN-debug] Listening and serving HTTP on :8080

5. 访问控制台

访问 IP:8080 可以登录界面进行登录,默认管理密码为:admin/lepusadmin

搭建开源美观的数据库监控系统 -Lepus

进入控制台

搭建开源美观的数据库监控系统 -Lepus

至此,lepus 在 centos7 系统下就安装完成了,再就是添加 mysql 监控节点和异常通知告警的配置了。

搭建开源美观的数据库监控系统 -Lepus

参考:https://www.lepus.cc/docs/lepus-v5/

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-06-17发表,共计5499字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中