| 
				
					
						
							 | 
			||
|---|---|---|
| blackbox_exporter | ||
| flask-consul | ||
| nginx-consul | ||
| screenshot | ||
| units | ||
| README.md | ||
| docker-build.sh | ||
| docker-compose.yml | ||
| docker-push.sh | ||
		
			
				
				README.md
			
		
		
			
			
				
				
			
		
	
	如何优雅的使用Consul管理站点监控
关注公众号【云原生DevOps】加入运维群交流,获取更多...
实现功能
- 基于Prometheus + Blackbox_Exporter实现站点与接口监控。
 - 基于Consul实现Prometheus监控目标的自动发现。
 - Blackbox Manager:基于Flask + Vue实现的Web管理平台,可以简单的对监控目标增删改查,便于分类维护管理。
 - 实现了一个脚本可批量导入监控目标到Consul。
 - 更新了一个Blackbox Exporter的Grafana展示看板。
 
v0.1.2更新
- 所有字段增加了排序功能
 - 新增筛选功能:可以根据名称或实例来进行关键字筛选
 - 新增清空查询条件按钮
 - 简化了web界面新增操作:
- 选择选项查询后,点击新增或自动填写好选择的选项
 - 增加确认并新增按钮,可以自动填上之前填写的前4个字段
 
 - 新增批量删除功能
 - 新增分页功能
 
docker-compose pull && docker-compose up -d
截图
Blackbox Manager Web管理界面
Blackbox Exporter Dashboard 截图
部署说明
部署Consul
安装
# 使用yum部署consul
yum install -y yum-utils
yum-config-manager --add-repo https://rpm.releases.hashicorp.com/RHEL/hashicorp.repo
yum -y install consul
# 或者直接下RPM包安装
wget https://rpm.releases.hashicorp.com/RHEL/7/x86_64/stable/consul-1.11.1-1.x86_64.rpm
rpm -ivh ./consul-1.11.1-1.x86_64.rpm
配置
vi /etc/consul.d/consul.hcl
data_dir = "/opt/consul"
client_addr = "0.0.0.0"
ui_config{
  enabled = true
}
server = true
bootstrap = true
acl = {
  enabled = true
  default_policy = "deny"
  enable_token_persistence = true
}
启动与鉴权配置
systemctl enable consul.service
systemctl start consul.service
# 获取登录密码
consul acl bootstrap
# 记录 SecretID
部署Blackbox Manager
使用docker-compose来部署
编辑docker-compose.yaml文件,修改传入的3个环境变量:
- 
consul的
token,consul的URL(/v1要保留),登录Blackbox Manager的密码 - 
启动:
docker-compose up -d - 
访问:
http://{IP}:1026 
Consul字段设计说明
- 所有数据存在一个名为
blackbox_exporter的Services项中,每个监控目标为一个子Service。 - 每个Service包含一个Tag,会自动配置为meta中的
module的值,作为Prometheus自动发现的tags。 - 每个Service使用Meta的kv保存监控目标的明细:
 module,company,project,env,name,instance- 分别表示:监控类型,公司部门,项目,环境,名称,实例url
 - 前5个字段合并即为consul的serviceID,作为唯一监控项标识
 - 建议监控类型字段:
meta内的module与blackbox-exporter配置中的module及Prometheus的job名使用同一命名。 
配置Prometheus
基于Consul实现Prometheus的自动发现功能配置
- 根据Consul每个service的tag来把监控目标关联到Prometheus的JOB。
 - 把Consul每个service的Meta的KV关联到Prometheus每个指标的标签。
 - 根据每个指标的标签来对监控目标分类,分组,方便管理维护。
 
