# xrkmonitor
**Repository Path**: czebin/open
## Basic Information
- **Project Name**: xrkmonitor
- **Description**: xrkmonitor - 集监控点监控(自定义监控)、日志监控、数据可视化以及监控告警为一体的国产开源云监控系统,众多云监控插件直接部署即可使用。
- **Primary Language**: C/C++
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: http://open.xrkmonitor.com
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 329
- **Created**: 2020-11-29
- **Last Updated**: 2020-12-17
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
### 项目简介
集监控点监控、日志监控、数据可视化及监控告警为一体的分布式开源监控系统。
通过插件方式支持常用监控需求,插件可自由选择且支持一键部署、移除、启用、禁用等操作。
提供丰富的图表和多种数据类型,满足对数据可视化的需要。
在线演示版地址:[http://open.xrkmonitor.com](http://open.xrkmonitor.com)
**相比其它开源监控系统优势**
1. 支持插件功能, 监控插件无需开发,自由选择监控插件,控制台安装即可使用
1. 集成告警功能, 支持多种告警方式
1. 集成分布式日志系统功能
1. 支持多种部署方式
a.集中部署(全部服务部署在一台机器,适合个人或者小团队开发者)
b.分布式部署(分布式部署在多台机器,适合小中型企业大规模监控需求)
1. 支持自动化配置(机器部署agent后自动注册到监控系统无需在控制台配置、视图根据上报自动绑定相关上报机器)
1. 支持多用户访问(子账号由管理员账号在控制台添加)
1. 上报接口支持主流开发语言,数据上报api 提供类似公共库接口的便捷
### 特色功能推荐
1. IP地址库: 支持通过IP地址上报时将IP地址转为物理地址,相同物理地址归并展示,一个监控API 即可轻松生成监控
数据的物理地址分布图,插件示例:[monitor_apache_log](https://gitee.com/xrkmonitorcom/monitor_apache_log)

1. 监控插件市场: 让监控成为可以复用的组件,无需开发一键安装即可使用,更多监控插件持续开发中

1. 分布式日志系统: 支持大规模系统日志上报,日志上报支持频率限制、日志染色、自定义字段等高级功能,控制台
日志查看支持按关键字、排除关键字、上报时间、上报机器等方式过滤日志,从茫茫日志中轻松找到您需要的日志

1. 视图机制: 监控图表支持视图定制模式,视图可按上报服务器、监控点随意组合,轻松定制您需要的监控视图,并
可在监控图表上直接设置告警值

1. 告警集成: 集成告警功能, 支持邮件、短信、微信、PC客户端等告警方式,告警功能无需开发直接可用

### docker 方式部署
以下假设宿主机的IP 地址为:192.168.128.210, 以v3.0 版本作为示例说明 docker 部署方法
1. 拉取 docker 镜像: docker pull registry.cn-hangzhou.aliyuncs.com/xrkmonitor/release:v3.0
1. 通过镜像启动容器:docker images 查看镜像ID,假设为:93297f01d06b
启动容器:
docker run -idt -p27000:27000/udp -p38080:38080/udp -p28080:28080/udp -p80:80 --env xrk_host_ip=192.168.128.210 --env xrk_http_port=8080 -v /data/xrkmonitor/docker_mysql:/var/lib/mysql -v /data/xrkmonitor/docker_slog:/home/mtreport/slog 93297f01d06b
参数说明:
-p27000:27000/udp -p38080:38080/udp -p28080:28080/udp -p80:80 日志、监控点、接入服务等的端口映射
--env xrk_host_ip=192.168.128.210 宿主机的ip地址, 根据实际情况传递
--env xrk_http_port=80 web 控制台的映射端口(可以使用非80端口映射容器80端口,相关问题可以查看在线文档的 docker 部署部分)
-v /data/xrkmonitor/docker_mysql:/var/lib/mysql, 挂载宿主机目录
-v /data/xrkmonitor/docker_slog:/home/mtreport/slog,挂载日志目录
1. docker ps -a 查看运行的容器,docker attach 进入容器,进入目录 /home/mtreport, 执行 ./start_docker.sh 启动监控系统服务
1. 在浏览器端使用宿主机IP即可访问控制台: http://192.168.128.210,控制台默认账号密码为:sadmin/sadmin
1. 如需停止服务可执行 : /home/mtreport/stop_docker.sh 脚本
可以使用 ps -elf |grep slog 命令查看运行的进程,使用 ps -elf |grep xrk_ 查看运行的内置插件
**agent 部署说明:**
容器中 /home/mtreport/slog_mtreport_client.tar.gz 为 agent 部署文件,可以将其拷贝到需要部署的机器上
SERVER_MASTER 配置改为宿主机的IP地址, 如果需要在宿主机上部署 agent,需要指定:AGENT_CLIENT_IP 不能与
容器启动时传递的xrk_host_ip 相同(xrk_host_ip 已被docker 容器使用了),IP 可以不存在,主要用于机器识别。
关于 agent 的详细说明可以参考文档。
docker 使用过程中如有问题可以加入我们的QQ群: 859052272 获取帮助。
### 使用 docker 镜像编译源码
使用 docker 镜像编译源码方法如下:
1. 拉取镜像: docker pull registry.cn-hangzhou.aliyuncs.com/xrkmonitor/compile:last
1. 执行镜像容器:docker run -idt [镜像id] (docker images 获取)
1. 进入容器:docker attach [容器id] (docker ps -a 获取)
1. 进入容器目录:/home/xrkmonitor/open, 执行 make 即可编译项目全部源码
1. 编译成功后生成集中部署包,进入 tools_sh 目录,执行:./make_all.sh 即可生成完整的集中部署包
关于集中部署请参考文档:[源码编译-集中部署](http://xrkmonitor.com/monitor/showdoc/showdoc/web/#/4?page_id=38)
docker 编译镜像安装了 vim/gcc/git 等工具,如需更新源码,进入目录:/home/xrkmonitor/open 执行 git pull 即可
如您想使用镜像进行二次开发,建议您挂载宿主机目录,将源码下载到挂载的目录进行修改, 不要使用容器中的
/home/xrkmonitor/open 目录,以免工作成果丢失。
### 在线部署
安装脚本: install.sh
从以下链接下载后, 按提示执行即可, 需要系统支持 bash
(wget http://xrkmonitor.com/monitor/download/install.sh; chmod +x install.sh; ./install.sh )
示例(如您安装失败可在评论区留言系统版本或者加入Q群咨询):
在线部署说明:
安装脚本会先检查当前系统是否支持在线安装, 如不支持您可以下载源码后在系统上编译安装
在线部署目前只支持集中部署方式, 即所有服务部署在一台机器上, 该机器上需要安装 mysql/apache
安装脚本使用中文 utf8 编码, 安装过程请将您的终端设置为 utf8, 以免出现乱码
安装脚本同时支持 root 账号和普通账号操作, 使用普通账号执行安装部署要求如下:
1. 在线部署使用动态链接库, 需要在指定目录下执行安装脚本, 目录为: /home/mtreport
2. 普通账号某些目录可能无权操作, 需要授权才能正常安装
卸载脚本: uninstall_xrkmonitor.sh
在线部署过程中会下载该脚本, 如需卸载可执行该脚本
在线部署详细说明文档:[在线部署](http://xrkmonitor.com/monitor/showdoc/showdoc/web/#/4?page_id=55)
我们强烈建议您先在本地虚拟机上执行在线安装, 熟悉安装流程后在实际部署到您的服务器上。
### 离线部署(自行编译源码)
如果在线安装失败或者需要二次开发, 可以使用源码编译方式安装
操作步骤:
1. git clone https://gitee.com/xrkmonitorcom/open.git 下载源码
2. 进入源码目录,执行 make 完成源码编译
3. 进入 tools_sh 目录,执行 make_all.sh 生成部署包
4. 在安装目录解压部署包,执行 local_install.sh 完成安装
(如遇编译环境问题,可以尝试使用docker 镜像编译)
监控系统卸载脚本: uninstall_xrkmonitor.sh,移除彻底不留丝毫痕迹
安装环境变量同在线安装一样, 具体可以查看说明文档: [源码编译-集中部署](http://xrkmonitor.com/monitor/showdoc/showdoc/web/#/4?page_id=38)
控制台默认账号密码: sadmin/sadmin
### 使用的技术方案
1. apache + mysql(监控点数据、配置信息使用 mysql 存储, 支持分布式部署)
2. 前端 web 控制台采用 [dwz 开源框架](http://jui.org/)
3. 前端监控图表采用开源 [echarts](https://www.echartsjs.com/zh/index.html) 绘制
4. 后台 cgi 使用开源的cgi模板引擎 - [clearsilver](http://www.clearsilver.net/), 所有cgi支持以fastcgi方式部署
5. 后台服务使用了开源的 socket 开发框架 - [C++ Sockets](http://www.alhem.net/Sockets/)
### 当前监控上报API支持的语言如下(更多语言支持在开发中)
1. [c/c++ 开发接口](http://xrkmonitor.com//monitor/showdoc/showdoc/web/#/4?page_id=45)
2. [php 开发接口](http://xrkmonitor.com//monitor/showdoc/showdoc/web/#/4?page_id=51)
3. [linux shell 开发接口](http://xrkmonitor.com//monitor/showdoc/showdoc/web/#/4?page_id=72)
4. [javascript 开发接口](http://xrkmonitor.com//monitor/showdoc/showdoc/web/#/4?page_id=76)
### 插件市场
1. [linux_base](https://gitee.com/xrkmonitorcom/plugin_linux_base) - c/c++语言开发,用于监控linux 系统 cpu/内存/磁盘/网络等资源
2. [monitor_apache_log](https://gitee.com/xrkmonitorcom/monitor_apache_log) - c/c++语言开发,用于监控apache 网站的流量访问量等
3. [linux_file_monitor](https://gitee.com/xrkmonitorcom/linux_file_monitor) - shell 语言开发,用于监控 linux系统文件目录的增删改变动
4. [monitor_website](https://gitee.com/xrkmonitorcom/monitor_website) - javascript 语言开发,用于监控网站访客基本信息和运行异常信息
**项目演示链接:[字符云监控项目演示 http://open.xrkmonitor.com](http://open.xrkmonitor.com)**
**在线文档:- [在线文档 http://xrkmonitor.com/monitor/dmt_open_doc.html](http://xrkmonitor.com/monitor/dmt_open_doc.html)**
### 联系我们
微信公众号:

邮箱:1820140912@qq.com
QQ群:859052272