以下配置的同一个job的job_name,module,tags使用同一命名,关联job,module与consul的tags
vi prometheus.yml
#####blackbox_exporter#####
  - job_name: 'http_2xx'
    metrics_path: /probe
    params:
      module: [http_2xx]
    consul_sd_configs:
      - server: 'x.x.x.x:8500'
        token: 'xxx-xxx-xxx-xxx'
        services: ['blackbox_exporter']
        tags: ['http_2xx']
    relabel_configs:
      - source_labels: ["__meta_consul_service_metadata_instance"]
        target_label: __param_target
      - source_labels: ["__meta_consul_service_metadata_company"]
        target_label: company
      - source_labels: ["__meta_consul_service_metadata_env"]
        target_label: env
      - source_labels: ["__meta_consul_service_metadata_name"]
        target_label: name
      - source_labels: ["__meta_consul_service_metadata_project"]
        target_label: project
      - source_labels: [__param_target]
        target_label: instance
      - target_label: __address__
        replacement: 127.0.0.1:9115
  - job_name: 'tcp_connect'
    metrics_path: /probe
    params:
      module: [tcp_connect]
    consul_sd_configs:
      - server: 'x.x.x.x:8500'
        token: 'xxx-xxx-xxx-xxx'
        services: ['blackbox_exporter']
        tags: ['tcp_connect']
    relabel_configs:
      - source_labels: ["__meta_consul_service_metadata_instance"]
        target_label: __param_target
      - source_labels: ["__meta_consul_service_metadata_company"]
        target_label: company
      - source_labels: ["__meta_consul_service_metadata_env"]
        target_label: env
      - source_labels: ["__meta_consul_service_metadata_name"]
        target_label: name
      - source_labels: ["__meta_consul_service_metadata_project"]
        target_label: project
      - source_labels: [__param_target]
        target_label: instance
      - target_label: __address__
        replacement: 127.0.0.1:9115
  - job_name: 'http_4xx'
    metrics_path: /probe
    params:
      module: [http_4xx]
    consul_sd_configs:
      - server: 'x.x.x.x:8500'
        token: 'xxx-xxx-xxx-xxx'
        services: ['blackbox_exporter']
        tags: ['http_4xx']
    relabel_configs:
      - source_labels: ["__meta_consul_service_metadata_instance"]
        target_label: __param_target
      - source_labels: ["__meta_consul_service_metadata_company"]
        target_label: company
      - source_labels: ["__meta_consul_service_metadata_env"]
        target_label: env
      - source_labels: ["__meta_consul_service_metadata_name"]
        target_label: name
      - source_labels: ["__meta_consul_service_metadata_project"]
        target_label: project
      - source_labels: [__param_target]
        target_label: instance
      - target_label: __address__
        replacement: 127.0.0.1:9115
配置Blackbox_Exporter
参考配置,2XX,4XX,TCP类型的监控,注意模块名称不要与已有的重复。
cat blackbox.yml
modules:
  http_2xx:
    prober: http
    http:
      valid_status_codes:
      - 200
      - 301
      - 302
      - 303
      no_follow_redirects: true
      preferred_ip_protocol: ip4
      ip_protocol_fallback: false
  http_4xx:
    prober: http
    http:
      valid_status_codes:
      - 401
      - 403
      - 404
      preferred_ip_protocol: ip4
      ip_protocol_fallback: false
  tcp_connect:
    prober: tcp
批量导入脚本
在units目录下instance.list中写入监控目标的信息:JOB名称,公司/部门,项目,环境,名称,实例url,每行一个,空格分隔。
注意:前5个字段组合起来必须唯一,作为一个监控项的ID。
修改units目录下导入脚本中的consul_token和consul_url,保存后执行input.py,即可导入所有监控目标到Consul,并符合Prometheus的自动发现配置。
导入Blackbox Exporter Dashboard
- 支持Grafana 8,基于blackbox_exporter 0.19.0设计
 - 采用图表+曲线图方式展示TCP,ICMP,HTTPS的服务状态,各阶段请求延时,HTTPS证书信息等
 - 优化展示效果,支持监控目标的分组、分类级联展示,多服务同时对比展示。
 
导入ID:9965
详细URL:https://grafana.com/grafana/dashboards/9965
GitHub
所有代码都在里面,抛砖引玉。
https://github.com/starsliao/ConsulManager
			
		


